Skip to content

addApprovedProviderSync

addApprovedProviderSync(client, options): Promise<OutputType>

Defined in: packages/synapse-core/src/warm-storage/add-approved-provider.ts:125

Add an approved provider for the client and wait for confirmation

This function approves a provider so that the client can create data sets with them. Waits for the transaction to be confirmed and returns the receipt with the event.

ParameterTypeDescription
clientClient<Transport, Chain, Account>The client to use to add the approved provider.
options{ contractAddress?: `0x${string}`; onHash?: (hash) => void; providerId: bigint; }addApprovedProviderSync.OptionsType
options.contractAddress?`0x${string}`Warm storage contract address. If not provided, the default is the storage contract address for the chain.
options.onHash?(hash) => voidCallback function called with the transaction hash before waiting for the receipt.
options.providerIdbigintThe ID of the provider to approve.

Promise<OutputType>

The transaction receipt and extracted event addApprovedProviderSync.OutputType

Errors addApprovedProviderSync.ErrorType

import { addApprovedProviderSync } from '@filoz/synapse-core/warm-storage'
import { createWalletClient, http } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { calibration } from '@filoz/synapse-core/chains'
const account = privateKeyToAccount('0x...')
const client = createWalletClient({
account,
chain: calibration,
transport: http(),
})
const { receipt, event } = await addApprovedProviderSync(client, {
providerId: 1n,
onHash: (hash) => console.log('Transaction sent:', hash),
})
console.log('Provider ID:', event.args.providerId)