eip: <to be assigned>
title: ERC: Content Attestation Registry
author: David Ammouial (@davux)
discussions-to: <URL>
status: Draft
type: Standards Track
category: ERC
created: 2019-03-29
A generic and privacy-aware registry of attested information.
This ERC describes a way for any entity to express and record its agreement with a given content, independently from the type of content, by storing a hash on chain along with a validity time range. Even though the existence of the agreement itself is provable and non-ambiguous, this specification doesn't place any semantics on the type of original content, how it's hashed, or what it means to agree with it. Likewise, it doesn't define any recommendation on the semantic validity of an attestation in relation to its recorded time range. As with any kind of recorded agreement, it is generally a good idea for the involved parties to ensure a mutual understanding on what is agreed upon and to what extent.
This ERC also allows the agreeing party to amend a previously recorded attestation by redefining the validity time range (including retracting the attestation altogether).
Traditionally, attesting to some kind of content is done through static signatures, e.g. a base64-encoded embedded RSA signature or a PGP signature. As for the smart contract world, hashes are often used in functions to certify content approval but no stable interface has been defined. This EIP is an attempt to homogenize a common interface for agreement that interoperable contract-based and web-based applications may start benefitting from.
Also, traditional signatures, in order to be retracted or amended, need to be put in context of Certificate Revocation Lists (CRLs) or similar mechanisms. This EIP attempts to leverage blockchain technology to remove the need for such centralized databases.
Attester
The attester of a given content is any entity, represented by an Ethereum address, that records its agreement with that content.
Attestation
In this specification, an attestation is defined as a (start time, end time) tuple that represents the time range during which a content is agreed upon by a specific attester.
Relying Party
The Relying Party for an attestation is an entity going through the process of reading an attestation for a given content and making conclusions on whether to trust that content.
Please note that the funcion names in this specification use the term "verify". This term could be mistakenly understood as "checking" the validity of some content, while it actually corresponds to the action of attesting to some content. While ambiguous, that term is kept for historical reasons.
The general idea of this EIP is that attesting a given content is equivalent to attesting a hash of that content, as long as the hashing function is known by the attester and the relying party.
An attestation is recorded as an (iat, exp)
tuple, where iat
("issued at") is the time the attestation starts to be valid, and exp
("expires") is the time after which the attestation is no longer valid.
Note the special meaning of the following values:
iat == 0
means the attester is NOT currently attesting to that content. In this case, the value ofexp
is irrelevant. Per Solidity rules, this is the initial value for any attestation. Its intended usage inside theattest()
function is to explicitly revoke an existing (i.e. non-zeroiat
) attestation.exp == 0
means the attester is not currently placing any expiration time on the attestation. Just like any other value, a value of0
may be amended later if the attester decides so.
This EIP defines the following functions:
verify
Used in a transaction to record an (iat, exp)
attestation of a given hash.
function verify(bytes32 hash, uint validDays) public;
verifications
Used to read the most recent attestation, if any, of a given hash
, recorded by a given attester
. Its return value is an (iat, exp)
tuple.
function verifications(bytes32 hash, address by) public;
This EIP defines the following event:
Verified
This event is emitted everytime a hash
is attested or revoked by an attester
and contains the iat
and exp
times of the attestation. A value of 0
for iat
means any previous attestation is being revoked. The event may be emitted with any values for iat
and exp
, including values equal to the previous ones (for example an already revoked attestation may be revoked again, or an attestation may be attested again with the same values).
event Verified(bytes32 indexed hash, address by, uint date, uint expDate);
The validity time range is a mere indication by the attester. This EIP does not define what policy should be applied by relying party software or people with respect to current time. Here are a few real-life policy examples:
- Safe policy. Some relying parties might decide that an attestation is only acceptable if the expiration time is at least 6 months in the future.
- Flexible policy. Some relying parties might leave a tolerance window during which they still accept an expired attestation.
- Strict policy. Some relying parties might only accept an attestation during the attestation time range.
- Some relying parties might apply more complex policies, e.g. where the tolerance depends on the identity of the attester, on the content, on the actual transaction time of the attestation, on the existence of previous attestations, etc.
Information stored on a blockchain is both public and permanent, which makes it a crucial decision to decide what to store and what not to store. For this reason, a balance should always be seeked between privacy and usefulness. Specifically, the decision to include validity times on chain rather than in the original content is a result of that subjective balance:
- Including validity times means leaking out information allowing to suspect or discard specific contents for a given hash. For example, time ranges of 3 weeks might give up certain types of documents, and exclude e.g. passports.
- Leaving validity times off-chain (typically in the original document) might not work very well for some types of documents where the issuer and the attester are separate entities and the attester doesn't have the liberty to emit an "attestation document" containing validity times.
This specification allows relying parties to store date information on-chain. However, the attester and the relying party are always free to use any non-zero value in the (iat, exp)
tuple and maintain date information off-chain instead.
To follow best practices, it was deemed equally secure, cheaper, and most respectful to privacy to record fixed-length bytes32
data rather than actual content.
This EIP doesn't introduce any known backwards compatibility issues.
An implementation may be found here.
Copyright and related rights waived via CC0.