"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.decryptCrowdsaleJson = exports.isCrowdsaleJson = void 0; const aes_js_1 = require("aes-js"); const index_js_1 = require("../address/index.js"); const index_js_2 = require("../crypto/index.js"); const id_js_1 = require("../hash/id.js"); const index_js_3 = require("../utils/index.js"); const utils_js_1 = require("./utils.js"); function isCrowdsaleJson(json) { try { const data = JSON.parse(json); if (data.encseed) { return true; } } catch (error) { } return false; } exports.isCrowdsaleJson = isCrowdsaleJson; // See: https://github.com/ethereum/pyethsaletool function decryptCrowdsaleJson(json, _password) { const data = JSON.parse(json); const password = (0, utils_js_1.getPassword)(_password); // Ethereum Address const address = (0, index_js_1.getAddress)((0, utils_js_1.spelunk)(data, "ethaddr:string!")); // Encrypted Seed const encseed = (0, utils_js_1.looseArrayify)((0, utils_js_1.spelunk)(data, "encseed:string!")); if (!encseed || (encseed.length % 16) !== 0) { index_js_3.logger.throwArgumentError("invalid encseed", "json", json); } const key = index_js_3.logger.getBytes((0, index_js_2.pbkdf2)(password, password, 2000, 32, "sha256")).slice(0, 16); const iv = encseed.slice(0, 16); const encryptedSeed = encseed.slice(16); // Decrypt the seed const aesCbc = new aes_js_1.CBC(key, iv); const seed = (0, aes_js_1.pkcs7Strip)(index_js_3.logger.getBytes(aesCbc.decrypt(encryptedSeed))); // This wallet format is weird... Convert the binary encoded hex to a string. let seedHex = ""; for (let i = 0; i < seed.length; i++) { seedHex += String.fromCharCode(seed[i]); } return { address, privateKey: (0, id_js_1.id)(seedHex) }; } exports.decryptCrowdsaleJson = decryptCrowdsaleJson; //# sourceMappingURL=json-crowdsale.js.map