Key Oracle
Simple Key Attestation
Last updated
Simple Key Attestation
Last updated
The KeyOracle contract acts as Dispatcher and is designed to model on-chain attestations by a pre-designated key-holder.
This enables a programmatic outsourcing of determining whether or not an event registered by the root key holder has happened. Any use case for firing events securely could be built on top of a Key Oracle.
The contract works by taking an event description from a root key holder, along with an associated key id that is able to fire the event at their will. The key id must belong to the root key holder. Thus, the event registration comes with the assumption that the root key holder trusts the assigned key to faithfully fire the event.
When the key holder attests to the event, the KeyOracle
contract fires the event on the TrustEventLog
, enabling its state to be reflected to Scribes
and other programs.
The KeyOracle has very little state or logic other than to keep track of key level dispatcher permissions per event.
The locksmith reference the contract relies on to check for key possession.
The event log reference where this contract will register and fire events to. For the KeyOracle
to work properly, each trust owner must approve it as a dispatcher at the Notary
.
This is a mapping for each key, to a set of events that the key can be responsible for.
For each event, which key is responsible for firing it.
The operations on this contract are simple. Register an event that can only be fired by a given key, and fire that even when the key holder attests.
Creates the key oracle. This method can only be called by a root key holder of a trust that has attested to the Notary
that the KeyOracle
contract is a valid dispatcher. The key assigned to the event must also be within the root key holder's trust model. The root key holder can specify a short description encoded as a bytes32
to describe the event significance.
Once a KeyOracle is susccessfully created, the specified key holder can come back and formally fire the event.