PHP WebShell

Текущая директория: /opt/BitGoJS/modules/sdk-coin-etc/dist/test/unit

Просмотр файла: etc.js

"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    var desc = Object.getOwnPropertyDescriptor(m, k);
    if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
      desc = { enumerable: true, get: function() { return m[k]; } };
    }
    Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
    if (k2 === undefined) k2 = k;
    o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
    Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
    o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
    var ownKeys = function(o) {
        ownKeys = Object.getOwnPropertyNames || function (o) {
            var ar = [];
            for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
            return ar;
        };
        return ownKeys(o);
    };
    return function (mod) {
        if (mod && mod.__esModule) return mod;
        var result = {};
        if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
        __setModuleDefault(result, mod);
        return result;
    };
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const sdk_test_1 = require("@bitgo/sdk-test");
const sdk_api_1 = require("@bitgo/sdk-api");
const src_1 = require("../../src");
const sinon_1 = __importDefault(require("sinon"));
const ethereumjs_util_1 = require("ethereumjs-util");
const getBuilder_1 = require("./getBuilder");
const should = __importStar(require("should"));
describe('Ethereum Classic', function () {
    let bitgo;
    before(function () {
        bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'mock' });
        bitgo.initializeTestVars();
        bitgo.safeRegister('etc', src_1.Etc.createInstance);
        bitgo.safeRegister('tetc', src_1.Tetc.createInstance);
    });
    it('should instantiate the coin', function () {
        let localBasecoin = bitgo.coin('tetc');
        localBasecoin.should.be.an.instanceof(src_1.Tetc);
        localBasecoin = bitgo.coin('etc');
        localBasecoin.should.be.an.instanceof(src_1.Etc);
    });
});
describe('Wallet Recovery Wizard', function () {
    let sandbox;
    let bitgo;
    let tetcCoin;
    const sourceRootAddress = '0x321cbe223ff1c3d0c03b73b8c648ef2d91e4aaa1';
    const backupKeyAddress = '0x921f162bfd472424d6065b919c3f6e3bf13fe3d7';
    const destinationWalletAddress = '0x76e2dcc49618f3b9769fc8a80b6991388570b3ae';
    const walletPassPhrase = 'Z@oOQ6fkpzjkJXxM<bN1';
    beforeEach(function () {
        sandbox = sinon_1.default.createSandbox();
        const callBack = sandbox.stub(src_1.Etc.prototype, 'queryAddressBalance');
        callBack.withArgs(sourceRootAddress).resolves(new ethereumjs_util_1.BN('2190000000000000000'));
        callBack.withArgs(backupKeyAddress).resolves(new ethereumjs_util_1.BN('190000000000000000'));
        callBack.withArgs('0x5273e0d869226ccf579a81b6d291fb3702ba9dec').resolves(new ethereumjs_util_1.BN('0'));
        callBack.withArgs('0x1b9af47cc3048fe1d31ad72299611d3df3926755').resolves(new ethereumjs_util_1.BN('190000000000000000'));
        callBack.withArgs('0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23').resolves(new ethereumjs_util_1.BN('2190000000000000000'));
    });
    afterEach(function () {
        sandbox.restore();
    });
    before(function () {
        bitgo = sdk_test_1.TestBitGo.decorate(sdk_api_1.BitGoAPI, { env: 'test' });
        bitgo.safeRegister('tetc', src_1.Tetc.createInstance);
        bitgo.initializeTestVars();
    });
    describe('Non-BitGo Recovery', function () {
        beforeEach(function () {
            tetcCoin = bitgo.coin('tetc');
        });
        it('should build a recovery transaction for non-bitgo recovery', async function () {
            const walletContractAddress = sourceRootAddress;
            const recovery = (await tetcCoin.recover({
                userKey: '{"iv":"rP+aJBBP5VkYiGmc0KPz4A==","v":1,"iter":10000,"ks":256,"ts":64,"mode":"ccm","adata":"","cipher":"aes","salt":"/B4OU/PQ1Eg=","ct":"HvCzOA23n6WxgFcBdH3ZqrLnZl5NckPPUyC/UDSv/KO8ZPBb1xZVTTY2ZY6/JBG8dHp/ApvAlRFm1SC+MjZ/OF9LC6Zjz8vsoLiS0BHB+z8Z6qB/16aWJbEIRzEmgEkWRn10l9m646GS00qGNHKG1VBURvUOYN4="}',
                backupKey: '{"iv":"rDHtZUUKxaCQaIzGMB0b0w==","v":1,"iter":10000,"ks":256,"ts":64,"mode":"ccm","adata":"","cipher":"aes","salt":"0bmqSuxoVlA=","ct":"LyKRuUNVcRzhY5LUF15jKdKOpP04nUHs88FYPK1ZB9yuBSEGduQPjJs+xO62NCDh3pyiX1YeHBe9N6Gsm5Va0jSCk8XQ5pCwNuiO1RXvESAhfrXCivJMfRLVmCgaM79YMWapL7syUa//6mhu/1l4tPBBoZoBYc8="}',
                walletContractAddress,
                walletPassphrase: walletPassPhrase,
                recoveryDestination: destinationWalletAddress,
            }));
            recovery.should.not.be.undefined();
            recovery.should.have.property('id');
            recovery.should.have.property('tx');
            const txBuilder = (0, getBuilder_1.getBuilder)('tetc');
            txBuilder.from(recovery.tx);
            const tx = await txBuilder.build();
            tx.toBroadcastFormat().should.not.be.empty();
        });
        it('should error when the backup key is unfunded (cannot pay gas)', async function () {
            await tetcCoin
                .recover({
                userKey: '{"iv":"RI3d7nXJnnMTJFEKE5U6CA==","v":1,"iter":10000,"ks":256,"ts":64,"mode":"ccm","adata":"","cipher":"aes","salt":"qZtZ8FXlr5I=","ct":"F49E7Pi3duSQ9v1iauXuQ6q6SqmGHLPQ9RNJTmfJp0AH2mwNe1bl/pMpwsaT12Ay3x3roLsi5+WFzePK8q1z43xwKfMWjTdsxj0yHpwa+8kOyckEnKyZ5J/AUw0nS7ujegTelaKR/wT2D+mvpJejQ+NRs9Lvyrg="}\n',
                backupKey: '{"iv":"XJPzySPeTTAbLVol9fsQUA==","v":1,"iter":10000,"ks":256,"ts":64,"mode":"ccm","adata":"","cipher":"aes","salt":"6LzbWSvK9Wo=","ct":"8fBnXkAX38ZtoHjN9MBUSkJ3dGgR8FuAmOo1sO7XfOu6Pan23YVpy468dKgl0C+UkzBQbnepNQ0UOf3kEudTYqt3/HgtvUcDdkkD3YDfEF1gVN7ndiBabF2C3SwnMNxUkuD0n5YWaRmaBPo+A2AGj4VrQ0wzFZs="}',
                walletContractAddress: destinationWalletAddress,
                walletPassphrase: walletPassPhrase,
                recoveryDestination: sourceRootAddress,
            })
                .should.be.rejectedWith('Backup key address 0x5273e0d869226ccf579a81b6d291fb3702ba9dec has balance  0 Gwei.This address must have a balance of at least 10000000 Gwei to perform recoveries. Try sending some funds to this address then retry.');
        });
        it('should get the next sequence id for an address', async function () {
            const baseCoin = bitgo.coin('tetc');
            const walletContractAddress = '0x2E0b5638Bf3F774AF116029b09415AA9FDD812d5';
            const sequenceId = await baseCoin.querySequenceId(walletContractAddress);
            sequenceId.should.not.be.undefined();
        });
    });
    describe('Unsigned sweep for cold wallet', function () {
        const userXprv = 'xprv9s21ZrQH143K38Cfd5PyKGajVbA1sZYwAKQif8qvJMfMmSY85spqTnd4taexRHc9F92QCgBzHosCauYcnJWT9eWxfFKvSjAKoSgQkf74DoM';
        const userXpub = 'xpub661MyMwAqRbcFcH8j6vygQXU3czWH2GnXYLKTXFXrhCLeEsGdR961awYjr3yC8eUj9rqhgFWHVbQJWqZS7kXpLBDzvoCKDLaBujsCH12Zfj';
        const backupXprv = 'xprv9s21ZrQH143K3WkGc7rUw4NU5ZZTPczbMk9GajGxpJYhJXtfnYUL4j1x6vAGcxUg9XFzEHpQWPy3aYyJZcuGnYbc2eNzrsyNn3SRNdQa1PC';
        const backupXpub = 'xpub661MyMwAqRbcGYaF52itktGhGDfiL9CBBTh4TSXV6QqGgXRbhSS5DAaTbdCPJA425XwkvwyCKtTmoxcUTAUgKUf7Qr5Ks9gJP9DTfiV2PhU';
        const walletContractAddress = '0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23';
        // tetc wallet 1 receiveAddress 4
        const recoveryDestination = '0x321cbe223ff1c3d0c03b73b8c648ef2d91e4aaa1';
        const gasPrice = 25000000000;
        beforeEach(function () {
            tetcCoin = bitgo.coin('tetc');
        });
        afterEach(function () {
            sandbox.restore();
        });
        it('should generate an ETH unsigned sweep', async function () {
            const transaction = (await tetcCoin.recover({
                userKey: userXpub,
                backupKey: backupXpub,
                walletContractAddress,
                recoveryDestination,
                gasPrice,
            }));
            should.exist(transaction);
            transaction.should.have.property('txHex');
            transaction.should.have.property('userKey');
            transaction.should.have.property('backupKey');
            transaction.should.have.property('gasLimit');
            transaction.gasLimit.should.equal('500000');
            transaction.should.have.property('gasPrice');
            transaction.gasPrice.should.equal('25000000000');
            transaction.should.have.property('walletContractAddress');
            transaction.walletContractAddress.should.equal('0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23');
            transaction.should.have.property('recipient');
        });
        it('should add a second signature', async function () {
            const transaction = (await tetcCoin.recover({
                userKey: userXpub,
                backupKey: backupXpub,
                walletContractAddress,
                recoveryDestination,
                gasPrice,
            }));
            const txPrebuild = {
                txHex: transaction.txHex,
            };
            const params = {
                txPrebuild,
                prv: userXprv,
            };
            // sign transaction once
            const halfSigned = await tetcCoin.signTransaction(params);
            const halfSignedParams = {
                txPrebuild: halfSigned,
                isLastSignature: true,
                walletContractAddress: walletContractAddress,
                prv: backupXprv,
            };
            // sign transaction twice with the "isLastSignature" flag
            const finalSignedTx = (await tetcCoin.signTransaction(halfSignedParams));
            finalSignedTx.should.have.property('txHex');
            const txBuilder = tetcCoin.getTransactionBuilder();
            txBuilder.from(finalSignedTx.txHex);
            const rebuiltTx = await txBuilder.build();
            rebuiltTx.signature.length.should.equal(2);
            rebuiltTx.outputs.length.should.equal(1);
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"etc.js","sourceRoot":"","sources":["../../../test/unit/etc.ts"],"names":[],"mappings":"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","sourcesContent":["import { TestBitGo, TestBitGoAPI } from '@bitgo/sdk-test';\nimport { BitGoAPI } from '@bitgo/sdk-api';\nimport { Etc, Tetc, TransactionBuilder } from '../../src';\nimport sinon from 'sinon';\nimport { OfflineVaultTxInfo, SignTransactionOptions } from '@bitgo/abstract-eth';\n\nimport { BN } from 'ethereumjs-util';\nimport { getBuilder } from './getBuilder';\nimport { FullySignedTransaction } from '@bitgo/sdk-core';\nimport * as should from 'should';\n\ndescribe('Ethereum Classic', function () {\n  let bitgo: TestBitGoAPI;\n\n  before(function () {\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'mock' });\n    bitgo.initializeTestVars();\n    bitgo.safeRegister('etc', Etc.createInstance);\n    bitgo.safeRegister('tetc', Tetc.createInstance);\n  });\n\n  it('should instantiate the coin', function () {\n    let localBasecoin = bitgo.coin('tetc');\n    localBasecoin.should.be.an.instanceof(Tetc);\n\n    localBasecoin = bitgo.coin('etc');\n    localBasecoin.should.be.an.instanceof(Etc);\n  });\n});\n\ndescribe('Wallet Recovery Wizard', function () {\n  let sandbox;\n  let bitgo: TestBitGoAPI;\n  let tetcCoin: Tetc;\n\n  const sourceRootAddress = '0x321cbe223ff1c3d0c03b73b8c648ef2d91e4aaa1';\n  const backupKeyAddress = '0x921f162bfd472424d6065b919c3f6e3bf13fe3d7';\n  const destinationWalletAddress = '0x76e2dcc49618f3b9769fc8a80b6991388570b3ae';\n  const walletPassPhrase = 'Z@oOQ6fkpzjkJXxM<bN1';\n\n  beforeEach(function () {\n    sandbox = sinon.createSandbox();\n    const callBack = sandbox.stub(Etc.prototype, 'queryAddressBalance' as keyof Etc);\n    callBack.withArgs(sourceRootAddress).resolves(new BN('2190000000000000000'));\n    callBack.withArgs(backupKeyAddress).resolves(new BN('190000000000000000'));\n    callBack.withArgs('0x5273e0d869226ccf579a81b6d291fb3702ba9dec').resolves(new BN('0'));\n    callBack.withArgs('0x1b9af47cc3048fe1d31ad72299611d3df3926755').resolves(new BN('190000000000000000'));\n    callBack.withArgs('0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23').resolves(new BN('2190000000000000000'));\n  });\n\n  afterEach(function () {\n    sandbox.restore();\n  });\n\n  before(function () {\n    bitgo = TestBitGo.decorate(BitGoAPI, { env: 'test' });\n    bitgo.safeRegister('tetc', Tetc.createInstance);\n    bitgo.initializeTestVars();\n  });\n\n  describe('Non-BitGo Recovery', function () {\n    beforeEach(function () {\n      tetcCoin = bitgo.coin('tetc') as Tetc;\n    });\n\n    it('should build a recovery transaction for non-bitgo recovery', async function () {\n      const walletContractAddress = sourceRootAddress;\n      const recovery = (await tetcCoin.recover({\n        userKey:\n          '{\"iv\":\"rP+aJBBP5VkYiGmc0KPz4A==\",\"v\":1,\"iter\":10000,\"ks\":256,\"ts\":64,\"mode\":\"ccm\",\"adata\":\"\",\"cipher\":\"aes\",\"salt\":\"/B4OU/PQ1Eg=\",\"ct\":\"HvCzOA23n6WxgFcBdH3ZqrLnZl5NckPPUyC/UDSv/KO8ZPBb1xZVTTY2ZY6/JBG8dHp/ApvAlRFm1SC+MjZ/OF9LC6Zjz8vsoLiS0BHB+z8Z6qB/16aWJbEIRzEmgEkWRn10l9m646GS00qGNHKG1VBURvUOYN4=\"}',\n        backupKey:\n          '{\"iv\":\"rDHtZUUKxaCQaIzGMB0b0w==\",\"v\":1,\"iter\":10000,\"ks\":256,\"ts\":64,\"mode\":\"ccm\",\"adata\":\"\",\"cipher\":\"aes\",\"salt\":\"0bmqSuxoVlA=\",\"ct\":\"LyKRuUNVcRzhY5LUF15jKdKOpP04nUHs88FYPK1ZB9yuBSEGduQPjJs+xO62NCDh3pyiX1YeHBe9N6Gsm5Va0jSCk8XQ5pCwNuiO1RXvESAhfrXCivJMfRLVmCgaM79YMWapL7syUa//6mhu/1l4tPBBoZoBYc8=\"}',\n        walletContractAddress,\n        walletPassphrase: walletPassPhrase,\n        recoveryDestination: destinationWalletAddress,\n      })) as OfflineVaultTxInfo;\n\n      recovery.should.not.be.undefined();\n      recovery.should.have.property('id');\n      recovery.should.have.property('tx');\n\n      const txBuilder = getBuilder('tetc') as TransactionBuilder;\n      txBuilder.from(recovery.tx);\n      const tx = await txBuilder.build();\n      tx.toBroadcastFormat().should.not.be.empty();\n    });\n\n    it('should error when the backup key is unfunded (cannot pay gas)', async function () {\n      await tetcCoin\n        .recover({\n          userKey:\n            '{\"iv\":\"RI3d7nXJnnMTJFEKE5U6CA==\",\"v\":1,\"iter\":10000,\"ks\":256,\"ts\":64,\"mode\":\"ccm\",\"adata\":\"\",\"cipher\":\"aes\",\"salt\":\"qZtZ8FXlr5I=\",\"ct\":\"F49E7Pi3duSQ9v1iauXuQ6q6SqmGHLPQ9RNJTmfJp0AH2mwNe1bl/pMpwsaT12Ay3x3roLsi5+WFzePK8q1z43xwKfMWjTdsxj0yHpwa+8kOyckEnKyZ5J/AUw0nS7ujegTelaKR/wT2D+mvpJejQ+NRs9Lvyrg=\"}\\n',\n          backupKey:\n            '{\"iv\":\"XJPzySPeTTAbLVol9fsQUA==\",\"v\":1,\"iter\":10000,\"ks\":256,\"ts\":64,\"mode\":\"ccm\",\"adata\":\"\",\"cipher\":\"aes\",\"salt\":\"6LzbWSvK9Wo=\",\"ct\":\"8fBnXkAX38ZtoHjN9MBUSkJ3dGgR8FuAmOo1sO7XfOu6Pan23YVpy468dKgl0C+UkzBQbnepNQ0UOf3kEudTYqt3/HgtvUcDdkkD3YDfEF1gVN7ndiBabF2C3SwnMNxUkuD0n5YWaRmaBPo+A2AGj4VrQ0wzFZs=\"}',\n          walletContractAddress: destinationWalletAddress,\n          walletPassphrase: walletPassPhrase,\n          recoveryDestination: sourceRootAddress,\n        })\n        .should.be.rejectedWith(\n          'Backup key address 0x5273e0d869226ccf579a81b6d291fb3702ba9dec has balance  0 Gwei.This address must have a balance of at least 10000000 Gwei to perform recoveries. Try sending some funds to this address then retry.'\n        );\n    });\n\n    it('should get the next sequence id for an address', async function () {\n      const baseCoin = bitgo.coin('tetc') as Tetc;\n      const walletContractAddress = '0x2E0b5638Bf3F774AF116029b09415AA9FDD812d5';\n      const sequenceId = await baseCoin.querySequenceId(walletContractAddress);\n      sequenceId.should.not.be.undefined();\n    });\n  });\n\n  describe('Unsigned sweep for cold wallet', function () {\n    const userXprv =\n      'xprv9s21ZrQH143K38Cfd5PyKGajVbA1sZYwAKQif8qvJMfMmSY85spqTnd4taexRHc9F92QCgBzHosCauYcnJWT9eWxfFKvSjAKoSgQkf74DoM';\n    const userXpub =\n      'xpub661MyMwAqRbcFcH8j6vygQXU3czWH2GnXYLKTXFXrhCLeEsGdR961awYjr3yC8eUj9rqhgFWHVbQJWqZS7kXpLBDzvoCKDLaBujsCH12Zfj';\n    const backupXprv =\n      'xprv9s21ZrQH143K3WkGc7rUw4NU5ZZTPczbMk9GajGxpJYhJXtfnYUL4j1x6vAGcxUg9XFzEHpQWPy3aYyJZcuGnYbc2eNzrsyNn3SRNdQa1PC';\n    const backupXpub =\n      'xpub661MyMwAqRbcGYaF52itktGhGDfiL9CBBTh4TSXV6QqGgXRbhSS5DAaTbdCPJA425XwkvwyCKtTmoxcUTAUgKUf7Qr5Ks9gJP9DTfiV2PhU';\n\n    const walletContractAddress = '0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23';\n    // tetc wallet 1 receiveAddress 4\n    const recoveryDestination = '0x321cbe223ff1c3d0c03b73b8c648ef2d91e4aaa1';\n    const gasPrice = 25000000000;\n\n    beforeEach(function () {\n      tetcCoin = bitgo.coin('tetc') as Tetc;\n    });\n\n    afterEach(function () {\n      sandbox.restore();\n    });\n\n    it('should generate an ETH unsigned sweep', async function () {\n      const transaction: OfflineVaultTxInfo = (await tetcCoin.recover({\n        userKey: userXpub,\n        backupKey: backupXpub,\n        walletContractAddress,\n        recoveryDestination,\n        gasPrice,\n      })) as OfflineVaultTxInfo;\n      should.exist(transaction);\n      transaction.should.have.property('txHex');\n      transaction.should.have.property('userKey');\n      transaction.should.have.property('backupKey');\n      transaction.should.have.property('gasLimit');\n      transaction.gasLimit.should.equal('500000');\n      transaction.should.have.property('gasPrice');\n      transaction.gasPrice.should.equal('25000000000');\n      transaction.should.have.property('walletContractAddress');\n      transaction.walletContractAddress.should.equal('0x7fcf95a9106a0ed3bd09e653c8ea3d5e489bfb23');\n      transaction.should.have.property('recipient');\n    });\n\n    it('should add a second signature', async function () {\n      const transaction = (await tetcCoin.recover({\n        userKey: userXpub,\n        backupKey: backupXpub,\n        walletContractAddress,\n        recoveryDestination,\n        gasPrice,\n      })) as OfflineVaultTxInfo;\n\n      const txPrebuild = {\n        txHex: transaction.txHex,\n      };\n\n      const params = {\n        txPrebuild,\n        prv: userXprv,\n      };\n      // sign transaction once\n      const halfSigned = await tetcCoin.signTransaction(params as SignTransactionOptions);\n      const halfSignedParams = {\n        txPrebuild: halfSigned,\n        isLastSignature: true,\n        walletContractAddress: walletContractAddress,\n        prv: backupXprv,\n      };\n      // sign transaction twice with the \"isLastSignature\" flag\n      const finalSignedTx = (await tetcCoin.signTransaction(\n        halfSignedParams as SignTransactionOptions\n      )) as FullySignedTransaction;\n      finalSignedTx.should.have.property('txHex');\n      const txBuilder = tetcCoin.getTransactionBuilder() as TransactionBuilder;\n      txBuilder.from(finalSignedTx.txHex);\n      const rebuiltTx = await txBuilder.build();\n      rebuiltTx.signature.length.should.equal(2);\n      rebuiltTx.outputs.length.should.equal(1);\n    });\n  });\n});\n"]}

Выполнить команду


Для локальной разработки. Не используйте в интернете!