aries-cloudagent-python
implements the specifications and protocols that are documented primarily in the aries-rfcs. The following is a curated and generally up to date list of the RFCs that are supported by aries-cloudagent-python
. We try to keep this list up to date, but if you have any questions, please contact us on the #aries channel on Hyperledger Rocketchat or through an issue in this repo. The list is divided into the same two sections as the Aries RFCs-concepts and features. A third section describes some features of the agent that are not yet captured by RFCs, or that are described by Indy HIPEs.
- 0003-protocols
- 0004-agents
- 0005-didcomm
- 0008-message-id-and-threading
- 0011-decorators
- 0017-attachments
- 0020-message-types
- 0046-mediators-and-relays
- 0047-json-LD-compatibility
- 0050-wallets
- 0094-cross-domain messaging
- 0019-encryption-envelope
- In Progress: 0023-did-exchange
- The agent currently supports the Indy-HIPE 0031-connection-protocol protocol. We will be deprecating that (but continuing to use it for existing implementations) and support DID Exchange as well. Note that the only difference between the protocols at this time is the protocol name and the message type names.
- The agent supports DID exchange initiated from both plaintext invitations and public DIDs that enable bypassing the invitation message.
- Note that the did:peer DID Method is not yet supported. We are currently exploring the specification and considering the impact of how the agent will support the specification.
- The 0030-sync-connection protocol is not yet supported, meaning that a pairwise DID, once exchanged, cannot be updated.
- 0035-didcomm-transports
- The agent currently supports HTTP and WebSockets for both inbound and outbound messaging. Transports are pluggable and an agent instance can use multiple inbound and outbound transports.
- 0031-discover-features
- 0032-message-timing
- 0035-report-problem
- Claiming support for this protocol is tricky. The intention of this protocol is that it define a standard mechanism for handling errors in executing a protocol. However, the error handling is in the context of each protocol. Thus, while this protocol is technically supported in the agent, it is adopted by each protocol and thus it's handling is specific to each protocol.
- In Progress 0036-issue-credential - see PR #60
- The agent (along with a number of other agents in the community) currently supports Version 0.1 of this protocol. This protocol will be deprecated when support for RFC 0036 is added.
- To Be Implemented 0037-present-proof
- The agent (along with a number of other agents in the community) currently supports Version 0.1 of this protocol. This protocol will be deprecated when support for RFC 0037 is added.
- Work is just starting (as of the time of this update) on implementing RFC 0037 and should be completed before any other agent supports it. Should anyone need support for this now, we'll up the priority of this work.
- 0048-trust-ping
- 0067-didcomm-diddoc-conventions
- 0092-transport-return-route
- Support for this RFC makes ACA-Py a great candidate to be the persistent endpoint cloud agent for a mobile agent.
- 0095-basic-message
- An Adminstrative API is core to the functionality of the ACA-Py implementation. The Administrative API is extended by each protocol deployed in an instance of ACA-Py. Each protocol provides a set of HTTP JSON requests to control the use of the protocol. With the Adminstrative API, a controller application can initiate instances of protocols (for example, issuing a credential) and can respond to events triggered by protocols started by other agents and protocols that are in flight.
- Protocol events are triggered as messages are received from other agents. The events are sent using a webhook mechanism to a controller for the ACA-Py agent instance. The controller is expected to handle the event, potentially responding by sending a request to the Administrative API.
- Action Menu is a protocol to enable a simple request/response mechanism between agents. We anticipate using the mechanism to enable (for example) an enterprise agent to send a list of actions to a connected agent used by a person. From the menu, the person can select an action (possibly with a text parameter), triggering the enterprise agent to take some action. Think of it like an Interactive Voice Response (IVR) system used in automated call handling system. Just not as annoying.
- An Aries RFC for Action Menu will be introduced Real Soon Now.