Self Sovereign Identity is a lifetime portable identity for any person, organization, or thing that does not depend on any centralized authority and can never be taken away. Self-sovereign identity is a two-party relationship model, with no third party coming between you and the organization, now considered your “peer”.
SSI is possible today with DIDs and Verifiable Credentials.
Verifiable Credential (VC) is the new format for interoperable digital credential being defined by the W3C Verifiable Claims Working Group. Verifiable credentials conform to the W3C’s Verifiable Credentials Data Model, and they facilitate interactions using a pattern called the triangle of trust:
Issuers create credentials, usually by having JSON docs digitally signed in a special way. Holders store them, and verifiers ask for proof based upon them. Verifiable presentations that Holders provide to Verifiers are packages of evidence—either credentials, or data derived from one or more credentials—built by holders to satisfy a verifier’s requirements. Verifiers learn with certainty which issuers have attested something by checking digital signatures against a verifiable data registry (typically, a blockchain).
The set of guidelines and tools in this repository will help you to build mobile identity agents to hold verifiable credentials in a self sovereign identity ecosystem. These identity agents will be compatible with standards such as:
- Trust Over IP
- Hyperledger Aries
- DIDComm
- W3C Verifiable Credentials (UNDER DEVELOPMENT)
- W3C Decentralized Identifiers (UNDER DEVELOPMENT)
These tools depend on the Evernym Consumer Agency SaaS service to act as a communication mediator in the cloud which provides a persistent address for communication and herd anonymity. Access to the Consumer Agency is provided to Evernym customers (see the section "Getting Help").
Evernym provides commercial support to customers. If you would like help from Evernym, please contact us.
Connecting and exchanging encrypted data between an Agency (server side) and an Edge Client (mobile application) consists of several steps and is supported by a secured, encrypted protocol library (VCX).
Going through this tutorial we will create a simple application which will allow us to accept and present verifiable encrypted credentials.
Before starting, please read the Base Concepts document containing explanations for terms that will be frequently used in this guide.
- Create a new App
- Configure application storage
- Initialize Wallet and Cloud Agent on a specific Agency (web server)
- Receive messages from the Cloud Agent
- Establish a connection with another user
- Accept offered credential
- Respond to a proof request
- Exchange secured structured messages
- Handle Connection Invitations with attached messages
- Configuration — The list of all VCX library configuration options.
- New Messages Processing
- Credentials With Attachments
- Push Notifications
- Frequently asked questions
- Advanced Techniques
- Troubleshooting
- Errors — The list of all possible errors and their definitions.
- Developer Guide for MSDK migration from protocol type 3.0 to 4.0
- Verity-SDK Samples - samples can be used for testing of different application use cases.
- React-Native-White-Label-App - React-Native package built using MSDK which allows the quick building of customized digital wallets
- Connect.Me Public Beta — Most of the features of the Evernym Mobile SDK are showcased in Connect.Me. You can use upcoming releases of Connect.Me by clicking the appropriate link from your device.
This effort is part of a project that has received funding from the European Union’s Horizon 2020 research and innovation program under grant agreement No 871932 delivered through our participation in the eSSIF-Lab, which aims to advance the broad adoption of self-sovereign identity for the benefit of all.