PHP WebShell

Текущая директория: /opt/BitGoJS/modules/abstract-substrate/dist/src/lib

Просмотр файла: transaction.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 });
exports.Transaction = void 0;
const sdk_core_1 = require("@bitgo/sdk-core");
const keyring_1 = __importStar(require("@polkadot/keyring"));
const util_1 = require("@polkadot/util");
const txwrapper_polkadot_1 = require("@substrate/txwrapper-polkadot");
const keyPair_1 = require("./keyPair");
const utils_1 = __importDefault(require("./utils"));
const Extrinsic_1 = require("@polkadot/types/extrinsic/v4/Extrinsic");
const constants_1 = require("./constants");
class Transaction extends sdk_core_1.BaseTransaction {
    constructor(coinConfig) {
        super(coinConfig);
    }
    /** @inheritdoc */
    canSign({ key }) {
        const kp = new keyPair_1.KeyPair({ prv: key });
        const addr = kp.getAddress(this.getAddressFormat());
        return addr === this._sender;
    }
    /**
     * Sign a substrate transaction and update the transaction hex
     *
     * @param {KeyPair} keyPair - ed signature
     */
    sign(keyPair) {
        if (!this._substrateTransaction) {
            throw new sdk_core_1.InvalidTransactionError('No transaction data to sign');
        }
        const { prv, pub } = keyPair.getKeys();
        if (!prv) {
            throw new sdk_core_1.SigningError('Missing private key');
        }
        const signingPayload = txwrapper_polkadot_1.construct.signingPayload(this._substrateTransaction, {
            registry: this._registry,
        });
        // Sign a payload. This operation should be performed on an offline device.
        const keyring = new keyring_1.default({ type: 'ed25519' });
        const secretKey = new Uint8Array(Buffer.from(prv, 'hex'));
        const publicKey = new Uint8Array(Buffer.from(pub, 'hex'));
        const signingKeyPair = keyring.addFromPair({ secretKey, publicKey });
        const txHex = utils_1.default.createSignedTx(signingKeyPair, signingPayload, this._substrateTransaction, {
            metadataRpc: this._substrateTransaction.metadataRpc,
            registry: this._registry,
        });
        // get signature from signed txHex generated above
        this._signatures = [utils_1.default.recoverSignatureFromRawTx(txHex, { registry: this._registry })];
        this._signedTransaction = txHex;
    }
    /**
     * Adds the signature to the Substrate Transaction
     * @param {string} signature
     */
    addSignature(signature) {
        this._signedTransaction = utils_1.default.serializeSignedTransaction(this._substrateTransaction, signature, this._substrateTransaction.metadataRpc, this._registry);
    }
    /**
     * Returns a serialized representation of this transaction with a fake signature attached which
     * can be used to estimate transaction fees.
     */
    fakeSign() {
        return utils_1.default.serializeSignedTransaction(this._substrateTransaction, Transaction.FAKE_SIGNATURE, this._substrateTransaction.metadataRpc, this._registry);
    }
    registry(registry) {
        this._registry = registry;
    }
    chainName(chainName) {
        this._chainName = chainName;
    }
    sender(sender) {
        this._sender = sender;
    }
    /** @inheritdoc */
    toBroadcastFormat() {
        if (!this._substrateTransaction) {
            throw new sdk_core_1.InvalidTransactionError('Empty transaction');
        }
        if (this._signedTransaction && this._signedTransaction.length > 0) {
            return this._signedTransaction;
        }
        else {
            return txwrapper_polkadot_1.construct.signingPayload(this._substrateTransaction, {
                registry: this._registry,
            });
        }
    }
    transactionSize() {
        return this.toBroadcastFormat().length / 2;
    }
    /** @inheritdoc */
    toJson() {
        if (!this._substrateTransaction) {
            throw new sdk_core_1.InvalidTransactionError('Empty transaction');
        }
        const decodedTx = (0, txwrapper_polkadot_1.decode)(this._substrateTransaction, {
            metadataRpc: this._substrateTransaction.metadataRpc,
            registry: this._registry,
            isImmortalEra: utils_1.default.isZeroHex(this._substrateTransaction.era),
        });
        const result = {
            id: txwrapper_polkadot_1.construct.txHash(this.toBroadcastFormat()),
            sender: decodedTx.address,
            referenceBlock: decodedTx.blockHash,
            blockNumber: decodedTx.blockNumber,
            genesisHash: decodedTx.genesisHash,
            nonce: decodedTx.nonce,
            specVersion: decodedTx.specVersion,
            transactionVersion: decodedTx.transactionVersion,
            eraPeriod: decodedTx.eraPeriod,
            chainName: this._chainName,
            tip: decodedTx.tip ? Number(decodedTx.tip) : 0,
        };
        const txMethod = decodedTx.method.args;
        if (this.type === sdk_core_1.TransactionType.Send) {
            if (utils_1.default.isTransfer(txMethod)) {
                const keypairDest = new keyPair_1.KeyPair({
                    pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.dest.id)).toString('hex'),
                });
                result.to = keypairDest.getAddress(this.getAddressFormat());
                result.amount = txMethod.value;
            }
            else if (utils_1.default.isTransferAll(txMethod)) {
                const keypairDest = new keyPair_1.KeyPair({
                    pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.dest.id)).toString('hex'),
                });
                result.to = keypairDest.getAddress(this.getAddressFormat());
                result.keepAlive = txMethod.keepAlive;
            }
            else {
                throw new sdk_core_1.ParseTransactionError(`Serializing unknown Transfer type parameters`);
            }
        }
        else if (this.type === sdk_core_1.TransactionType.StakingActivate) {
            if (utils_1.default.isAddStake(txMethod)) {
                const keypairDest = new keyPair_1.KeyPair({
                    pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.hotkey)).toString('hex'),
                });
                // hotkey address of validator
                result.to = keypairDest.getAddress(this.getAddressFormat());
                result.amount = txMethod.amountStaked.toString();
                result.netuid = txMethod.netuid;
            }
        }
        else if (this.type === sdk_core_1.TransactionType.StakingDeactivate) {
            if (utils_1.default.isRemoveStake(txMethod)) {
                const keypairDest = new keyPair_1.KeyPair({
                    pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.hotkey)).toString('hex'),
                });
                // hotkey address of validator
                result.to = keypairDest.getAddress(this.getAddressFormat());
                result.amount = txMethod.amountUnstaked.toString();
                result.netuid = txMethod.netuid;
            }
        }
        return result;
    }
    explainTransferTransaction(json, explanationResult) {
        return {
            ...explanationResult,
            outputs: [
                {
                    address: json.to?.toString() || '',
                    amount: json.amount?.toString() || '',
                },
            ],
        };
    }
    explainStakeTransaction(json, explanationResult) {
        return {
            ...explanationResult,
            outputs: [
                {
                    address: json.to?.toString() || '',
                    amount: json.amount?.toString() || '',
                },
            ],
        };
    }
    explainUnstakeTransaction(json, explanationResult) {
        return {
            ...explanationResult,
            outputs: [
                {
                    address: json.sender.toString() || '',
                    amount: json.amount?.toString() || '',
                },
            ],
        };
    }
    /** @inheritdoc */
    explainTransaction() {
        const result = this.toJson();
        const outputs = [];
        const explanationResult = {
            // txhash used to identify the transactions
            id: result.id,
            outputAmount: result.amount?.toString() || '0',
            changeAmount: '0',
            changeOutputs: [],
            outputs,
            fee: {
                fee: result.tip?.toString() || '',
                type: 'tip',
            },
            type: this.type,
        };
        switch (this.type) {
            case sdk_core_1.TransactionType.Send:
                return this.explainTransferTransaction(result, explanationResult);
            case sdk_core_1.TransactionType.StakingActivate:
                return this.explainStakeTransaction(result, explanationResult);
            case sdk_core_1.TransactionType.StakingDeactivate:
                return this.explainUnstakeTransaction(result, explanationResult);
            default:
                throw new sdk_core_1.InvalidTransactionError('Transaction type not supported');
        }
    }
    /**
     * Load the input and output data on this transaction.
     */
    loadInputsAndOutputs() {
        if (!this._substrateTransaction) {
            return;
        }
        const decodedTx = (0, txwrapper_polkadot_1.decode)(this._substrateTransaction, {
            metadataRpc: this._substrateTransaction.metadataRpc,
            registry: this._registry,
            isImmortalEra: utils_1.default.isZeroHex(this._substrateTransaction.era),
        });
        if (this.type === sdk_core_1.TransactionType.Send) {
            this.decodeInputsAndOutputsForSend(decodedTx);
        }
        else if (this.type === sdk_core_1.TransactionType.StakingActivate) {
            this.decodeInputsAndOutputsForStakingActivate(decodedTx);
        }
        else if (this.type === sdk_core_1.TransactionType.StakingDeactivate) {
            this.decodeInputsAndOutputsForStakingDeactivate(decodedTx);
        }
    }
    decodeInputsAndOutputsForSend(decodedTx) {
        const txMethod = decodedTx.method.args;
        let to;
        let value;
        let from;
        if (utils_1.default.isTransferAll(txMethod)) {
            const keypairDest = new keyPair_1.KeyPair({
                pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.dest.id)).toString('hex'),
            });
            to = keypairDest.getAddress(this.getAddressFormat());
            value = '0'; // substrate transferAll's do not deserialize amounts
            from = decodedTx.address;
        }
        else if (utils_1.default.isTransfer(txMethod)) {
            const keypairDest = new keyPair_1.KeyPair({
                pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.dest.id)).toString('hex'),
            });
            to = keypairDest.getAddress(this.getAddressFormat());
            value = txMethod.value;
            from = decodedTx.address;
        }
        else {
            throw new sdk_core_1.ParseTransactionError(`Loading inputs of unknown Transfer type parameters`);
        }
        this._outputs = [
            {
                address: to,
                value,
                coin: this._coinConfig.name,
            },
        ];
        this._inputs = [
            {
                address: from,
                value,
                coin: this._coinConfig.name,
            },
        ];
    }
    decodeInputsAndOutputsForStakingActivate(decodedTx) {
        const txMethod = decodedTx.method.args;
        let to;
        let value;
        let from;
        if (utils_1.default.isAddStake(txMethod)) {
            const keypairDest = new keyPair_1.KeyPair({
                pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.hotkey)).toString('hex'),
            });
            to = keypairDest.getAddress(this.getAddressFormat());
            value = txMethod.amountStaked.toString();
            from = decodedTx.address;
        }
        else {
            throw new sdk_core_1.ParseTransactionError(`Loading inputs of unknown StakingActivate type parameters`);
        }
        this._outputs = [
            {
                address: to,
                value,
                coin: this._coinConfig.name,
            },
        ];
        this._inputs = [
            {
                address: from,
                value,
                coin: this._coinConfig.name,
            },
        ];
    }
    decodeInputsAndOutputsForStakingDeactivate(decodedTx) {
        const txMethod = decodedTx.method.args;
        let to;
        let value;
        let from;
        if (utils_1.default.isRemoveStake(txMethod)) {
            const keypairDest = new keyPair_1.KeyPair({
                pub: Buffer.from((0, keyring_1.decodeAddress)(txMethod.hotkey)).toString('hex'),
            });
            to = keypairDest.getAddress(this.getAddressFormat());
            value = txMethod.amountUnstaked.toString();
            from = decodedTx.address;
        }
        else {
            throw new sdk_core_1.ParseTransactionError(`Loading inputs of unknown StakingDeactivate type parameters`);
        }
        this._outputs = [
            {
                address: from,
                value,
                coin: this._coinConfig.name,
            },
        ];
        this._inputs = [
            {
                address: to,
                value,
                coin: this._coinConfig.name,
            },
        ];
    }
    /**
     * Constructs a signed payload using construct.signTx
     * This method will be called during the build step if a TSS signature
     * is added and will set the signTransaction which is the txHex that will be broadcasted
     * As well as add the signature used to sign to the signature array in hex format
     *
     * @param {Buffer} signature The signature to be added to a substrate transaction
     */
    constructSignedPayload(signature) {
        // 0x00 means its an ED25519 signature
        const edSignature = `0x00${signature.toString('hex')}`;
        try {
            this._signedTransaction = txwrapper_polkadot_1.construct.signedTx(this._substrateTransaction, edSignature, {
                registry: this._registry,
                metadataRpc: this._substrateTransaction.metadataRpc,
            });
        }
        catch (e) {
            throw new sdk_core_1.SigningError(`Unable to sign transaction with signature ${edSignature} ` + e);
        }
        this._signatures = [signature.toString('hex')];
    }
    setTransaction(tx) {
        this._substrateTransaction = tx;
    }
    /** @inheritdoc **/
    get signablePayload() {
        const extrinsicPayload = this._registry.createType('ExtrinsicPayload', this._substrateTransaction, {
            version: Extrinsic_1.EXTRINSIC_VERSION,
        });
        return (0, util_1.u8aToBuffer)(extrinsicPayload.toU8a({ method: true }));
    }
    /**
     * Set the transaction type.
     *
     * @param {TransactionType} transactionType The transaction type to be set.
     */
    transactionType(transactionType) {
        this._type = transactionType;
    }
    getAddressFormat() {
        return constants_1.DEFAULT_SUBSTRATE_PREFIX;
    }
}
exports.Transaction = Transaction;
Transaction.FAKE_SIGNATURE = `0x${Buffer.from(new Uint8Array(256).fill(1)).toString('hex')}`;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction.js","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseKey,\n  BaseTransaction,\n  InvalidTransactionError,\n  ParseTransactionError,\n  SigningError,\n  TransactionRecipient,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport Keyring, { decodeAddress } from '@polkadot/keyring';\nimport { u8aToBuffer } from '@polkadot/util';\nimport { construct, decode } from '@substrate/txwrapper-polkadot';\nimport { UnsignedTransaction } from '@substrate/txwrapper-core';\nimport { TypeRegistry } from '@substrate/txwrapper-core/lib/types';\nimport { KeyPair } from './keyPair';\nimport { DecodedTx, HexString, TransactionExplanation, TxData } from './iface';\nimport utils from './utils';\nimport { EXTRINSIC_VERSION } from '@polkadot/types/extrinsic/v4/Extrinsic';\nimport { DEFAULT_SUBSTRATE_PREFIX } from './constants';\n\nexport class Transaction extends BaseTransaction {\n  protected _substrateTransaction: UnsignedTransaction;\n  private _signedTransaction?: string;\n  private _registry: TypeRegistry;\n  private _chainName: string;\n  private _sender: string;\n\n  private static FAKE_SIGNATURE = `0x${Buffer.from(new Uint8Array(256).fill(1)).toString('hex')}`;\n\n  constructor(coinConfig: Readonly<CoinConfig>) {\n    super(coinConfig);\n  }\n\n  /** @inheritdoc */\n  canSign({ key }: BaseKey): boolean {\n    const kp = new KeyPair({ prv: key });\n    const addr = kp.getAddress(this.getAddressFormat());\n    return addr === this._sender;\n  }\n\n  /**\n   * Sign a substrate transaction and update the transaction hex\n   *\n   * @param {KeyPair} keyPair - ed signature\n   */\n  sign(keyPair: KeyPair): void {\n    if (!this._substrateTransaction) {\n      throw new InvalidTransactionError('No transaction data to sign');\n    }\n    const { prv, pub } = keyPair.getKeys();\n    if (!prv) {\n      throw new SigningError('Missing private key');\n    }\n    const signingPayload = construct.signingPayload(this._substrateTransaction, {\n      registry: this._registry,\n    });\n    // Sign a payload. This operation should be performed on an offline device.\n    const keyring = new Keyring({ type: 'ed25519' });\n    const secretKey = new Uint8Array(Buffer.from(prv, 'hex'));\n    const publicKey = new Uint8Array(Buffer.from(pub, 'hex'));\n    const signingKeyPair = keyring.addFromPair({ secretKey, publicKey });\n    const txHex = utils.createSignedTx(signingKeyPair, signingPayload, this._substrateTransaction, {\n      metadataRpc: this._substrateTransaction.metadataRpc,\n      registry: this._registry,\n    });\n\n    // get signature from signed txHex generated above\n    this._signatures = [utils.recoverSignatureFromRawTx(txHex, { registry: this._registry })];\n    this._signedTransaction = txHex;\n  }\n\n  /**\n   * Adds the signature to the Substrate Transaction\n   * @param {string} signature\n   */\n  addSignature(signature: string): void {\n    this._signedTransaction = utils.serializeSignedTransaction(\n      this._substrateTransaction,\n      signature,\n      this._substrateTransaction.metadataRpc,\n      this._registry\n    );\n  }\n\n  /**\n   * Returns a serialized representation of this transaction with a fake signature attached which\n   * can be used to estimate transaction fees.\n   */\n  fakeSign(): string {\n    return utils.serializeSignedTransaction(\n      this._substrateTransaction,\n      Transaction.FAKE_SIGNATURE,\n      this._substrateTransaction.metadataRpc,\n      this._registry\n    );\n  }\n\n  registry(registry: TypeRegistry): void {\n    this._registry = registry;\n  }\n\n  chainName(chainName: string): void {\n    this._chainName = chainName;\n  }\n\n  sender(sender: string): void {\n    this._sender = sender;\n  }\n\n  /** @inheritdoc */\n  toBroadcastFormat(): string {\n    if (!this._substrateTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    if (this._signedTransaction && this._signedTransaction.length > 0) {\n      return this._signedTransaction;\n    } else {\n      return construct.signingPayload(this._substrateTransaction, {\n        registry: this._registry,\n      });\n    }\n  }\n\n  transactionSize(): number {\n    return this.toBroadcastFormat().length / 2;\n  }\n\n  /** @inheritdoc */\n  toJson(): TxData {\n    if (!this._substrateTransaction) {\n      throw new InvalidTransactionError('Empty transaction');\n    }\n    const decodedTx = decode(this._substrateTransaction, {\n      metadataRpc: this._substrateTransaction.metadataRpc,\n      registry: this._registry,\n      isImmortalEra: utils.isZeroHex(this._substrateTransaction.era),\n    }) as unknown as DecodedTx;\n\n    const result: TxData = {\n      id: construct.txHash(this.toBroadcastFormat()),\n      sender: decodedTx.address,\n      referenceBlock: decodedTx.blockHash,\n      blockNumber: decodedTx.blockNumber,\n      genesisHash: decodedTx.genesisHash,\n      nonce: decodedTx.nonce,\n      specVersion: decodedTx.specVersion,\n      transactionVersion: decodedTx.transactionVersion,\n      eraPeriod: decodedTx.eraPeriod,\n      chainName: this._chainName,\n      tip: decodedTx.tip ? Number(decodedTx.tip) : 0,\n    };\n\n    const txMethod = decodedTx.method.args;\n    if (this.type === TransactionType.Send) {\n      if (utils.isTransfer(txMethod)) {\n        const keypairDest = new KeyPair({\n          pub: Buffer.from(decodeAddress(txMethod.dest.id)).toString('hex'),\n        });\n        result.to = keypairDest.getAddress(this.getAddressFormat());\n        result.amount = txMethod.value;\n      } else if (utils.isTransferAll(txMethod)) {\n        const keypairDest = new KeyPair({\n          pub: Buffer.from(decodeAddress(txMethod.dest.id)).toString('hex'),\n        });\n        result.to = keypairDest.getAddress(this.getAddressFormat());\n        result.keepAlive = txMethod.keepAlive;\n      } else {\n        throw new ParseTransactionError(`Serializing unknown Transfer type parameters`);\n      }\n    } else if (this.type === TransactionType.StakingActivate) {\n      if (utils.isAddStake(txMethod)) {\n        const keypairDest = new KeyPair({\n          pub: Buffer.from(decodeAddress(txMethod.hotkey)).toString('hex'),\n        });\n        // hotkey address of validator\n        result.to = keypairDest.getAddress(this.getAddressFormat());\n        result.amount = txMethod.amountStaked.toString();\n        result.netuid = txMethod.netuid;\n      }\n    } else if (this.type === TransactionType.StakingDeactivate) {\n      if (utils.isRemoveStake(txMethod)) {\n        const keypairDest = new KeyPair({\n          pub: Buffer.from(decodeAddress(txMethod.hotkey)).toString('hex'),\n        });\n        // hotkey address of validator\n        result.to = keypairDest.getAddress(this.getAddressFormat());\n        result.amount = txMethod.amountUnstaked.toString();\n        result.netuid = txMethod.netuid;\n      }\n    }\n\n    return result;\n  }\n\n  explainTransferTransaction(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation {\n    return {\n      ...explanationResult,\n      outputs: [\n        {\n          address: json.to?.toString() || '',\n          amount: json.amount?.toString() || '',\n        },\n      ],\n    };\n  }\n\n  explainStakeTransaction(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation {\n    return {\n      ...explanationResult,\n      outputs: [\n        {\n          address: json.to?.toString() || '',\n          amount: json.amount?.toString() || '',\n        },\n      ],\n    };\n  }\n\n  explainUnstakeTransaction(json: TxData, explanationResult: TransactionExplanation): TransactionExplanation {\n    return {\n      ...explanationResult,\n      outputs: [\n        {\n          address: json.sender.toString() || '',\n          amount: json.amount?.toString() || '',\n        },\n      ],\n    };\n  }\n\n  /** @inheritdoc */\n  explainTransaction(): TransactionExplanation {\n    const result = this.toJson();\n    const outputs: TransactionRecipient[] = [];\n    const explanationResult: TransactionExplanation = {\n      // txhash used to identify the transactions\n      id: result.id,\n      outputAmount: result.amount?.toString() || '0',\n      changeAmount: '0',\n      changeOutputs: [],\n      outputs,\n      fee: {\n        fee: result.tip?.toString() || '',\n        type: 'tip',\n      },\n      type: this.type,\n    };\n    switch (this.type) {\n      case TransactionType.Send:\n        return this.explainTransferTransaction(result, explanationResult);\n      case TransactionType.StakingActivate:\n        return this.explainStakeTransaction(result, explanationResult);\n      case TransactionType.StakingDeactivate:\n        return this.explainUnstakeTransaction(result, explanationResult);\n      default:\n        throw new InvalidTransactionError('Transaction type not supported');\n    }\n  }\n\n  /**\n   * Load the input and output data on this transaction.\n   */\n  loadInputsAndOutputs(): void {\n    if (!this._substrateTransaction) {\n      return;\n    }\n    const decodedTx = decode(this._substrateTransaction, {\n      metadataRpc: this._substrateTransaction.metadataRpc,\n      registry: this._registry,\n      isImmortalEra: utils.isZeroHex(this._substrateTransaction.era),\n    }) as unknown as DecodedTx;\n\n    if (this.type === TransactionType.Send) {\n      this.decodeInputsAndOutputsForSend(decodedTx);\n    } else if (this.type === TransactionType.StakingActivate) {\n      this.decodeInputsAndOutputsForStakingActivate(decodedTx);\n    } else if (this.type === TransactionType.StakingDeactivate) {\n      this.decodeInputsAndOutputsForStakingDeactivate(decodedTx);\n    }\n  }\n\n  private decodeInputsAndOutputsForSend(decodedTx: DecodedTx) {\n    const txMethod = decodedTx.method.args;\n    let to: string;\n    let value: string;\n    let from: string;\n    if (utils.isTransferAll(txMethod)) {\n      const keypairDest = new KeyPair({\n        pub: Buffer.from(decodeAddress(txMethod.dest.id)).toString('hex'),\n      });\n      to = keypairDest.getAddress(this.getAddressFormat());\n      value = '0'; // substrate transferAll's do not deserialize amounts\n      from = decodedTx.address;\n    } else if (utils.isTransfer(txMethod)) {\n      const keypairDest = new KeyPair({\n        pub: Buffer.from(decodeAddress(txMethod.dest.id)).toString('hex'),\n      });\n      to = keypairDest.getAddress(this.getAddressFormat());\n      value = txMethod.value;\n      from = decodedTx.address;\n    } else {\n      throw new ParseTransactionError(`Loading inputs of unknown Transfer type parameters`);\n    }\n    this._outputs = [\n      {\n        address: to,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n\n    this._inputs = [\n      {\n        address: from,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n  }\n\n  private decodeInputsAndOutputsForStakingActivate(decodedTx: DecodedTx) {\n    const txMethod = decodedTx.method.args;\n    let to: string;\n    let value: string;\n    let from: string;\n    if (utils.isAddStake(txMethod)) {\n      const keypairDest = new KeyPair({\n        pub: Buffer.from(decodeAddress(txMethod.hotkey)).toString('hex'),\n      });\n      to = keypairDest.getAddress(this.getAddressFormat());\n      value = txMethod.amountStaked.toString();\n      from = decodedTx.address;\n    } else {\n      throw new ParseTransactionError(`Loading inputs of unknown StakingActivate type parameters`);\n    }\n    this._outputs = [\n      {\n        address: to,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n\n    this._inputs = [\n      {\n        address: from,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n  }\n\n  private decodeInputsAndOutputsForStakingDeactivate(decodedTx: DecodedTx) {\n    const txMethod = decodedTx.method.args;\n    let to: string;\n    let value: string;\n    let from: string;\n    if (utils.isRemoveStake(txMethod)) {\n      const keypairDest = new KeyPair({\n        pub: Buffer.from(decodeAddress(txMethod.hotkey)).toString('hex'),\n      });\n      to = keypairDest.getAddress(this.getAddressFormat());\n      value = txMethod.amountUnstaked.toString();\n      from = decodedTx.address;\n    } else {\n      throw new ParseTransactionError(`Loading inputs of unknown StakingDeactivate type parameters`);\n    }\n    this._outputs = [\n      {\n        address: from,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n\n    this._inputs = [\n      {\n        address: to,\n        value,\n        coin: this._coinConfig.name,\n      },\n    ];\n  }\n\n  /**\n   * Constructs a signed payload using construct.signTx\n   * This method will be called during the build step if a TSS signature\n   * is added and will set the signTransaction which is the txHex that will be broadcasted\n   * As well as add the signature used to sign to the signature array in hex format\n   *\n   * @param {Buffer} signature The signature to be added to a substrate transaction\n   */\n  constructSignedPayload(signature: Buffer): void {\n    // 0x00 means its an ED25519 signature\n    const edSignature = `0x00${signature.toString('hex')}` as HexString;\n\n    try {\n      this._signedTransaction = construct.signedTx(this._substrateTransaction, edSignature, {\n        registry: this._registry,\n        metadataRpc: this._substrateTransaction.metadataRpc,\n      });\n    } catch (e) {\n      throw new SigningError(`Unable to sign transaction with signature ${edSignature} ` + e);\n    }\n\n    this._signatures = [signature.toString('hex')];\n  }\n\n  setTransaction(tx: UnsignedTransaction): void {\n    this._substrateTransaction = tx;\n  }\n\n  /** @inheritdoc **/\n  get signablePayload(): Buffer {\n    const extrinsicPayload = this._registry.createType('ExtrinsicPayload', this._substrateTransaction, {\n      version: EXTRINSIC_VERSION,\n    });\n    return u8aToBuffer(extrinsicPayload.toU8a({ method: true }));\n  }\n\n  /**\n   * Set the transaction type.\n   *\n   * @param {TransactionType} transactionType The transaction type to be set.\n   */\n  transactionType(transactionType: TransactionType): void {\n    this._type = transactionType;\n  }\n\n  protected getAddressFormat(): number {\n    return DEFAULT_SUBSTRATE_PREFIX;\n  }\n}\n"]}

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


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