- A policy is a collection of
ruleswith defined criteria. - Each rule contains a specified
action,operation, andcriteria:- An
actioncan eitheracceptorrejecta transaction if the criteria in the rule are met. criteriais an array of logical expressions. All parameters must evaluate to true for the action to be applied.- An
operationcorresponds to a CDP v2 API:signEvmTransactionorsignSolTransactionfor signing transactions (to set a transaction limit).sendEvmTransactionfor signing a transaction, and sending it to a supported network.signEvmHashfor signing an arbitrary 32 byte hash.signEvmMessagefor signing an EIP-191 message.prepareUserOperationfor preparing user operations on a smart account.sendUserOperationfor sending user operations using a smart account.
- An
- A rule indicates how an operation should behave, specifying whether a request with defined criteria should be accepted or rejected.
Policy Scope
Policies can be applied at the project and/or account level:- Project-level policy: A
project-level policy applies to all accounts in a CDP Project. Only one project-level policy can be applied to accounts within a CDP Project at any given time. - Account-level policy: An
account-level policy applies to one or more accounts. An account can have at most one account-level policy at any given time.
scope field of a policy:
Policy Evaluation
Project-level policies are evaluated first, followed by account-level policies. The Policy Engine will process the request against each rule in the order it is defined within therules array:
- If the rule’s
criteria(processed as a logical AND operation applied to a list of independently evaluated boolean expressions) are met,acceptorrejectbehavior is applied immediately and the engine stops further evaluation of the policy. - If after policy evaluation, no rule’s
criteriaare met, the engine moves to processing the next policy (i.e., anaccount-level policy). - If no further policies exist, the request is rejected.
- Evaluate the first rule: For a
signEvmTransactionrequest, accept the request if the transaction is less than or equal to 1000000000000000000 wei OR - Evaluate the second rule: if the request is a
signEvmTransactionrequest, accept the request if the transaction is less than or equal to 2000000000000000000 wei AND the request is made to the address0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE. - If the request does not meet the criteria of either rule, the engine will move on to evaluate an
account-level policy (if one exists). - Otherwise, the request is rejected.
Policy Application
Project-level policies are applied to all accounts in a CDP Project. They will apply retroactively even if the project-level policy is created after the account was created. To disable a project-level policy, you must remove the project-level policy from the CDP Project using thedeletePolicy operation.
Account-level policies can be applied in two ways:
-
By specifying the
accountPolicyfield in the request body of thecreateEvmAccountandcreateSolAccountoperations. -
By specifying the
accountPolicyfield in the request body of theupdateEvmAccountandupdateSolanaAccountoperations.
Criteria
The following criteria are supported:SignEvmTransaction Criteria
ethValue
A criterion based on the value of the transaction. The transaction’svalue field is compared to the criterion’s ethValue field using the operator field.
evmAddress
A criterion based on the recipient address of the transaction. The transaction’sto field is compared to the criterion’s addresses field using the operator field.
evmData
A criterion based on encoded transaction data that evaluates the function being called, as well as any number of arguments accessed by either name or index. Currently this criterion only supports primitive types;string, bool, uint(8,16,32,64,256), int(8,16,32,64,256), address, and both fixed and dynamic length bytes.
netUSDChange
A criterion based on the USD denominated market value of assets being transferred, or exposing the sender to. The types of assets included in the calculation include native assets,ERC20, ERC721, and ERC1155 tokens. The sum total USD amount of assets being transferred and exposed is compared to the criterion’s changeCents field using the operator field. If signing a testnet transaction, then this criterion configuration will be ignored.
SendEvmTransaction Criteria
ethValue
A criterion based on the value of the transaction. The transaction’svalue field is compared to the criterion’s ethValue field using the operator field.
evmAddress
A criterion based on the recipient address of the transaction. The transaction’sto field is compared to the criterion’s addresses field using the operator field.
evmNetwork
A criterion based on the intended network of the transaction. Thenetwork field in the sendEvmTransaction request body is compared to the criterion’s networks field using the operator field.
Valid networks for this criterion include:
basebase-sepoliaethereumethereum-sepoliaavalanchepolygonoptimismarbitrum
evmData
A criterion based on encoded transaction data that evaluates the function being called, as well as any number of arguments accessed by either name or index. Currently this criterion only supports primitive types;string, bool, uint(8,16,32,64,256), int(8,16,32,64,256), address, and both fixed and dynamic length bytes.
netUSDChange
A criterion based on the USD denominated market value of assets being transferred, or exposing the sender to. The types of assets included in the calculation include native assets,ERC20, ERC721, and ERC1155 tokens. The sum total USD amount of assets being transferred and exposed is compared to the criterion’s changeCents field using the operator field. If sending a testnet transaction, then this criterion configuration will be ignored.
SendUserOperation Criteria
ethValue
A criterion based on the value of the user operation. The operation’svalue fields are compared to the criterion’s ethValue field using the operator field.
evmAddress
A criterion based on the recipient address of the operation. The operation’sto fields are compared to the criterion’s addresses field using the operator field.
evmData
A criterion based on encoded transaction data that evaluates the function being called, as well as any number of arguments accessed by either name or index. Currently this criterion only supports primitive types;string, bool, uint(8,16,32,64,256), int(8,16,32,64,256), address, and both fixed and dynamic length bytes.
PrepareUserOperation Criteria
ethValue
A criterion based on the value of the user operation. The operation’svalue fields are compared to the criterion’s ethValue field using the operator field.
evmAddress
A criterion based on the recipient address of the user operation. The operation’sto fields are compared to the criterion’s addresses field using the operator field.
evmNetwork
A criterion based on the intended network of the user operation. Thenetwork field in the prepareUserOperation request body is compared to the criterion’s networks field using the operator field.
Valid networks for this criterion include:
base-sepoliabasearbitrumoptimismzorapolygonbnbavalancheethereumethereum-sepolia
evmData
A criterion based on encoded transaction data that evaluates the function being called, as well as any number of arguments accessed by either name or index. Currently this criterion only supports primitive types;string, bool, uint(8,16,32,64,256), int(8,16,32,64,256), address, and both fixed and dynamic length bytes.
SignEvmHash Criteria
ThesignEvmHash operation does not accept any criteria. To prevent this operation from being executed by any account, specify a rule with signEvmHash as the operation, and reject as its action.
SignEvmMessage Criteria
evmMessage
A criterion based on the intended message to be signed. Thematch field in the criteria is a RE2 compliant regular expression that will be executed against the message in the API request.
SignSolMessage Criteria
solMessage
A criterion based on the intended message to be signed. Thematch field in the criteria is a RE2 compliant regular expression that will be executed against the message in the API request.
SignSolTransaction Criteria
solAddress
A criterion based on the recipient addresses of the transaction. The criterion’saddress field is compared to the list of addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
solValue
A criterion based on the value of the transaction. The criterion’ssolValue field is compared to the transaction’s value, which is the amount of SOL in lamports being transferred, using the operator field.
splAddress
A criterion based on the recipient addresses of SPL token transfer instructions in the transaction. The criterion’saddresses field is compared to the list of SPL token transfer recipient addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
splValue
A criterion based on the SPL token value of SPL token transfer instructions in the transaction. The criterion’ssplValue field is compared to the transaction instruction’s value field, which is the amount of the SPL token being transferred, using the operator field.
mintAddress
A criterion based on the token mint addresses of SPL token transfer instructions in the transaction. The criterion’saddresses field is compared to the list of token mint addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
solData
A criterion based on Solana transaction instruction data. The criterion uses Interface Definition Language (IDL) specifications to decode and validate instruction data against specific rules. Theidls field specifies which Solana programs to validate against (either known program names like “SystemProgram” and “TokenProgram”, or custom IDL objects), and the conditions field defines instruction-specific validation rules including instruction names and parameter constraints.
programId
A criterion based on the program IDs of a transaction’s instructions. The criterion’sprogramIds field is compared to the list of program IDs in the transaction’s instructions using the operator field.
SendSolTransaction Criteria
solAddress
A criterion based on the recipient addresses of the transaction. The criterion’saddress field is compared to the list of addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
solValue
A criterion based on the value of the transaction. The criterion’ssolValue field is compared to the transaction’s value, which is the amount of SOL in lamports being transferred, using the operator field.
splAddress
A criterion based on the recipient addresses of SPL token transfer instructions in the transaction. The criterion’saddresses field is compared to the list of SPL token transfer recipient addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
splValue
A criterion based on the SPL token value of SPL token transfer instructions in the transaction. The criterion’ssplValue field is compared to the transaction instruction’s value field, which is the amount of the SPL token being transferred, using the operator field.
mintAddress
A criterion based on the token mint addresses of SPL token transfer instructions in the transaction. The criterion’saddresses field is compared to the list of token mint addresses in the transaction’s accountKeys (for legacy transactions) or staticAccountKeys (for V0 transactions) array using the operator field.
solData
A criterion based on Solana transaction instruction data. The criterion uses Interface Definition Language (IDL) specifications to decode and validate instruction data against specific rules. Theidls field specifies which Solana programs to validate against (either known program names like “SystemProgram” and “TokenProgram”, or custom IDL objects), and the conditions field defines instruction-specific validation rules including instruction names and parameter constraints.
programId
A criterion based on the program IDs of a transaction’s instructions. The criterion’sprogramIds field is compared to the list of program IDs in the transaction’s instructions using the operator field.
solNetwork
A criterion based on the intended network of the transaction. Thenetwork field in the sendSolanaTransaction request body is compared to the criterion’s networks field using the operator field.
Valid networks for this criterion include:
solana-devnetsolana
Restricting Contract Interactions on Ethereum
Smart contract function restrictions serve as a critical security and governance mechanism in decentralized applications, allowing developers and organizations to implement fine-grained access controls over their protocol interactions. One of the primary use cases for function restrictions is protecting high-risk operations from unauthorized access such as:- Fund transfers - Contract upgrades - Parameter modifications - Emergency pauses
Policy Engine supports such restrictions that evaluate against transaction data with the
evmDatacriterion for thesignEvmTransaction, andsendEvmTransactionoperations.
Examples
USD Limits
The following example demonstrates a policy that only allows transactions to transfer, or expose the sender to, less than $100.00 worth of assets at a time. This USD denominated amount includes native assets,ERC20, ERC721, and ERC1155 tokens calculated using current market prices.