@bitgo-beta/sdk-coin-trx 1.2.3-alpha.43 → 1.2.3-alpha.430
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/resources/protobuf/Contract.proto +32 -0
- package/dist/resources/protobuf/tron.d.ts +1478 -214
- package/dist/resources/protobuf/tron.js +6312 -2600
- package/dist/resources/protobuf/tron.proto +6 -0
- package/dist/src/index.js +6 -2
- package/dist/src/lib/constants.d.ts +3 -0
- package/dist/src/lib/constants.d.ts.map +1 -0
- package/dist/src/lib/constants.js +6 -0
- package/dist/src/lib/contractCallBuilder.d.ts +1 -35
- package/dist/src/lib/contractCallBuilder.d.ts.map +1 -1
- package/dist/src/lib/contractCallBuilder.js +12 -75
- package/dist/src/lib/delegateResourceTxBuilder.d.ts +27 -0
- package/dist/src/lib/delegateResourceTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/delegateResourceTxBuilder.js +98 -0
- package/dist/src/lib/enum.d.ts +36 -1
- package/dist/src/lib/enum.d.ts.map +1 -1
- package/dist/src/lib/enum.js +40 -4
- package/dist/src/lib/freezeBalanceTxBuilder.d.ts +71 -0
- package/dist/src/lib/freezeBalanceTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/freezeBalanceTxBuilder.js +211 -0
- package/dist/src/lib/iface.d.ts +220 -2
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.d.ts +0 -1
- package/dist/src/lib/keyPair.d.ts.map +1 -1
- package/dist/src/lib/keyPair.js +31 -18
- package/dist/src/lib/resourceManagementTxBuilder.d.ts +72 -0
- package/dist/src/lib/resourceManagementTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/resourceManagementTxBuilder.js +150 -0
- package/dist/src/lib/tokenTransferBuilder.d.ts +1 -1
- package/dist/src/lib/tokenTransferBuilder.js +3 -3
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +92 -6
- package/dist/src/lib/transactionBuilder.d.ts +50 -5
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +110 -21
- package/dist/src/lib/undelegateResourceTxBuilder.d.ts +27 -0
- package/dist/src/lib/undelegateResourceTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/undelegateResourceTxBuilder.js +98 -0
- package/dist/src/lib/unfreezeBalanceTxBuilder.d.ts +65 -0
- package/dist/src/lib/unfreezeBalanceTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/unfreezeBalanceTxBuilder.js +204 -0
- package/dist/src/lib/utils.d.ts +85 -4
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +445 -47
- package/dist/src/lib/voteWitnessTxBuilder.d.ts +62 -0
- package/dist/src/lib/voteWitnessTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/voteWitnessTxBuilder.js +219 -0
- package/dist/src/lib/withdrawBuilder.d.ts +49 -0
- package/dist/src/lib/withdrawBuilder.d.ts.map +1 -0
- package/dist/src/lib/withdrawBuilder.js +167 -0
- package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.d.ts +49 -0
- package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.d.ts.map +1 -0
- package/dist/src/lib/withdrawExpireUnfreezeTxBuilder.js +167 -0
- package/dist/src/lib/wrappedBuilder.d.ts +56 -0
- package/dist/src/lib/wrappedBuilder.d.ts.map +1 -1
- package/dist/src/lib/wrappedBuilder.js +86 -2
- package/dist/src/trx.d.ts +78 -4
- package/dist/src/trx.d.ts.map +1 -1
- package/dist/src/trx.js +436 -147
- package/dist/src/trxToken.d.ts +2 -2
- package/dist/src/trxToken.d.ts.map +1 -1
- package/dist/src/trxToken.js +5 -5
- package/dist/test/fixtures.d.ts +40 -0
- package/dist/test/fixtures.d.ts.map +1 -0
- package/dist/test/fixtures.js +46 -0
- package/dist/test/resources.d.ts +586 -0
- package/dist/test/resources.d.ts.map +1 -0
- package/dist/test/resources.js +746 -0
- package/dist/test/unit/index.d.ts +2 -0
- package/dist/test/unit/index.d.ts.map +1 -0
- package/dist/test/unit/index.js +19 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +163 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +38 -0
- package/dist/test/unit/transactionBuilder/contractCallBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/contractCallBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/contractCallBuilder.js +315 -0
- package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/delegateResourceTxBuilder.js +255 -0
- package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/freezeBalanceTxBuilder.js +285 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +42 -0
- package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/undelegateResourceTxBuilder.js +255 -0
- package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/unfreezeBalanceTxBuilder.js +256 -0
- package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/voteWitnessTxBuilder.js +277 -0
- package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/withdrawBalanceBuilder.js +213 -0
- package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/withdrawExpireUnfreezeTxBuilder.js +213 -0
- package/dist/test/unit/transactionBuilder/wrappedBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder/wrappedBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder/wrappedBuilder.js +50 -0
- package/dist/test/unit/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder.js +178 -0
- package/dist/test/unit/trx.d.ts +2 -0
- package/dist/test/unit/trx.d.ts.map +1 -0
- package/dist/test/unit/trx.js +639 -0
- package/dist/test/unit/util.d.ts +2 -0
- package/dist/test/unit/util.d.ts.map +1 -0
- package/dist/test/unit/util.js +141 -0
- package/dist/test/unit/verifyTransaction.d.ts +2 -0
- package/dist/test/unit/verifyTransaction.d.ts.map +1 -0
- package/dist/test/unit/verifyTransaction.js +378 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +20 -15
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -118
- package/resources/README.md +0 -31
- package/resources/protobuf/Contract.proto +0 -256
- package/resources/protobuf/Discover.proto +0 -44
- package/resources/protobuf/tron.d.ts +0 -11205
- package/resources/protobuf/tron.js +0 -33480
- package/resources/protobuf/tron.proto +0 -677
package/dist/src/lib/iface.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbnRyeSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IENvbnRyYWN0VHlwZSwgUGVybWlzc2lvblR5cGUgfSBmcm9tICcuL2VudW0nO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjY291bnQge1xuICBwdWJsaWNLZXk6IHN0cmluZztcbiAgcHJpdmF0ZUtleTogc3RyaW5nO1xuICBhZGRyZXNzOiB7XG4gICAgYmFzZTU4OiBzdHJpbmc7XG4gICAgaGV4OiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFyYW1ldGVyIHtcbiAgdmFsdWU6IHN0cmluZztcbiAgdHlwZVVybDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRyYWN0IHtcbiAgcGFyYW1ldGVyOiBQYXJhbWV0ZXI7XG4gIHR5cGU6IHN0cmluZztcbn1cblxuLyoqXG4gKiBUaGlzIGludGVyZmFjZSByZXByZXNlbnRzIGEgZm9ybSBvZjpcbiAqXG4gKiBAZXh0ZXJuYWwgaHR0cHM6Ly9naXRodWIuY29tL0JpdEdvL2JpdGdvLWFjY291bnQtbGliL2Jsb2IvNWYyODI1ODg3MDE3NzhhNDQyMWM3NWZhNjFmNDI3MTNmNTZlOTViOS9yZXNvdXJjZXMvcHJvdG9idWYvdHJvbi5wcm90byNMMjM5XG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25SZWNlaXB0IHtcbiAgLyoqXG4gICAqIFRoaXMgZG9lcyBub3QgZXhpc3QgaW4gcHJvdG9idWYgYmVjYXVzZSBpdCdzIGF0dGFjaGVkIGJ5IHRoZSBub2RlIHJwYyBjYWxscy5cbiAgICovXG4gIHR4SUQ/OiBzdHJpbmc7XG4gIHJhd19kYXRhOiBSYXdEYXRhO1xuICByYXdfZGF0YV9oZXg6IHN0cmluZztcbiAgc2lnbmF0dXJlPzogQXJyYXk8c3RyaW5nPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSYXdEYXRhIHtcbiAgZXhwaXJhdGlvbjogbnVtYmVyO1xuICB0aW1lc3RhbXA6IG51bWJlcjtcbiAgcmVmX2Jsb2NrX2J5dGVzOiBzdHJpbmc7XG4gIHJlZl9ibG9ja19oYXNoOiBzdHJpbmc7XG4gIGZlZV9saW1pdD86IG51bWJlcjtcbiAgY29udHJhY3RUeXBlPzogQ29udHJhY3RUeXBlO1xuICBjb250cmFjdDogVHJhbnNmZXJDb250cmFjdFtdIHwgQWNjb3VudFBlcm1pc3Npb25VcGRhdGVDb250cmFjdFtdIHwgVHJpZ2dlclNtYXJ0Q29udHJhY3RbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBWYWx1ZSB7XG4gIHR5cGVfdXJsPzogc3RyaW5nO1xuICB2YWx1ZTogVmFsdWVGaWVsZHM7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmFsdWVGaWVsZHMge1xuICBhbW91bnQ6IG51bWJlcjtcbiAgLy8gYmFzZTU4IGVuY29kZWQgYWRkcmVzc2VzXG4gIG93bmVyX2FkZHJlc3M6IHN0cmluZztcbiAgdG9fYWRkcmVzczogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zZmVyQ29udHJhY3Qge1xuICBwYXJhbWV0ZXI6IFZhbHVlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyaWdnZXJTbWFydENvbnRyYWN0IHtcbiAgcGFyYW1ldGVyOiBDb250cmFjdENhbGxWYWx1ZTtcbiAgdHlwZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb250cmFjdENhbGxWYWx1ZSB7XG4gIHR5cGVfdXJsPzogc3RyaW5nO1xuICB2YWx1ZTogQ29udHJhY3RDYWxsVmFsdWVGaWVsZHM7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29udHJhY3RDYWxsVmFsdWVGaWVsZHMge1xuICBkYXRhOiBzdHJpbmc7XG4gIGNvbnRyYWN0X2FkZHJlc3M6IHN0cmluZztcbiAgb3duZXJfYWRkcmVzczogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFjY291bnRQZXJtaXNzaW9uVXBkYXRlQ29udHJhY3Qge1xuICBvd25lckFkZHJlc3M6IHN0cmluZztcbiAgb3duZXI6IFBlcm1pc3Npb247XG4gIHdpdG5lc3M/OiBQZXJtaXNzaW9uO1xuICBhY3RpdmVzOiBBcnJheTxQZXJtaXNzaW9uPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQZXJtaXNzaW9uIHtcbiAgdHlwZTogUGVybWlzc2lvblR5cGU7XG4gIHRocmVzaG9sZDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBlcm1pc3Npb25LZXkge1xuICBhZGRyZXNzOiBzdHJpbmc7XG4gIHdlaWdodDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJsb2NrIHtcbiAgbnVtYmVyOiBudW1iZXI7XG4gIGhhc2g6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGZWUge1xuICBmZWVMaW1pdDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRyYWN0RW50cnkgZXh0ZW5kcyBFbnRyeSB7XG4gIGRhdGE/OiBzdHJpbmc7XG4gIGNvbnRyYWN0QWRkcmVzcz86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBY2NvdW50SW5mbyB7XG4gIGFkZHJlc3M6IHN0cmluZztcbiAgYmFsYW5jZTogbnVtYmVyO1xuICBvd25lcl9wZXJtaXNzaW9uOiB7XG4gICAga2V5czogW1Blcm1pc3Npb25LZXldO1xuICB9O1xuICBhY3RpdmVfcGVybWlzc2lvbjogW3sga2V5czogW1Blcm1pc3Npb25LZXldIH1dO1xuICB0cmMyMDogW1JlY29yZDxzdHJpbmcsIHN0cmluZz5dO1xufVxuIl19
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iface.js","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"","sourcesContent":["import { Entry } from '@bitgo-beta/sdk-core';\nimport { ContractType, PermissionType, TronResource } from './enum';\n\nexport interface Account {\n  publicKey: string;\n  privateKey: string;\n  address: {\n    base58: string;\n    hex: string;\n  };\n}\n\nexport interface Parameter {\n  value: string;\n  typeUrl: string;\n}\n\nexport interface Contract {\n  parameter: Parameter;\n  type: string;\n}\n\n/**\n * This interface represents a form of:\n *\n * @external https://github.com/BitGo/bitgo-account-lib/blob/5f282588701778a4421c75fa61f42713f56e95b9/resources/protobuf/tron.proto#L239\n */\nexport interface TransactionReceipt {\n  /**\n   * This does not exist in protobuf because it's attached by the node rpc calls.\n   */\n  txID?: string;\n  raw_data: RawData;\n  raw_data_hex: string;\n  signature?: Array<string>;\n}\n\nexport interface RawData {\n  expiration: number;\n  timestamp: number;\n  ref_block_bytes: string;\n  ref_block_hash: string;\n  fee_limit?: number;\n  contractType?: ContractType;\n  contract:\n    | TransferContract[]\n    | AccountPermissionUpdateContract[]\n    | TriggerSmartContract[]\n    | FreezeBalanceV2Contract[]\n    | VoteWitnessContract[]\n    | UnfreezeBalanceV2Contract[]\n    | WithdrawExpireUnfreezeContract[]\n    | WithdrawBalanceContract[]\n    | ResourceManagementContract[];\n}\n\nexport interface Value {\n  type_url?: string;\n  value: ValueFields;\n}\n\nexport interface ValueFields {\n  amount: number;\n  // base58 encoded addresses\n  owner_address: string;\n  to_address: string;\n}\n\nexport interface TransferContract {\n  parameter: Value;\n}\n\nexport interface TriggerSmartContract {\n  parameter: ContractCallValue;\n  type?: string;\n}\n\nexport interface ContractCallValue {\n  type_url?: string;\n  value: ContractCallValueFields;\n}\n\nexport interface ContractCallValueFields {\n  data: string;\n  contract_address: string;\n  owner_address: string;\n}\n\nexport interface AccountPermissionUpdateContract {\n  ownerAddress: string;\n  owner: Permission;\n  witness?: Permission;\n  actives: Array<Permission>;\n}\n\nexport interface Permission {\n  type: PermissionType;\n  threshold: number;\n}\n\nexport interface PermissionKey {\n  address: string;\n  weight: number;\n}\n\nexport interface Block {\n  number: number;\n  hash: string;\n}\n\nexport interface Fee {\n  feeLimit: string;\n}\n\nexport interface ContractEntry extends Entry {\n  data?: string;\n  contractAddress?: string;\n}\n\nexport interface AccountInfo {\n  address: string;\n  balance: number;\n  owner_permission: {\n    keys: [PermissionKey];\n  };\n  active_permission: [{ keys: [PermissionKey] }];\n  trc20: [Record<string, string>];\n}\n\n/**\n * Freeze balance contract value fields\n */\nexport interface FreezeBalanceValueFields {\n  resource: string;\n  frozen_balance: number;\n  owner_address: string;\n}\n\n/**\n * Unfreeze transaction value fields\n */\nexport interface UnfreezeBalanceValueFields {\n  resource: string;\n  unfreeze_balance: number;\n  owner_address: string;\n}\n\n/**\n * Freeze balance contract value interface\n */\nexport interface FreezeBalanceValue {\n  type_url?: string;\n  value: FreezeBalanceValueFields;\n}\n\n/**\n * Freeze balance v2 contract interface\n */\nexport interface FreezeBalanceV2Contract {\n  parameter: FreezeBalanceValue;\n  type?: string;\n}\n\n/**\n * Unfreeze balance contract value interface\n */\nexport interface UnfreezeBalanceValue {\n  type_url?: string;\n  value: UnfreezeBalanceValueFields;\n}\n\n/**\n * Unfreeze balance v2 contract interface\n */\nexport interface UnfreezeBalanceV2Contract {\n  parameter: UnfreezeBalanceValue;\n  type?: string;\n}\n\n/**\n * Freeze balance contract parameter interface\n */\nexport interface FreezeBalanceContractParameter {\n  parameter: {\n    value: {\n      resource: TronResource;\n      frozen_balance: number;\n      owner_address: string;\n    };\n  };\n}\n\n/**\n * Withdraw transaction value fields\n */\nexport interface WithdrawExpireUnfreezeValueFields {\n  owner_address: string;\n}\n\n/**\n * Withdraw balance contract value interface\n */\nexport interface WithdrawExpireUnfreezeValue {\n  type_url?: string;\n  value: WithdrawExpireUnfreezeValueFields;\n}\n\n/**\n * Withdraw expire unfreeze contract interface\n */\nexport interface WithdrawExpireUnfreezeContract {\n  parameter: WithdrawExpireUnfreezeValue;\n  type?: string;\n}\n\nexport interface WithdrawBalanceContract {\n  // same as withdraw expire unfreeze\n  parameter: WithdrawExpireUnfreezeValue;\n  type?: string;\n}\n\nexport interface UnfreezeBalanceContractParameter {\n  parameter: {\n    value: {\n      resource: TronResource;\n      unfreeze_balance: number;\n      owner_address: string;\n    };\n  };\n}\n\n/**\n * Freeze balance contract decoded interface\n */\nexport interface FreezeContractDecoded {\n  ownerAddress?: string;\n  resource?: string;\n  frozenBalance?: string | number;\n}\n\n/**\n * Unfreeze balance contract decoded interface\n */\nexport interface UnfreezeContractDecoded {\n  ownerAddress?: string;\n  resource?: number;\n  unfreezeBalance?: string | number;\n}\n\n/**\n * Withdraw expire unfreeze contract decoded interface\n */\nexport interface WithdrawContractDecoded {\n  ownerAddress?: string;\n}\n\n/**\n * Vote data in a vote transaction\n */\nexport interface VoteWitnessData {\n  vote_address: string;\n  vote_count: number;\n}\n\n/**\n * Vote transaction value fields\n */\nexport interface VoteWitnessValueFields {\n  owner_address: string;\n  votes: VoteWitnessData[];\n}\n\n/**\n * Vote contract value interface\n */\nexport interface VoteWitnessValue {\n  type_url?: string;\n  value: VoteWitnessValueFields;\n}\n\n/**\n * Vote witness contract interface\n */\nexport interface VoteWitnessContract {\n  parameter: VoteWitnessValue;\n  type?: string;\n}\n\n/**\n * Vote witness contract decoded interface\n */\nexport interface VoteContractDecoded {\n  ownerAddress?: string;\n  votes?: Array<{\n    voteAddress?: string;\n    voteCount?: string | number;\n  }>;\n}\n\n/**\n * Vote witness contract parameter interface\n */\nexport interface VoteWitnessContractParameter {\n  parameter: {\n    value: {\n      owner_address: string;\n      votes: Array<{\n        vote_address: string;\n        vote_count: number;\n      }>;\n    };\n  };\n}\n\n/**\n * Withdraw expire unfreeze contract parameter interface\n */\nexport interface WithdrawExpireUnfreezeContractParameter {\n  parameter: {\n    value: {\n      owner_address: string;\n    };\n  };\n}\n\n/**\n * Delegate/Undelegate resource value interface\n */\nexport interface ResourceManagementTxValueFields {\n  balance: number;\n  receiver_address: string;\n  owner_address: string;\n  resource: string;\n}\n\n/**\n * Delegate/Undelegate resource parameters interface\n */\nexport interface ResourceManagmentTxParams {\n  value: ResourceManagementTxValueFields;\n  type_url?: string;\n}\n\n/**\n * Delegate/Undelegate resource contract interface\n */\nexport interface ResourceManagementContract {\n  parameter: ResourceManagmentTxParams;\n  type?: string;\n}\n\n/**\n * Delegate/Undelegate resource contract parameter interface\n */\nexport interface ResourceManagementContractParameter {\n  parameter: {\n    value: {\n      resource: TronResource;\n      balance: string | number;\n      owner_address: string;\n      receiver_address: string;\n    };\n  };\n}\n\n/**\n * Delegate/Undelegate resource contract decoded interface\n */\nexport interface ResourceManagementContractDecoded {\n  ownerAddress?: string;\n  receiverAddress?: string;\n  balance?: string | number;\n  resource?: TronResource;\n}\n"]}
|
package/dist/src/lib/index.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -14,13 +18,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
14
18
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
15
19
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
16
20
|
};
|
|
17
|
-
var __importStar = (this && this.__importStar) || function (
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
};
|
|
21
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
22
|
+
var ownKeys = function(o) {
|
|
23
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
24
|
+
var ar = [];
|
|
25
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
26
|
+
return ar;
|
|
27
|
+
};
|
|
28
|
+
return ownKeys(o);
|
|
29
|
+
};
|
|
30
|
+
return function (mod) {
|
|
31
|
+
if (mod && mod.__esModule) return mod;
|
|
32
|
+
var result = {};
|
|
33
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
34
|
+
__setModuleDefault(result, mod);
|
|
35
|
+
return result;
|
|
36
|
+
};
|
|
37
|
+
})();
|
|
24
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
39
|
exports.Utils = exports.Interface = exports.Enum = void 0;
|
|
26
40
|
__exportStar(require("./keyPair"), exports);
|
|
@@ -36,4 +50,4 @@ const Interface = __importStar(require("./iface"));
|
|
|
36
50
|
exports.Interface = Interface;
|
|
37
51
|
const Utils = __importStar(require("./utils"));
|
|
38
52
|
exports.Utils = Utils;
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDRDQUEwQjtBQUMxQiw0Q0FBMEI7QUFDMUIsZ0RBQThCO0FBQzlCLG1EQUFpQztBQUNqQyx3REFBc0M7QUFDdEMsNENBQTBCO0FBQzFCLHlEQUF1QztBQUV2Qyw2Q0FBK0I7QUFJdEIsb0JBQUk7QUFIYixtREFBcUM7QUFHdEIsOEJBQVM7QUFGeEIsK0NBQWlDO0FBRVAsc0JBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2tleVBhaXInO1xuZXhwb3J0ICogZnJvbSAnLi9hZGRyZXNzJztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi93cmFwcGVkQnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRyYWN0Q2FsbEJ1aWxkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9idWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vdG9rZW5UcmFuc2ZlckJ1aWxkZXInO1xuXG5pbXBvcnQgKiBhcyBFbnVtIGZyb20gJy4vZW51bSc7XG5pbXBvcnQgKiBhcyBJbnRlcmZhY2UgZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgKiBhcyBVdGlscyBmcm9tICcuL3V0aWxzJztcblxuZXhwb3J0IHsgRW51bSwgSW50ZXJmYWNlLCBVdGlscyB9O1xuIl19
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,aAAa,EACb,WAAW,EAIX,cAAc,EACd,wBAAwB,EACzB,MAAM,sBAAsB,CAAC;AAK9B;;GAEG;AACH,qBAAa,OAAQ,SAAQ,wBAAwB;IACnD;;;;;OAKG;gBACS,MAAM,CAAC,EAAE,cAAc;IAoBnC;;;;OAIG;IACH,OAAO,IAAI,WAAW;IAOtB;;;;;OAKG;IACH,UAAU,CAAC,MAAM,CAAC,EAAE,aAAa,GAAG,MAAM;IAc1C;;;;;;OAMG;IACH,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM;IAUpC;;;;;;OAMG;IACH,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;CAK7D"}
|
package/dist/src/lib/keyPair.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,16 +15,26 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
21
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
36
|
exports.KeyPair = void 0;
|
|
23
|
-
const
|
|
37
|
+
const secp256k1_1 = require("@bitgo-beta/secp256k1");
|
|
24
38
|
const crypto_1 = require("crypto");
|
|
25
39
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
26
40
|
const Utils = __importStar(require("./utils"));
|
|
@@ -38,16 +52,16 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
38
52
|
constructor(source) {
|
|
39
53
|
super(source);
|
|
40
54
|
if (!source) {
|
|
41
|
-
const seed = crypto_1.randomBytes(DEFAULT_SEED_SIZE_BYTES);
|
|
42
|
-
this.hdNode =
|
|
55
|
+
const seed = (0, crypto_1.randomBytes)(DEFAULT_SEED_SIZE_BYTES);
|
|
56
|
+
this.hdNode = secp256k1_1.bip32.fromSeed(seed);
|
|
43
57
|
}
|
|
44
|
-
else if (sdk_core_1.isSeed(source)) {
|
|
45
|
-
this.hdNode =
|
|
58
|
+
else if ((0, sdk_core_1.isSeed)(source)) {
|
|
59
|
+
this.hdNode = secp256k1_1.bip32.fromSeed(source.seed);
|
|
46
60
|
}
|
|
47
|
-
else if (sdk_core_1.isPrivateKey(source)) {
|
|
61
|
+
else if ((0, sdk_core_1.isPrivateKey)(source)) {
|
|
48
62
|
super.recordKeysFromPrivateKey(source.prv);
|
|
49
63
|
}
|
|
50
|
-
else if (sdk_core_1.isPublicKey(source)) {
|
|
64
|
+
else if ((0, sdk_core_1.isPublicKey)(source)) {
|
|
51
65
|
super.recordKeysFromPublicKey(source.pub);
|
|
52
66
|
}
|
|
53
67
|
else {
|
|
@@ -63,10 +77,9 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
63
77
|
* @returns {DefaultKeys} The keys in the protocol default key format
|
|
64
78
|
*/
|
|
65
79
|
getKeys() {
|
|
66
|
-
var _a;
|
|
67
80
|
return {
|
|
68
81
|
pub: this.getPublicKey({ compressed: false }).toString('hex').toUpperCase(),
|
|
69
|
-
prv:
|
|
82
|
+
prv: this.getPrivateKey()?.toString('hex').toUpperCase(),
|
|
70
83
|
};
|
|
71
84
|
}
|
|
72
85
|
/**
|
|
@@ -118,4 +131,4 @@ class KeyPair extends sdk_core_1.Secp256k1ExtendedKeyPair {
|
|
|
118
131
|
}
|
|
119
132
|
}
|
|
120
133
|
exports.KeyPair = KeyPair;
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../src/lib/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import { bip32 } from '@bitgo-beta/secp256k1';\nimport { randomBytes } from 'crypto';\nimport {\n  AddressFormat,\n  DefaultKeys,\n  isPrivateKey,\n  isPublicKey,\n  isSeed,\n  KeyPairOptions,\n  Secp256k1ExtendedKeyPair,\n} from '@bitgo-beta/sdk-core';\nimport * as Utils from './utils';\n\nconst DEFAULT_SEED_SIZE_BYTES = 16;\n\n/**\n * Tron keys and address management.\n */\nexport class KeyPair extends Secp256k1ExtendedKeyPair {\n  /**\n   * Public constructor. By default, creates a key pair with a random master seed.\n   *\n   * @param {KeyPairOptions} source Either a master seed, a private key (extended or raw), or a public key\n   *     (extended, compressed, or uncompressed)\n   */\n  constructor(source?: KeyPairOptions) {\n    super(source);\n    if (!source) {\n      const seed = randomBytes(DEFAULT_SEED_SIZE_BYTES);\n      this.hdNode = bip32.fromSeed(seed);\n    } else if (isSeed(source)) {\n      this.hdNode = bip32.fromSeed(source.seed);\n    } else if (isPrivateKey(source)) {\n      super.recordKeysFromPrivateKey(source.prv);\n    } else if (isPublicKey(source)) {\n      super.recordKeysFromPublicKey(source.pub);\n    } else {\n      throw new Error('Invalid key pair options');\n    }\n\n    if (this.hdNode) {\n      this.keyPair = Secp256k1ExtendedKeyPair.toKeyPair(this.hdNode);\n    }\n  }\n\n  /**\n   * Tron default keys format is raw private and uncompressed public key\n   *\n   * @returns {DefaultKeys} The keys in the protocol default key format\n   */\n  getKeys(): DefaultKeys {\n    return {\n      pub: this.getPublicKey({ compressed: false }).toString('hex').toUpperCase(),\n      prv: this.getPrivateKey()?.toString('hex').toUpperCase(),\n    };\n  }\n\n  /**\n   * Get a public address in the specified format, or in base58 if none is provided.\n   *\n   * @param {AddressFormat} format The address specified format\n   * @returns {string} The public address in the specified format\n   */\n  getAddress(format?: AddressFormat): string {\n    const { pub } = this.getKeys();\n    // These are custom Tron methods. They can probably be replaced with other methods or libraries\n    const addressBytes = Utils.getRawAddressFromPubKey(Buffer.from(pub, 'hex'));\n\n    if (!format || format === AddressFormat.base58) {\n      // Default address are in hex\n      return Utils.getBase58AddressFromByteArray(addressBytes);\n    } else if (format === AddressFormat.hex) {\n      return Utils.getHexAddressFromByteArray(addressBytes);\n    }\n    throw new Error('Unsupported address format');\n  }\n\n  /**\n   * Generates a signature for an arbitrary string with the current private key using keccak256\n   * hashing algorithm. Throws if there is no private key.\n   *\n   * @param {string} message to produce a signature for\n   * @returns {Buffer} The signature as a buffer\n   */\n  signMessage(message: string): Buffer {\n    const messageToSign = Buffer.from(message).toString('hex');\n    const { prv } = this.getKeys();\n    if (!prv) {\n      throw new Error('Missing private key');\n    }\n    const signature = Utils.signString(messageToSign, prv, true).replace(/^0x/, '');\n    return Buffer.from(signature, 'hex');\n  }\n\n  /**\n   * Verifies a message signature using the current public key.\n   *\n   * @param {string} message signed\n   * @param {Buffer} signature to verify\n   * @returns {boolean} True if the message was signed with the current key pair\n   */\n  verifySignature(message: string, signature: Buffer): boolean {\n    const messageToVerify = Buffer.from(message).toString('hex');\n    const address = this.getAddress(AddressFormat.base58);\n    return Utils.verifySignature(messageToVerify, address, signature.toString('hex'), true);\n  }\n}\n"]}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { BaseKey } from '@bitgo-beta/sdk-core';
|
|
2
|
+
import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
|
|
3
|
+
import { TransactionBuilder } from './transactionBuilder';
|
|
4
|
+
import { Transaction } from './transaction';
|
|
5
|
+
import { ResourceManagementContract } from './iface';
|
|
6
|
+
import { Address } from './address';
|
|
7
|
+
/**
|
|
8
|
+
* Abstract base class for resource management transaction builders (delegate/undelegate)
|
|
9
|
+
*/
|
|
10
|
+
export declare abstract class ResourceManagementTxBuilder extends TransactionBuilder {
|
|
11
|
+
protected _signingKeys: BaseKey[];
|
|
12
|
+
protected _balance: string;
|
|
13
|
+
protected _resource: string;
|
|
14
|
+
protected _receiverAddress: string;
|
|
15
|
+
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
16
|
+
/**
|
|
17
|
+
* Set the balance amount
|
|
18
|
+
*
|
|
19
|
+
* @param amount amount in TRX to delegate/undelegate
|
|
20
|
+
* @returns the builder with the new parameter set
|
|
21
|
+
*/
|
|
22
|
+
setBalance(amount: string): this;
|
|
23
|
+
/**
|
|
24
|
+
* Set the receiver address
|
|
25
|
+
*
|
|
26
|
+
* @param address receiver address for the delegate/undelegate operation
|
|
27
|
+
* @returns the builder with the new parameter set
|
|
28
|
+
*/
|
|
29
|
+
setReceiverAddress(address: Address): this;
|
|
30
|
+
/**
|
|
31
|
+
* Set the resource type
|
|
32
|
+
*
|
|
33
|
+
* @param resource resource type to delegate/undelegate
|
|
34
|
+
* @returns the builder with the new parameter set
|
|
35
|
+
*/
|
|
36
|
+
setResource(resource: string): this;
|
|
37
|
+
/** @inheritdoc */
|
|
38
|
+
extendValidTo(extensionMs: number): void;
|
|
39
|
+
/**
|
|
40
|
+
* Validates the transaction
|
|
41
|
+
*
|
|
42
|
+
* @param {Transaction} transaction - The transaction to validate
|
|
43
|
+
* @throws {void}
|
|
44
|
+
*/
|
|
45
|
+
validateTransaction(transaction: Transaction): void;
|
|
46
|
+
/** @inheritdoc */
|
|
47
|
+
protected buildImplementation(): Promise<Transaction>;
|
|
48
|
+
/** @inheritdoc */
|
|
49
|
+
protected signImplementation(key: BaseKey): Transaction;
|
|
50
|
+
protected applySignatures(): void;
|
|
51
|
+
/**
|
|
52
|
+
* Validates if the transaction is a valid delegate/undelegate transaction
|
|
53
|
+
*
|
|
54
|
+
* @throws {BuildTransactionError} when the transaction is invalid
|
|
55
|
+
*/
|
|
56
|
+
protected validateResourceManagementTransactionFields(): void;
|
|
57
|
+
/**
|
|
58
|
+
* Initialize the delegate/undelegate contract call specific data
|
|
59
|
+
*
|
|
60
|
+
* @param {ResourceManagementContract} resourceManagementContractCall object with delegate txn data
|
|
61
|
+
*/
|
|
62
|
+
protected initResourceManagementContractCall(resourceManagementContractCall: ResourceManagementContract): void;
|
|
63
|
+
/**
|
|
64
|
+
* Helper method to create the delegate/undelegate resource transaction
|
|
65
|
+
*/
|
|
66
|
+
protected abstract createResourceManagementTransaction(): void;
|
|
67
|
+
/**
|
|
68
|
+
* Helper method to get the resource delegate/undelegate transaction raw data hex
|
|
69
|
+
*/
|
|
70
|
+
protected abstract getResourceManagementTxRawDataHex(): string;
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=resourceManagementTxBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resourceManagementTxBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/resourceManagementTxBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAA+D,MAAM,sBAAsB,CAAC;AAC5G,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC;;GAEG;AACH,8BAAsB,2BAA4B,SAAQ,kBAAkB;IAC1E,SAAS,CAAC,YAAY,EAAE,OAAO,EAAE,CAAC;IAClC,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,SAAS,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,gBAAgB,EAAE,MAAM,CAAC;gBAEvB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAM7C;;;;;OAKG;IACH,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAMhC;;;;;OAKG;IACH,kBAAkB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAM1C;;;;;OAKG;IACH,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMnC,kBAAkB;IAClB,aAAa,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAoBxC;;;;;OAKG;IACH,mBAAmB,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAInD,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAa3D,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IASvD,SAAS,CAAC,eAAe,IAAI,IAAI;IAQjC;;;;OAIG;IACH,SAAS,CAAC,2CAA2C,IAAI,IAAI;IAsB7D;;;;OAIG;IACH,SAAS,CAAC,kCAAkC,CAAC,8BAA8B,EAAE,0BAA0B,GAAG,IAAI;IAmB9G;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,mCAAmC,IAAI,IAAI;IAE9D;;OAEG;IACH,SAAS,CAAC,QAAQ,CAAC,iCAAiC,IAAI,MAAM;CAC/D"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.ResourceManagementTxBuilder = void 0;
|
|
7
|
+
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
8
|
+
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
|
9
|
+
const transactionBuilder_1 = require("./transactionBuilder");
|
|
10
|
+
const transaction_1 = require("./transaction");
|
|
11
|
+
const utils_1 = require("./utils");
|
|
12
|
+
/**
|
|
13
|
+
* Abstract base class for resource management transaction builders (delegate/undelegate)
|
|
14
|
+
*/
|
|
15
|
+
class ResourceManagementTxBuilder extends transactionBuilder_1.TransactionBuilder {
|
|
16
|
+
constructor(_coinConfig) {
|
|
17
|
+
super(_coinConfig);
|
|
18
|
+
this._signingKeys = [];
|
|
19
|
+
this.transaction = new transaction_1.Transaction(_coinConfig);
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Set the balance amount
|
|
23
|
+
*
|
|
24
|
+
* @param amount amount in TRX to delegate/undelegate
|
|
25
|
+
* @returns the builder with the new parameter set
|
|
26
|
+
*/
|
|
27
|
+
setBalance(amount) {
|
|
28
|
+
this.validateValue(new bignumber_js_1.default(amount));
|
|
29
|
+
this._balance = amount;
|
|
30
|
+
return this;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Set the receiver address
|
|
34
|
+
*
|
|
35
|
+
* @param address receiver address for the delegate/undelegate operation
|
|
36
|
+
* @returns the builder with the new parameter set
|
|
37
|
+
*/
|
|
38
|
+
setReceiverAddress(address) {
|
|
39
|
+
this.validateAddress(address);
|
|
40
|
+
this._receiverAddress = (0, utils_1.getHexAddressFromBase58Address)(address.address);
|
|
41
|
+
return this;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Set the resource type
|
|
45
|
+
*
|
|
46
|
+
* @param resource resource type to delegate/undelegate
|
|
47
|
+
* @returns the builder with the new parameter set
|
|
48
|
+
*/
|
|
49
|
+
setResource(resource) {
|
|
50
|
+
this.validateResource(resource);
|
|
51
|
+
this._resource = resource;
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
/** @inheritdoc */
|
|
55
|
+
extendValidTo(extensionMs) {
|
|
56
|
+
if (this.transaction.signature && this.transaction.signature.length > 0) {
|
|
57
|
+
throw new sdk_core_1.ExtendTransactionError('Cannot extend a signed transaction');
|
|
58
|
+
}
|
|
59
|
+
if (extensionMs <= 0) {
|
|
60
|
+
throw new Error('Value cannot be below zero');
|
|
61
|
+
}
|
|
62
|
+
if (extensionMs > utils_1.TRANSACTION_MAX_EXPIRATION) {
|
|
63
|
+
throw new sdk_core_1.ExtendTransactionError('The expiration cannot be extended more than one year');
|
|
64
|
+
}
|
|
65
|
+
if (this._expiration) {
|
|
66
|
+
this._expiration = this._expiration + extensionMs;
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
throw new Error('There is not expiration to extend');
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* Validates the transaction
|
|
74
|
+
*
|
|
75
|
+
* @param {Transaction} transaction - The transaction to validate
|
|
76
|
+
* @throws {void}
|
|
77
|
+
*/
|
|
78
|
+
validateTransaction(transaction) {
|
|
79
|
+
this.validateResourceManagementTransactionFields();
|
|
80
|
+
}
|
|
81
|
+
/** @inheritdoc */
|
|
82
|
+
async buildImplementation() {
|
|
83
|
+
this.createResourceManagementTransaction();
|
|
84
|
+
if (this._signingKeys.length > 0) {
|
|
85
|
+
this.applySignatures();
|
|
86
|
+
}
|
|
87
|
+
if (!this.transaction.id) {
|
|
88
|
+
throw new sdk_core_1.BuildTransactionError('A valid transaction must have an id');
|
|
89
|
+
}
|
|
90
|
+
return Promise.resolve(this.transaction);
|
|
91
|
+
}
|
|
92
|
+
/** @inheritdoc */
|
|
93
|
+
signImplementation(key) {
|
|
94
|
+
if (this._signingKeys.some((signingKey) => signingKey.key === key.key)) {
|
|
95
|
+
throw new sdk_core_1.SigningError('Duplicated key');
|
|
96
|
+
}
|
|
97
|
+
this._signingKeys.push(key);
|
|
98
|
+
return this.transaction;
|
|
99
|
+
}
|
|
100
|
+
applySignatures() {
|
|
101
|
+
if (!this.transaction.inputs) {
|
|
102
|
+
throw new sdk_core_1.SigningError('Transaction has no inputs');
|
|
103
|
+
}
|
|
104
|
+
this._signingKeys.forEach((key) => this.applySignature(key));
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Validates if the transaction is a valid delegate/undelegate transaction
|
|
108
|
+
*
|
|
109
|
+
* @throws {BuildTransactionError} when the transaction is invalid
|
|
110
|
+
*/
|
|
111
|
+
validateResourceManagementTransactionFields() {
|
|
112
|
+
if (!this._balance) {
|
|
113
|
+
throw new sdk_core_1.BuildTransactionError('Missing parameter: balance');
|
|
114
|
+
}
|
|
115
|
+
if (!this._ownerAddress) {
|
|
116
|
+
throw new sdk_core_1.BuildTransactionError('Missing parameter: source');
|
|
117
|
+
}
|
|
118
|
+
if (!this._resource) {
|
|
119
|
+
throw new sdk_core_1.BuildTransactionError('Missing parameter: resource');
|
|
120
|
+
}
|
|
121
|
+
if (!this._receiverAddress) {
|
|
122
|
+
throw new sdk_core_1.BuildTransactionError('Missing parameter: receiver address');
|
|
123
|
+
}
|
|
124
|
+
if (!this._refBlockBytes || !this._refBlockHash) {
|
|
125
|
+
throw new sdk_core_1.BuildTransactionError('Missing block reference information');
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Initialize the delegate/undelegate contract call specific data
|
|
130
|
+
*
|
|
131
|
+
* @param {ResourceManagementContract} resourceManagementContractCall object with delegate txn data
|
|
132
|
+
*/
|
|
133
|
+
initResourceManagementContractCall(resourceManagementContractCall) {
|
|
134
|
+
const { resource, owner_address, balance, receiver_address } = resourceManagementContractCall.parameter.value;
|
|
135
|
+
if (owner_address) {
|
|
136
|
+
this.source({ address: (0, utils_1.getBase58AddressFromHex)(owner_address) });
|
|
137
|
+
}
|
|
138
|
+
if (resource) {
|
|
139
|
+
this.setResource(resource);
|
|
140
|
+
}
|
|
141
|
+
if (balance !== undefined) {
|
|
142
|
+
this.setBalance(balance.toString());
|
|
143
|
+
}
|
|
144
|
+
if (receiver_address) {
|
|
145
|
+
this.setReceiverAddress({ address: (0, utils_1.getBase58AddressFromHex)(receiver_address) });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
exports.ResourceManagementTxBuilder = ResourceManagementTxBuilder;
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resourceManagementTxBuilder.js","sourceRoot":"","sources":["../../../src/lib/resourceManagementTxBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { BaseKey, ExtendTransactionError, BuildTransactionError, SigningError } from '@bitgo-beta/sdk-core';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport BigNumber from 'bignumber.js';\n\nimport { TransactionBuilder } from './transactionBuilder';\nimport { Transaction } from './transaction';\nimport { ResourceManagementContract } from './iface';\nimport { Address } from './address';\nimport { getBase58AddressFromHex, TRANSACTION_MAX_EXPIRATION, getHexAddressFromBase58Address } from './utils';\n\n/**\n * Abstract base class for resource management transaction builders (delegate/undelegate)\n */\nexport abstract class ResourceManagementTxBuilder extends TransactionBuilder {\n  protected _signingKeys: BaseKey[];\n  protected _balance: string;\n  protected _resource: string;\n  protected _receiverAddress: string;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this._signingKeys = [];\n    this.transaction = new Transaction(_coinConfig);\n  }\n\n  /**\n   * Set the balance amount\n   *\n   * @param amount amount in TRX to delegate/undelegate\n   * @returns the builder with the new parameter set\n   */\n  setBalance(amount: string): this {\n    this.validateValue(new BigNumber(amount));\n    this._balance = amount;\n    return this;\n  }\n\n  /**\n   * Set the receiver address\n   *\n   * @param address receiver address for the delegate/undelegate operation\n   * @returns the builder with the new parameter set\n   */\n  setReceiverAddress(address: Address): this {\n    this.validateAddress(address);\n    this._receiverAddress = getHexAddressFromBase58Address(address.address);\n    return this;\n  }\n\n  /**\n   * Set the resource type\n   *\n   * @param resource resource type to delegate/undelegate\n   * @returns the builder with the new parameter set\n   */\n  setResource(resource: string): this {\n    this.validateResource(resource);\n    this._resource = resource;\n    return this;\n  }\n\n  /** @inheritdoc */\n  extendValidTo(extensionMs: number): void {\n    if (this.transaction.signature && this.transaction.signature.length > 0) {\n      throw new ExtendTransactionError('Cannot extend a signed transaction');\n    }\n\n    if (extensionMs <= 0) {\n      throw new Error('Value cannot be below zero');\n    }\n\n    if (extensionMs > TRANSACTION_MAX_EXPIRATION) {\n      throw new ExtendTransactionError('The expiration cannot be extended more than one year');\n    }\n\n    if (this._expiration) {\n      this._expiration = this._expiration + extensionMs;\n    } else {\n      throw new Error('There is not expiration to extend');\n    }\n  }\n\n  /**\n   * Validates the transaction\n   *\n   * @param {Transaction} transaction - The transaction to validate\n   * @throws {void}\n   */\n  validateTransaction(transaction: Transaction): void {\n    this.validateResourceManagementTransactionFields();\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    this.createResourceManagementTransaction();\n\n    if (this._signingKeys.length > 0) {\n      this.applySignatures();\n    }\n\n    if (!this.transaction.id) {\n      throw new BuildTransactionError('A valid transaction must have an id');\n    }\n    return Promise.resolve(this.transaction);\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    if (this._signingKeys.some((signingKey) => signingKey.key === key.key)) {\n      throw new SigningError('Duplicated key');\n    }\n    this._signingKeys.push(key);\n\n    return this.transaction;\n  }\n\n  protected applySignatures(): void {\n    if (!this.transaction.inputs) {\n      throw new SigningError('Transaction has no inputs');\n    }\n\n    this._signingKeys.forEach((key) => this.applySignature(key));\n  }\n\n  /**\n   * Validates if the transaction is a valid delegate/undelegate transaction\n   *\n   * @throws {BuildTransactionError} when the transaction is invalid\n   */\n  protected validateResourceManagementTransactionFields(): void {\n    if (!this._balance) {\n      throw new BuildTransactionError('Missing parameter: balance');\n    }\n\n    if (!this._ownerAddress) {\n      throw new BuildTransactionError('Missing parameter: source');\n    }\n\n    if (!this._resource) {\n      throw new BuildTransactionError('Missing parameter: resource');\n    }\n\n    if (!this._receiverAddress) {\n      throw new BuildTransactionError('Missing parameter: receiver address');\n    }\n\n    if (!this._refBlockBytes || !this._refBlockHash) {\n      throw new BuildTransactionError('Missing block reference information');\n    }\n  }\n\n  /**\n   * Initialize the delegate/undelegate contract call specific data\n   *\n   * @param {ResourceManagementContract} resourceManagementContractCall object with delegate txn data\n   */\n  protected initResourceManagementContractCall(resourceManagementContractCall: ResourceManagementContract): void {\n    const { resource, owner_address, balance, receiver_address } = resourceManagementContractCall.parameter.value;\n    if (owner_address) {\n      this.source({ address: getBase58AddressFromHex(owner_address) });\n    }\n\n    if (resource) {\n      this.setResource(resource);\n    }\n\n    if (balance !== undefined) {\n      this.setBalance(balance.toString());\n    }\n\n    if (receiver_address) {\n      this.setReceiverAddress({ address: getBase58AddressFromHex(receiver_address) });\n    }\n  }\n\n  /**\n   * Helper method to create the delegate/undelegate resource transaction\n   */\n  protected abstract createResourceManagementTransaction(): void;\n\n  /**\n   * Helper method to get the resource delegate/undelegate transaction raw data hex\n   */\n  protected abstract getResourceManagementTxRawDataHex(): string;\n}\n"]}
|
|
@@ -14,7 +14,7 @@ export declare class TokenTransferBuilder extends ContractCallBuilder {
|
|
|
14
14
|
* @param recipientAddress - recipient of token transfer
|
|
15
15
|
* @param amount - token amount
|
|
16
16
|
*/
|
|
17
|
-
tokenTransferData(recipientAddress: string, amount:
|
|
17
|
+
tokenTransferData(recipientAddress: string, amount: string): this;
|
|
18
18
|
/** @inheritdoc */
|
|
19
19
|
protected fromImplementation(rawTransaction: any): Transaction;
|
|
20
20
|
/** @inheritdoc */
|
|
@@ -22,10 +22,10 @@ class TokenTransferBuilder extends contractCallBuilder_1.ContractCallBuilder {
|
|
|
22
22
|
*/
|
|
23
23
|
tokenTransferData(recipientAddress, amount) {
|
|
24
24
|
this.validateAddress({ address: recipientAddress });
|
|
25
|
-
const recipientHex = utils_1.getHexAddressFromBase58Address(recipientAddress);
|
|
25
|
+
const recipientHex = (0, utils_1.getHexAddressFromBase58Address)(recipientAddress);
|
|
26
26
|
const types = ['address', 'uint256'];
|
|
27
27
|
const values = [recipientHex, amount];
|
|
28
|
-
const tokenTransferData = utils_1.encodeDataParams(types, values, methodId);
|
|
28
|
+
const tokenTransferData = (0, utils_1.encodeDataParams)(types, values, methodId);
|
|
29
29
|
this.data(tokenTransferData);
|
|
30
30
|
return this;
|
|
31
31
|
}
|
|
@@ -39,4 +39,4 @@ class TokenTransferBuilder extends contractCallBuilder_1.ContractCallBuilder {
|
|
|
39
39
|
}
|
|
40
40
|
}
|
|
41
41
|
exports.TokenTransferBuilder = TokenTransferBuilder;
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5UcmFuc2ZlckJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3Rva2VuVHJhbnNmZXJCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLCtEQUE0RDtBQUU1RCxtQ0FBMkU7QUFFM0UscUhBQXFIO0FBQ3JILHFGQUFxRjtBQUNyRixNQUFNLFFBQVEsR0FBRyxZQUFZLENBQUM7QUFFOUIsTUFBYSxvQkFBcUIsU0FBUSx5Q0FBbUI7SUFJM0QsWUFBWSxXQUFpQztRQUMzQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDckIsQ0FBQztJQUVELGtCQUFrQjtJQUNSLEtBQUssQ0FBQyxtQkFBbUI7UUFDakMsT0FBTyxNQUFNLEtBQUssQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO0lBQzNDLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILGlCQUFpQixDQUFDLGdCQUF3QixFQUFFLE1BQWM7UUFDeEQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxDQUFDLENBQUM7UUFDcEQsTUFBTSxZQUFZLEdBQUcsSUFBQSxzQ0FBOEIsRUFBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRXRFLE1BQU0sS0FBSyxHQUFHLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQ3JDLE1BQU0sTUFBTSxHQUFHLENBQUMsWUFBWSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3RDLE1BQU0saUJBQWlCLEdBQUcsSUFBQSx3QkFBZ0IsRUFBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3BFLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUM3QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxrQkFBa0I7SUFDUixrQkFBa0IsQ0FBQyxjQUFtQjtRQUM5QyxPQUFPLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsa0JBQWtCO0lBQ1Isa0JBQWtCLENBQUMsR0FBWTtRQUN2QyxPQUFPLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN2QyxDQUFDO0NBQ0Y7QUF2Q0Qsb0RBdUNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZUNvaW4gYXMgQ29pbkNvbmZpZyB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHsgQmFzZUtleSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCB7IENvbnRyYWN0Q2FsbEJ1aWxkZXIgfSBmcm9tICcuL2NvbnRyYWN0Q2FsbEJ1aWxkZXInO1xuaW1wb3J0IHsgVHJhbnNhY3Rpb24gfSBmcm9tICcuL3RyYW5zYWN0aW9uJztcbmltcG9ydCB7IGdldEhleEFkZHJlc3NGcm9tQmFzZTU4QWRkcmVzcywgZW5jb2RlRGF0YVBhcmFtcyB9IGZyb20gJy4vdXRpbHMnO1xuXG4vLyB0aGUgZmlyc3QgNCBieXRlcyBvZiB0aGUgS2VjY2FrLTI1NiBlbmNvZGVkIGZ1bmN0aW9uIHNlbGVjdG9yIHVzZWQgaW4gdG9rZW4gdHJhbnNmZXJzLCAndHJhbnNmZXIoYWRkcmVzcyx1aW50MjU2KSdcbi8vIHRoaXMgbXVzdCBiZSBjb25jYXRlbmF0ZWQgd2l0aCB0aGUgZW5jb2RlZCBwYXJhbWV0ZXJzLCByZWNpcGllbnRBZGRyZXNzIGFuZCBhbW91bnRcbmNvbnN0IG1ldGhvZElkID0gJzB4YTkwNTljYmInO1xuXG5leHBvcnQgY2xhc3MgVG9rZW5UcmFuc2ZlckJ1aWxkZXIgZXh0ZW5kcyBDb250cmFjdENhbGxCdWlsZGVyIHtcbiAgcHJpdmF0ZSBfcmVjaXBpZW50QWRkcmVzczsgLy8gY3VycmVudGx5IG9ubHkgc3VwcG9ydCAxIHRva2VuL3RyYW5zZmVyXG4gIHByaXZhdGUgX2Ftb3VudDtcblxuICBjb25zdHJ1Y3RvcihfY29pbkNvbmZpZzogUmVhZG9ubHk8Q29pbkNvbmZpZz4pIHtcbiAgICBzdXBlcihfY29pbkNvbmZpZyk7XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGFzeW5jIGJ1aWxkSW1wbGVtZW50YXRpb24oKTogUHJvbWlzZTxUcmFuc2FjdGlvbj4ge1xuICAgIHJldHVybiBhd2FpdCBzdXBlci5idWlsZEltcGxlbWVudGF0aW9uKCk7XG4gIH1cblxuICAvKipcbiAgICogU2V0IHRoZSBkYXRhIHdpdGggdGhlIHRyYW5zZmVyIG1ldGhvZCBjYWxsIGFuZCBwYXJhbWV0ZXJzXG4gICAqXG4gICAqIEBwYXJhbSByZWNpcGllbnRBZGRyZXNzIC0gcmVjaXBpZW50IG9mIHRva2VuIHRyYW5zZmVyXG4gICAqIEBwYXJhbSBhbW91bnQgLSB0b2tlbiBhbW91bnRcbiAgICovXG4gIHRva2VuVHJhbnNmZXJEYXRhKHJlY2lwaWVudEFkZHJlc3M6IHN0cmluZywgYW1vdW50OiBzdHJpbmcpOiB0aGlzIHtcbiAgICB0aGlzLnZhbGlkYXRlQWRkcmVzcyh7IGFkZHJlc3M6IHJlY2lwaWVudEFkZHJlc3MgfSk7XG4gICAgY29uc3QgcmVjaXBpZW50SGV4ID0gZ2V0SGV4QWRkcmVzc0Zyb21CYXNlNThBZGRyZXNzKHJlY2lwaWVudEFkZHJlc3MpO1xuXG4gICAgY29uc3QgdHlwZXMgPSBbJ2FkZHJlc3MnLCAndWludDI1NiddO1xuICAgIGNvbnN0IHZhbHVlcyA9IFtyZWNpcGllbnRIZXgsIGFtb3VudF07XG4gICAgY29uc3QgdG9rZW5UcmFuc2ZlckRhdGEgPSBlbmNvZGVEYXRhUGFyYW1zKHR5cGVzLCB2YWx1ZXMsIG1ldGhvZElkKTtcbiAgICB0aGlzLmRhdGEodG9rZW5UcmFuc2ZlckRhdGEpO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gIHByb3RlY3RlZCBmcm9tSW1wbGVtZW50YXRpb24ocmF3VHJhbnNhY3Rpb246IGFueSk6IFRyYW5zYWN0aW9uIHtcbiAgICByZXR1cm4gc3VwZXIuZnJvbUltcGxlbWVudGF0aW9uKHJhd1RyYW5zYWN0aW9uKTtcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICBwcm90ZWN0ZWQgc2lnbkltcGxlbWVudGF0aW9uKGtleTogQmFzZUtleSk6IFRyYW5zYWN0aW9uIHtcbiAgICByZXR1cm4gc3VwZXIuc2lnbkltcGxlbWVudGF0aW9uKGtleSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EACL,OAAO,EACP,eAAe,EAGf,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAS9B,OAAO,
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/lib/transaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAG7D,OAAO,EACL,OAAO,EACP,eAAe,EAGf,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAS9B,OAAO,EACL,aAAa,EAGb,kBAAkB,EAQnB,MAAM,SAAS,CAAC;AAEjB;;GAEG;AACH,qBAAa,WAAY,SAAQ,eAAe;IAE9C,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,OAAO,EAAE,aAAa,EAAE,CAAC;IACnC,SAAS,CAAC,QAAQ,EAAE,aAAa,EAAE,CAAC;IAEpC,OAAO,CAAC,kBAAkB,CAAU;IACpC,OAAO,CAAC,YAAY,CAAC,CAAqB;IAE1C;;;;;OAKG;gBACS,UAAU,EAAE,QAAQ,CAAC,UAAU,CAAC,EAAE,cAAc,CAAC,EAAE,kBAAkB;IAejF;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAmK3B;;;OAGG;IACH,OAAO,CAAC,QAAQ;IAUhB;;;;OAIG;IACH,gBAAgB,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAgC3C;;OAEG;IACH,IAAI,SAAS,IAAI,MAAM,EAAE,CAKxB;IACD;;;OAGG;IACH,IAAI,SAAS,IAAI,MAAM,CAEtB;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,MAAM,CAEpB;IAED,kBAAkB;IAClB,IAAI,OAAO,IAAI,aAAa,EAAE,CAE7B;IAED,kBAAkB;IAClB,IAAI,MAAM,IAAI,aAAa,EAAE,CAE5B;IAED,kBAAkB;IAClB,OAAO,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;IAO9B;;;;OAIG;IACH,qBAAqB,CAAC,EAAE,EAAE,kBAAkB;IAK5C;;;;OAIG;IACH,kBAAkB,CAAC,eAAe,EAAE,eAAe,GAAG,IAAI;IAI1D,kBAAkB;IAClB,MAAM,IAAI,kBAAkB;IAO5B,kBAAkB;IAClB,iBAAiB,IAAI,GAAG;CAGzB"}
|