Error Code Registry

AITP error codes returned in error envelopes (AitpError.code). v0.1 is JSON-only; codes are string constants in the canonical JSON wire format (see RFC-AITP-0001 §5.6).

Stability: The codes listed below are stable for v0.1. Implementations MUST treat unknown codes as opaque failures and MUST NOT key behavior off codes that are not in this registry. New codes can be added without an RFC; renaming or removing an existing code is a breaking change and requires the RFC process.

spec_status column. Each code below carries a spec_status of either core or draft. core codes are part of v0.1 conformance and MAY be emitted by any conformant implementation. draft codes are reserved for post-v0.1 RFCs (currently RFC-AITP-0010 Session Trust Bundle and RFC-AITP-0011 Multi-hop Delegation) and MUST NOT be used by v0.1 implementations except when implementing the cited draft RFC. v0.1 conformance runners MUST treat receipt of a draft code from an implementation that does not opt into the corresponding draft as a non-conformance.

Code naming convention

Object-level failures use the <OBJECT>_<FAILURE> form (e.g. MANIFEST_SIGNATURE_INVALID, TCT_EXPIRED, DELEGATION_SCOPE_EXCEEDED). Envelope-level failures use bare codes (e.g. INVALID_SIGNATURE, REPLAY_DETECTED). This granularity is deliberate: a consumer needs to know which object failed, not only that something failed. New codes proposed via the RFC process MUST follow this convention.

Envelope-level codes

CodeMeaningRetryablespec_statusSpec
INVALID_ENVELOPEEnvelope failed schema validation.falsecoreRFC-AITP-0001 §5.6
INVALID_SIGNATURESignature verification failed.falsecoreRFC-AITP-0001 §5.4
REPLAY_DETECTEDDuplicate message_id.falsecoreRFC-AITP-0001 §5.5
TIMESTAMP_EXPIREDTimestamp outside tolerance.truecoreRFC-AITP-0001 §5.5
UNKNOWN_VERSIONUnsupported version field.falsecoreRFC-AITP-0001 §7
IDENTITY_FAILEDIdentity binding could not be verified.falsecoreRFC-AITP-0002
POLICY_VIOLATIONRequested capability not granted.falsecoreRFC-AITP-0004 §4
GRANT_OVERFLOWPeer-issued TCT grants exceed offered_capabilities.falsecoreRFC-AITP-0004
INSUFFICIENT_GRANTSReceived peer-issued TCT lacks a capability listed in the receiver's own required_peer_capabilities.falsecoreRFC-AITP-0004 §5.3/§5.4
KEY_RESOLUTION_FAILEDCould not resolve issuer or peer keys.truecoreRFC-AITP-0007

TCT-verification codes (RFC-AITP-0005)

Returned when a peer evaluates a TCT outside the handshake context — e.g. via a TCT verification API or local verification of a presented TCT.

CodeMeaningRetryablespec_status
TCT_EXPIREDTCT expires_at is in the past.falsecore
TCT_REVOKEDTCT jti is in the issuing peer's deny list.falsecore
TCT_SIGNATURE_INVALIDTCT signature does not validate under the issuing peer's key.falsecore
TCT_EXPIRES_AFTER_MANIFESTTCT expires_at exceeds the issuing peer's Manifest expires_at (RFC-AITP-0004 §4.3). The peer-issued TCT cannot outlive the credential that authenticates its issuer's key.falsecore

Downstream PoP codes (RFC-AITP-0005 §6)

CodeMeaningRetryablespec_status
POP_CHALLENGE_INVALIDChallenge envelope was malformed or stale.falsecore
POP_RESPONSE_INVALIDResponse signature failed verification against binding.cnf.falsecore

Manifest codes (RFC-AITP-0003)

CodeMeaningRetryablespec_status
MANIFEST_EXPIREDexpires_at is in the past.falsecore
MANIFEST_SIGNATURE_INVALIDSignature verification failed.falsecore
MANIFEST_POP_FAILEDProof-of-possession verification failed.falsecore
INCOMPATIBLE_TRUST_ANCHORSNo overlap in accepted trust anchors.falsecore
INCOMPATIBLE_IDENTITY_TYPEPeer's identity.type is not present in the receiver's accepted_identity_types. More specific than INCOMPATIBLE_TRUST_ANCHORS: signals identity-type incompatibility (e.g. pinned_key vs. oidc) rather than trust-anchor incompatibility.falsecore
MANIFEST_VERSION_UNKNOWNversion not supported by this implementation.falsecore

Mutual Handshake codes (RFC-AITP-0004)

Returned in error envelopes during the four-message handshake.

CodeMeaningspec_status
INCOMPATIBLE_TRUST_ANCHORSNo trust-anchor overlap.core
INCOMPATIBLE_IDENTITY_TYPEPeer's identity type not in accepted_identity_types.core
MANIFEST_SIGNATURE_INVALIDPeer's Manifest signature invalid.core
MANIFEST_POP_FAILEDPeer's Manifest PoP failed.core
POP_VERIFICATION_FAILEDRound-2 PoP signature failed.core
NONCE_MISMATCHpop_nonce_echo mismatch.core
AUDIENCE_MISMATCHTCT audience ≠ self AID.core
GRANT_OVERFLOWTCT grants exceed peer's offered_capabilities.core
TCT_EXPIREDTCT already expired.core
TCT_EXPIRES_AFTER_MANIFESTTCT expires_at exceeds issuer's Manifest expires_at.core
IDENTITY_FAILEDPeer identity verification failed.core
REPLAY_DETECTEDDuplicate message_id.core
TIMESTAMP_EXPIREDEnvelope timestamp outside tolerance.core

Manifest-service codes

Returned by an HTTP endpoint serving /.well-known/aitp-manifest or by an out-of-band manifest lookup.

CodeMeaningspec_status
MANIFEST_EXPIREDexpires_at in the past.core
MANIFEST_SIGNATURE_INVALIDSignature verification failed.core
MANIFEST_POP_FAILEDProof-of-possession failed.core
MANIFEST_VERSION_UNKNOWNVersion not supported.core
MANIFEST_NOT_FOUNDNo manifest for the requested AID.core

Delegation codes (RFC-AITP-0006)

Delegation-layer codes carry the DELEGATION_ prefix so they cannot be confused with the envelope-level or manifest-level codes that share the same root.

CodeMeaningspec_status
DELEGATION_AUDIENCE_MISMATCHaudience ≠ issuer_aid.core
DELEGATION_SCOPE_EXCEEDEDscope ⊄ grant_proof.capabilities.core
DELEGATION_INVALID_GRANT_PROOFgrant_proof.signature invalid, or grant_proof.subject ≠ issued_by.core
DELEGATION_SOURCE_TCT_REVOKEDgrant_proof.source_tct_jti is in the issuing peer's deny list.core
DELEGATION_INVALID_SIGNATUREdelegation.signature invalid.core
DELEGATION_EXPIREDToken or grant proof expired.core
DELEGATION_POP_FAILEDProof-of-possession failed.core
DELEGATION_MULTIHOP_NOT_SUPPORTEDMulti-hop attempt detected (v0.1 implementations reject multi-hop tokens).core

DELEGATION_MULTIHOP_NOT_SUPPORTED is a core v0.1 code, not a draft code. v0.1 implementations with default max_hops = 0 MUST emit this code for any delegation token with a non-empty chain field — rejecting multi-hop is the required v0.1 behavior, not an optional one. The code is distinct from the draft codes in the "Multi-hop delegation codes (RFC-AITP-0011, post-v0.1)" table below: those codes (DELEGATION_HOP_LIMIT_EXCEEDED, DELEGATION_CHAIN_HASH_MISMATCH) are emitted by v0.2 implementations that have opted into multi-hop and are validating chain semantics. DELEGATION_MULTIHOP_NOT_SUPPORTED is the v0.1 refusal to even parse the chain — a structural rejection before any per-hop verification. See conformance fixture del-004 for the pinned behavior.

Multi-hop delegation codes (RFC-AITP-0011, post-v0.1)

These codes are reserved for v0.2 multi-hop delegation (RFC-AITP-0011 is currently Draft and not part of v0.1 conformance). Implementations targeting only v0.1 will not emit them.

CodeMeaningspec_status
DELEGATION_HOP_LIMIT_EXCEEDEDChain length exceeds max_delegation_hops (default 3).draft
DELEGATION_CHAIN_HASH_MISMATCHchain_hash does not match the chain array contents (truncation or tampering detected).draft

Session Trust Bundle codes (RFC-AITP-0010, post-v0.1)

These codes are reserved for v0.2 Session Trust Bundles (RFC-AITP-0010 is currently Draft and not part of v0.1 conformance). The granular code set was pinned to align with the aitp-rs adapter that emits them ahead of v0.2 conformance.

CodeMeaningspec_status
BUNDLE_INVALID_SIGNATURECoordinator's outer bundle signature failed verification under the coordinator's Manifest key.draft
BUNDLE_VERSION_MISMATCHversion is not "aitp/0.1" (or a later version this implementation supports).draft
BUNDLE_EXPIREDexpires_at is in the past at verification time.draft
BUNDLE_EXPIRY_WINDOW_INVARIANTexpires_at is greater than min(participants[*].tct.expires_at) (violates RFC-AITP-0010 §6).draft
BUNDLE_COORDINATOR_ISSUER_MISMATCHOne or more participants[*].tct.issuer values do not equal coordinator.draft
BUNDLE_AUDIENCE_MISMATCHA participants[i].tct.audience does not equal participants[i].aid.draft
BUNDLE_EMPTY_PARTICIPANTSparticipants array is empty.draft
BUNDLE_PARTICIPANT_TCT_INVALIDAt least one embedded participant TCT failed standard TCT verification.draft
BUNDLE_NOT_MEMBERReceiver's AID is not in participants[*].aid.draft
SESSION_BUNDLE_INVALIDAggregate fallback — implementations MAY return this when a deployment policy requires a single-error surface for bundles, in lieu of the specific codes above.draft

Adding a code

Open a PR adding a row to one of the tables above. Verifiers MUST NOT reveal which specific policy check failed beyond the registered code; reason strings are informational only.