PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.WalletInitializationBuilder = void 0;
const casper_js_sdk_1 = require("casper-js-sdk");
const sdk_core_1 = require("@bitgo/sdk-core");
const transactionBuilder_1 = require("./transactionBuilder");
const utils_1 = require("./utils");
const constants_1 = require("./constants");
const keyPair_1 = require("./keyPair");
const DEFAULT_OWNER_WEIGHT = 1;
class WalletInitializationBuilder extends transactionBuilder_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._owners = [];
        this._contract = Uint8Array.from(Buffer.from(utils_1.casperContractHexCode, 'hex'));
    }
    // region Base Builder
    /** @inheritdoc */
    async buildImplementation() {
        const args = this.buildWalletParameters();
        const extraArguments = new Map();
        extraArguments.set(constants_1.TRANSACTION_TYPE, casper_js_sdk_1.CLValueBuilder.string(sdk_core_1.TransactionType[sdk_core_1.TransactionType.WalletInitialization]));
        for (let index = 0; index < this._owners.length; index++) {
            const ownerPublicKey = Buffer.from(this._owners[index].address.value()).toString('hex');
            const ownerAddress = new keyPair_1.KeyPair({ pub: ownerPublicKey }).getAddress();
            extraArguments.set(constants_1.OWNER_PREFIX + index, casper_js_sdk_1.CLValueBuilder.string(ownerAddress));
        }
        this._session = { moduleBytes: this._contract, args: casper_js_sdk_1.RuntimeArgs.fromMap(args), extraArguments: extraArguments };
        this.transaction.setTransactionType(sdk_core_1.TransactionType.WalletInitialization);
        return await super.buildImplementation();
    }
    /**
     * Build args needed to create a session, then we can send this session with the contract
     *
     * @returns {WalletInitContractArgs} contracts args to create a session
     */
    buildWalletParameters() {
        const accounts = this._owners.map((owner) => casper_js_sdk_1.CLValueBuilder.byteArray(owner.address.toAccountHash()));
        const weights = this._owners.map((owner) => casper_js_sdk_1.CLValueBuilder.u8(owner.weight));
        // set source address weight to zero to disable the master private key from signing.
        accounts.push(casper_js_sdk_1.CLValueBuilder.byteArray(casper_js_sdk_1.CLPublicKey.fromHex(this._source.address).toAccountHash()));
        weights.push(casper_js_sdk_1.CLValueBuilder.u8(0));
        return {
            action: casper_js_sdk_1.CLValueBuilder.string(constants_1.WALLET_INITIALIZATION_CONTRACT_ACTION),
            // This typo is on purpose since the contract we use for multisig wallet initialization expect this argument to be written like this.
            deployment_thereshold: casper_js_sdk_1.CLValueBuilder.u8(transactionBuilder_1.DEFAULT_N),
            key_management_threshold: casper_js_sdk_1.CLValueBuilder.u8(transactionBuilder_1.DEFAULT_M),
            accounts: casper_js_sdk_1.CLValueBuilder.list(accounts),
            weights: casper_js_sdk_1.CLValueBuilder.list(weights),
        };
    }
    /** @inheritdoc */
    initBuilder(tx) {
        super.initBuilder(tx);
        this.transaction.setTransactionType(sdk_core_1.TransactionType.WalletInitialization);
        for (let ownerIndex = 0; ownerIndex < transactionBuilder_1.DEFAULT_M; ownerIndex++) {
            const ownerCLValue = tx.casperTx.session.getArgByName(constants_1.OWNER_PREFIX + ownerIndex);
            this.owner(ownerCLValue.value());
        }
    }
    // endregion
    // region Common builder methods
    /**
     * Set one of the owners of the multisig wallet.
     *
     * @param {string} address The public key of the owner's account
     * @returns {WalletInitializationBuilder} This wallet initialization builder
     */
    owner(address) {
        if (this._owners.length >= transactionBuilder_1.DEFAULT_M) {
            throw new sdk_core_1.BuildTransactionError('A maximum of ' + transactionBuilder_1.DEFAULT_M + ' owners can be set for a multisig wallet');
        }
        this.validateAddress({ address: address });
        for (const _owner of this._owners) {
            if (address.substr(0, 2) + Buffer.from(_owner.address.value()).toString('hex') === address) {
                throw new sdk_core_1.BuildTransactionError('Duplicated owner: ' + address);
            }
        }
        this._owners.push({ address: casper_js_sdk_1.CLPublicKey.fromHex(address), weight: DEFAULT_OWNER_WEIGHT });
        return this;
    }
    // endregion
    // region Validators
    validateMandatoryFields() {
        if (this._owners.length === 0) {
            throw new sdk_core_1.BuildTransactionError('Invalid transaction: missing wallet owners');
        }
        if (this._owners.length !== transactionBuilder_1.DEFAULT_M) {
            throw new sdk_core_1.BuildTransactionError(`Invalid transaction: wrong number of owners -- required: ${transactionBuilder_1.DEFAULT_M}, found: ${this._owners.length}`);
        }
        super.validateMandatoryFields();
    }
}
exports.WalletInitializationBuilder = WalletInitializationBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"walletInitializationBuilder.js","sourceRoot":"","sources":["../../../src/lib/walletInitializationBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { CLValue, CLPublicKey as PublicKey, RuntimeArgs, CLValueBuilder, CLString } from 'casper-js-sdk';\nimport { BuildTransactionError, TransactionType } from '@bitgo/sdk-core';\nimport { TransactionBuilder, DEFAULT_M, DEFAULT_N } from './transactionBuilder';\nimport { Transaction } from './transaction';\nimport { Owner, WalletInitContractArgs } from './ifaces';\nimport { casperContractHexCode } from './utils';\nimport { OWNER_PREFIX, TRANSACTION_TYPE, WALLET_INITIALIZATION_CONTRACT_ACTION } from './constants';\nimport { KeyPair } from './keyPair';\n\nconst DEFAULT_OWNER_WEIGHT = 1;\nexport class WalletInitializationBuilder extends TransactionBuilder {\n  private _owners: Owner[] = [];\n  private _contract: Uint8Array;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._contract = Uint8Array.from(Buffer.from(casperContractHexCode, 'hex'));\n  }\n\n  // region Base Builder\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const args = this.buildWalletParameters();\n    const extraArguments = new Map<string, CLValue>();\n\n    extraArguments.set(TRANSACTION_TYPE, CLValueBuilder.string(TransactionType[TransactionType.WalletInitialization]));\n    for (let index = 0; index < this._owners.length; index++) {\n      const ownerPublicKey = Buffer.from(this._owners[index].address.value()).toString('hex');\n      const ownerAddress = new KeyPair({ pub: ownerPublicKey }).getAddress();\n      extraArguments.set(OWNER_PREFIX + index, CLValueBuilder.string(ownerAddress));\n    }\n\n    this._session = { moduleBytes: this._contract, args: RuntimeArgs.fromMap(args), extraArguments: extraArguments };\n    this.transaction.setTransactionType(TransactionType.WalletInitialization);\n    return await super.buildImplementation();\n  }\n\n  /**\n   * Build args needed to create a session, then we can send this session with the contract\n   *\n   * @returns {WalletInitContractArgs} contracts args to create a session\n   */\n  private buildWalletParameters(): WalletInitContractArgs {\n    const accounts = this._owners.map((owner) => CLValueBuilder.byteArray(owner.address.toAccountHash()));\n    const weights = this._owners.map((owner) => CLValueBuilder.u8(owner.weight));\n\n    // set source address weight to zero to disable the master private key from signing.\n    accounts.push(CLValueBuilder.byteArray(PublicKey.fromHex(this._source.address).toAccountHash()));\n    weights.push(CLValueBuilder.u8(0));\n\n    return {\n      action: CLValueBuilder.string(WALLET_INITIALIZATION_CONTRACT_ACTION),\n      // This typo is on purpose since the contract we use for multisig wallet initialization expect this argument to be written like this.\n      deployment_thereshold: CLValueBuilder.u8(DEFAULT_N),\n      key_management_threshold: CLValueBuilder.u8(DEFAULT_M),\n      accounts: CLValueBuilder.list(accounts),\n      weights: CLValueBuilder.list(weights),\n    };\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    this.transaction.setTransactionType(TransactionType.WalletInitialization);\n    for (let ownerIndex = 0; ownerIndex < DEFAULT_M; ownerIndex++) {\n      const ownerCLValue = tx.casperTx.session.getArgByName(OWNER_PREFIX + ownerIndex) as CLString;\n      this.owner(ownerCLValue.value());\n    }\n  }\n\n  // endregion\n\n  // region Common builder methods\n  /**\n   * Set one of the owners of the multisig wallet.\n   *\n   * @param {string} address The public key of the owner's account\n   * @returns {WalletInitializationBuilder} This wallet initialization builder\n   */\n  owner(address: string): this {\n    if (this._owners.length >= DEFAULT_M) {\n      throw new BuildTransactionError('A maximum of ' + DEFAULT_M + ' owners can be set for a multisig wallet');\n    }\n    this.validateAddress({ address: address });\n    for (const _owner of this._owners) {\n      if (address.substr(0, 2) + Buffer.from(_owner.address.value()).toString('hex') === address) {\n        throw new BuildTransactionError('Duplicated owner: ' + address);\n      }\n    }\n\n    this._owners.push({ address: PublicKey.fromHex(address), weight: DEFAULT_OWNER_WEIGHT });\n    return this;\n  }\n  // endregion\n\n  // region Validators\n  validateMandatoryFields(): void {\n    if (this._owners.length === 0) {\n      throw new BuildTransactionError('Invalid transaction: missing wallet owners');\n    }\n\n    if (this._owners.length !== DEFAULT_M) {\n      throw new BuildTransactionError(\n        `Invalid transaction: wrong number of owners -- required: ${DEFAULT_M}, found: ${this._owners.length}`\n      );\n    }\n    super.validateMandatoryFields();\n  }\n  // endregion\n}\n"]}

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


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