viem
Version:
1,444 lines (1,443 loc) • 116 kB
TypeScript
import type { Address } from 'abitype';
import type { KeyAuthorization } from 'ox/tempo';
import type { Account } from '../../accounts/types.js';
import type { ReadContractReturnType } from '../../actions/public/readContract.js';
import type { WatchContractEventParameters } from '../../actions/public/watchContractEvent.js';
import { sendTransaction } from '../../actions/wallet/sendTransaction.js';
import { sendTransactionSync } from '../../actions/wallet/sendTransactionSync.js';
import type { WriteContractReturnType } from '../../actions/wallet/writeContract.js';
import { writeContract } from '../../actions/wallet/writeContract.js';
import { writeContractSync } from '../../actions/wallet/writeContractSync.js';
import type { Client } from '../../clients/createClient.js';
import type { Transport } from '../../clients/transports/createTransport.js';
import type { BaseErrorType } from '../../errors/base.js';
import type { Chain } from '../../types/chain.js';
import type { ExtractAbiItem, GetEventArgs } from '../../types/contract.js';
import type { Log, Log as viem_Log } from '../../types/log.js';
import type { Hex } from '../../types/misc.js';
import type { Compute, UnionOmit } from '../../types/utils.js';
import * as Abis from '../Abis.js';
import type { AccessKeyAccount, resolveAccessKey } from '../Account.js';
import { signKeyAuthorization } from '../Account.js';
import type { GetAccountParameter, ReadParameters, WriteParameters } from '../internal/types.js';
import type { TransactionReceipt } from '../Transaction.js';
/**
* Authorizes an access key by signing a key authorization and sending a transaction.
*
* @example
* ```ts
* import { createClient, http } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions, Account } from 'viem/tempo'
* import { generatePrivateKey } from 'viem/accounts'
*
* const account = Account.from({ privateKey: '0x...' })
* const client = createClient({
* account,
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* })
*
* const accessKey = Account.fromP256(generatePrivateKey(), {
* access: account,
* })
*
* const hash = await Actions.accessKey.authorize(client, {
* accessKey,
* expiry: Math.floor((Date.now() + 30_000) / 1000),
* })
* ```
*
* @param client - Client.
* @param parameters - Parameters.
* @returns The transaction hash.
*/
export declare function authorize<chain extends Chain | undefined, account extends Account | undefined>(client: Client<Transport, chain, account>, parameters: authorize.Parameters<chain, account>): Promise<authorize.ReturnValue>;
export declare namespace authorize {
type Parameters<chain extends Chain | undefined = Chain | undefined, account extends Account | undefined = Account | undefined> = WriteParameters<chain, account> & Args;
type Args = {
/** The access key to authorize. */
accessKey: resolveAccessKey.Parameters;
/**
* Whether to authorize the key as an admin key. Admin keys are unrestricted
* and can manage the account's other access keys; `expiry`, `limits`, and
* `scopes` are ignored. Requires the T6 hardfork.
*
* [TIP-1049](https://tips.sh/1049)
*/
admin?: boolean | undefined;
/** The chain ID. */
chainId?: number | undefined;
/** Unix timestamp when the key expires. */
expiry?: number | undefined;
/** Spending limits per token. */
limits?: {
token: Address;
limit: bigint;
period?: number | undefined;
}[] | undefined;
/** Call scopes restricting which contracts/selectors this key can call. */
scopes?: KeyAuthorization.Scope[] | undefined;
/**
* Optional 32-byte witness bound into the authorization's signing hash.
*
* Applications use this to bind a single signature to an arbitrary offchain
* context (e.g. a server-issued challenge), or as a revocation handle that
* can be burned onchain (see {@link burnWitness}) to invalidate the
* authorization before it is submitted.
*
* [TIP-1053](https://tips.sh/1053)
*/
witness?: Hex | undefined;
};
type ReturnValue = WriteContractReturnType;
type ErrorType = BaseErrorType;
/** @internal */
function inner<action extends typeof sendTransaction | typeof sendTransactionSync, chain extends Chain | undefined, account extends Account | undefined>(action: action, client: Client<Transport, chain, account>, parameters: authorize.Parameters<chain, account>): Promise<ReturnType<action>>;
function extractEvent(logs: Log[]): Log<bigint, number, false, undefined, true, readonly [{
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "tuple";
readonly name: "config";
readonly components: readonly [{
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint64";
readonly name: "period";
}];
}, {
readonly type: "bool";
readonly name: "allowAnyCalls";
}, {
readonly type: "tuple[]";
readonly name: "allowedCalls";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "tuple";
readonly name: "config";
readonly components: readonly [{
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint64";
readonly name: "period";
}];
}, {
readonly type: "bool";
readonly name: "allowAnyCalls";
}, {
readonly type: "tuple[]";
readonly name: "allowedCalls";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeAdminKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "burnKeyAuthorizationWitness";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "revokeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [];
}, {
readonly name: "updateSpendingLimit";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "newLimit";
}];
readonly outputs: readonly [];
}, {
readonly name: "setAllowedCalls";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "tuple[]";
readonly name: "scopes";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "removeAllowedCalls";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "target";
}];
readonly outputs: readonly [];
}, {
readonly name: "getKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "tuple";
readonly components: readonly [{
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "bool";
readonly name: "isRevoked";
}];
}];
}, {
readonly name: "getRemainingLimit";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}];
readonly outputs: readonly [{
readonly type: "uint256";
readonly name: "remaining";
}];
}, {
readonly name: "getRemainingLimitWithPeriod";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}];
readonly outputs: readonly [{
readonly type: "uint256";
readonly name: "remaining";
}, {
readonly type: "uint64";
readonly name: "periodEnd";
}];
}, {
readonly name: "getAllowedCalls";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "bool";
readonly name: "isScoped";
}, {
readonly type: "tuple[]";
readonly name: "scopes";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}, {
readonly name: "isKeyAuthorizationWitnessBurned";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [{
readonly type: "bool";
}];
}, {
readonly name: "isAdminKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "bool";
}];
}, {
readonly name: "getTransactionKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [];
readonly outputs: readonly [{
readonly type: "address";
}];
}, {
readonly name: "KeyAuthorized";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "uint64";
readonly name: "expiry";
}];
}, {
readonly name: "AdminKeyAuthorized";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}];
}, {
readonly name: "KeyRevoked";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}];
}, {
readonly name: "SpendingLimitUpdated";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "token";
readonly indexed: true;
}, {
readonly type: "uint256";
readonly name: "newLimit";
}];
}, {
readonly name: "AccessKeySpend";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "token";
readonly indexed: true;
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint256";
readonly name: "remainingLimit";
}];
}, {
readonly name: "KeyAuthorizationWitness";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "bytes32";
readonly name: "witness";
readonly indexed: true;
}];
}, {
readonly name: "KeyAuthorizationWitnessBurned";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "bytes32";
readonly name: "witness";
readonly indexed: true;
}];
}, {
readonly name: "UnauthorizedCaller";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAlreadyExists";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyNotFound";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyExpired";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "SpendingLimitExceeded";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidSpendingLimit";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidSignatureType";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "ZeroPublicKey";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "ExpiryInPast";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAlreadyRevoked";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "SignatureTypeMismatch";
readonly type: "error";
readonly inputs: readonly [{
readonly type: "uint8";
readonly name: "expected";
}, {
readonly type: "uint8";
readonly name: "actual";
}];
}, {
readonly name: "CallNotAllowed";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidCallScope";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidKeyId";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidKeyAuthorizationWitness";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAuthorizationWitnessAlreadyBurned";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "LegacyAuthorizeKeySelectorChanged";
readonly type: "error";
readonly inputs: readonly [{
readonly type: "bytes4";
readonly name: "newSelector";
}];
}], "KeyAuthorized">;
}
/**
* Authorizes an access key and waits for the transaction receipt.
*
* @example
* ```ts
* import { createClient, http } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions, Account } from 'viem/tempo'
* import { generatePrivateKey } from 'viem/accounts'
*
* const account = Account.from({ privateKey: '0x...' })
* const client = createClient({
* account,
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* })
*
* const accessKey = Account.fromP256(generatePrivateKey(), {
* access: account,
* })
*
* const { receipt, ...result } = await Actions.accessKey.authorizeSync(client, {
* accessKey,
* expiry: Math.floor((Date.now() + 30_000) / 1000),
* })
* ```
*
* @param client - Client.
* @param parameters - Parameters.
* @returns The transaction receipt and event data.
*/
export declare function authorizeSync<chain extends Chain | undefined, account extends Account | undefined>(client: Client<Transport, chain, account>, parameters: authorizeSync.Parameters<chain, account>): Promise<authorizeSync.ReturnValue>;
export declare namespace authorizeSync {
type Parameters<chain extends Chain | undefined = Chain | undefined, account extends Account | undefined = Account | undefined> = authorize.Parameters<chain, account>;
type Args = authorize.Args;
type ReturnValue = Compute<GetEventArgs<typeof Abis.accountKeychain, 'KeyAuthorized', {
IndexedOnly: false;
Required: true;
}> & {
receipt: TransactionReceipt;
}>;
type ErrorType = BaseErrorType;
}
/**
* Burns a key-authorization witness, invalidating any authorization bound to
* it before it is submitted onchain.
*
* Once burned, an `authorizeKey` call carrying the same `witness` will revert.
* This lets applications issue a signed authorization offchain (see
* {@link authorize}) while retaining the ability to revoke it.
*
* [TIP-1053](https://tips.sh/1053)
*
* @example
* ```ts
* import { createClient, http } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions } from 'viem/tempo'
* import { privateKeyToAccount } from 'viem/accounts'
*
* const client = createClient({
* account: privateKeyToAccount('0x...'),
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* })
*
* const hash = await Actions.accessKey.burnWitness(client, {
* witness: '0x...',
* })
* ```
*
* @param client - Client.
* @param parameters - Parameters.
* @returns The transaction hash.
*/
export declare function burnWitness<chain extends Chain | undefined, account extends Account | undefined>(client: Client<Transport, chain, account>, parameters: burnWitness.Parameters<chain, account>): Promise<burnWitness.ReturnValue>;
export declare namespace burnWitness {
type Parameters<chain extends Chain | undefined = Chain | undefined, account extends Account | undefined = Account | undefined> = WriteParameters<chain, account> & Args;
type Args = {
/** The 32-byte witness to burn. */
witness: Hex;
};
type ReturnValue = WriteContractReturnType;
type ErrorType = BaseErrorType;
/** @internal */
function inner<action extends typeof writeContract | typeof writeContractSync, chain extends Chain | undefined, account extends Account | undefined>(action: action, client: Client<Transport, chain, account>, parameters: burnWitness.Parameters<chain, account>): Promise<ReturnType<action>>;
/**
* Defines a call to the `burnKeyAuthorizationWitness` function.
*
* Can be passed as a parameter to:
* - [`estimateContractGas`](https://viem.sh/docs/contract/estimateContractGas): estimate the gas cost of the call
* - [`simulateContract`](https://viem.sh/docs/contract/simulateContract): simulate the call
* - [`sendCalls`](https://viem.sh/docs/actions/wallet/sendCalls): send multiple calls
*
* @example
* ```ts
* import { createClient, http, walletActions } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions } from 'viem/tempo'
*
* const client = createClient({
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* }).extend(walletActions)
*
* const hash = await client.sendTransaction({
* calls: [
* Actions.accessKey.burnWitness.call({ witness: '0x...' }),
* ],
* })
* ```
*
* @param args - Arguments.
* @returns The call.
*/
function call(args: Args): {
abi: [{
readonly name: "burnKeyAuthorizationWitness";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}];
functionName: "burnKeyAuthorizationWitness";
} & {
args: readonly [`0x${string}`];
} & {
address: Address;
} & {
data: Hex;
to: Address;
};
function extractEvent(logs: Log[]): Log<bigint, number, false, undefined, true, readonly [{
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "tuple";
readonly name: "config";
readonly components: readonly [{
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint64";
readonly name: "period";
}];
}, {
readonly type: "bool";
readonly name: "allowAnyCalls";
}, {
readonly type: "tuple[]";
readonly name: "allowedCalls";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "tuple";
readonly name: "config";
readonly components: readonly [{
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "tuple[]";
readonly name: "limits";
readonly components: readonly [{
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint64";
readonly name: "period";
}];
}, {
readonly type: "bool";
readonly name: "allowAnyCalls";
}, {
readonly type: "tuple[]";
readonly name: "allowedCalls";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "authorizeAdminKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "burnKeyAuthorizationWitness";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [];
}, {
readonly name: "revokeKey";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [];
}, {
readonly name: "updateSpendingLimit";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}, {
readonly type: "uint256";
readonly name: "newLimit";
}];
readonly outputs: readonly [];
}, {
readonly name: "setAllowedCalls";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "tuple[]";
readonly name: "scopes";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
readonly outputs: readonly [];
}, {
readonly name: "removeAllowedCalls";
readonly type: "function";
readonly stateMutability: "nonpayable";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "target";
}];
readonly outputs: readonly [];
}, {
readonly name: "getKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "tuple";
readonly components: readonly [{
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint64";
readonly name: "expiry";
}, {
readonly type: "bool";
readonly name: "enforceLimits";
}, {
readonly type: "bool";
readonly name: "isRevoked";
}];
}];
}, {
readonly name: "getRemainingLimit";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}];
readonly outputs: readonly [{
readonly type: "uint256";
readonly name: "remaining";
}];
}, {
readonly name: "getRemainingLimitWithPeriod";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "address";
readonly name: "token";
}];
readonly outputs: readonly [{
readonly type: "uint256";
readonly name: "remaining";
}, {
readonly type: "uint64";
readonly name: "periodEnd";
}];
}, {
readonly name: "getAllowedCalls";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "bool";
readonly name: "isScoped";
}, {
readonly type: "tuple[]";
readonly name: "scopes";
readonly components: readonly [{
readonly type: "address";
readonly name: "target";
}, {
readonly type: "tuple[]";
readonly name: "selectorRules";
readonly components: readonly [{
readonly type: "bytes4";
readonly name: "selector";
}, {
readonly type: "address[]";
readonly name: "recipients";
}];
}];
}];
}, {
readonly name: "isKeyAuthorizationWitnessBurned";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "bytes32";
readonly name: "witness";
}];
readonly outputs: readonly [{
readonly type: "bool";
}];
}, {
readonly name: "isAdminKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "bool";
}];
}, {
readonly name: "getTransactionKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [];
readonly outputs: readonly [{
readonly type: "address";
}];
}, {
readonly name: "KeyAuthorized";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "uint64";
readonly name: "expiry";
}];
}, {
readonly name: "AdminKeyAuthorized";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}];
}, {
readonly name: "KeyRevoked";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}];
}, {
readonly name: "SpendingLimitUpdated";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "token";
readonly indexed: true;
}, {
readonly type: "uint256";
readonly name: "newLimit";
}];
}, {
readonly name: "AccessKeySpend";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "publicKey";
readonly indexed: true;
}, {
readonly type: "address";
readonly name: "token";
readonly indexed: true;
}, {
readonly type: "uint256";
readonly name: "amount";
}, {
readonly type: "uint256";
readonly name: "remainingLimit";
}];
}, {
readonly name: "KeyAuthorizationWitness";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "bytes32";
readonly name: "witness";
readonly indexed: true;
}];
}, {
readonly name: "KeyAuthorizationWitnessBurned";
readonly type: "event";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
readonly indexed: true;
}, {
readonly type: "bytes32";
readonly name: "witness";
readonly indexed: true;
}];
}, {
readonly name: "UnauthorizedCaller";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAlreadyExists";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyNotFound";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyExpired";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "SpendingLimitExceeded";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidSpendingLimit";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidSignatureType";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "ZeroPublicKey";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "ExpiryInPast";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAlreadyRevoked";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "SignatureTypeMismatch";
readonly type: "error";
readonly inputs: readonly [{
readonly type: "uint8";
readonly name: "expected";
}, {
readonly type: "uint8";
readonly name: "actual";
}];
}, {
readonly name: "CallNotAllowed";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidCallScope";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidKeyId";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "InvalidKeyAuthorizationWitness";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "KeyAuthorizationWitnessAlreadyBurned";
readonly type: "error";
readonly inputs: readonly [];
}, {
readonly name: "LegacyAuthorizeKeySelectorChanged";
readonly type: "error";
readonly inputs: readonly [{
readonly type: "bytes4";
readonly name: "newSelector";
}];
}], "KeyAuthorizationWitnessBurned">;
}
/**
* Burns a key-authorization witness and waits for the transaction receipt.
*
* @example
* ```ts
* import { createClient, http } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions } from 'viem/tempo'
* import { privateKeyToAccount } from 'viem/accounts'
*
* const client = createClient({
* account: privateKeyToAccount('0x...'),
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* })
*
* const { receipt, ...result } = await Actions.accessKey.burnWitnessSync(client, {
* witness: '0x...',
* })
* ```
*
* @param client - Client.
* @param parameters - Parameters.
* @returns The transaction receipt and event data.
*/
export declare function burnWitnessSync<chain extends Chain | undefined, account extends Account | undefined>(client: Client<Transport, chain, account>, parameters: burnWitnessSync.Parameters<chain, account>): Promise<burnWitnessSync.ReturnValue>;
export declare namespace burnWitnessSync {
type Parameters<chain extends Chain | undefined = Chain | undefined, account extends Account | undefined = Account | undefined> = burnWitness.Parameters<chain, account>;
type Args = burnWitness.Args;
type ReturnValue = Compute<GetEventArgs<typeof Abis.accountKeychain, 'KeyAuthorizationWitnessBurned', {
IndexedOnly: false;
Required: true;
}> & {
receipt: TransactionReceipt;
}>;
type ErrorType = BaseErrorType;
}
/**
* Gets access key information.
*
* @example
* ```ts
* import { createClient, http } from 'viem'
* import { tempo } from 'viem/chains'
* import { Actions } from 'viem/tempo'
*
* const client = createClient({
* chain: tempo.extend({ feeToken: '0x20c0000000000000000000000000000000000001' }),
* transport: http(),
* })
*
* const key = await Actions.accessKey.getMetadata(client, {
* account: '0x...',
* accessKey: '0x...',
* })
* ```
*
* @param client - Client.
* @param parameters - Parameters.
* @returns The key information.
*/
export declare function getMetadata<chain extends Chain | undefined, account extends Account | undefined>(client: Client<Transport, chain, account>, parameters: getMetadata.Parameters<account>): Promise<getMetadata.ReturnValue>;
export declare namespace getMetadata {
type Parameters<account extends Account | undefined = Account | undefined> = ReadParameters & GetAccountParameter<account> & Pick<Args, 'accessKey'>;
type Args = {
/** Account address. */
account: Address;
/** The access key. */
accessKey: Address | AccessKeyAccount;
};
type ReturnValue = {
/** The access key address. */
address: Address;
/** The key type. */
keyType: 'secp256k1' | 'p256' | 'webAuthn';
/** The expiry timestamp. */
expiry: bigint;
/** The spending policy. */
spendPolicy: 'limited' | 'unlimited';
/** Whether the key is revoked. */
isRevoked: boolean;
};
/**
* Defines a call to the `getKey` function.
*
* @param args - Arguments.
* @returns The call.
*/
function call(args: Args): {
abi: [{
readonly name: "getKey";
readonly type: "function";
readonly stateMutability: "view";
readonly inputs: readonly [{
readonly type: "address";
readonly name: "account";
}, {
readonly type: "address";
readonly name: "keyId";
}];
readonly outputs: readonly [{
readonly type: "tuple";
readonly components: readonly [{
readonly type: "uint8";
readonly name: "signatureType";
}, {
readonly type: "address";
readonly name: "keyId";
}, {
readonly type: "uint64";
readonly name: "expiry";
}, {