@fuel-ts/account .Predicate
Predicate
provides methods to populate transaction data with predicate information and sending transactions with them.
Name | Type |
---|---|
TInputData | extends InputValue [] |
↳ Predicate
• new Predicate<TInputData
>(«destructured»
): Predicate
<TInputData
>
Creates an instance of the Predicate class.
Name | Type |
---|---|
TInputData | extends InputValue [] |
Name | Type |
---|---|
«destructured» | PredicateParams <TInputData > |
Predicate
<TInputData
>
packages/account/src/predicate/predicate.ts:52
• Protected
Optional
_connector: FuelConnector
packages/account/src/account.ts:67
• Protected
Optional
_provider: Provider
The provider used to interact with the network.
packages/account/src/account.ts:65
• Readonly
address: AbstractAddress
The address associated with the account.
packages/account/src/account.ts:60
• bytes: Uint8Array
packages/account/src/predicate/predicate.ts:39
• Optional
interface: Interface
<JsonAbi
>
packages/account/src/predicate/predicate.ts:41
• predicateData: TInputData
packages/account/src/predicate/predicate.ts:40
• get
provider(): Provider
The provider used to interact with the network.
Throws
FuelError
if the provider is not set.
A Provider instance.
Account.provider
packages/account/src/account.ts:89
• set
provider(provider
): void
Sets the provider for the account.
Name | Type | Description |
---|---|---|
provider | Provider | A Provider instance. |
void
Account.provider
packages/account/src/account.ts:102
▸ connect(provider
): Provider
Changes the provider connection for the account.
Name | Type | Description |
---|---|---|
provider | Provider | A Provider instance. |
The updated Provider instance.
packages/account/src/account.ts:112
▸ createTransfer(destination
, amount
, assetId?
, txParams?
): Promise
<TransactionRequest
>
A helper that creates a transfer transaction request and returns it.
Name | Type | Description |
---|---|---|
destination | string | AbstractAddress | The address of the destination. |
amount | BigNumberish | The amount of coins to transfer. |
assetId? | BytesLike | The asset ID of the coins to transfer. |
txParams | TxParamsType | The transaction parameters (gasLimit, tip, maturity, maxFee, witnessLimit). |
Promise
<TransactionRequest
>
A promise that resolves to the prepared transaction request.
packages/account/src/account.ts:371
▸ fund<T
>(request
, params
): Promise
<T
>
Funds a transaction request by adding the necessary resources.
Name | Type | Description |
---|---|---|
T | extends TransactionRequest | The type of the TransactionRequest. |
Name | Type | Description |
---|---|---|
request | T | The transaction request to fund. |
params | EstimatedTxParams | The estimated transaction parameters. |
Promise
<T
>
The funded transaction request.
packages/account/src/account.ts:254
▸ getBalance(assetId?
): Promise
<BN
>
Retrieves the balance of the account for the given asset.
Name | Type | Description |
---|---|---|
assetId? | BytesLike | The asset ID to check the balance for. |
Promise
<BN
>
A promise that resolves to the balance amount.
packages/account/src/account.ts:206
▸ getBalances(): Promise
<CoinQuantity
[]>
Retrieves all the balances for the account.
Promise
<CoinQuantity
[]>
A promise that resolves to an array of Coins and their quantities.
packages/account/src/account.ts:217
▸ getCoins(assetId?
): Promise
<Coin
[]>
Retrieves coins owned by the account.
Name | Type | Description |
---|---|---|
assetId? | BytesLike | The asset ID of the coins to retrieve. |
Promise
<Coin
[]>
A promise that resolves to an array of Coins.
packages/account/src/account.ts:137
▸ getIndexFromPlaceholderWitness(request
): number
Returns the index of the witness placeholder that was added to this predicate. If no witness placeholder was added, it returns -1.
Name | Type | Description |
---|---|---|
request | TransactionRequest | The transaction request. |
number
The index of the witness placeholder, or -1 if there is no witness placeholder.
packages/account/src/predicate/predicate.ts:251
▸ getMessages(): Promise
<Message
[]>
Retrieves messages owned by the account.
Promise
<Message
[]>
A promise that resolves to an array of Messages.
packages/account/src/account.ts:171
▸ getPredicateData(): Uint8Array
Uint8Array
packages/account/src/predicate/predicate.ts:127
▸ getResourcesToSpend(quantities
, excludedIds?
): Promise
<Resource
[]>
Retrieves resources satisfying the spend query for the account.
Name | Type | Description |
---|---|---|
quantities | CoinQuantityLike [] | IDs of coins to exclude. |
excludedIds? | ExcludeResourcesOption | IDs of resources to be excluded from the query. |
Promise
<Resource
[]>
A promise that resolves to an array of Resources.
packages/account/src/predicate/predicate.ts:183
▸ populateTransactionPredicateData<T
>(transactionRequestLike
): T
Populates the transaction data with predicate data.
Name | Type |
---|---|
T | extends TransactionRequest |
Name | Type | Description |
---|---|---|
transactionRequestLike | TransactionRequestLike | The transaction request-like object. |
T
The transaction request with predicate data.
packages/account/src/predicate/predicate.ts:80
▸ sendTransaction(transactionRequestLike
): Promise
<TransactionResponse
>
Sends a transaction with the populated predicate data.
Name | Type | Description |
---|---|---|
transactionRequestLike | TransactionRequestLike | The transaction request-like object. |
Promise
<TransactionResponse
>
A promise that resolves to the transaction response.
packages/account/src/predicate/predicate.ts:111
▸ signMessage(message
): Promise
<string
>
Name | Type |
---|---|
message | string |
Promise
<string
>
packages/account/src/account.ts:540
▸ signTransaction(transactionRequestLike
): Promise
<string
>
Signs a transaction with the wallet's private key.
Name | Type | Description |
---|---|---|
transactionRequestLike | TransactionRequestLike | The transaction request to sign. |
Promise
<string
>
A promise that resolves to the signature of the transaction.
packages/account/src/account.ts:553
▸ simulateTransaction(transactionRequestLike
): Promise
<CallResult
>
Simulates a transaction with the populated predicate data.
Name | Type | Description |
---|---|---|
transactionRequestLike | TransactionRequestLike | The transaction request-like object. |
Promise
<CallResult
>
A promise that resolves to the call result.
packages/account/src/predicate/predicate.ts:122
▸ transfer(destination
, amount
, assetId?
, txParams?
): Promise
<TransactionResponse
>
Transfers coins to a destination address.
Name | Type | Description |
---|---|---|
destination | string | AbstractAddress | The address of the destination. |
amount | BigNumberish | The amount of coins to transfer. |
assetId? | BytesLike | The asset ID of the coins to transfer. |
txParams | TxParamsType | The transaction parameters (gasLimit, maturity). |
Promise
<TransactionResponse
>
A promise that resolves to the transaction response.
packages/account/src/account.ts:410
▸ transferToContract(contractId
, amount
, assetId?
, txParams?
): Promise
<TransactionResponse
>
Transfers coins to a contract address.
Name | Type | Description |
---|---|---|
contractId | string | AbstractAddress | The address of the contract. |
amount | BigNumberish | The amount of coins to transfer. |
assetId? | BytesLike | The asset ID of the coins to transfer. |
txParams | TxParamsType | The optional transaction parameters. |
Promise
<TransactionResponse
>
A promise that resolves to the transaction response.
packages/account/src/account.ts:440
▸ withdrawToBaseLayer(recipient
, amount
, txParams?
): Promise
<TransactionResponse
>
Withdraws an amount of the base asset to the base chain.
Name | Type | Description |
---|---|---|
recipient | string | AbstractAddress | Address of the recipient on the base chain. |
amount | BigNumberish | Amount of base asset. |
txParams | TxParamsType | The optional transaction parameters. |
Promise
<TransactionResponse
>
A promise that resolves to the transaction response.
packages/account/src/account.ts:498
▸ processPredicateData(bytes
, jsonAbi?
, configurableConstants?
): Object
Processes the predicate data and returns the altered bytecode and interface.
Name | Type | Description |
---|---|---|
bytes | BytesLike | The bytes of the predicate. |
jsonAbi? | JsonAbi | The JSON ABI of the predicate. |
configurableConstants? | Object | Optional configurable constants for the predicate. |
Object
An object containing the new predicate bytes and interface.
Name | Type |
---|---|
predicateBytes | Uint8Array |
predicateInterface | undefined | Interface <JsonAbi > |
packages/account/src/predicate/predicate.ts:144
▸ setConfigurableConstants(bytes
, configurableConstants
, abiInterface?
): Uint8Array
Sets the configurable constants for the predicate.
Name | Type | Description |
---|---|---|
bytes | Uint8Array | The bytes of the predicate. |
configurableConstants | Object | Configurable constants to be set. |
abiInterface? | Interface <JsonAbi > | The ABI interface of the predicate. |
Uint8Array
The mutated bytes with the configurable constants set.