swarms/ideas/145-identity.md
Ricardo Guilherme Schmidt 20790723cd lint
2018-04-12 10:39:13 +08:00

6.8 KiB
Raw Blame History

Self-sovereign Identity

Preamble

Idea: 145-identity
Title: Self-sovereign Identity
Status: In Progress 
Created: 2018-05-04
Requires: 150-gas-abstraction 151-ens-usernames 152-friends-recovery 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:

  1. Verification of personal information is required for each single sign on service.
  2. Services usually require trusting your personal information to multiple companies, which may collect it.
  3. Some services require payment credentials to be stored in their database, which might be abused.
  4. Recovering lost/compromised Identity requires an authorithy, which might be censored/abused.
  5. 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:

  1. Verified claims over Identity could be required by services.
  2. Personal data is held by Identity owner
  3. Payment system is done by payment authorizations made by Identity owner.
  4. Recovering lost/compromised Identity is done by recovery smart contracts, such as 152-friends-recover .
  5. 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:

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 Management: User may setup keys & recovery options for its identity, confirm claims and even update the contract code.

Requirements & Dependencies

  • ERC725 and ERC735 should be approved as standard and used in contracts interface, this swarm might influence how this standards end up defined, this is important for the solution working better with unknown future applications.

  • Idea #150-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.

  • Idea #151-ens-usernames is important as a shortcut for user's identity address, otherwise QR-Codes or big hexadecimal strings would be needed.

  • Idea 152-friends-recovery is important to provide a first recovery contract option that uses friends to recover.

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
    • Select a recovery contract

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

Fully integrated on Status App.

Supporting Role Communication

Copyright and related rights waived via CC0.