PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.BaseTransactionBuilder = void 0;
const errors_1 = require("./errors");
/**
 * Generic transaction builder to be extended with coin specific logic.
 * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.
 */
class BaseTransactionBuilder {
    /**
     * Base constructor.
     *
     * @param _coinConfig BaseCoin from statics library
     */
    constructor(_coinConfig) {
        this._coinConfig = _coinConfig;
    }
    /**
     * Parse a transaction based on existing data. The input format is determined by the coin
     * extending this class. Some examples are hex, base64, or JSON.
     *
     * @param rawTransaction A raw transaction to be parsed
     * @param isFirstSigner Whether the transaction is being signed by the first signer
     */
    from(rawTransaction, isFirstSigner) {
        this.validateRawTransaction(rawTransaction);
        this.transaction = this.fromImplementation(rawTransaction, isFirstSigner);
    }
    /**
     * Validate keys and sign the transaction.
     *
     * @param key One of the keys associated with this transaction
     */
    sign(key) {
        this.validateKey(key);
        if (!this.transaction.canSign(key)) {
            throw new errors_1.SigningError('Private key cannot sign the transaction');
        }
        this.transaction = this.signImplementation(key);
    }
    /**
     * Adds a signature to the transaction.
     *
     * @param publicKey public key that produced the signature
     * @param signature raw signature as a hex encoded Buffer
     */
    addSignature(publicKey, signature) {
        throw new errors_1.SigningError(`${this.coinName()} does not support adding signatures directly.`);
    }
    /**
     * Finalize the transaction by performing any extra step like calculating hashes, verifying
     * integrity, or adding default values.
     *
     * @returns valid coin specific transaction (signed or unsigned)
     */
    async build() {
        this.validateTransaction(this.transaction);
        return this.buildImplementation();
    }
    /**
     * Get the underlying coin full name as specified in the statics library.
     */
    displayName() {
        return this._coinConfig.fullName;
    }
    /**
     * Get the underlying coin full name as specified in the statics library.
     */
    coinName() {
        return this._coinConfig.name;
    }
    /**
     * Verified validity windows params if them exist and return a valid validity windows.
     * Unit param must be specified
     * If params are not consistent, default params will be return based on firstValid and minDuration
     * @param {ValidityWindow} params validity windows parameters to validate.
     * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'
     * @param {Number} [params.minDuration] Optional - Minimum duration of the window
     * @param {Number} [params.maxDuration] Optional - Maximum duration of the window
     * @param {Number} [params.firstValid] Optional - First valid value
     * @param {Number} [params.lastValid] Optional - Last valid value
     * @returns {ValidityWindow} verified validity windows or default values
     */
    getValidityWindow(params) {
        if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {
            throw new Error('Unit parameter must be specified as blockheight or timestamp');
        }
        const unit = params.unit;
        let defaultMinDuration;
        let defaultMaxDuration;
        let defaultFirstValid;
        let defaultLastValid;
        /* Set Default Params
          minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight
          maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.
         */
        if (unit === 'timestamp') {
            defaultMinDuration = 0;
            defaultMaxDuration = 31536000000;
            defaultFirstValid = Date.now();
            defaultLastValid = defaultFirstValid + defaultMaxDuration;
        }
        else {
            defaultMinDuration = 0;
            defaultMaxDuration = 1000000;
            defaultFirstValid = 0;
            defaultLastValid = defaultFirstValid + defaultMaxDuration;
        }
        // If any params exist, they will be used, otherwise it will be used default params.
        let firstValid = params.firstValid || defaultFirstValid;
        let lastValid = params.lastValid || defaultLastValid;
        let minDuration = params.minDuration || defaultMinDuration;
        let maxDuration = params.maxDuration || defaultMaxDuration;
        /* Validate Params:
          minDuration < maxDuration
          firstValid < lastValid
          firstValid + minDuration <= lastValid <= firstValid + maxDuration
         */
        if (minDuration >= maxDuration) {
            throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);
        }
        firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;
        minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;
        maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;
        lastValid =
            lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration
                ? lastValid
                : firstValid + maxDuration;
        return {
            firstValid,
            lastValid,
            minDuration,
            maxDuration,
            unit,
        };
    }
}
exports.BaseTransactionBuilder = BaseTransactionBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseTransactionBuilder.js","sourceRoot":"","sources":["../../../../src/account-lib/baseCoin/baseTransactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { BaseAddress, BaseKey, PublicKey, ValidityWindow } from './iface';\nimport { BaseTransaction } from './baseTransaction';\nimport { SigningError } from './errors';\n\n/**\n * Generic transaction builder to be extended with coin specific logic.\n * Provide a set of default steps (i.e. from, sign, build) and enforces mandatory validations.\n */\nexport abstract class BaseTransactionBuilder {\n  protected _coinConfig: Readonly<CoinConfig>;\n  /**\n   * Base constructor.\n   *\n   * @param _coinConfig BaseCoin from statics library\n   */\n  protected constructor(_coinConfig: Readonly<CoinConfig>) {\n    this._coinConfig = _coinConfig;\n  }\n\n  /**\n   * Parse a transaction based on existing data. The input format is determined by the coin\n   * extending this class. Some examples are hex, base64, or JSON.\n   *\n   * @param rawTransaction A raw transaction to be parsed\n   * @param isFirstSigner Whether the transaction is being signed by the first signer\n   */\n  from(rawTransaction: any, isFirstSigner?: boolean): void {\n    this.validateRawTransaction(rawTransaction);\n    this.transaction = this.fromImplementation(rawTransaction, isFirstSigner);\n  }\n\n  /**\n   * Coin specific implementation of {@code from}.\n   *\n   * @see {@link from}\n   * @returns the parsed coin specific transaction object\n   */\n  protected abstract fromImplementation(rawTransaction: any, isFirstSigner?: boolean): BaseTransaction;\n\n  /**\n   * Validate keys and sign the transaction.\n   *\n   * @param key One of the keys associated with this transaction\n   */\n  sign(key: BaseKey): void {\n    this.validateKey(key);\n    if (!this.transaction.canSign(key)) {\n      throw new SigningError('Private key cannot sign the transaction');\n    }\n\n    this.transaction = this.signImplementation(key);\n  }\n\n  /**\n   * Adds a signature to the transaction.\n   *\n   * @param publicKey public key that produced the signature\n   * @param signature raw signature as a hex encoded Buffer\n   */\n  addSignature(publicKey: PublicKey, signature: Buffer): void {\n    throw new SigningError(`${this.coinName()} does not support adding signatures directly.`);\n  }\n\n  /**\n   * Coin specific implementation of {@code sign}.\n   *\n   * @see {@link sign}\n   * @returns coin specific transaction with signature data\n   */\n  protected abstract signImplementation(key: BaseKey): BaseTransaction;\n\n  /**\n   * Finalize the transaction by performing any extra step like calculating hashes, verifying\n   * integrity, or adding default values.\n   *\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  async build(): Promise<BaseTransaction> {\n    this.validateTransaction(this.transaction);\n    return this.buildImplementation();\n  }\n\n  /**\n   * Coin specific implementation of {@code build}.\n   *\n   * @see {@link build}\n   * @returns valid coin specific transaction (signed or unsigned)\n   */\n  protected abstract buildImplementation(): Promise<BaseTransaction>;\n\n  /**\n   * Check the private key is present and is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BaseKey} key Private key to validate\n   */\n  abstract validateKey(key: BaseKey): void;\n\n  /**\n   * Check the address provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param address Address data to be validated\n   * @param addressFormat The format the address should be in if more than one is supported\n   */\n  abstract validateAddress(address: BaseAddress, addressFormat?: string): void;\n\n  /**\n   * Check the amount provided is valid in the blockchain context, throw otherwise.\n   *\n   * @param {BigNumber} value Transaction amount\n   */\n  abstract validateValue(value: BigNumber): void;\n\n  /**\n   * Check the raw transaction has a valid format in the blockchain context, throw otherwise.\n   *\n   * @param rawTransaction Transaction in any format\n   */\n  abstract validateRawTransaction(rawTransaction: any): void;\n\n  /**\n   * Check the transaction mandatory fields per transaction type and ensures it is valid, throw\n   * otherwise.\n   *\n   * @param {BaseTransaction} transaction\n   */\n  abstract validateTransaction(transaction?: BaseTransaction): void;\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  displayName(): string {\n    return this._coinConfig.fullName;\n  }\n\n  /**\n   * Get the underlying coin full name as specified in the statics library.\n   */\n  coinName(): string {\n    return this._coinConfig.name;\n  }\n\n  /**\n   * Verified validity windows params if them exist and return a valid validity windows.\n   * Unit param must be specified\n   * If params are not consistent, default params will be return based on firstValid and minDuration\n   * @param {ValidityWindow} params validity windows parameters to validate.\n   * @param {String} params.unit Parameter that could be 'blockheight' or 'timestamp'\n   * @param {Number} [params.minDuration] Optional - Minimum duration of the window\n   * @param {Number} [params.maxDuration] Optional - Maximum duration of the window\n   * @param {Number} [params.firstValid] Optional - First valid value\n   * @param {Number} [params.lastValid] Optional - Last valid value\n   * @returns {ValidityWindow} verified validity windows or default values\n   */\n  getValidityWindow(params: ValidityWindow): ValidityWindow {\n    if (!params.unit || (params.unit !== 'timestamp' && params.unit !== 'blockheight')) {\n      throw new Error('Unit parameter must be specified as blockheight or timestamp');\n    }\n    const unit = params.unit;\n    let defaultMinDuration: number;\n    let defaultMaxDuration: number;\n    let defaultFirstValid: number;\n    let defaultLastValid: number;\n\n    /* Set Default Params\n      minimum duration is set as 1 hr (3600000 msec) if unit is timestamp or 20 blocks if it is blockheight\n      maximum duration is set as 1 year (31536000000 msec) if unit is timestamp or 1000000 blocks if it is blockheight.\n     */\n    if (unit === 'timestamp') {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 31536000000;\n      defaultFirstValid = Date.now();\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    } else {\n      defaultMinDuration = 0;\n      defaultMaxDuration = 1000000;\n      defaultFirstValid = 0;\n      defaultLastValid = defaultFirstValid + defaultMaxDuration;\n    }\n\n    // If any params exist, they will be used, otherwise it will be used default params.\n    let firstValid: number = params.firstValid || defaultFirstValid;\n    let lastValid: number = params.lastValid || defaultLastValid;\n    let minDuration: number = params.minDuration || defaultMinDuration;\n    let maxDuration: number = params.maxDuration || defaultMaxDuration;\n\n    /* Validate Params:\n      minDuration < maxDuration\n      firstValid < lastValid\n      firstValid + minDuration <= lastValid <= firstValid + maxDuration\n     */\n    if (minDuration >= maxDuration) {\n      throw new Error(`Expected maxDuration (${maxDuration}) to be grather than minDuration (${minDuration})`);\n    }\n    firstValid = firstValid >= 0 ? firstValid : defaultFirstValid;\n    minDuration = minDuration >= 0 ? minDuration : defaultMinDuration;\n    maxDuration = maxDuration > minDuration ? maxDuration : defaultMaxDuration;\n    lastValid =\n      lastValid >= firstValid + minDuration && lastValid <= firstValid + maxDuration\n        ? lastValid\n        : firstValid + maxDuration;\n\n    return {\n      firstValid,\n      lastValid,\n      minDuration,\n      maxDuration,\n      unit,\n    };\n  }\n\n  /**\n   * Get the transaction being built.\n   */\n  protected abstract get transaction(): BaseTransaction;\n\n  /**\n   * Set the transaction being built.\n   */\n  protected abstract set transaction(transaction: BaseTransaction);\n}\n"]}

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


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