AEON GP Integrity v1
Convention identifier: aeon.gp.integrity.v1
Status
Draft interoperability convention
1. Purpose
aeon.gp.integrity.v1 defines a deterministic hashing model for AEON documents.
It exists to ensure that independent implementations produce the same hash for the same covered canonical assignment state.
This convention is intended as the foundation for:
aeon.gp.signature.v1- self-verifying documents
- tamper detection
- security envelopes
2. Scope
aeon.gp.integrity.v1 defines:
- what content is covered by the hash
- what content is excluded
- how canonical hash input is constructed
- how the final hash is produced
It does not define:
- signature algorithms
- trust models
- key handling
- encryption
- audit/event-stream hashing
3. Integrity Model
aeon.gp.integrity.v1 hashes the document’s final canonical state, not the original source text and not the original write order.
This means two source documents that produce the same covered canonical assignment state must produce the same integrity hash.
Example:
and
must produce the same canonical hash when their covered canonical assignment state is identical.
4. Coverage
The integrity hash covers:
aeon:header- all document body content
- all final effective bindings in the document state
The integrity hash excludes:
aeon:envelope- comments
- annotations
- source whitespace
- transport-level formatting artifacts
- fields excluded by canonical AEON form
5. Envelope Exclusion Rule
If present, aeon:envelope is excluded from hash coverage.
aeon:envelope must be the final binding in the document.
No bindings may follow it.
Only trailing whitespace or comments may appear after it.
6. Canonical Hashing Input
The input to hashing is the UTF-8 serialization of the document’s final canonical assignment state.
This state is produced after AEON Core parsing and canonical rendering rules have been applied.
The canonical hash input consists of one line per final canonical path.
Each line must be serialized as:
Where:
<canonical_path>is the final canonical AEON path<canonical_value>is the canonical AEON value serialization\tis a single U+0009 tab character\nis a single U+000A line feed character
7. Canonical Path Ordering
All emitted lines must be ordered lexicographically by <canonical_path>.
This ordering is applied after final document state resolution.
This means integrity hashing is state-based, not chronology-based.
8. Canonical Value Serialization
Canonical value serialization must follow AEON Core canonical rendering rules.
At minimum, the following normalizations apply.
8.1 Null
8.2 Boolean
8.3 Numbers
Numbers must be serialized in canonical decimal form:
- no exponent notation
- no superfluous leading
+ - no unnecessary trailing zeros
-0must serialize as0
Examples:
8.4 Strings
Strings must be serialized in canonical quoted form with required escaping.
Example:
8.5 Arrays
Arrays must be serialized in canonical compact form using AEON core rules.
Example:
8.6 Objects
Objects must be serialized in canonical compact form using AEON core rules, including canonical key ordering where applicable.
Example:
9. Hash Algorithm Declaration
The hash algorithm must be declared in the envelope.
Example:
Initial recommended algorithm:
Other algorithms may be allowed by profile or convention.
10. Hash Output
The hash value is the digest of the canonical hash input byte stream encoded as UTF-8.
The resulting digest must be represented as an AEON bytes literal unless a selected profile explicitly requires another representation.
Example:
Profiles that require a textual digest representation must define the encoding and comparison rules explicitly.
11. Verification Procedure
To verify an integrity hash, a processor must:
- Parse the AEON document using AEON core rules
- Confirm that
aeon:envelope, if present, is final - Exclude
aeon:envelopefrom coverage - Resolve the document to its final canonical state
- Serialize one line per final canonical path using:
<canonical_path>\t<canonical_value>\n
- Sort lines lexicographically by canonical path
- Encode the full stream as UTF-8
- Compute the declared hash
- Compare with
aeon:envelope.integrity.hash
12. Example
Source document
Final canonical state
Conceptually:
These UTF-8 bytes are hashed.
13. Non-Goals
aeon.gp.integrity.v1 does not preserve:
- source ordering
- write chronology
- event timing
- append history
Those belong to a separate event-log convention.
14. Relationship to Other Security Conventions
aeon.gp.integrity.v1 is the foundation for:
aeon.gp.security.v1— envelope structureaeon.gp.signature.v1— signatures over the integrity hashaeon.gp.encryption.v1— optional encrypted payload structures
It is distinct from possible future conventions for ordered event-sequence integrity, subtree hashing, and proof structures.
15. One-Line Definition
aeon.gp.integrity.v1 defines deterministic state-based hashing of AEON documents by hashing the UTF-8 serialization of the final canonical assignment state, excluding aeon:envelope.