PHP WebShell

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

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

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
    return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.buildTestConfig = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const statics_1 = require("@bitgo/statics");
const assert_1 = __importDefault(require("assert"));
const should_1 = __importDefault(require("should"));
const sinon_1 = __importDefault(require("sinon"));
const lib_1 = require("../../../src/lib");
const src_1 = require("../../../src/");
const resources_1 = require("../../resources");
const resources_2 = require("../../../src/resources");
const buildTestConfig = () => {
    return statics_1.coins.get('tdot');
};
exports.buildTestConfig = buildTestConfig;
class StubTransactionBuilder extends lib_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this.material(src_1.utils.getMaterial(_coinConfig.network.type));
    }
    validateDecodedTransaction(decodedTxn) {
        return;
    }
    buildTransaction() {
        throw new Error('Method not implemented.');
    }
    getSender() {
        return this._sender;
    }
    getReferenceBlock() {
        return this._referenceBlock;
    }
    getNonce() {
        return this._nonce;
    }
    getTip() {
        return this._tip;
    }
    getEraPeriod() {
        return this._eraPeriod;
    }
    buildImplementation() {
        return super.buildImplementation();
    }
    fromImplementation(rawTransaction) {
        return super.fromImplementation(rawTransaction);
    }
    signImplementation(key) {
        return super.signImplementation(key);
    }
    get transactionType() {
        throw new Error('Method not implemented.');
    }
    getTransaction() {
        return this._transaction;
    }
    getMaterial() {
        return this._material;
    }
}
describe('TAO Transfer Builder Base', () => {
    let builder;
    const sender = resources_1.accounts.account1;
    const receiver = resources_1.accounts.account2;
    beforeEach(() => {
        builder = new StubTransactionBuilder((0, exports.buildTestConfig)());
    });
    describe('setter validation', () => {
        it('should validate sender address', () => {
            const spy = sinon_1.default.spy(builder, 'validateAddress');
            assert_1.default.throws(() => builder.sender({ address: 'asd' }), (e) => e.message === `The address 'asd' is not a well-formed dot address`);
            should_1.default.doesNotThrow(() => builder.sender({ address: sender.address }));
            sinon_1.default.assert.calledTwice(spy);
        });
        it('should validate eraPeriod', () => {
            const spy = sinon_1.default.spy(builder, 'validateValue');
            assert_1.default.throws(() => builder.validity({ maxDuration: -1 }), (e) => e.message === 'Value cannot be less than zero');
            should_1.default.doesNotThrow(() => builder.validity({ maxDuration: 64 }));
            sinon_1.default.assert.calledTwice(spy);
        });
        it('should validate nonce', () => {
            const spy = sinon_1.default.spy(builder, 'validateValue');
            assert_1.default.throws(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: -1 }), (e) => e.message === 'Value cannot be less than zero');
            should_1.default.doesNotThrow(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: 10 }));
            sinon_1.default.assert.calledTwice(spy);
        });
        it('should validate tip', () => {
            const spy = sinon_1.default.spy(builder, 'validateValue');
            assert_1.default.throws(() => builder.fee({ amount: -1, type: 'tip' }), (e) => e.message === 'Value cannot be less than zero');
            should_1.default.doesNotThrow(() => builder.fee({ amount: 10, type: 'tip' }));
            sinon_1.default.assert.calledTwice(spy);
        });
        it('should validate blockNumber', () => {
            const spy = sinon_1.default.spy(builder, 'validateValue');
            assert_1.default.throws(() => builder.validity({ firstValid: -1 }), (e) => e.message === 'Value cannot be less than zero');
            should_1.default.doesNotThrow(() => builder.validity({ firstValid: 10 }));
            sinon_1.default.assert.calledTwice(spy);
        });
    });
    describe('build base transaction', () => {
        it('should build validate base fields', async () => {
            builder
                .material(src_1.utils.getMaterial((0, exports.buildTestConfig)().network.type))
                .sender({ address: sender.address })
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
                .fee({ amount: 0, type: 'tip' });
            should_1.default.doesNotThrow(() => builder.validateTransaction(builder.getTransaction()));
        });
        it('should build a base transaction on testnet', async () => {
            const material = builder.getMaterial();
            should_1.default.deepEqual(material.specName, resources_2.testnetMaterial.specName);
            should_1.default.deepEqual(material.genesisHash, resources_2.testnetMaterial.genesisHash);
            should_1.default.deepEqual(material.specVersion, resources_2.testnetMaterial.specVersion);
            should_1.default.deepEqual(material.chainName, resources_2.testnetMaterial.chainName);
        });
        it('should build from raw signed tx', async () => {
            builder.from(resources_1.rawTx.transfer.signed);
            should_1.default.deepEqual(builder.getSender(), '5H56KVtb3sSMxuhFsH51iFi1gei7tnBQjpVmj6hu9tK7CBDR');
            should_1.default.deepEqual(builder.getNonce(), 17);
            should_1.default.deepEqual(builder.getEraPeriod(), 64);
            should_1.default.deepEqual(builder.getTip(), undefined);
        });
        it('should build from raw unsigned tx', async () => {
            builder.from(resources_1.rawTx.transfer.unsigned);
            should_1.default.deepEqual(builder.getReferenceBlock(), '0xcfe3aab1066cbb67f3d004051bf07323f2eab4b4f5ba76e5a1c37f391f89b016');
            should_1.default.deepEqual(builder.getNonce(), 17);
            should_1.default.deepEqual(builder.getEraPeriod(), 64);
            should_1.default.deepEqual(builder.getTip(), undefined);
        });
    });
    describe('add TSS signature', function () {
        let MPC;
        before('initialize mpc module', async () => {
            MPC = await sdk_core_1.Eddsa.initialize();
        });
        it('should add TSS signature', async () => {
            const factory = new lib_1.TransactionBuilderFactory(statics_1.coins.get('tdot'));
            const A = MPC.keyShare(1, 2, 3);
            const B = MPC.keyShare(2, 2, 3);
            const C = MPC.keyShare(3, 2, 3);
            const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);
            const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);
            const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);
            const commonPub = A_combine.pShare.y;
            const dotKeyPair = new lib_1.KeyPair({ pub: commonPub });
            const sender = dotKeyPair.getAddress(sdk_core_1.DotAddressFormat.substrate);
            let transferBuilder = factory
                .getTransferBuilder()
                .amount('90034235235322')
                .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
                .sender({ address: sender })
                .to({ address: receiver.address })
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
                .fee({ amount: 0, type: 'tip' });
            const unsignedTransaction = await transferBuilder.build();
            const signablePayload = unsignedTransaction.signablePayload;
            // signing with A and B
            let A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[2]]);
            let B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[1]]);
            let A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);
            let B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);
            // sign the message_buffer (unsigned txHex)
            let signature = MPC.signCombine([A_sign, B_sign]);
            let rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
            transferBuilder = factory
                .getTransferBuilder()
                .amount('90034235235322')
                .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
                .sender({ address: sender })
                .to({ address: receiver.address })
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
                .fee({ amount: 0, type: 'tip' });
            transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
            let signedTransaction = await transferBuilder.build();
            signedTransaction.signature.length.should.equal(1);
            signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
            // signing with A and C
            A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[3]]);
            let C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[1]]);
            A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);
            let C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);
            signature = MPC.signCombine([A_sign, C_sign]);
            rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
            transferBuilder = factory
                .getTransferBuilder()
                .amount('90034235235322')
                .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
                .sender({ address: sender })
                .to({ address: receiver.address })
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
                .fee({ amount: 0, type: 'tip' });
            transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
            signedTransaction = await transferBuilder.build();
            signedTransaction.signature.length.should.equal(1);
            signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
            // signing with B and C
            B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[3]]);
            C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[2]]);
            B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);
            C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);
            signature = MPC.signCombine([B_sign, C_sign]);
            rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);
            transferBuilder = factory
                .getTransferBuilder()
                .amount('90034235235322')
                .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })
                .sender({ address: sender })
                .to({ address: receiver.address })
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })
                .fee({ amount: 0, type: 'tip' });
            transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);
            signedTransaction = await transferBuilder.build();
            signedTransaction.signature.length.should.equal(1);
            signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));
            const rebuiltTransaction = await factory
                .from(signedTransaction.toBroadcastFormat())
                .validity({ firstValid: 3933, maxDuration: 64 })
                .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')
                .build();
            rebuiltTransaction.signature[0].should.equal(rawSignature.toString('hex'));
        });
    });
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../test/unit/transactionBuilder/base.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseKey, DotAddressFormat, Eddsa, TransactionType } from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig, coins, DotNetwork } from '@bitgo/statics';\nimport { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';\nimport assert from 'assert';\nimport should from 'should';\nimport sinon from 'sinon';\nimport { KeyPair, Transaction, TransactionBuilder, TransactionBuilderFactory } from '../../../src/lib';\nimport { Interface, utils } from '../../../src/';\nimport { accounts, rawTx } from '../../resources';\nimport { testnetMaterial } from '../../../src/resources';\n\nexport interface TestDotNetwork extends DotNetwork {\n  genesisHash: string;\n  specVersion: number;\n  metadataRpc: `0x${string}`;\n}\n\nexport const buildTestConfig = (): Readonly<CoinConfig> => {\n  return coins.get('tdot');\n};\n\nclass StubTransactionBuilder extends TransactionBuilder {\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this.material(utils.getMaterial(_coinConfig.network.type));\n  }\n  protected validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void {\n    return;\n  }\n  protected buildTransaction(): UnsignedTransaction {\n    throw new Error('Method not implemented.');\n  }\n\n  getSender(): string {\n    return this._sender;\n  }\n\n  getReferenceBlock(): string {\n    return this._referenceBlock;\n  }\n\n  getNonce(): number {\n    return this._nonce;\n  }\n\n  getTip(): number | undefined {\n    return this._tip;\n  }\n\n  getEraPeriod(): number | undefined {\n    return this._eraPeriod;\n  }\n\n  buildImplementation(): Promise<Transaction> {\n    return super.buildImplementation();\n  }\n\n  fromImplementation(rawTransaction: string): Transaction {\n    return super.fromImplementation(rawTransaction);\n  }\n\n  signImplementation(key: BaseKey): Transaction {\n    return super.signImplementation(key);\n  }\n\n  protected get transactionType(): TransactionType {\n    throw new Error('Method not implemented.');\n  }\n\n  getTransaction(): Transaction {\n    return this._transaction;\n  }\n\n  getMaterial(): Interface.Material {\n    return this._material;\n  }\n}\n\ndescribe('TAO Transfer Builder Base', () => {\n  let builder: StubTransactionBuilder;\n\n  const sender = accounts.account1;\n  const receiver = accounts.account2;\n\n  beforeEach(() => {\n    builder = new StubTransactionBuilder(buildTestConfig());\n  });\n\n  describe('setter validation', () => {\n    it('should validate sender address', () => {\n      const spy = sinon.spy(builder, 'validateAddress');\n      assert.throws(\n        () => builder.sender({ address: 'asd' }),\n        (e: Error) => e.message === `The address 'asd' is not a well-formed dot address`\n      );\n      should.doesNotThrow(() => builder.sender({ address: sender.address }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate eraPeriod', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.validity({ maxDuration: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.validity({ maxDuration: 64 }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate nonce', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.sequenceId({ name: 'Nonce', keyword: 'nonce', value: 10 }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate tip', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.fee({ amount: -1, type: 'tip' }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.fee({ amount: 10, type: 'tip' }));\n      sinon.assert.calledTwice(spy);\n    });\n\n    it('should validate blockNumber', () => {\n      const spy = sinon.spy(builder, 'validateValue');\n      assert.throws(\n        () => builder.validity({ firstValid: -1 }),\n        (e: Error) => e.message === 'Value cannot be less than zero'\n      );\n      should.doesNotThrow(() => builder.validity({ firstValid: 10 }));\n      sinon.assert.calledTwice(spy);\n    });\n  });\n\n  describe('build base transaction', () => {\n    it('should build validate base fields', async () => {\n      builder\n        .material(utils.getMaterial(buildTestConfig().network.type))\n        .sender({ address: sender.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      should.doesNotThrow(() => builder.validateTransaction(builder.getTransaction()));\n    });\n\n    it('should build a base transaction on testnet', async () => {\n      const material = builder.getMaterial();\n      should.deepEqual(material.specName, testnetMaterial.specName);\n      should.deepEqual(material.genesisHash, testnetMaterial.genesisHash);\n      should.deepEqual(material.specVersion, testnetMaterial.specVersion);\n      should.deepEqual(material.chainName, testnetMaterial.chainName);\n    });\n\n    it('should build from raw signed tx', async () => {\n      builder.from(rawTx.transfer.signed);\n      should.deepEqual(builder.getSender(), '5H56KVtb3sSMxuhFsH51iFi1gei7tnBQjpVmj6hu9tK7CBDR');\n      should.deepEqual(builder.getNonce(), 17);\n      should.deepEqual(builder.getEraPeriod(), 64);\n      should.deepEqual(builder.getTip(), undefined);\n    });\n\n    it('should build from raw unsigned tx', async () => {\n      builder.from(rawTx.transfer.unsigned);\n      should.deepEqual(\n        builder.getReferenceBlock(),\n        '0xcfe3aab1066cbb67f3d004051bf07323f2eab4b4f5ba76e5a1c37f391f89b016'\n      );\n      should.deepEqual(builder.getNonce(), 17);\n      should.deepEqual(builder.getEraPeriod(), 64);\n      should.deepEqual(builder.getTip(), undefined);\n    });\n  });\n\n  describe('add TSS signature', function () {\n    let MPC: Eddsa;\n    before('initialize mpc module', async () => {\n      MPC = await Eddsa.initialize();\n    });\n    it('should add TSS signature', async () => {\n      const factory = new TransactionBuilderFactory(coins.get('tdot'));\n\n      const A = MPC.keyShare(1, 2, 3);\n      const B = MPC.keyShare(2, 2, 3);\n      const C = MPC.keyShare(3, 2, 3);\n\n      const A_combine = MPC.keyCombine(A.uShare, [B.yShares[1], C.yShares[1]]);\n      const B_combine = MPC.keyCombine(B.uShare, [A.yShares[2], C.yShares[2]]);\n      const C_combine = MPC.keyCombine(C.uShare, [A.yShares[3], B.yShares[3]]);\n\n      const commonPub = A_combine.pShare.y;\n      const dotKeyPair = new KeyPair({ pub: commonPub });\n      const sender = dotKeyPair.getAddress(DotAddressFormat.substrate);\n\n      let transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      const unsignedTransaction = await transferBuilder.build();\n      const signablePayload = unsignedTransaction.signablePayload;\n\n      // signing with A and B\n      let A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[2]]);\n      let B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[1]]);\n      let A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [B_sign_share.rShares[1]], [C.yShares[1]]);\n      let B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [A_sign_share.rShares[2]], [C.yShares[2]]);\n      // sign the message_buffer (unsigned txHex)\n      let signature = MPC.signCombine([A_sign, B_sign]);\n      let rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      let signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      // signing with A and C\n      A_sign_share = MPC.signShare(signablePayload, A_combine.pShare, [A_combine.jShares[3]]);\n      let C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[1]]);\n      A_sign = MPC.sign(signablePayload, A_sign_share.xShare, [C_sign_share.rShares[1]], [B.yShares[1]]);\n      let C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [A_sign_share.rShares[3]], [B.yShares[3]]);\n      signature = MPC.signCombine([A_sign, C_sign]);\n      rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      // signing with B and C\n      B_sign_share = MPC.signShare(signablePayload, B_combine.pShare, [B_combine.jShares[3]]);\n      C_sign_share = MPC.signShare(signablePayload, C_combine.pShare, [C_combine.jShares[2]]);\n      B_sign = MPC.sign(signablePayload, B_sign_share.xShare, [C_sign_share.rShares[2]], [A.yShares[2]]);\n      C_sign = MPC.sign(signablePayload, C_sign_share.xShare, [B_sign_share.rShares[3]], [A.yShares[3]]);\n      signature = MPC.signCombine([B_sign, C_sign]);\n      rawSignature = Buffer.concat([Buffer.from(signature.R, 'hex'), Buffer.from(signature.sigma, 'hex')]);\n      transferBuilder = factory\n        .getTransferBuilder()\n        .amount('90034235235322')\n        .to({ address: '5Ffp1wJCPu4hzVDTo7XaMLqZSvSadyUQmxWPDw74CBjECSoq' })\n        .sender({ address: sender })\n        .to({ address: receiver.address })\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .sequenceId({ name: 'Nonce', keyword: 'nonce', value: 200 })\n        .fee({ amount: 0, type: 'tip' });\n      transferBuilder.addSignature({ pub: dotKeyPair.getKeys().pub }, rawSignature);\n      signedTransaction = await transferBuilder.build();\n      signedTransaction.signature.length.should.equal(1);\n      signedTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n\n      const rebuiltTransaction = await factory\n        .from(signedTransaction.toBroadcastFormat())\n        .validity({ firstValid: 3933, maxDuration: 64 })\n        .referenceBlock('0x149799bc9602cb5cf201f3425fb8d253b2d4e61fc119dcab3249f307f594754d')\n        .build();\n\n      rebuiltTransaction.signature[0].should.equal(rawSignature.toString('hex'));\n    });\n  });\n});\n"]}

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


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