- Authors: Stephen Curran
- Status: PROPOSED
- Since: 2020-09-30
- Status Note: In step 0 - community is reviewing the proposed approach. Target Completion Date: 2020.12.31
- Supersedes:
- Start Date: 2020-06-07
- Tags: feature, community-update
The Aries community has agreed to transition from using the invitation
messages in RFC 0160 Connections
and RFC 0023 DID Exchange to using the plaintext invitation
message in RFC 0434 Out of Band and from using RFC 0160 to RFC 0023 for establishing agent-to-agent connections.
As well, the community has agreed to transition from using RFC 0056 Service Decorator to execute connection-less instances of the RFC 0037 Present Proof protocol to using the out-of-band invitation message.
This RFC follows the guidance in RFC 0345 about community-coordinated updates to (try to) ensure that independently deployed, interoperable agents remain interoperable throughout this transition.
The transition from the old to new messages will occur in four steps:
- Pre-work: Agent builders agree on the transition plan outlined in this RFC and the target date for completing Step 1.
- Any RFC updates related to this transition needed before starting the transition are completed.
- Step 1: Agent builders update all agent code bases and deployments to accept incoming out-of-band messages requesting equivalent-to-current functionality.
- Equivalent-to-current functionality includes:
- RFC 160 Connections invitations
- Connection-less Present Proof protocol instances using the service decorator
- See the section below on Step 1 out-of-band messages
- During Step 1, all agents should continue to send the current invitation and connection-less protocol messages.
- Each agent builder SHOULD notify the community they have completed Step 1 by submitting a PR to update their entry in the implementations section.
- Equivalent-to-current functionality includes:
- Step 2: Agent builders update all agent code bases and deployments to send out out-of-band invitations equivalent to the current invitation and connection-less protocol messages, and Agent builders add full out-of-band and did-exchange (RFC 0023) protocol support to all agent code bases and deployments.
- Messages from existing RFCs being replaced by the out-of-band protocol are marked as
deprecated
. - Full out-of-band support is NOT required—just support for the out-of-band equivalents of the old
invitation
messages. - Each agent builder SHOULD notify the community they have completed Step 2 by submitting a PR to update their entry in the implementations section.
- Messages from existing RFCs being replaced by the out-of-band protocol are marked as
- Step 3: Support for the current invitation and connection-less protocol messages can be removed from all implementations and deployments, and all out-of-band
invitation
capabilities that align with the then current Aries Interop Profile (AIP) may be offered.
The definition of Step 1 has been deliberately defined to limit the impact of the changes on existing code bases. An implementation may be able to do as little as convert an incoming out-of-band protocol message into its "current format" equivalent and process the message, thus deferring larger changes to the message handling code. The following examples show the equivalence between out-of-band and current messages and the constraints on the out-of-band invitations used in Step 2.
The following is the out-of-band invitation
message equivalent to an RFC 0160 Connections invitation
message that may be used in Step 2.
{
"@type": "https://didcomm.org/out-of-band/1.0/invitation",
"@id": "1234-1234-1234-1234",
"label": "Faber College",
"goal_code": "establish-connection",
"goal": "To establish a connection",
"handshake_protocols": ["did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/connections/1.0/invitation"],
"service": [
{
"id": "#inline"
"type": "did-communication",
"recipientKeys": ["did:key:z6MkpTHR8VNsBxYAAWHut2Geadd9jSwuBV8xRoAnwWsdvktH"],
"routingKeys": [],
"serviceEndpoint": "https://example.com:5000"
}
]
}
The constraints on this form of the out-of-band invitation
sent during Step 2 are:
goal_code
andgoal
are ignored.handshake_protocols
MUST have exactly one entry and that entry must bedid:sov:BzCbsNYhMrjHiqZDTUASHg;spec/connections/1.0/invitation
.request~attach
MUST NOT be present.service
MUST have exactly one entry and be in the form above or be a single DID (but not both).
This out-of-band message can be transformed to the following RFC 0160 Connection invitation
message.
{
"@type": "did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/connections/1.0/invitation",
"@id": "1234-1234-1234-1234",
"label": "Faber College",
"recipientKeys": ["6MkpTHR8VNsBxYAAWHut2Geadd9jSwuBV8xRoAnwWsdvktH"],
"serviceEndpoint": "https://example.com:5000",
"routingKeys": []
}
Note the use of did:key
in the out-of-band message and the "naked" public key in the connection message. Ideally, full support for did:key
will be added during Step 1. However, if there is not time for an agent builder to add full support, the transformation can be accomplished using simple text transformations between the did:key
format and the (only) public key format used in current Aries agents.
If the out-of-band message service
item is a single DID, the resulting transformed message is comparably different. For example, this out-of-band invitation
message:
{
"@type": "https://didcomm.org/out-of-band/%VER/invitation",
"@id": "<id used for context as pthid>",
"label": "Faber College",
"goal_code": "issue-vc",
"goal": "To issue a Faber College Graduate credential",
"handshake_protocols": ["https://didcomm.org/connections/1.0"],
"service": ["did:sov:LjgpST2rjsoxYegQDRm7EL"]
}
The did
form of the connection invitation is implied, as shown here:
{
"@type": "did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/connections/1.0/invitation",
"@id": "1234-1234-1234-1234",
"label": "Faber College",
"did": ["did:sov:LjgpST2rjsoxYegQDRm7EL"]
}
The most common connection-less form being used in production is the request-presentation
message from the RFC 0037 Present Proof protocol. The out-of-band invitation for that request looks like this, using the inline form of the service entry.
{
"@type": "https://didcomm.org/out-of-band/%VER/invitation",
"@id": "1234-1234-1234-1234",
"label": "Faber College",
"goal_code": "present-proof",
"goal": "Request proof of some claims from verified credentials",
"request~attach": [
{
"@id": "request-0",
"mime-type": "application/json",
"data": {
"json": {
"@type": "did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/present-proof/1.0/request-presentation",
"@id": "<uuid-request>",
"comment": "some comment",
"request_presentations~attach": [
{
"@id": "libindy-request-presentation-0",
"mime-type": "application/json",
"data": {
"base64": "<bytes for base64>"
}
}
]
}
}
}
],
"service": [
{
"id": "#inline"
"type": "did-communication",
"recipientKeys": ["did:key:z6MkpTHR8VNsBxYAAWHut2Geadd9jSwuBV8xRoAnwWsdvktH"],
"routingKeys": [],
"serviceEndpoint": "https://example.com:5000"
}
]
}
The constraints on this form of the out-of-band invitation
sent during Step 2 are:
goal_code
is ignored andgoal
is used as thecomment
.handshake_protocols
MUST NOT be present.request~attach
MUST have exactly one entry and that entry must be arequest-presentation
message.service
MUST have exactly one entry and be in the form above or be a single DID (but not both).
This out-of-band message can be transformed to the following RFC 0037 Present Proof request-presentation
message with an RFC 0056 Service Decorator item.
{
"@type": "did:sov:BzCbsNYhMrjHiqZDTUASHg;spec/present-proof/1.0/request-presentation",
"@id": "1234-1234-1234-1234",
"comment": "Request proof of some claims from verified credentials",
"~service": {
"recipientKeys": ["6MkpTHR8VNsBxYAAWHut2Geadd9jSwuBV8xRoAnwWsdvktH"],
"routingKeys": [],
"serviceEndpoint": "https://example.com:5000"
},
"request_presentations~attach": [
{
"@id": "libindy-request-presentation-0",
"mime-type": "application/json",
"data": {
"base64": "<bytes for base64>"
}
}
]
}
If the DID form of the out-of-band invitation
message service
entry was used, the ~service
item would be comparably altered.
During Step 2 URL Shortening as defined in RFC 0434 Out of Band must be supported.
The community coordination triggers between the steps above will be as follows:
- Pre-work to Step 1 - a PR to this RFC is merged that sets the RFC status to ACCEPTED.
- The ACCEPTED version of this RFC is included in a new Aries Interop Profile version.
- Step 1 to Step 2 - the community agrees that the majority of the deployed agents have completed Step 1. A PR to this RFC is merged that sets the RFC status to ADOPTED.
- Agent builders indicate completion of Step 1 by updating the Implementations section of this RFC.
- A PR to RFC 0160 Connections and RFC 0023 DID Exchange marks the
invitation
messages as deprecated. - The ADOPTED version of this RFC is included in the then-current Aries Interop Profile version.
- Step 2 to Step 3 - the community agrees that the majority of the deployed agents have completed Step 2. A PR to this RFC is merged that sets the RFC status to RETIRED.
- Agent builders indicate completion of Step 2 by updating the Implementations section of this RFC.
To enable agent builders to independently update their code bases and deployed agents to support the out-of-band protocol while maintaining interoperability.
The general mechanism for this type of transition is documented in RFC 0345 about community-coordinated updates.
The specific sequence of events to make this particular transition is outlined in the summary section of this RFC.
See the summary section of this RFC for the details of this transition.
None identified.
This approach balances the speed of adoption with the need for independent deployment and interoperability.
The approach outlined in RFC 0345 about community-coordinated updates is a well-known pattern for using deprecation to make breaking changes in an ecosystem. That said, this is the first attempt to use this approach in Aries. Adjustments to the transition plan will be made as needed, and RFC 0345 will be updated based on lessons learned in executing this plan.
- Are the constraints on the proposed "equivalent to existing" messages sufficiently clear?
- Does the community want to support the connection-less
Issue Credential
process to be supported in Step 2?
The following table lists the status of various agent code bases and deployments with respect to the steps of this transition. Agent builders MUST update this table as they complete steps of the transition.
Name / Link | Implementation Notes |
---|
|