@bitgo/sdk-coin-sui 5.22.0 → 5.23.0

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.
Files changed (46) hide show
  1. package/dist/src/lib/iface.d.ts +19 -1
  2. package/dist/src/lib/iface.d.ts.map +1 -1
  3. package/dist/src/lib/iface.js +8 -1
  4. package/dist/src/lib/mystenlab/builder/Inputs.d.ts +31 -2
  5. package/dist/src/lib/mystenlab/builder/Inputs.d.ts.map +1 -1
  6. package/dist/src/lib/mystenlab/builder/Inputs.js +43 -3
  7. package/dist/src/lib/mystenlab/builder/TransactionBlock.d.ts +29 -0
  8. package/dist/src/lib/mystenlab/builder/TransactionBlock.d.ts.map +1 -1
  9. package/dist/src/lib/mystenlab/builder/TransactionBlock.js +23 -1
  10. package/dist/src/lib/mystenlab/builder/TransactionDataBlock.d.ts +21 -0
  11. package/dist/src/lib/mystenlab/builder/TransactionDataBlock.d.ts.map +1 -1
  12. package/dist/src/lib/mystenlab/builder/TransactionDataBlock.js +6 -2
  13. package/dist/src/lib/mystenlab/types/coin.d.ts +4 -2
  14. package/dist/src/lib/mystenlab/types/coin.d.ts.map +1 -1
  15. package/dist/src/lib/mystenlab/types/coin.js +3 -2
  16. package/dist/src/lib/mystenlab/types/sui-bcs.d.ts +18 -0
  17. package/dist/src/lib/mystenlab/types/sui-bcs.d.ts.map +1 -1
  18. package/dist/src/lib/mystenlab/types/sui-bcs.js +13 -1
  19. package/dist/src/lib/tokenTransferBuilder.d.ts +30 -2
  20. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
  21. package/dist/src/lib/tokenTransferBuilder.js +82 -12
  22. package/dist/src/lib/tokenTransferTransaction.d.ts +3 -1
  23. package/dist/src/lib/tokenTransferTransaction.d.ts.map +1 -1
  24. package/dist/src/lib/tokenTransferTransaction.js +26 -12
  25. package/dist/src/lib/transaction.d.ts.map +1 -1
  26. package/dist/src/lib/transaction.js +23 -1
  27. package/dist/src/lib/transactionBuilder.d.ts +7 -1
  28. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  29. package/dist/src/lib/transactionBuilder.js +15 -2
  30. package/dist/src/lib/transferBuilder.d.ts +44 -1
  31. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  32. package/dist/src/lib/transferBuilder.js +118 -2
  33. package/dist/src/lib/transferTransaction.d.ts.map +1 -1
  34. package/dist/src/lib/transferTransaction.js +17 -9
  35. package/dist/src/lib/utils.d.ts +11 -2
  36. package/dist/src/lib/utils.d.ts.map +1 -1
  37. package/dist/src/lib/utils.js +26 -2
  38. package/dist/src/sui.d.ts +2 -2
  39. package/dist/src/sui.d.ts.map +1 -1
  40. package/dist/src/sui.js +35 -7
  41. package/dist/test/unit/sui.js +64 -40
  42. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +107 -1
  43. package/dist/test/unit/transactionBuilder/transferBuilder.js +131 -1
  44. package/dist/test/unit/utils.js +106 -1
  45. package/dist/tsconfig.tsbuildinfo +1 -1
  46. package/package.json +7 -7
@@ -25,6 +25,7 @@ export interface TxData {
25
25
  ProgrammableTransaction: SuiProgrammableTransaction;
26
26
  };
27
27
  inputObjects?: SuiObjectRef[];
28
+ fundsInAddressBalance?: string;
28
29
  }
29
30
  export type TransferProgrammableTransaction = ProgrammableTransaction | {
30
31
  inputs: CallArg[] | TransactionBlockInput[];
@@ -60,7 +61,9 @@ export interface SuiTransaction<T = SuiProgrammableTransaction> {
60
61
  sender: string;
61
62
  tx: T;
62
63
  gasData: GasData;
64
+ expiration?: TransactionExpiration;
63
65
  inputObjects?: SuiObjectRef[];
66
+ fundsInAddressBalance?: string;
64
67
  }
65
68
  export interface RequestAddStake {
66
69
  amount: number;
@@ -123,10 +126,25 @@ export declare enum MethodNames {
123
126
  /**
124
127
  * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking/staked_wal.move#L143
125
128
  */
126
- WalrusSplitStakedWal = "::staked_wal::split"
129
+ WalrusSplitStakedWal = "::staked_wal::split",
130
+ /**
131
+ * Redeem funds from the address balance system into a Coin<T> object.
132
+ * Used with the BalanceWithdrawal CallArg to spend from address balance.
133
+ *
134
+ * @see https://docs.sui.io/concepts/sui-move-concepts/address-balance
135
+ */
136
+ RedeemFunds = "::coin::redeem_funds"
127
137
  }
128
138
  export interface SuiObjectInfo extends SuiObjectRef {
129
139
  /** balance */
130
140
  balance: BigNumber;
131
141
  }
142
+ export interface SuiBalanceInfo {
143
+ /** Total balance combining coin object balance and address balance */
144
+ totalBalance: string;
145
+ /** Balance held in coin objects (UTXO-style Coin<T> objects) */
146
+ coinObjectBalance: string;
147
+ /** Balance held in the address balance system (not in coin objects) */
148
+ fundsInAddressBalance: string;
149
+ }
132
150
  //# sourceMappingURL=iface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"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"}
@@ -59,5 +59,12 @@ var MethodNames;
59
59
  * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking/staked_wal.move#L143
60
60
  */
61
61
  MethodNames["WalrusSplitStakedWal"] = "::staked_wal::split";
62
+ /**
63
+ * Redeem funds from the address balance system into a Coin<T> object.
64
+ * Used with the BalanceWithdrawal CallArg to spend from address balance.
65
+ *
66
+ * @see https://docs.sui.io/concepts/sui-move-concepts/address-balance
67
+ */
68
+ MethodNames["RedeemFunds"] = "::coin::redeem_funds";
62
69
  })(MethodNames || (exports.MethodNames = MethodNames = {}));
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iface.js","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":";;;AAeA,IAAY,kBASX;AATD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,2CAAqB,CAAA;IACrB,qDAA+B,CAAA;IAC/B,2CAAqB,CAAA;IACrB,qDAA+B,CAAA;IAC/B,iEAA2C,CAAA;IAC3C,+EAAyD,CAAA;IACzD,iEAA2C,CAAA;AAC7C,CAAC,EATW,kBAAkB,kCAAlB,kBAAkB,QAS7B;AAwGD;;GAEG;AACH,IAAY,WA2CX;AA3CD,WAAY,WAAW;IACrB;;;;OAIG;IACH,kEAAmD,CAAA;IACnD;;;;OAIG;IACH,4EAA6D,CAAA;IAC7D;;;;OAIG;IACH,yDAA0C,CAAA;IAC1C;;;;OAIG;IACH,6DAA8C,CAAA;IAC9C;;;;OAIG;IACH,iEAAkD,CAAA;IAClD;;OAEG;IACH,+EAAgE,CAAA;IAChE;;OAEG;IACH,gEAAiD,CAAA;IACjD;;OAEG;IACH,2DAA4C,CAAA;AAC9C,CAAC,EA3CW,WAAW,2BAAX,WAAW,QA2CtB","sourcesContent":["import {\n  TransactionExplanation as BaseTransactionExplanation,\n  TransactionType as BitGoTransactionType,\n} from '@bitgo/sdk-core';\nimport BigNumber from 'bignumber.js';\nimport {\n  CallArg,\n  GasData,\n  ProgrammableTransaction,\n  SuiAddress,\n  SuiObjectRef,\n  TransactionExpiration,\n} from './mystenlab/types';\nimport { TransactionBlockInput, TransactionType } from './mystenlab/builder';\n\nexport enum SuiTransactionType {\n  Transfer = 'Transfer',\n  AddStake = 'AddStake',\n  WithdrawStake = 'WithdrawStake',\n  CustomTx = 'CustomTx',\n  TokenTransfer = 'TokenTransfer',\n  WalrusStakeWithPool = 'WalrusStakeWithPool',\n  WalrusRequestWithdrawStake = 'WalrusRequestWithdrawStake',\n  WalrusWithdrawStake = 'WalrusWithdrawStake',\n}\n\nexport interface TransactionExplanation extends BaseTransactionExplanation {\n  type: BitGoTransactionType;\n}\n\nexport type SuiProgrammableTransaction =\n  | TransferProgrammableTransaction\n  | StakingProgrammableTransaction\n  | UnstakingProgrammableTransaction\n  | CustomProgrammableTransaction\n  | TokenTransferProgrammableTransaction\n  | WalrusStakingProgrammableTransaction\n  | WalrusWithdrawStakeProgrammableTransaction;\n\nexport interface TxData {\n  id?: string;\n  sender: SuiAddress;\n  expiration: TransactionExpiration;\n  gasData: GasData;\n  kind: {\n    ProgrammableTransaction: SuiProgrammableTransaction;\n  };\n  inputObjects?: SuiObjectRef[];\n}\n\nexport type TransferProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type StakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type UnstakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type CustomProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type TokenTransferProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type WalrusStakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type WalrusWithdrawStakeProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport interface SuiTransaction<T = SuiProgrammableTransaction> {\n  id?: string;\n  type: SuiTransactionType;\n  sender: string;\n  tx: T;\n  gasData: GasData;\n  inputObjects?: SuiObjectRef[];\n}\n\nexport interface RequestAddStake {\n  amount: number;\n  validatorAddress: SuiAddress;\n}\n\nexport interface RequestWithdrawStakedSui {\n  amount?: number;\n  stakedSui: SuiObjectRef;\n}\n\nexport interface RequestWalrusStakeWithPool {\n  amount: number;\n  validatorAddress: SuiAddress;\n}\n\nexport interface RequestWalrusWithdrawStake {\n  amount?: number;\n  stakedWal: SuiObjectRef;\n}\n\n/**\n * Method names for the transaction method. Names change based on the type of transaction e.g 'request_add_delegation_mul_coin' for the staking transaction\n */\nexport enum MethodNames {\n  /**\n   * Add stake to a validator's staking pool.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/sui_system.md#function-request_add_stake\n   */\n  RequestAddStake = '::sui_system::request_add_stake',\n  /**\n   * Withdraw some portion of a stake from a validator's staking pool.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/sui_system.md#function-request_withdraw_stake\n   */\n  RequestWithdrawStake = '::sui_system::request_withdraw_stake',\n  /**\n   * Split StakedSui self to two parts, one with principal split_amount, and the remaining principal is left in self.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/staking_pool.md#0x3_staking_pool_split\n   */\n  StakingPoolSplit = '::staking_pool::split',\n  /**\n   * Transfer ownership of obj to recipient.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/transfer.md#function-public_transfer\n   */\n  PublicTransfer = '::transfer::public_transfer',\n  /**\n   * Walrus stake with pool.\n   *\n   * @see https://github.com/MystenLabs/walrus-docs/blob/8ba15d67d7ed0e728077e1600866fddd46fd113b/contracts/walrus/sources/staking.move#L289\n   */\n  WalrusStakeWithPool = '::staking::stake_with_pool',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking.move#L221\n   */\n  WalrusRequestWithdrawStake = '::staking::request_withdraw_stake',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking.move#L231\n   */\n  WalrusWithdrawStake = '::staking::withdraw_stake',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking/staked_wal.move#L143\n   */\n  WalrusSplitStakedWal = '::staked_wal::split',\n}\n\nexport interface SuiObjectInfo extends SuiObjectRef {\n  /** balance */\n  balance: BigNumber;\n}\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iface.js","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":";;;AAeA,IAAY,kBASX;AATD,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,2CAAqB,CAAA;IACrB,qDAA+B,CAAA;IAC/B,2CAAqB,CAAA;IACrB,qDAA+B,CAAA;IAC/B,iEAA2C,CAAA;IAC3C,+EAAyD,CAAA;IACzD,iEAA2C,CAAA;AAC7C,CAAC,EATW,kBAAkB,kCAAlB,kBAAkB,QAS7B;AA2GD;;GAEG;AACH,IAAY,WAkDX;AAlDD,WAAY,WAAW;IACrB;;;;OAIG;IACH,kEAAmD,CAAA;IACnD;;;;OAIG;IACH,4EAA6D,CAAA;IAC7D;;;;OAIG;IACH,yDAA0C,CAAA;IAC1C;;;;OAIG;IACH,6DAA8C,CAAA;IAC9C;;;;OAIG;IACH,iEAAkD,CAAA;IAClD;;OAEG;IACH,+EAAgE,CAAA;IAChE;;OAEG;IACH,gEAAiD,CAAA;IACjD;;OAEG;IACH,2DAA4C,CAAA;IAC5C;;;;;OAKG;IACH,mDAAoC,CAAA;AACtC,CAAC,EAlDW,WAAW,2BAAX,WAAW,QAkDtB","sourcesContent":["import {\n  TransactionExplanation as BaseTransactionExplanation,\n  TransactionType as BitGoTransactionType,\n} from '@bitgo/sdk-core';\nimport BigNumber from 'bignumber.js';\nimport {\n  CallArg,\n  GasData,\n  ProgrammableTransaction,\n  SuiAddress,\n  SuiObjectRef,\n  TransactionExpiration,\n} from './mystenlab/types';\nimport { TransactionBlockInput, TransactionType } from './mystenlab/builder';\n\nexport enum SuiTransactionType {\n  Transfer = 'Transfer',\n  AddStake = 'AddStake',\n  WithdrawStake = 'WithdrawStake',\n  CustomTx = 'CustomTx',\n  TokenTransfer = 'TokenTransfer',\n  WalrusStakeWithPool = 'WalrusStakeWithPool',\n  WalrusRequestWithdrawStake = 'WalrusRequestWithdrawStake',\n  WalrusWithdrawStake = 'WalrusWithdrawStake',\n}\n\nexport interface TransactionExplanation extends BaseTransactionExplanation {\n  type: BitGoTransactionType;\n}\n\nexport type SuiProgrammableTransaction =\n  | TransferProgrammableTransaction\n  | StakingProgrammableTransaction\n  | UnstakingProgrammableTransaction\n  | CustomProgrammableTransaction\n  | TokenTransferProgrammableTransaction\n  | WalrusStakingProgrammableTransaction\n  | WalrusWithdrawStakeProgrammableTransaction;\n\nexport interface TxData {\n  id?: string;\n  sender: SuiAddress;\n  expiration: TransactionExpiration;\n  gasData: GasData;\n  kind: {\n    ProgrammableTransaction: SuiProgrammableTransaction;\n  };\n  inputObjects?: SuiObjectRef[];\n  fundsInAddressBalance?: string;\n}\n\nexport type TransferProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type StakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type UnstakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type CustomProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type TokenTransferProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type WalrusStakingProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport type WalrusWithdrawStakeProgrammableTransaction =\n  | ProgrammableTransaction\n  | {\n      inputs: CallArg[] | TransactionBlockInput[];\n      transactions: TransactionType[];\n    };\n\nexport interface SuiTransaction<T = SuiProgrammableTransaction> {\n  id?: string;\n  type: SuiTransactionType;\n  sender: string;\n  tx: T;\n  gasData: GasData;\n  expiration?: TransactionExpiration;\n  inputObjects?: SuiObjectRef[];\n  fundsInAddressBalance?: string;\n}\n\nexport interface RequestAddStake {\n  amount: number;\n  validatorAddress: SuiAddress;\n}\n\nexport interface RequestWithdrawStakedSui {\n  amount?: number;\n  stakedSui: SuiObjectRef;\n}\n\nexport interface RequestWalrusStakeWithPool {\n  amount: number;\n  validatorAddress: SuiAddress;\n}\n\nexport interface RequestWalrusWithdrawStake {\n  amount?: number;\n  stakedWal: SuiObjectRef;\n}\n\n/**\n * Method names for the transaction method. Names change based on the type of transaction e.g 'request_add_delegation_mul_coin' for the staking transaction\n */\nexport enum MethodNames {\n  /**\n   * Add stake to a validator's staking pool.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/sui_system.md#function-request_add_stake\n   */\n  RequestAddStake = '::sui_system::request_add_stake',\n  /**\n   * Withdraw some portion of a stake from a validator's staking pool.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/sui_system.md#function-request_withdraw_stake\n   */\n  RequestWithdrawStake = '::sui_system::request_withdraw_stake',\n  /**\n   * Split StakedSui self to two parts, one with principal split_amount, and the remaining principal is left in self.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/staking_pool.md#0x3_staking_pool_split\n   */\n  StakingPoolSplit = '::staking_pool::split',\n  /**\n   * Transfer ownership of obj to recipient.\n   *\n   * @see https://github.com/MystenLabs/sui/blob/main/crates/sui-framework/docs/transfer.md#function-public_transfer\n   */\n  PublicTransfer = '::transfer::public_transfer',\n  /**\n   * Walrus stake with pool.\n   *\n   * @see https://github.com/MystenLabs/walrus-docs/blob/8ba15d67d7ed0e728077e1600866fddd46fd113b/contracts/walrus/sources/staking.move#L289\n   */\n  WalrusStakeWithPool = '::staking::stake_with_pool',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking.move#L221\n   */\n  WalrusRequestWithdrawStake = '::staking::request_withdraw_stake',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking.move#L231\n   */\n  WalrusWithdrawStake = '::staking::withdraw_stake',\n  /**\n   * @see https://github.com/MystenLabs/walrus-docs/blob/9307e66df0ea3f6555cdef78d46aefa62737e216/contracts/walrus/sources/staking/staked_wal.move#L143\n   */\n  WalrusSplitStakedWal = '::staked_wal::split',\n  /**\n   * Redeem funds from the address balance system into a Coin<T> object.\n   * Used with the BalanceWithdrawal CallArg to spend from address balance.\n   *\n   * @see https://docs.sui.io/concepts/sui-move-concepts/address-balance\n   */\n  RedeemFunds = '::coin::redeem_funds',\n}\n\nexport interface SuiObjectInfo extends SuiObjectRef {\n  /** balance */\n  balance: BigNumber;\n}\n\nexport interface SuiBalanceInfo {\n  /** Total balance combining coin object balance and address balance */\n  totalBalance: string;\n  /** Balance held in coin objects (UTXO-style Coin<T> objects) */\n  coinObjectBalance: string;\n  /** Balance held in the address balance system (not in coin objects) */\n  fundsInAddressBalance: string;\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { Infer } from 'superstruct';
2
- import { ObjectId, SharedObjectRef, SuiObjectRef } from '../types';
2
+ import { ObjectId, SharedObjectRef, SuiObjectRef, TypeTag } from '../types';
3
3
  export declare const PureCallArg: import("superstruct").Struct<{
4
4
  Pure: number[];
5
5
  }, {
@@ -34,8 +34,23 @@ export declare const ObjectCallArg: import("superstruct").Struct<{
34
34
  };
35
35
  }, null>;
36
36
  }>;
37
+ export declare const BalanceWithdrawalCallArg: import("superstruct").Struct<{
38
+ BalanceWithdrawal: {
39
+ amount: string | number | bigint;
40
+ type_: Record<string, unknown>;
41
+ };
42
+ }, {
43
+ BalanceWithdrawal: import("superstruct").Struct<{
44
+ amount: string | number | bigint;
45
+ type_: Record<string, unknown>;
46
+ }, {
47
+ amount: import("superstruct").Struct<string | number | bigint, null>;
48
+ type_: import("superstruct").Struct<Record<string, unknown>, null>;
49
+ }>;
50
+ }>;
37
51
  export type PureCallArg = Infer<typeof PureCallArg>;
38
52
  export type ObjectCallArg = Infer<typeof ObjectCallArg>;
53
+ export type BalanceWithdrawalCallArg = Infer<typeof BalanceWithdrawalCallArg>;
39
54
  export declare const BuilderCallArg: import("superstruct").Struct<{
40
55
  Pure: number[];
41
56
  } | {
@@ -52,14 +67,28 @@ export declare const BuilderCallArg: import("superstruct").Struct<{
52
67
  mutable: boolean;
53
68
  };
54
69
  };
70
+ } | {
71
+ BalanceWithdrawal: {
72
+ amount: string | number | bigint;
73
+ type_: Record<string, unknown>;
74
+ };
55
75
  }, null>;
56
76
  export type BuilderCallArg = Infer<typeof BuilderCallArg>;
57
77
  export declare const Inputs: {
58
78
  Pure(data: unknown, type?: string): PureCallArg;
59
79
  ObjectRef(ref: SuiObjectRef): ObjectCallArg;
60
80
  SharedObjectRef(ref: SharedObjectRef): ObjectCallArg;
81
+ /**
82
+ * Create a BalanceWithdrawal CallArg that withdraws `amount` from the sender's
83
+ * address balance at execution time. Use with `0x2::coin::redeem_funds` to
84
+ * convert the withdrawal into a `Coin<T>` object.
85
+ *
86
+ * @param amount - amount in base units (MIST for SUI)
87
+ * @param type_ - the TypeTag of the coin (defaults to SUI)
88
+ */
89
+ BalanceWithdrawal(amount: bigint | number, type_: TypeTag): BalanceWithdrawalCallArg;
61
90
  };
62
- export declare function getIdFromCallArg(arg: ObjectId | ObjectCallArg): string;
91
+ export declare function getIdFromCallArg(arg: ObjectId | ObjectCallArg | BalanceWithdrawalCallArg): string;
63
92
  export declare function getSharedObjectInput(arg: BuilderCallArg): SharedObjectRef | undefined;
64
93
  export declare function isSharedObjectInput(arg: BuilderCallArg): boolean;
65
94
  export declare function isMutableSharedObjectInput(arg: BuilderCallArg): boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"Inputs.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/Inputs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,EAAkC,MAAM,aAAa,CAAC;AACpF,OAAO,EAAuB,QAAQ,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAcxF,eAAO,MAAM,WAAW;;;;EAAqC,CAAC;AAC9D,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAAgC,CAAC;AAC3D,MAAM,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AACpD,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,aAAa,CAAC,CAAC;AAExD,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;QAAsC,CAAC;AAClE,MAAM,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;AAE1D,eAAO,MAAM,MAAM;eACN,OAAO,SAAS,MAAM,GAAG,WAAW;mBAKhC,YAAY,GAAG,aAAa;yBAGtB,eAAe,GAAG,aAAa;CAGrD,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,QAAQ,GAAG,aAAa,GAAG,MAAM,CAQtE;AAED,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,cAAc,GAAG,eAAe,GAAG,SAAS,CAErF;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAEhE;AAED,wBAAgB,0BAA0B,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAEvE"}
1
+ {"version":3,"file":"Inputs.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/Inputs.ts"],"names":[],"mappings":"AAAA,OAAO,EAA0B,KAAK,EAAkC,MAAM,aAAa,CAAC;AAC5F,OAAO,EAAuB,QAAQ,EAAE,eAAe,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AA6BjG,eAAO,MAAM,WAAW;;;;EAAqC,CAAC;AAC9D,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAAgC,CAAC;AAC3D,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;EAOnC,CAAC;AACH,MAAM,MAAM,WAAW,GAAG,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AACpD,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,aAAa,CAAC,CAAC;AACxD,MAAM,MAAM,wBAAwB,GAAG,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE9E,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;QAAgE,CAAC;AAC5F,MAAM,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;AAE1D,eAAO,MAAM,MAAM;eACN,OAAO,SAAS,MAAM,GAAG,WAAW;mBAKhC,YAAY,GAAG,aAAa;yBAGtB,eAAe,GAAG,aAAa;IAGpD;;;;;;;OAOG;8BACuB,MAAM,GAAG,MAAM,SAAS,OAAO,GAAG,wBAAwB;CAGrF,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,QAAQ,GAAG,aAAa,GAAG,wBAAwB,GAAG,MAAM,CAYjG;AAED,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,cAAc,GAAG,eAAe,GAAG,SAAS,CAErF;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAEhE;AAED,wBAAgB,0BAA0B,CAAC,GAAG,EAAE,cAAc,GAAG,OAAO,CAEvE"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Inputs = exports.BuilderCallArg = exports.ObjectCallArg = exports.PureCallArg = void 0;
3
+ exports.Inputs = exports.BuilderCallArg = exports.BalanceWithdrawalCallArg = exports.ObjectCallArg = exports.PureCallArg = void 0;
4
4
  exports.getIdFromCallArg = getIdFromCallArg;
5
5
  exports.getSharedObjectInput = getSharedObjectInput;
6
6
  exports.isSharedObjectInput = isSharedObjectInput;
@@ -18,9 +18,34 @@ const ObjectArg = (0, superstruct_1.union)([
18
18
  }),
19
19
  }),
20
20
  ]);
21
+ // @mysten/bcs v0.7 decodes U64 as string; bigint/number are used at build time.
22
+ const bigintOrInteger = (0, superstruct_1.define)('bigintOrInteger', (value) => {
23
+ if (typeof value === 'bigint')
24
+ return true;
25
+ if (typeof value === 'number')
26
+ return Number.isInteger(value);
27
+ if (typeof value === 'string') {
28
+ try {
29
+ BigInt(value);
30
+ return true;
31
+ }
32
+ catch {
33
+ return false;
34
+ }
35
+ }
36
+ return false;
37
+ });
21
38
  exports.PureCallArg = (0, superstruct_1.object)({ Pure: (0, superstruct_1.array)((0, superstruct_1.integer)()) });
22
39
  exports.ObjectCallArg = (0, superstruct_1.object)({ Object: ObjectArg });
23
- exports.BuilderCallArg = (0, superstruct_1.union)([exports.PureCallArg, exports.ObjectCallArg]);
40
+ exports.BalanceWithdrawalCallArg = (0, superstruct_1.object)({
41
+ BalanceWithdrawal: (0, superstruct_1.object)({
42
+ amount: bigintOrInteger,
43
+ // TypeTag is a recursive union; object() ensures the value is a non-null object
44
+ // matching all TypeTag variants ({ bool: null }, { struct: StructTag }, etc.)
45
+ type_: (0, superstruct_1.object)(),
46
+ }),
47
+ });
48
+ exports.BuilderCallArg = (0, superstruct_1.union)([exports.PureCallArg, exports.ObjectCallArg, exports.BalanceWithdrawalCallArg]);
24
49
  exports.Inputs = {
25
50
  Pure(data, type) {
26
51
  return {
@@ -33,11 +58,26 @@ exports.Inputs = {
33
58
  SharedObjectRef(ref) {
34
59
  return { Object: { Shared: ref } };
35
60
  },
61
+ /**
62
+ * Create a BalanceWithdrawal CallArg that withdraws `amount` from the sender's
63
+ * address balance at execution time. Use with `0x2::coin::redeem_funds` to
64
+ * convert the withdrawal into a `Coin<T>` object.
65
+ *
66
+ * @param amount - amount in base units (MIST for SUI)
67
+ * @param type_ - the TypeTag of the coin (defaults to SUI)
68
+ */
69
+ BalanceWithdrawal(amount, type_) {
70
+ return { BalanceWithdrawal: { amount, type_ } };
71
+ },
36
72
  };
37
73
  function getIdFromCallArg(arg) {
38
74
  if (typeof arg === 'string') {
39
75
  return (0, types_1.normalizeSuiAddress)(arg);
40
76
  }
77
+ if ('BalanceWithdrawal' in arg) {
78
+ // BalanceWithdrawal inputs have no object ID; they cannot be deduplicated by ID
79
+ return '';
80
+ }
41
81
  if ('ImmOrOwned' in arg.Object) {
42
82
  return arg.Object.ImmOrOwned.objectId;
43
83
  }
@@ -52,4 +92,4 @@ function isSharedObjectInput(arg) {
52
92
  function isMutableSharedObjectInput(arg) {
53
93
  return getSharedObjectInput(arg)?.mutable ?? false;
54
94
  }
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSW5wdXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9teXN0ZW5sYWIvYnVpbGRlci9JbnB1dHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBcUNBLDRDQVFDO0FBRUQsb0RBRUM7QUFFRCxrREFFQztBQUVELGdFQUVDO0FBekRELDZDQUFvRjtBQUNwRixvQ0FBd0Y7QUFDeEYsK0JBQWdDO0FBRWhDLE1BQU0sU0FBUyxHQUFHLElBQUEsbUJBQUssRUFBQztJQUN0QixJQUFBLG9CQUFNLEVBQUMsRUFBRSxVQUFVLEVBQUUsb0JBQVksRUFBRSxDQUFDO0lBQ3BDLElBQUEsb0JBQU0sRUFBQztRQUNMLE1BQU0sRUFBRSxJQUFBLG9CQUFNLEVBQUM7WUFDYixRQUFRLEVBQUUsSUFBQSxvQkFBTSxHQUFFO1lBQ2xCLG9CQUFvQixFQUFFLElBQUEsbUJBQUssRUFBQyxDQUFDLElBQUEscUJBQU8sR0FBRSxFQUFFLElBQUEsb0JBQU0sR0FBRSxDQUFDLENBQUM7WUFDbEQsT0FBTyxFQUFFLElBQUEscUJBQU8sR0FBRTtTQUNuQixDQUFDO0tBQ0gsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVVLFFBQUEsV0FBVyxHQUFHLElBQUEsb0JBQU0sRUFBQyxFQUFFLElBQUksRUFBRSxJQUFBLG1CQUFLLEVBQUMsSUFBQSxxQkFBTyxHQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDakQsUUFBQSxhQUFhLEdBQUcsSUFBQSxvQkFBTSxFQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7QUFJOUMsUUFBQSxjQUFjLEdBQUcsSUFBQSxtQkFBSyxFQUFDLENBQUMsbUJBQVcsRUFBRSxxQkFBYSxDQUFDLENBQUMsQ0FBQztBQUdyRCxRQUFBLE1BQU0sR0FBRztJQUNwQixJQUFJLENBQUMsSUFBYSxFQUFFLElBQWE7UUFDL0IsT0FBTztZQUNMLElBQUksRUFBRSxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksWUFBWSxVQUFVLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsYUFBTyxDQUFDLEdBQUcsQ0FBQyxJQUFLLEVBQUUsSUFBSSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUM7U0FDekYsQ0FBQztJQUNKLENBQUM7SUFDRCxTQUFTLENBQUMsR0FBaUI7UUFDekIsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLFVBQVUsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDO0lBQ3pDLENBQUM7SUFDRCxlQUFlLENBQUMsR0FBb0I7UUFDbEMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDO0lBQ3JDLENBQUM7Q0FDRixDQUFDO0FBRUYsU0FBZ0IsZ0JBQWdCLENBQUMsR0FBNkI7SUFDNUQsSUFBSSxPQUFPLEdBQUcsS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUM1QixPQUFPLElBQUEsMkJBQW1CLEVBQUMsR0FBRyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUNELElBQUksWUFBWSxJQUFJLEdBQUcsQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUMvQixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQztJQUN4QyxDQUFDO0lBQ0QsT0FBTyxHQUFHLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7QUFDcEMsQ0FBQztBQUVELFNBQWdCLG9CQUFvQixDQUFDLEdBQW1CO0lBQ3RELE9BQU8sT0FBTyxHQUFHLEtBQUssUUFBUSxJQUFJLFFBQVEsSUFBSSxHQUFHLElBQUksUUFBUSxJQUFJLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7QUFDOUcsQ0FBQztBQUVELFNBQWdCLG1CQUFtQixDQUFDLEdBQW1CO0lBQ3JELE9BQU8sQ0FBQyxDQUFDLG9CQUFvQixDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3JDLENBQUM7QUFFRCxTQUFnQiwwQkFBMEIsQ0FBQyxHQUFtQjtJQUM1RCxPQUFPLG9CQUFvQixDQUFDLEdBQUcsQ0FBQyxFQUFFLE9BQU8sSUFBSSxLQUFLLENBQUM7QUFDckQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFycmF5LCBib29sZWFuLCBJbmZlciwgaW50ZWdlciwgb2JqZWN0LCBzdHJpbmcsIHVuaW9uIH0gZnJvbSAnc3VwZXJzdHJ1Y3QnO1xuaW1wb3J0IHsgbm9ybWFsaXplU3VpQWRkcmVzcywgT2JqZWN0SWQsIFNoYXJlZE9iamVjdFJlZiwgU3VpT2JqZWN0UmVmIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgYnVpbGRlciB9IGZyb20gJy4vYmNzJztcblxuY29uc3QgT2JqZWN0QXJnID0gdW5pb24oW1xuICBvYmplY3QoeyBJbW1Pck93bmVkOiBTdWlPYmplY3RSZWYgfSksXG4gIG9iamVjdCh7XG4gICAgU2hhcmVkOiBvYmplY3Qoe1xuICAgICAgb2JqZWN0SWQ6IHN0cmluZygpLFxuICAgICAgaW5pdGlhbFNoYXJlZFZlcnNpb246IHVuaW9uKFtpbnRlZ2VyKCksIHN0cmluZygpXSksXG4gICAgICBtdXRhYmxlOiBib29sZWFuKCksXG4gICAgfSksXG4gIH0pLFxuXSk7XG5cbmV4cG9ydCBjb25zdCBQdXJlQ2FsbEFyZyA9IG9iamVjdCh7IFB1cmU6IGFycmF5KGludGVnZXIoKSkgfSk7XG5leHBvcnQgY29uc3QgT2JqZWN0Q2FsbEFyZyA9IG9iamVjdCh7IE9iamVjdDogT2JqZWN0QXJnIH0pO1xuZXhwb3J0IHR5cGUgUHVyZUNhbGxBcmcgPSBJbmZlcjx0eXBlb2YgUHVyZUNhbGxBcmc+O1xuZXhwb3J0IHR5cGUgT2JqZWN0Q2FsbEFyZyA9IEluZmVyPHR5cGVvZiBPYmplY3RDYWxsQXJnPjtcblxuZXhwb3J0IGNvbnN0IEJ1aWxkZXJDYWxsQXJnID0gdW5pb24oW1B1cmVDYWxsQXJnLCBPYmplY3RDYWxsQXJnXSk7XG5leHBvcnQgdHlwZSBCdWlsZGVyQ2FsbEFyZyA9IEluZmVyPHR5cGVvZiBCdWlsZGVyQ2FsbEFyZz47XG5cbmV4cG9ydCBjb25zdCBJbnB1dHMgPSB7XG4gIFB1cmUoZGF0YTogdW5rbm93biwgdHlwZT86IHN0cmluZyk6IFB1cmVDYWxsQXJnIHtcbiAgICByZXR1cm4ge1xuICAgICAgUHVyZTogQXJyYXkuZnJvbShkYXRhIGluc3RhbmNlb2YgVWludDhBcnJheSA/IGRhdGEgOiBidWlsZGVyLnNlcih0eXBlISwgZGF0YSkudG9CeXRlcygpKSxcbiAgICB9O1xuICB9LFxuICBPYmplY3RSZWYocmVmOiBTdWlPYmplY3RSZWYpOiBPYmplY3RDYWxsQXJnIHtcbiAgICByZXR1cm4geyBPYmplY3Q6IHsgSW1tT3JPd25lZDogcmVmIH0gfTtcbiAgfSxcbiAgU2hhcmVkT2JqZWN0UmVmKHJlZjogU2hhcmVkT2JqZWN0UmVmKTogT2JqZWN0Q2FsbEFyZyB7XG4gICAgcmV0dXJuIHsgT2JqZWN0OiB7IFNoYXJlZDogcmVmIH0gfTtcbiAgfSxcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRJZEZyb21DYWxsQXJnKGFyZzogT2JqZWN0SWQgfCBPYmplY3RDYWxsQXJnKTogc3RyaW5nIHtcbiAgaWYgKHR5cGVvZiBhcmcgPT09ICdzdHJpbmcnKSB7XG4gICAgcmV0dXJuIG5vcm1hbGl6ZVN1aUFkZHJlc3MoYXJnKTtcbiAgfVxuICBpZiAoJ0ltbU9yT3duZWQnIGluIGFyZy5PYmplY3QpIHtcbiAgICByZXR1cm4gYXJnLk9iamVjdC5JbW1Pck93bmVkLm9iamVjdElkO1xuICB9XG4gIHJldHVybiBhcmcuT2JqZWN0LlNoYXJlZC5vYmplY3RJZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldFNoYXJlZE9iamVjdElucHV0KGFyZzogQnVpbGRlckNhbGxBcmcpOiBTaGFyZWRPYmplY3RSZWYgfCB1bmRlZmluZWQge1xuICByZXR1cm4gdHlwZW9mIGFyZyA9PT0gJ29iamVjdCcgJiYgJ09iamVjdCcgaW4gYXJnICYmICdTaGFyZWQnIGluIGFyZy5PYmplY3QgPyBhcmcuT2JqZWN0LlNoYXJlZCA6IHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzU2hhcmVkT2JqZWN0SW5wdXQoYXJnOiBCdWlsZGVyQ2FsbEFyZyk6IGJvb2xlYW4ge1xuICByZXR1cm4gISFnZXRTaGFyZWRPYmplY3RJbnB1dChhcmcpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNNdXRhYmxlU2hhcmVkT2JqZWN0SW5wdXQoYXJnOiBCdWlsZGVyQ2FsbEFyZyk6IGJvb2xlYW4ge1xuICByZXR1cm4gZ2V0U2hhcmVkT2JqZWN0SW5wdXQoYXJnKT8ubXV0YWJsZSA/PyBmYWxzZTtcbn1cbiJdfQ==
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Inputs.js","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/Inputs.ts"],"names":[],"mappings":"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","sourcesContent":["import { array, boolean, define, Infer, integer, object, string, union } from 'superstruct';\nimport { normalizeSuiAddress, ObjectId, SharedObjectRef, SuiObjectRef, TypeTag } from '../types';\nimport { builder } from './bcs';\n\nconst ObjectArg = union([\n  object({ ImmOrOwned: SuiObjectRef }),\n  object({\n    Shared: object({\n      objectId: string(),\n      initialSharedVersion: union([integer(), string()]),\n      mutable: boolean(),\n    }),\n  }),\n]);\n\n// @mysten/bcs v0.7 decodes U64 as string; bigint/number are used at build time.\nconst bigintOrInteger = define<bigint | number | string>('bigintOrInteger', (value) => {\n  if (typeof value === 'bigint') return true;\n  if (typeof value === 'number') return Number.isInteger(value);\n  if (typeof value === 'string') {\n    try {\n      BigInt(value);\n      return true;\n    } catch {\n      return false;\n    }\n  }\n  return false;\n});\n\nexport const PureCallArg = object({ Pure: array(integer()) });\nexport const ObjectCallArg = object({ Object: ObjectArg });\nexport const BalanceWithdrawalCallArg = object({\n  BalanceWithdrawal: object({\n    amount: bigintOrInteger,\n    // TypeTag is a recursive union; object() ensures the value is a non-null object\n    // matching all TypeTag variants ({ bool: null }, { struct: StructTag }, etc.)\n    type_: object(),\n  }),\n});\nexport type PureCallArg = Infer<typeof PureCallArg>;\nexport type ObjectCallArg = Infer<typeof ObjectCallArg>;\nexport type BalanceWithdrawalCallArg = Infer<typeof BalanceWithdrawalCallArg>;\n\nexport const BuilderCallArg = union([PureCallArg, ObjectCallArg, BalanceWithdrawalCallArg]);\nexport type BuilderCallArg = Infer<typeof BuilderCallArg>;\n\nexport const Inputs = {\n  Pure(data: unknown, type?: string): PureCallArg {\n    return {\n      Pure: Array.from(data instanceof Uint8Array ? data : builder.ser(type!, data).toBytes()),\n    };\n  },\n  ObjectRef(ref: SuiObjectRef): ObjectCallArg {\n    return { Object: { ImmOrOwned: ref } };\n  },\n  SharedObjectRef(ref: SharedObjectRef): ObjectCallArg {\n    return { Object: { Shared: ref } };\n  },\n  /**\n   * Create a BalanceWithdrawal CallArg that withdraws `amount` from the sender's\n   * address balance at execution time. Use with `0x2::coin::redeem_funds` to\n   * convert the withdrawal into a `Coin<T>` object.\n   *\n   * @param amount - amount in base units (MIST for SUI)\n   * @param type_ - the TypeTag of the coin (defaults to SUI)\n   */\n  BalanceWithdrawal(amount: bigint | number, type_: TypeTag): BalanceWithdrawalCallArg {\n    return { BalanceWithdrawal: { amount, type_ } };\n  },\n};\n\nexport function getIdFromCallArg(arg: ObjectId | ObjectCallArg | BalanceWithdrawalCallArg): string {\n  if (typeof arg === 'string') {\n    return normalizeSuiAddress(arg);\n  }\n  if ('BalanceWithdrawal' in arg) {\n    // BalanceWithdrawal inputs have no object ID; they cannot be deduplicated by ID\n    return '';\n  }\n  if ('ImmOrOwned' in arg.Object) {\n    return arg.Object.ImmOrOwned.objectId;\n  }\n  return arg.Object.Shared.objectId;\n}\n\nexport function getSharedObjectInput(arg: BuilderCallArg): SharedObjectRef | undefined {\n  return typeof arg === 'object' && 'Object' in arg && 'Shared' in arg.Object ? arg.Object.Shared : undefined;\n}\n\nexport function isSharedObjectInput(arg: BuilderCallArg): boolean {\n  return !!getSharedObjectInput(arg);\n}\n\nexport function isMutableSharedObjectInput(arg: BuilderCallArg): boolean {\n  return getSharedObjectInput(arg)?.mutable ?? false;\n}\n"]}
@@ -45,6 +45,7 @@ export declare class TransactionBlock {
45
45
  Pure(data: unknown, type?: string): import("./Inputs").PureCallArg;
46
46
  ObjectRef(ref: SuiObjectRef): ObjectCallArg;
47
47
  SharedObjectRef(ref: import("../types").SharedObjectRef): ObjectCallArg;
48
+ BalanceWithdrawal(amount: bigint | number, type_: import("../types").TypeTag): import("./Inputs").BalanceWithdrawalCallArg;
48
49
  };
49
50
  setSender(sender: string): void;
50
51
  /**
@@ -223,6 +224,13 @@ export declare class TransactionBlock {
223
224
  Epoch: number;
224
225
  } | {
225
226
  None: true | null;
227
+ } | {
228
+ ValidDuring: {
229
+ minEpoch: number;
230
+ maxEpoch: number;
231
+ chain: string;
232
+ nonce: number;
233
+ };
226
234
  } | null | undefined;
227
235
  };
228
236
  get [TRANSACTION_BRAND](): boolean;
@@ -274,6 +282,27 @@ export declare class TransactionBlock {
274
282
  };
275
283
  /** Add a transaction to the transaction block. */
276
284
  add(transaction: TransactionType): TransactionResult;
285
+ /**
286
+ * Create a BalanceWithdrawal argument that withdraws `amount` from the sender's
287
+ * address balance at execution time. Pass this as an argument to
288
+ * `0x2::coin::redeem_funds` to receive a `Coin<T>` object:
289
+ *
290
+ * ```typescript
291
+ * const [coin] = tx.moveCall({
292
+ * target: '0x2::coin::redeem_funds',
293
+ * typeArguments: ['0x2::sui::SUI'],
294
+ * arguments: [tx.withdrawal({ amount: 1_000_000n })],
295
+ * });
296
+ * tx.transferObjects([coin], recipientAddress);
297
+ * ```
298
+ *
299
+ * @param amount - amount in base units (e.g. MIST for SUI)
300
+ * @param type - coin type string, defaults to `'0x2::sui::SUI'`
301
+ */
302
+ withdrawal({ amount, type: coinType }: {
303
+ amount: bigint | number;
304
+ type?: string;
305
+ }): TransactionArgument;
277
306
  splitCoins(...args: Parameters<(typeof Transactions)['SplitCoins']>): TransactionResult;
278
307
  mergeCoins(...args: Parameters<(typeof Transactions)['MergeCoins']>): TransactionResult;
279
308
  publish(...args: Parameters<(typeof Transactions)['Publish']>): TransactionResult;
@@ -1 +1 @@
1
- {"version":3,"file":"TransactionBlock.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionBlock.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TransactionBlock.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionBlock.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,eAAe,EAAyB,MAAM,gBAAgB,CAAC;AAC3G,OAAO,EAA4C,aAAa,EAAE,MAAM,UAAU,CAAC;AACnF,OAAO,EAA+B,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAI5F,KAAK,iBAAiB,GAAG,mBAAmB,GAAG,mBAAmB,EAAE,CAAC;AA8CrE,QAAA,MAAM,iBAAiB,eAAoC,CAAC;AAY5D,UAAU,YAAY;IACpB,mBAAmB,CAAC,EAAE,OAAO,CAAC;CAC/B;AAED;;GAEG;AACH,qBAAa,gBAAgB;;IAC3B,oFAAoF;IACpF,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,gBAAgB;IAIhD;;;OAGG;IACH,MAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,UAAU;IAU/C;;;;;OAKG;IACH,MAAM,CAAC,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,UAAU;IAe3C,kEAAkE;IAClE,MAAM,KAAK,YAAY;;qBAVjB,CAAR;yBAA4C,CAAC;;;;;;;gBAyC5B,CAAC;;MA7Bf;IAED,4DAA4D;IAC5D,MAAM,KAAK,MAAM;;;;;MAEhB;IAED,SAAS,CAAC,MAAM,EAAE,MAAM;IAGxB;;;OAGG;IACH,iBAAiB,CAAC,MAAM,EAAE,MAAM;IAKhC,aAAa,CAAC,UAAU,CAAC,EAAE,qBAAqB;IAGhD,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAGlC,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAGpC,WAAW,CAAC,KAAK,EAAE,MAAM;IAGzB,aAAa,CAAC,QAAQ,EAAE,YAAY,EAAE;IAQtC,4DAA4D;IAC5D,IAAI,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAEZ;IAID,IAAI,CAAC,iBAAiB,CAAC,YAEtB;gBAEW,WAAW,CAAC,EAAE,gBAAgB;IAI1C,yEAAyE;IACzE,IAAI,GAAG,IAAI,mBAAmB,CAE7B;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,IAAI,EAAE,QAAQ,GAAG,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO;;;;;;IAgB9C;;OAEG;IACH,MAAM,CAAC,KAAK,EAAE,QAAQ,GAAG,aAAa;;;;;;IAOtC;;OAEG;IACH,IAAI;IACF;;;OAGG;IACH,KAAK,EAAE,OAAO;IACd;;;OAGG;IACH,IAAI,CAAC,EAAE,MAAM;;;;;;IASf,kDAAkD;IAClD,GAAG,CAAC,WAAW,EAAE,eAAe;IAOhC;;;;;;;;;;;;;;;;OAgBG;IACH,UAAU,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,QAA0B,EAAE,EAAE;QAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,mBAAmB;IAKzH,UAAU,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC;IAGnE,UAAU,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC;IAGnE,OAAO,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,SAAS,CAAC,CAAC;IAG7D,QAAQ,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,UAAU,CAAC,CAAC;IAG/D,eAAe,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,iBAAiB,CAAC,CAAC;IAG7E,WAAW,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,OAAO,YAAY,CAAC,CAAC,aAAa,CAAC,CAAC;IAIrE;;;;;;;;;;;OAWG;IACH,SAAS;IAIT,0CAA0C;IACpC,KAAK,CAAC,EAAE,mBAAmB,EAAE,GAAE,YAAiB,GAAG,OAAO,CAAC,UAAU,CAAC;IAI5E,gCAAgC;IAC1B,SAAS,IAAI,OAAO,CAAC,MAAM,CAAC;CAGnC"}
@@ -19,6 +19,7 @@ const types_1 = require("../types");
19
19
  const Transactions_1 = require("./Transactions");
20
20
  const Inputs_1 = require("./Inputs");
21
21
  const TransactionDataBlock_1 = require("./TransactionDataBlock");
22
+ const type_tag_serializer_1 = require("../txn-data-serializers/type-tag-serializer");
22
23
  const utils_1 = require("./utils");
23
24
  function createTransactionResult(index) {
24
25
  const baseResult = { kind: 'Result', index };
@@ -209,6 +210,27 @@ class TransactionBlock {
209
210
  return createTransactionResult(index - 1);
210
211
  }
211
212
  // Method shorthands:
213
+ /**
214
+ * Create a BalanceWithdrawal argument that withdraws `amount` from the sender's
215
+ * address balance at execution time. Pass this as an argument to
216
+ * `0x2::coin::redeem_funds` to receive a `Coin<T>` object:
217
+ *
218
+ * ```typescript
219
+ * const [coin] = tx.moveCall({
220
+ * target: '0x2::coin::redeem_funds',
221
+ * typeArguments: ['0x2::sui::SUI'],
222
+ * arguments: [tx.withdrawal({ amount: 1_000_000n })],
223
+ * });
224
+ * tx.transferObjects([coin], recipientAddress);
225
+ * ```
226
+ *
227
+ * @param amount - amount in base units (e.g. MIST for SUI)
228
+ * @param type - coin type string, defaults to `'0x2::sui::SUI'`
229
+ */
230
+ withdrawal({ amount, type: coinType = '0x2::sui::SUI' }) {
231
+ const typeTag = type_tag_serializer_1.TypeTagSerializer.parseFromStr(coinType, true);
232
+ return this.input('object', Inputs_1.Inputs.BalanceWithdrawal(amount, typeTag));
233
+ }
212
234
  splitCoins(...args) {
213
235
  return this.add(Transactions_1.Transactions.SplitCoins(...args));
214
236
  }
@@ -252,4 +274,4 @@ class TransactionBlock {
252
274
  }
253
275
  }
254
276
  exports.TransactionBlock = TransactionBlock;
255
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TransactionBlock.js","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionBlock.ts"],"names":[],"mappings":"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","sourcesContent":["import { fromB64 } from '@mysten/bcs';\nimport { is, mask } from 'superstruct';\nimport { ObjectId, SuiObjectRef } from '../types';\nimport { Transactions, TransactionArgument, TransactionType, TransactionBlockInput } from './Transactions';\nimport { BuilderCallArg, getIdFromCallArg, Inputs, ObjectCallArg } from './Inputs';\nimport { TransactionBlockDataBuilder, TransactionExpiration } from './TransactionDataBlock';\nimport { create } from './utils';\n\ntype TransactionResult = TransactionArgument & TransactionArgument[];\n\nfunction createTransactionResult(index: number): TransactionResult {\n  const baseResult: TransactionArgument = { kind: 'Result', index };\n\n  const nestedResults: TransactionArgument[] = [];\n  const nestedResultFor = (resultIndex: number): TransactionArgument =>\n    (nestedResults[resultIndex] ??= {\n      kind: 'NestedResult',\n      index,\n      resultIndex,\n    });\n\n  return new Proxy(baseResult, {\n    set() {\n      throw new Error('The transaction result is a proxy, and does not support setting properties directly');\n    },\n    // TODO: Instead of making this return a concrete argument, we should ideally\n    // make it reference-based (so that this gets resolved at build-time), which\n    // allows re-ordering transactions.\n    get(target, property) {\n      // This allows this transaction argument to be used in the singular form:\n      if (property in target) {\n        return Reflect.get(target, property);\n      }\n\n      // Support destructuring:\n      if (property === Symbol.iterator) {\n        return function* () {\n          let i = 0;\n          while (true) {\n            yield nestedResultFor(i);\n            i++;\n          }\n        };\n      }\n\n      if (typeof property === 'symbol') return;\n\n      const resultIndex = parseInt(property, 10);\n      if (Number.isNaN(resultIndex) || resultIndex < 0) return;\n      return nestedResultFor(resultIndex);\n    },\n  }) as TransactionResult;\n}\n\nconst TRANSACTION_BRAND = Symbol.for('@mysten/transaction');\n\n// The maximum number of gas objects that can be selected for one transaction.\nconst MAX_GAS_OBJECTS = 256;\n\n// The maximum gas that is allowed.\nconst MAX_GAS = 1000000000;\n\n// A guess about how much overhead each coin provides for gas calculations.\n// @ts-ignore\nconst GAS_OVERHEAD_PER_COIN = 10n;\n\ninterface BuildOptions {\n  onlyTransactionKind?: boolean;\n}\n\n/**\n * Transaction Builder\n */\nexport class TransactionBlock {\n  /** Returns `true` if the object is an instance of the Transaction builder class. */\n  static is(obj: unknown): obj is TransactionBlock {\n    return !!obj && typeof obj === 'object' && (obj as any)[TRANSACTION_BRAND] === true;\n  }\n\n  /**\n   * Converts from a serialize transaction kind (built with `build({ onlyTransactionKind: true })`) to a `Transaction` class.\n   * Supports either a byte array, or base64-encoded bytes.\n   */\n  static fromKind(serialized: string | Uint8Array) {\n    const tx = new TransactionBlock();\n\n    tx.#blockData = TransactionBlockDataBuilder.fromKindBytes(\n      typeof serialized === 'string' ? fromB64(serialized) : serialized\n    );\n\n    return tx;\n  }\n\n  /**\n   * Converts from a serialized transaction format to a `Transaction` class.\n   * There are two supported serialized formats:\n   * - A string returned from `Transaction#serialize`. The serialized format must be compatible, or it will throw an error.\n   * - A byte array (or base64-encoded bytes) containing BCS transaction data.\n   */\n  static from(serialized: string | Uint8Array) {\n    const tx = new TransactionBlock();\n\n    // Check for bytes:\n    if (typeof serialized !== 'string' || !serialized.startsWith('{')) {\n      tx.#blockData = TransactionBlockDataBuilder.fromBytes(\n        typeof serialized === 'string' ? fromB64(serialized) : serialized\n      );\n    } else {\n      tx.#blockData = TransactionBlockDataBuilder.restore(JSON.parse(serialized));\n    }\n\n    return tx;\n  }\n\n  /** A helper to retrieve the Transaction builder `Transactions` */\n  static get Transactions() {\n    return Transactions;\n  }\n\n  /** A helper to retrieve the Transaction builder `Inputs` */\n  static get Inputs() {\n    return Inputs;\n  }\n\n  setSender(sender: string) {\n    this.#blockData.sender = sender;\n  }\n  /**\n   * Sets the sender only if it has not already been set.\n   * This is useful for sponsored transaction flows where the sender may not be the same as the signer address.\n   */\n  setSenderIfNotSet(sender: string) {\n    if (!this.#blockData.sender) {\n      this.#blockData.sender = sender;\n    }\n  }\n  setExpiration(expiration?: TransactionExpiration) {\n    this.#blockData.expiration = expiration;\n  }\n  setGasPrice(price: number | bigint) {\n    this.#blockData.gasConfig.price = String(price);\n  }\n  setGasBudget(budget: number | bigint) {\n    this.#blockData.gasConfig.budget = String(budget);\n  }\n  setGasOwner(owner: string) {\n    this.#blockData.gasConfig.owner = owner;\n  }\n  setGasPayment(payments: SuiObjectRef[]) {\n    if (payments.length >= MAX_GAS_OBJECTS) {\n      throw new Error(`Payment objects exceed maximum amount ${MAX_GAS_OBJECTS}`);\n    }\n    this.#blockData.gasConfig.payment = payments.map((payment) => mask(payment, SuiObjectRef));\n  }\n\n  #blockData: TransactionBlockDataBuilder;\n  /** Get a snapshot of the transaction data, in JSON form: */\n  get blockData() {\n    return this.#blockData.snapshot();\n  }\n\n  // Used to brand transaction classes so that they can be identified, even between multiple copies\n  // of the builder.\n  get [TRANSACTION_BRAND]() {\n    return true;\n  }\n\n  constructor(transaction?: TransactionBlock) {\n    this.#blockData = new TransactionBlockDataBuilder(transaction ? transaction.#blockData : undefined);\n  }\n\n  /** Returns an argument for the gas coin, to be used in a transaction. */\n  get gas(): TransactionArgument {\n    return { kind: 'GasCoin' };\n  }\n\n  /**\n   * Dynamically create a new input, which is separate from the `input`. This is important\n   * for generated clients to be able to define unique inputs that are non-overlapping with the\n   * defined inputs.\n   *\n   * For `Uint8Array` type automatically convert the input into a `Pure` CallArg, since this\n   * is the format required for custom serialization.\n   *\n   */\n  input(type: 'object' | 'pure', value?: unknown) {\n    const index = this.#blockData.inputs.length;\n    const input = create(\n      {\n        kind: 'Input',\n        // bigints can't be serialized to JSON, so just string-convert them here:\n        value: typeof value === 'bigint' ? String(value) : value,\n        index,\n        type,\n      },\n      TransactionBlockInput\n    );\n    this.#blockData.inputs.push(input);\n    return input;\n  }\n\n  /**\n   * Add a new object input to the transaction.\n   */\n  object(value: ObjectId | ObjectCallArg) {\n    const id = getIdFromCallArg(value);\n    // deduplicate\n    const inserted = this.#blockData.inputs.find((i) => i.type === 'object' && id === getIdFromCallArg(i.value));\n    return inserted ?? this.input('object', value);\n  }\n\n  /**\n   * Add a new non-object input to the transaction.\n   */\n  pure(\n    /**\n     * The pure value that will be used as the input value. If this is a Uint8Array, then the value\n     * is assumed to be raw bytes, and will be used directly.\n     */\n    value: unknown,\n    /**\n     * The BCS type to serialize the value into. If not provided, the type will automatically be determined\n     * based on how the input is used.\n     */\n    type?: string\n  ) {\n    // TODO: we can also do some deduplication here\n    return this.input(\n      'pure',\n      value instanceof Uint8Array ? Inputs.Pure(value) : type ? Inputs.Pure(value, type) : value\n    );\n  }\n\n  /** Add a transaction to the transaction block. */\n  add(transaction: TransactionType) {\n    const index = this.#blockData.transactions.push(transaction);\n    return createTransactionResult(index - 1);\n  }\n\n  // Method shorthands:\n\n  splitCoins(...args: Parameters<(typeof Transactions)['SplitCoins']>) {\n    return this.add(Transactions.SplitCoins(...args));\n  }\n  mergeCoins(...args: Parameters<(typeof Transactions)['MergeCoins']>) {\n    return this.add(Transactions.MergeCoins(...args));\n  }\n  publish(...args: Parameters<(typeof Transactions)['Publish']>) {\n    return this.add(Transactions.Publish(...args));\n  }\n  moveCall(...args: Parameters<(typeof Transactions)['MoveCall']>) {\n    return this.add(Transactions.MoveCall(...args));\n  }\n  transferObjects(...args: Parameters<(typeof Transactions)['TransferObjects']>) {\n    return this.add(Transactions.TransferObjects(...args));\n  }\n  makeMoveVec(...args: Parameters<(typeof Transactions)['MakeMoveVec']>) {\n    return this.add(Transactions.MakeMoveVec(...args));\n  }\n\n  /**\n   * Serialize the transaction to a string so that it can be sent to a separate context.\n   * This is different from `build` in that it does not serialize to BCS bytes, and instead\n   * uses a separate format that is unique to the transaction builder. This allows\n   * us to serialize partially-complete transactions, that can then be completed and\n   * built in a separate context.\n   *\n   * For example, a dapp can construct a transaction, but not provide gas objects\n   * or a gas budget. The transaction then can be sent to the wallet, where this\n   * information is automatically filled in (e.g. by querying for coin objects\n   * and performing a dry run).\n   */\n  serialize() {\n    return JSON.stringify(this.#blockData.snapshot());\n  }\n\n  /** Build the transaction to BCS bytes. */\n  async build({ onlyTransactionKind }: BuildOptions = {}): Promise<Uint8Array> {\n    return this.#blockData.build({ onlyTransactionKind });\n  }\n\n  /** Derive transaction digest */\n  async getDigest(): Promise<string> {\n    return this.#blockData.getDigest();\n  }\n}\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TransactionBlock.js","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionBlock.ts"],"names":[],"mappings":"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","sourcesContent":["import { fromB64 } from '@mysten/bcs';\nimport { is, mask } from 'superstruct';\nimport { ObjectId, SuiObjectRef } from '../types';\nimport { Transactions, TransactionArgument, TransactionType, TransactionBlockInput } from './Transactions';\nimport { BuilderCallArg, getIdFromCallArg, Inputs, ObjectCallArg } from './Inputs';\nimport { TransactionBlockDataBuilder, TransactionExpiration } from './TransactionDataBlock';\nimport { TypeTagSerializer } from '../txn-data-serializers/type-tag-serializer';\nimport { create } from './utils';\n\ntype TransactionResult = TransactionArgument & TransactionArgument[];\n\nfunction createTransactionResult(index: number): TransactionResult {\n  const baseResult: TransactionArgument = { kind: 'Result', index };\n\n  const nestedResults: TransactionArgument[] = [];\n  const nestedResultFor = (resultIndex: number): TransactionArgument =>\n    (nestedResults[resultIndex] ??= {\n      kind: 'NestedResult',\n      index,\n      resultIndex,\n    });\n\n  return new Proxy(baseResult, {\n    set() {\n      throw new Error('The transaction result is a proxy, and does not support setting properties directly');\n    },\n    // TODO: Instead of making this return a concrete argument, we should ideally\n    // make it reference-based (so that this gets resolved at build-time), which\n    // allows re-ordering transactions.\n    get(target, property) {\n      // This allows this transaction argument to be used in the singular form:\n      if (property in target) {\n        return Reflect.get(target, property);\n      }\n\n      // Support destructuring:\n      if (property === Symbol.iterator) {\n        return function* () {\n          let i = 0;\n          while (true) {\n            yield nestedResultFor(i);\n            i++;\n          }\n        };\n      }\n\n      if (typeof property === 'symbol') return;\n\n      const resultIndex = parseInt(property, 10);\n      if (Number.isNaN(resultIndex) || resultIndex < 0) return;\n      return nestedResultFor(resultIndex);\n    },\n  }) as TransactionResult;\n}\n\nconst TRANSACTION_BRAND = Symbol.for('@mysten/transaction');\n\n// The maximum number of gas objects that can be selected for one transaction.\nconst MAX_GAS_OBJECTS = 256;\n\n// The maximum gas that is allowed.\nconst MAX_GAS = 1000000000;\n\n// A guess about how much overhead each coin provides for gas calculations.\n// @ts-ignore\nconst GAS_OVERHEAD_PER_COIN = 10n;\n\ninterface BuildOptions {\n  onlyTransactionKind?: boolean;\n}\n\n/**\n * Transaction Builder\n */\nexport class TransactionBlock {\n  /** Returns `true` if the object is an instance of the Transaction builder class. */\n  static is(obj: unknown): obj is TransactionBlock {\n    return !!obj && typeof obj === 'object' && (obj as any)[TRANSACTION_BRAND] === true;\n  }\n\n  /**\n   * Converts from a serialize transaction kind (built with `build({ onlyTransactionKind: true })`) to a `Transaction` class.\n   * Supports either a byte array, or base64-encoded bytes.\n   */\n  static fromKind(serialized: string | Uint8Array) {\n    const tx = new TransactionBlock();\n\n    tx.#blockData = TransactionBlockDataBuilder.fromKindBytes(\n      typeof serialized === 'string' ? fromB64(serialized) : serialized\n    );\n\n    return tx;\n  }\n\n  /**\n   * Converts from a serialized transaction format to a `Transaction` class.\n   * There are two supported serialized formats:\n   * - A string returned from `Transaction#serialize`. The serialized format must be compatible, or it will throw an error.\n   * - A byte array (or base64-encoded bytes) containing BCS transaction data.\n   */\n  static from(serialized: string | Uint8Array) {\n    const tx = new TransactionBlock();\n\n    // Check for bytes:\n    if (typeof serialized !== 'string' || !serialized.startsWith('{')) {\n      tx.#blockData = TransactionBlockDataBuilder.fromBytes(\n        typeof serialized === 'string' ? fromB64(serialized) : serialized\n      );\n    } else {\n      tx.#blockData = TransactionBlockDataBuilder.restore(JSON.parse(serialized));\n    }\n\n    return tx;\n  }\n\n  /** A helper to retrieve the Transaction builder `Transactions` */\n  static get Transactions() {\n    return Transactions;\n  }\n\n  /** A helper to retrieve the Transaction builder `Inputs` */\n  static get Inputs() {\n    return Inputs;\n  }\n\n  setSender(sender: string) {\n    this.#blockData.sender = sender;\n  }\n  /**\n   * Sets the sender only if it has not already been set.\n   * This is useful for sponsored transaction flows where the sender may not be the same as the signer address.\n   */\n  setSenderIfNotSet(sender: string) {\n    if (!this.#blockData.sender) {\n      this.#blockData.sender = sender;\n    }\n  }\n  setExpiration(expiration?: TransactionExpiration) {\n    this.#blockData.expiration = expiration;\n  }\n  setGasPrice(price: number | bigint) {\n    this.#blockData.gasConfig.price = String(price);\n  }\n  setGasBudget(budget: number | bigint) {\n    this.#blockData.gasConfig.budget = String(budget);\n  }\n  setGasOwner(owner: string) {\n    this.#blockData.gasConfig.owner = owner;\n  }\n  setGasPayment(payments: SuiObjectRef[]) {\n    if (payments.length >= MAX_GAS_OBJECTS) {\n      throw new Error(`Payment objects exceed maximum amount ${MAX_GAS_OBJECTS}`);\n    }\n    this.#blockData.gasConfig.payment = payments.map((payment) => mask(payment, SuiObjectRef));\n  }\n\n  #blockData: TransactionBlockDataBuilder;\n  /** Get a snapshot of the transaction data, in JSON form: */\n  get blockData() {\n    return this.#blockData.snapshot();\n  }\n\n  // Used to brand transaction classes so that they can be identified, even between multiple copies\n  // of the builder.\n  get [TRANSACTION_BRAND]() {\n    return true;\n  }\n\n  constructor(transaction?: TransactionBlock) {\n    this.#blockData = new TransactionBlockDataBuilder(transaction ? transaction.#blockData : undefined);\n  }\n\n  /** Returns an argument for the gas coin, to be used in a transaction. */\n  get gas(): TransactionArgument {\n    return { kind: 'GasCoin' };\n  }\n\n  /**\n   * Dynamically create a new input, which is separate from the `input`. This is important\n   * for generated clients to be able to define unique inputs that are non-overlapping with the\n   * defined inputs.\n   *\n   * For `Uint8Array` type automatically convert the input into a `Pure` CallArg, since this\n   * is the format required for custom serialization.\n   *\n   */\n  input(type: 'object' | 'pure', value?: unknown) {\n    const index = this.#blockData.inputs.length;\n    const input = create(\n      {\n        kind: 'Input',\n        // bigints can't be serialized to JSON, so just string-convert them here:\n        value: typeof value === 'bigint' ? String(value) : value,\n        index,\n        type,\n      },\n      TransactionBlockInput\n    );\n    this.#blockData.inputs.push(input);\n    return input;\n  }\n\n  /**\n   * Add a new object input to the transaction.\n   */\n  object(value: ObjectId | ObjectCallArg) {\n    const id = getIdFromCallArg(value);\n    // deduplicate\n    const inserted = this.#blockData.inputs.find((i) => i.type === 'object' && id === getIdFromCallArg(i.value));\n    return inserted ?? this.input('object', value);\n  }\n\n  /**\n   * Add a new non-object input to the transaction.\n   */\n  pure(\n    /**\n     * The pure value that will be used as the input value. If this is a Uint8Array, then the value\n     * is assumed to be raw bytes, and will be used directly.\n     */\n    value: unknown,\n    /**\n     * The BCS type to serialize the value into. If not provided, the type will automatically be determined\n     * based on how the input is used.\n     */\n    type?: string\n  ) {\n    // TODO: we can also do some deduplication here\n    return this.input(\n      'pure',\n      value instanceof Uint8Array ? Inputs.Pure(value) : type ? Inputs.Pure(value, type) : value\n    );\n  }\n\n  /** Add a transaction to the transaction block. */\n  add(transaction: TransactionType) {\n    const index = this.#blockData.transactions.push(transaction);\n    return createTransactionResult(index - 1);\n  }\n\n  // Method shorthands:\n\n  /**\n   * Create a BalanceWithdrawal argument that withdraws `amount` from the sender's\n   * address balance at execution time. Pass this as an argument to\n   * `0x2::coin::redeem_funds` to receive a `Coin<T>` object:\n   *\n   * ```typescript\n   * const [coin] = tx.moveCall({\n   *   target: '0x2::coin::redeem_funds',\n   *   typeArguments: ['0x2::sui::SUI'],\n   *   arguments: [tx.withdrawal({ amount: 1_000_000n })],\n   * });\n   * tx.transferObjects([coin], recipientAddress);\n   * ```\n   *\n   * @param amount - amount in base units (e.g. MIST for SUI)\n   * @param type   - coin type string, defaults to `'0x2::sui::SUI'`\n   */\n  withdrawal({ amount, type: coinType = '0x2::sui::SUI' }: { amount: bigint | number; type?: string }): TransactionArgument {\n    const typeTag = TypeTagSerializer.parseFromStr(coinType, true);\n    return this.input('object', Inputs.BalanceWithdrawal(amount, typeTag));\n  }\n\n  splitCoins(...args: Parameters<(typeof Transactions)['SplitCoins']>) {\n    return this.add(Transactions.SplitCoins(...args));\n  }\n  mergeCoins(...args: Parameters<(typeof Transactions)['MergeCoins']>) {\n    return this.add(Transactions.MergeCoins(...args));\n  }\n  publish(...args: Parameters<(typeof Transactions)['Publish']>) {\n    return this.add(Transactions.Publish(...args));\n  }\n  moveCall(...args: Parameters<(typeof Transactions)['MoveCall']>) {\n    return this.add(Transactions.MoveCall(...args));\n  }\n  transferObjects(...args: Parameters<(typeof Transactions)['TransferObjects']>) {\n    return this.add(Transactions.TransferObjects(...args));\n  }\n  makeMoveVec(...args: Parameters<(typeof Transactions)['MakeMoveVec']>) {\n    return this.add(Transactions.MakeMoveVec(...args));\n  }\n\n  /**\n   * Serialize the transaction to a string so that it can be sent to a separate context.\n   * This is different from `build` in that it does not serialize to BCS bytes, and instead\n   * uses a separate format that is unique to the transaction builder. This allows\n   * us to serialize partially-complete transactions, that can then be completed and\n   * built in a separate context.\n   *\n   * For example, a dapp can construct a transaction, but not provide gas objects\n   * or a gas budget. The transaction then can be sent to the wallet, where this\n   * information is automatically filled in (e.g. by querying for coin objects\n   * and performing a dry run).\n   */\n  serialize() {\n    return JSON.stringify(this.#blockData.snapshot());\n  }\n\n  /** Build the transaction to BCS bytes. */\n  async build({ onlyTransactionKind }: BuildOptions = {}): Promise<Uint8Array> {\n    return this.#blockData.build({ onlyTransactionKind });\n  }\n\n  /** Derive transaction digest */\n  async getDigest(): Promise<string> {\n    return this.#blockData.getDigest();\n  }\n}\n"]}
@@ -4,6 +4,13 @@ export declare const TransactionExpiration: import("superstruct").Struct<{
4
4
  Epoch: number;
5
5
  } | {
6
6
  None: true | null;
7
+ } | {
8
+ ValidDuring: {
9
+ minEpoch: number;
10
+ maxEpoch: number;
11
+ chain: string;
12
+ nonce: number;
13
+ };
7
14
  } | null | undefined, null>;
8
15
  export type TransactionExpiration = Infer<typeof TransactionExpiration>;
9
16
  declare const GasConfig: import("superstruct").Struct<{
@@ -199,6 +206,13 @@ export declare const SerializedTransactionDataBuilder: import("superstruct").Str
199
206
  Epoch: number;
200
207
  } | {
201
208
  None: true | null;
209
+ } | {
210
+ ValidDuring: {
211
+ minEpoch: number;
212
+ maxEpoch: number;
213
+ chain: string;
214
+ nonce: number;
215
+ };
202
216
  } | null | undefined;
203
217
  }, {
204
218
  version: import("superstruct").Struct<1, 1>;
@@ -207,6 +221,13 @@ export declare const SerializedTransactionDataBuilder: import("superstruct").Str
207
221
  Epoch: number;
208
222
  } | {
209
223
  None: true | null;
224
+ } | {
225
+ ValidDuring: {
226
+ minEpoch: number;
227
+ maxEpoch: number;
228
+ chain: string;
229
+ nonce: number;
230
+ };
210
231
  } | null | undefined, null>;
211
232
  gasConfig: import("superstruct").Struct<{
212
233
  payment?: {
@@ -1 +1 @@
1
- {"version":3,"file":"TransactionDataBlock.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionDataBlock.ts"],"names":[],"mappings":"AACA,OAAO,EAIL,KAAK,EASN,MAAM,aAAa,CAAC;AAIrB,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAIxE,eAAO,MAAM,qBAAqB;;;;2BAEjC,CAAC;AACF,MAAM,MAAM,qBAAqB,GAAG,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAexE,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;EAKb,CAAC;AACH,KAAK,SAAS,GAAG,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC;AAEzC,eAAO,MAAM,gCAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAO3C,CAAC;AACH,MAAM,MAAM,gCAAgC,GAAG,KAAK,CAAC,OAAO,gCAAgC,CAAC,CAAC;AAQ9F,eAAO,MAAM,yBAAyB,QAAa,CAAC;AAEpD,qBAAa,2BAA2B;IACtC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU;IA8BtC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU;IAiClC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,gCAAgC;IAOrD;;;;;OAKG;IACH,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU;IAK3C,OAAO,EAAG,CAAC,CAAU;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,qBAAqB,CAAC;IACnC,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,qBAAqB,EAAE,CAAC;IAChC,YAAY,EAAE,eAAe,EAAE,CAAC;gBAEpB,KAAK,CAAC,EAAE,2BAA2B;IAQ/C,KAAK,CAAC,EACJ,SAAS,EACT,mBAAmB,GACpB,GAAE;QACD,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,EAAE,QAAQ,GAAG,WAAW,GAAG,YAAY,CAAC,CAAC;QAC9F,mBAAmB,CAAC,EAAE,OAAO,CAAC;KAC1B;IA0DN,SAAS;IAKT,QAAQ,IAAI,gCAAgC;CAG7C"}
1
+ {"version":3,"file":"TransactionDataBlock.d.ts","sourceRoot":"","sources":["../../../../../src/lib/mystenlab/builder/TransactionDataBlock.ts"],"names":[],"mappings":"AACA,OAAO,EAIL,KAAK,EASN,MAAM,aAAa,CAAC;AAIrB,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;AAIxE,eAAO,MAAM,qBAAqB;;;;;;;;;;;2BAQjC,CAAC;AACF,MAAM,MAAM,qBAAqB,GAAG,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAexE,QAAA,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;EAKb,CAAC;AACH,KAAK,SAAS,GAAG,KAAK,CAAC,OAAO,SAAS,CAAC,CAAC;AAEzC,eAAO,MAAM,gCAAgC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAO3C,CAAC;AACH,MAAM,MAAM,gCAAgC,GAAG,KAAK,CAAC,OAAO,gCAAgC,CAAC,CAAC;AAQ9F,eAAO,MAAM,yBAAyB,QAAa,CAAC;AAEpD,qBAAa,2BAA2B;IACtC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU;IA8BtC,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU;IAiClC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,gCAAgC;IAOrD;;;;;OAKG;IACH,MAAM,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU;IAK3C,OAAO,EAAG,CAAC,CAAU;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,qBAAqB,CAAC;IACnC,SAAS,EAAE,SAAS,CAAC;IACrB,MAAM,EAAE,qBAAqB,EAAE,CAAC;IAChC,YAAY,EAAE,eAAe,EAAE,CAAC;gBAEpB,KAAK,CAAC,EAAE,2BAA2B;IAQ/C,KAAK,CAAC,EACJ,SAAS,EACT,mBAAmB,GACpB,GAAE;QACD,SAAS,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,EAAE,QAAQ,GAAG,WAAW,GAAG,YAAY,CAAC,CAAC;QAC9F,mBAAmB,CAAC,EAAE,OAAO,CAAC;KAC1B;IA0DN,SAAS;IAKT,QAAQ,IAAI,gCAAgC;CAG7C"}