Admin Notary
Overview
This policy is useful for contracts that have sensitive admin functions that need to be called frequently, and you don't necessarily want to use a Multi-Sig wallet to call them (although this can also be used on top of a Multi-Sig for even better security).
You can use this policy to allow a 3rd party notary to approve the call after off-chain authentication verifying that the owner of the contract is the one making the call.
Protected Attack Vector
This policy protects against an attacker that may have gained access to a privileged private key of the protocol (i.e. a private key of one of the admins of the protocol) and attempts to send a malicious transaction to your protocol.
Even with the privileged private key, the transaction will be blocked by this policy - unless it's data was pre-approved by a 3rd party notary.
How It Works
When one of your protocol admins needs to send a transaction to the protocol, they will first need to send the transaction's data to a 3rd party notary.
The notary will then need to hash the transaction's data and approve it on the policy. Approval for the transaction is given by the notary calling the
approveCall()
function of the policy.Once the transaction has been approved, the protocol admin can send the transaction, and the policy will allow it to go through.
Setup Instructions
Deploy your own version of this policy (see Source Code).
The default
expirationTime
for each 3rd party approval is 1 day. If you want to change this, issue asetExpirationTime()
call to set a new expiration.Add the newly deployed policy to the Firewall (you can do this Globally or Per-Method, see Policy Administration).
That's it!
Properties
expirationTime
uint
the default amount of time a call hash is valid for after it is approved
adminCallHashApprovalTimestamp
mapping
(bytes32 => uint)
the timestamp that a call hash was approved at (if approved at all)
Methods
approveCall()
function approveCall(bytes32 _callHash)
function approveCall(bytes32 _callHash)
Callable only by the policy owner (i.e. the notary). Approves transaction data that was hashed by a notary so that the protocol's admin(s) will be able to send the transaction securely.
_callHash
bytes32
the hashed transaction data
setExpirationTime()
function setExpirationTime(uint _expirationTime)
function setExpirationTime(uint _expirationTime)
Callable only by the policy owner (i.e. the notary). Sets the expiration time for approved transaction data. If a protocol admin sends a transaction after the approval has expired, the transaction will not be allowed to go through (it will be reverted by the policy). This setting is global for all approvals.
_expirationTime
uint
the expiration time for approvals
Security Lifecycle
This policy runs during the Firewall's Pre-Execution hook.
Source Code
On our GitHub repository: AdminCallPolicy.sol
Last updated