@fuel-ts/program .FunctionInvocationScope
Represents a scope for invoking a function.
Name | Type | Description |
---|---|---|
TArgs | extends any [] = any [] | The type of the function arguments. |
TReturn | any | The type of the return value. |
BaseInvocationScope
<TReturn
>
↳ FunctionInvocationScope
• new FunctionInvocationScope<TArgs
, TReturn
>(program
, func
, args
): FunctionInvocationScope
<TArgs
, TReturn
>
Constructs an instance of FunctionInvocationScope.
Name | Type |
---|---|
TArgs | extends any [] = any [] |
TReturn | any |
Name | Type | Description |
---|---|---|
program | AbstractProgram | The program. |
func | FunctionFragment <JsonAbi , string > | The function fragment. |
args | TArgs | The arguments. |
FunctionInvocationScope
<TArgs
, TReturn
>
BaseInvocationScope<TReturn>.constructor
functions/invocation-scope.ts:34
• Protected
args: TArgs
functions/invocation-scope.ts:25
• Private
Optional
callParameters: Partial
<{ forward
: CoinQuantityLike
; gasLimit
: BigNumberish
}>
functions/invocation-scope.ts:23
• Protected
externalAbis: Record
<string
, JsonAbi
> = {}
BaseInvocationScope.externalAbis
functions/base-invocation-scope.ts:65
• Private
Optional
forward: CoinQuantity
functions/invocation-scope.ts:24
• Protected
func: FunctionFragment
<JsonAbi
, string
>
functions/invocation-scope.ts:22
• Protected
functionInvocationScopes: InvocationScopeLike
[] = []
BaseInvocationScope.functionInvocationScopes
functions/base-invocation-scope.ts:60
• Protected
hasCallParamsGasLimit: boolean
= false
BaseInvocationScope.hasCallParamsGasLimit
functions/base-invocation-scope.ts:64
• Protected
isMultiCall: boolean
= false
BaseInvocationScope.isMultiCall
functions/base-invocation-scope.ts:63
• Protected
program: AbstractProgram
BaseInvocationScope.program
functions/base-invocation-scope.ts:59
• Protected
requiredCoins: CoinQuantity
[] = []
BaseInvocationScope.requiredCoins
functions/base-invocation-scope.ts:62
• Protected
transactionRequest: ScriptTransactionRequest
BaseInvocationScope.transactionRequest
functions/base-invocation-scope.ts:58
• Protected
Optional
txParameters: Partial
<{ gasLimit
: BigNumberish
; gasPrice
: BigNumberish
; maturity?
: number
; maxFee?
: BigNumberish
; variableOutputs
: number
; witnessLimit?
: BigNumberish
}>
BaseInvocationScope.txParameters
functions/base-invocation-scope.ts:61
• get
calls(): ContractCall
[]
Getter for the contract calls.
ContractCall
[]
An array of contract calls.
BaseInvocationScope.calls
functions/base-invocation-scope.ts:88
▸ addCall(funcScope
): FunctionInvocationScope
<TArgs
, TReturn
>
Adds a single call to the invocation scope.
Name | Type | Description |
---|---|---|
funcScope | InvocationScopeLike | The function scope to add. |
FunctionInvocationScope
<TArgs
, TReturn
>
The current instance of the class.
BaseInvocationScope.addCall
functions/base-invocation-scope.ts:167
▸ addCalls(funcScopes
): FunctionInvocationScope
<TArgs
, TReturn
>
Adds multiple calls to the invocation scope.
Name | Type | Description |
---|---|---|
funcScopes | InvocationScopeLike [] | An array of function scopes to add. |
FunctionInvocationScope
<TArgs
, TReturn
>
The current instance of the class.
BaseInvocationScope.addCalls
functions/base-invocation-scope.ts:178
▸ addContracts(contracts
): FunctionInvocationScope
<TArgs
, TReturn
>
Adds contracts to the invocation scope.
Name | Type | Description |
---|---|---|
contracts | AbstractContract [] | An array of contracts to add. |
FunctionInvocationScope
<TArgs
, TReturn
>
The current instance of the class.
BaseInvocationScope.addContracts
functions/base-invocation-scope.ts:315
▸ addSigners(signers
): FunctionInvocationScope
<TArgs
, TReturn
>
FunctionInvocationScope
<TArgs
, TReturn
>
BaseInvocationScope.addSigners
functions/base-invocation-scope.ts:341
▸ addTransfer(destination
, amount
, assetId
): FunctionInvocationScope
<TArgs
, TReturn
>
Adds an asset transfer to an Account on the contract call transaction request.
Name | Type | Description |
---|---|---|
destination | string | AbstractAddress | The address of the destination. |
amount | BigNumberish | The amount of coins to transfer. |
assetId | string | The asset ID of the coins to transfer. |
FunctionInvocationScope
<TArgs
, TReturn
>
The current instance of the class.
BaseInvocationScope.addTransfer
functions/base-invocation-scope.ts:331
▸ call<T
>(): Promise
<FunctionInvocationResult
<T
, void
>>
Submits a transaction.
Name | Type |
---|---|
T | TReturn |
Promise
<FunctionInvocationResult
<T
, void
>>
The result of the function invocation.
BaseInvocationScope.call
functions/base-invocation-scope.ts:363
▸ callParams(callParams
): FunctionInvocationScope
<TArgs
, TReturn
>
Sets the call parameters for the function invocation.
Throws
If the function is not payable and forward is set.
Name | Type | Description |
---|---|---|
callParams | Partial <{ forward : CoinQuantityLike ; gasLimit : BigNumberish }> | The call parameters. |
FunctionInvocationScope
<TArgs
, TReturn
>
The instance of FunctionInvocationScope.
functions/invocation-scope.ts:77
▸ checkGasLimitTotal(): void
Checks if the total gas limit is within the acceptable range.
void
BaseInvocationScope.checkGasLimitTotal
functions/base-invocation-scope.ts:210
▸ dryRun<T
>(): Promise
<InvocationCallResult
<T
>>
Executes a transaction in dry run mode.
Name | Type |
---|---|
T | TReturn |
Promise
<InvocationCallResult
<T
>>
The result of the invocation call.
BaseInvocationScope.dryRun
functions/base-invocation-scope.ts:416
▸ fundWithRequiredCoins(): Promise
<FunctionInvocationScope
<TArgs
, TReturn
>>
Funds the transaction with the required coins.
Promise
<FunctionInvocationScope
<TArgs
, TReturn
>>
The current instance of the class.
BaseInvocationScope.fundWithRequiredCoins
functions/base-invocation-scope.ts:247
▸ get<T
>(): Promise
<InvocationCallResult
<T
>>
Name | Type |
---|---|
T | TReturn |
Promise
<InvocationCallResult
<T
>>
BaseInvocationScope.get
functions/base-invocation-scope.ts:430
▸ getCallConfig(): CallConfig
<TArgs
>
Gets the call configuration.
CallConfig
<TArgs
>
The call configuration.
functions/invocation-scope.ts:47
▸ getProvider(): Provider
BaseInvocationScope.getProvider
functions/base-invocation-scope.ts:444
▸ getRequiredCoins(): CoinQuantity
[]
Gets the required coins for the transaction.
CoinQuantity
[]
An array of required coin quantities.
BaseInvocationScope.getRequiredCoins
functions/base-invocation-scope.ts:130
▸ getTransactionCost(options?
): Promise
<TransactionCost
>
Gets the transaction cost ny dry running the transaction.
Name | Type | Description |
---|---|---|
options? | Partial <{ fundTransaction : boolean ; gasPrice : BigNumberish }> | Optional transaction cost options. |
Promise
<TransactionCost
>
The transaction cost details.
BaseInvocationScope.getTransactionCost
functions/base-invocation-scope.ts:229
▸ getTransactionId(chainId?
): Promise
<string
>
Obtains the ID of a transaction.
Name | Type | Description |
---|---|---|
chainId? | number | the chainId to use to hash the transaction with |
Promise
<string
>
the ID of the transaction.
BaseInvocationScope.getTransactionId
functions/base-invocation-scope.ts:456
▸ getTransactionRequest(): Promise
<ScriptTransactionRequest
>
Prepares and returns the transaction request object.
Promise
<ScriptTransactionRequest
>
The prepared transaction request.
BaseInvocationScope.getTransactionRequest
functions/base-invocation-scope.ts:353
▸ prepareTransaction(): Promise
<void
>
Prepares the transaction by updating the script request, required coins, and checking the gas limit.
Promise
<void
>
BaseInvocationScope.prepareTransaction
functions/base-invocation-scope.ts:188
▸ setArguments(...args
): FunctionInvocationScope
<TArgs
, TReturn
>
Sets the arguments for the function invocation.
Name | Type | Description |
---|---|---|
...args | TArgs | The arguments. |
FunctionInvocationScope
<TArgs
, TReturn
>
The instance of FunctionInvocationScope.
functions/invocation-scope.ts:65
▸ simulate<T
>(): Promise
<InvocationCallResult
<T
>>
Simulates a transaction.
Name | Type |
---|---|
T | TReturn |
Promise
<InvocationCallResult
<T
>>
The result of the invocation call.
BaseInvocationScope.simulate
functions/base-invocation-scope.ts:389
▸ txParams(txParams
): FunctionInvocationScope
<TArgs
, TReturn
>
Sets the transaction parameters.
Name | Type | Description |
---|---|---|
txParams | Partial <{ gasLimit : BigNumberish ; gasPrice : BigNumberish ; maturity? : number ; maxFee? : BigNumberish ; variableOutputs : number ; witnessLimit? : BigNumberish }> | The transaction parameters to set. |
FunctionInvocationScope
<TArgs
, TReturn
>
The current instance of the class.
BaseInvocationScope.txParams
functions/base-invocation-scope.ts:291
▸ updateContractInputAndOutput(): void
Updates the transaction request with the current input/output.
void
BaseInvocationScope.updateContractInputAndOutput
functions/base-invocation-scope.ts:116
▸ updateRequiredCoins(): void
Updates the required coins for the transaction.
void
BaseInvocationScope.updateRequiredCoins
functions/base-invocation-scope.ts:143
▸ updateScriptRequest(): void
Updates the script request with the current contract calls.
void
BaseInvocationScope.updateScriptRequest