7.0 KiB
Self-sovereign Identity
Preamble
Idea: #145-identity
Title: Identity
Status: In Progress
Created: 2018-05-04
Requires: #27 #73 ERC725 ERC735
Summary
Creates a common user-owned credentials for authentication on smart contracts and for enhancing users security with multisig and optional recovery.
Swarm Participants
- Lead Contributor: @3esmit
- Contributor: @richard-ramos
- UX (Etherum Foundation/Mist): @alexvandesande
- Testing & Evaluation: (help needed)
- PM: (help needed)
- UX (Status): (help needed)
Product Overview
Self sovereign identity can disrupt single sign on services by using blockchain ledger, smart contracts and encryption techniques.
Traditional sign-in:
- Verification of personal information is required for each single sign on service.
- Services usually require trusting your personal information to multiple companies, which may collect it.
- Some services require payment credentials to be stored in their database, which might be abused.
- Recovering lost/compromised Identity requires an authorithy, which might be censored/abused.
- Access to your Identity is available as long as service decides.
In traditional services you can get conforted by having an authority taking care of your data, which not only control your access to it, but also can read it (and sell it).
Self-sovereign identity sign-in:
- Verified claims over Identity could be required by services.
- Personal data is held by Identity owner
- Payment system is done by payment authorizations made by Identity owner.
- Recovering lost/compromised Identity is done by recovery smart contracts, such a Secret MultiSig with trusted friends addreses; or other recovery method.
- Access to Identity is available as long as owner decides.
In self-sovering identity its owner have full resposability over its safety, but also have full control of their Identity.
Fundamental terms:
- ID Manager (owner) can define MultiSig public keys required for its management/actions;
- ID Manager (owner) can define a Recovery contract;
- ID Manager (owner) can define public keys for other; users knowing how to encrypt data for identity owner;
- ID Manager (owner) can accept claims;
- ID Manager (owner) can make claims.
Status Use Case:
From user perspective, instead of talking to obscure address/contracts, users would able to confirm that a person is whom they expect to be interacting. Mainly because they usually know by community network who is the Identity holder and can safely assume is the right person.
This is important for chat system, where Identities provide the right key for others messaging, and Identity owners can always update this keys as they want.
Recovery contract, if safely defined, will garantee that Identity owner is able to get back their Identity from loss or theft, therefore no need to create a new one and ask friends to update their contact list with your new Identity.
External references:
- EIP#725
- EIP#735
- Fabian Vogelsteller - ERC: Identity - Ethereum London
- DEVCON3: ERC Identity
- Jolocom: enabling blockchain agnostic self- sovereign identity - Kai Wagner
- Mist: UX insight - Alexande Van de Sande
- DEVCON1: Digital Identity - Christian Lundkvist
- uPort – Usable key management & identity - Rouven Heck and Dr. Christian Lundkvist
- ConsenSys and uPort: Powering Decentralized Identity
- Self-sovereign BigchainDB data injection in smart contracts through the Jolocom Identity Gateway
- IDbox – Cost efficient device for self-sovereign identity
Product Description
- Smart contracts: See GDocs Identity Terms Intent and Identity Readme
- Basic contracts demo: Helps engaging developers and bug hunting.
- Identity Sign-in: Actions for user creating or recovering their wallets.
- Identity Usage: User may select their Identity to make tansactions in behalf of.
- Identity Friend's "Recover Help" Request: User is able to confirm executions when asked by someone from their contact list.
- Identity Management: User may setup keys & recovery options for its identity, confirm claims and even update the contract code.
Requirements & Dependencies
-
ERC#725 and ERC#735 should be approved as standard, this swarm might influence how this standards end up defined, this is important for the solution working better with unknown future applications.
-
#27 ENS subdomain registry is important as a shortcut for user's identity address, otherwise QR-Codes or big hexadecimal strings would be needed.
-
#73 Gas abstraction enables users to only use SNT* for everything in ethereum, or any other token/ether hold by Identity. *Only SNT can be used to gas relay deploy of Identity, after that user is free to choice.
Dates
Proof-of-concept
Goal Date: 2018-05-15
Description:
- Working contracts system
- Basic UI for direct interaction with blockchain
Minimal Viable Product
Goal Date: 2018-06-01
Description:
- Status Wallet enables creation, association or recovery of Identity
- Status Wallet enables transactions to be executed by Identity
- Identity management (basic)
Testing Days required:
Seamless Status Integration
Goal Date: 2018-06-15
- Identity Sign-in:
- Create new;
- Reconfigure existing;
- Identity Usage:
- Interact with other contracts in behalf of Identity;
- Sign claims about others Identity.
- Identity Management
- Keys: Add/Remove/Update
- Accept Claims
- Update of Kernel
Recovery Support
Goal Date: 2018-07-01
- Recovery: Setup/Update/Cancel Update
- Request recovery to selected "friends".
- Confirm/reject other's recovery request
Success Metrics
Status Users opt-in using an Identity to enhance interaction with decetralize systems (such as Status itself). Developers start using Status Identity implementation as base. New users adopt Status because Identity support, which will be required for many dapps in future.
Exit criteria
Ethereum Foundation approval of ERC#725 and ERC#735 standard interfaces. Fully integrated on Status App.
Supporting Role Communication
Copyright
Copyright and related rights waived via CC0.