PHP WebShell

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

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

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.TokenAssociateBuilder = void 0;
const proto_1 = require("@hashgraph/proto");
const sdk_core_1 = require("@bitgo/sdk-core");
const utils_1 = require("./utils");
const transactionBuilder_1 = require("./transactionBuilder");
const constants_1 = require("./constants");
class TokenAssociateBuilder extends transactionBuilder_1.TransactionBuilder {
    constructor(_coinConfig) {
        super(_coinConfig);
        this._tokenIds = [];
        this._txBodyData = new proto_1.proto.TokenAssociateTransactionBody();
        this._txBody.tokenAssociate = this._txBodyData;
    }
    /** @inheritdoc */
    initBuilder(tx) {
        super.initBuilder(tx);
        const tokenAssociateAccount = tx.txBody.tokenAssociate;
        if (tokenAssociateAccount && tokenAssociateAccount.tokens) {
            this.initTokenAssociation(tokenAssociateAccount);
        }
    }
    initTokenAssociation(tokenAssociateAccount) {
        tokenAssociateAccount.tokens.forEach((tokenId) => {
            const token = (0, utils_1.stringifyTokenId)(tokenId);
            this.validateToken(token);
            this._tokenIds.push(token);
        });
        if (tokenAssociateAccount.account) {
            const accountId = (0, utils_1.stringifyAccountId)(tokenAssociateAccount.account);
            this.account(accountId);
        }
    }
    /** @inheritdoc */
    signImplementation(key) {
        if (this._multiSignerKeyPairs.length >= constants_1.DEFAULT_SIGNER_NUMBER) {
            throw new sdk_core_1.SigningError('A maximum of ' + constants_1.DEFAULT_SIGNER_NUMBER + ' can sign the transaction.');
        }
        return super.signImplementation(key);
    }
    /** @inheritdoc */
    async buildImplementation() {
        this._txBodyData.tokens = this.buildTokenData();
        this._txBodyData.account = this.buildAccountData();
        this.transaction.setTransactionType(sdk_core_1.TransactionType.AssociatedTokenAccountInitialization);
        return await super.buildImplementation();
    }
    /** @inheritdoc */
    validateMandatoryFields() {
        if (!this._tokenIds || this._tokenIds.length < 1) {
            throw new sdk_core_1.BuildTransactionError('Invalid transaction: missing tokens to associate');
        }
        super.validateMandatoryFields();
    }
    /**
     * Set account to associate with tokens, defaults to this._source.address value
     *
     * @param {string} accountID - The name of the account to associate to the transaction
     * @returns {TokenAssociateBuilder} - This token association builder
     */
    account(accountID) {
        this.validateAccount(accountID);
        this._account = accountID;
        return this;
    }
    /**
     * Add a token to associate to the multisig wallet.
     *
     * @param {string} tokenName - The name of the token to associate to the transaction
     * @returns {TokenAssociateBuilder} - This token association builder
     */
    tokens(tokenName) {
        const tokenId = (0, utils_1.getHederaTokenIdFromName)(tokenName);
        if (!tokenId) {
            throw new sdk_core_1.BuildTransactionError('Unsupported token: ' + tokenName);
        }
        this.validateToken(tokenId);
        this._tokenIds.push(tokenId);
        return this;
    }
    buildTokenData() {
        return this._tokenIds.map(utils_1.buildHederaTokenID);
    }
    buildAccountData() {
        let accountId = this._account;
        if (!accountId) {
            accountId = this._source.address;
        }
        return (0, utils_1.buildHederaAccountID)(accountId);
    }
    validateAccount(accountID) {
        if (!(0, utils_1.isValidAddress)(accountID)) {
            throw new sdk_core_1.BuildTransactionError('Unsupported account address: ' + accountID);
        }
    }
    validateToken(tokenId) {
        if (this._tokenIds.includes(tokenId)) {
            throw new sdk_core_1.BuildTransactionError('Repeated token ID: ' + tokenId);
        }
        else if (!(0, utils_1.isValidHederaTokenID)(tokenId)) {
            throw new sdk_core_1.BuildTransactionError('Invalid token ID: ' + tokenId);
        }
    }
}
exports.TokenAssociateBuilder = TokenAssociateBuilder;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tokenAssociateBuilder.js","sourceRoot":"","sources":["../../../src/lib/tokenAssociateBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseCoin as CoinConfig } from '@bitgo/statics';\nimport { proto } from '@hashgraph/proto';\nimport { BaseKey, BuildTransactionError, SigningError, TransactionType } from '@bitgo/sdk-core';\nimport { Transaction } from './transaction';\nimport {\n  buildHederaAccountID,\n  buildHederaTokenID,\n  getHederaTokenIdFromName,\n  isValidAddress,\n  isValidHederaTokenID,\n  stringifyAccountId,\n  stringifyTokenId,\n} from './utils';\nimport { TransactionBuilder } from './transactionBuilder';\nimport { DEFAULT_SIGNER_NUMBER } from './constants';\n\nexport class TokenAssociateBuilder extends TransactionBuilder {\n  private readonly _txBodyData: proto.TokenAssociateTransactionBody;\n  private _account: string;\n  private _tokenIds: string[] = [];\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._txBodyData = new proto.TokenAssociateTransactionBody();\n    this._txBody.tokenAssociate = this._txBodyData;\n  }\n\n  /** @inheritdoc */\n  initBuilder(tx: Transaction): void {\n    super.initBuilder(tx);\n    const tokenAssociateAccount = tx.txBody.tokenAssociate;\n    if (tokenAssociateAccount && tokenAssociateAccount.tokens) {\n      this.initTokenAssociation(tokenAssociateAccount as proto.TokenAssociateTransactionBody);\n    }\n  }\n\n  private initTokenAssociation(tokenAssociateAccount: proto.ITokenAssociateTransactionBody): void {\n    tokenAssociateAccount.tokens!.forEach((tokenId: proto.ITokenID) => {\n      const token = stringifyTokenId(tokenId);\n      this.validateToken(token);\n      this._tokenIds.push(token);\n    });\n\n    if (tokenAssociateAccount.account) {\n      const accountId = stringifyAccountId(tokenAssociateAccount.account);\n      this.account(accountId);\n    }\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (this._multiSignerKeyPairs.length >= DEFAULT_SIGNER_NUMBER) {\n      throw new SigningError('A maximum of ' + DEFAULT_SIGNER_NUMBER + ' can sign the transaction.');\n    }\n    return super.signImplementation(key);\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this._txBodyData.tokens = this.buildTokenData();\n    this._txBodyData.account = this.buildAccountData();\n    this.transaction.setTransactionType(TransactionType.AssociatedTokenAccountInitialization);\n    return await super.buildImplementation();\n  }\n\n  /** @inheritdoc */\n  validateMandatoryFields(): void {\n    if (!this._tokenIds || this._tokenIds.length < 1) {\n      throw new BuildTransactionError('Invalid transaction: missing tokens to associate');\n    }\n\n    super.validateMandatoryFields();\n  }\n\n  /**\n   * Set account to associate with tokens, defaults to this._source.address value\n   *\n   * @param {string} accountID - The name of the account to associate to the transaction\n   * @returns {TokenAssociateBuilder} - This token association builder\n   */\n  account(accountID: string): this {\n    this.validateAccount(accountID);\n    this._account = accountID;\n    return this;\n  }\n\n  /**\n   * Add a token to associate to the multisig wallet.\n   *\n   * @param {string} tokenName - The name of the token to associate to the transaction\n   * @returns {TokenAssociateBuilder} - This token association builder\n   */\n  tokens(tokenName: string): this {\n    const tokenId = getHederaTokenIdFromName(tokenName);\n    if (!tokenId) {\n      throw new BuildTransactionError('Unsupported token: ' + tokenName);\n    }\n    this.validateToken(tokenId);\n    this._tokenIds.push(tokenId!);\n    return this;\n  }\n\n  private buildTokenData(): proto.TokenID[] {\n    return this._tokenIds.map(buildHederaTokenID);\n  }\n\n  private buildAccountData(): proto.AccountID {\n    let accountId = this._account;\n    if (!accountId) {\n      accountId = this._source.address;\n    }\n\n    return buildHederaAccountID(accountId);\n  }\n\n  private validateAccount(accountID: string): void {\n    if (!isValidAddress(accountID)) {\n      throw new BuildTransactionError('Unsupported account address: ' + accountID);\n    }\n  }\n\n  private validateToken(tokenId: string): void {\n    if (this._tokenIds.includes(tokenId)) {\n      throw new BuildTransactionError('Repeated token ID: ' + tokenId);\n    } else if (!isValidHederaTokenID(tokenId)) {\n      throw new BuildTransactionError('Invalid token ID: ' + tokenId);\n    }\n  }\n}\n"]}

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


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