Skip to content
This repository has been archived by the owner on Nov 5, 2021. It is now read-only.

Self-sovereign Identity #145

Merged
merged 8 commits into from
Apr 12, 2018
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
158 changes: 158 additions & 0 deletions ideas/145-identity.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,158 @@
# Self-sovereign Identity

## Preamble

Idea: #145
Title: Identity
Status: In Progress
Copy link
Contributor

@oskarth oskarth Apr 10, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems like idea as a whole is still in draft stage, but PoC is in progress? Not sure how we want to reflect this given all the requirements. Might be a good idea to mark it as draft for now (while some research work is still being done) while idea is getting fleshed out.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, the "idea/swarm" is in draft, but the PoC is in progress.
I'll sort out this.

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
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This sounds like a big project. Do you need other technical contributors?
What type of UX and PM support do you need?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Project Manager should help integrate Identity in Status other projects, if any. I could also take the role of PM, but If anyone want to take place.
UX is also about integration of Identity, not sure what to comment about it

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will externalize Recovery development in a new idea.


- 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 a Secret MultiSig with trusted friends addreses; or other recovery method.
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:
- [EIP#725](https://github.com/ethereum/EIPs/issues/725)
- [EIP#735](https://github.com/ethereum/EIPs/issues/735)
- [Fabian Vogelsteller - ERC: Identity - Ethereum London](https://www.youtube.com/watch?v=jv3BmGGFP7c)
- [DEVCON3: ERC Identity](https://www.youtube.com/watch?v=pkwYVagytuA)
- [Jolocom: enabling blockchain agnostic self- sovereign identity - Kai Wagner](https://www.youtube.com/watch?v=vkEdDj5HtVs)
- [Mist: UX insight - Alexande Van de Sande](https://gist.github.com/alexvandesande/434f143fc6d08cb4388479a3d9f527a9)
- [DEVCON1: Digital Identity - Christian Lundkvist](https://www.youtube.com/watch?v=QpaTOvAhLR4)
- [uPort – Usable key management & identity - Rouven Heck and Dr. Christian Lundkvist](https://www.youtube.com/watch?v=qRevDM9D8WE)
- [ConsenSys and uPort: Powering Decentralized Identity](https://www.youtube.com/watch?v=VXAZdBtN3N0)
- [Self-sovereign BigchainDB data injection in smart contracts through the Jolocom Identity Gateway](https://www.youtube.com/watch?v=8K-BDlsx8KQ)
- [IDbox – Cost efficient device for self-sovereign identity](https://www.youtube.com/watch?v=h1Oz3oEtZxE)




### Product Description
<!-- What functionality are you adding? What will this look like from a user perspective? Why is this important? -->

- Smart contracts: See [GDocs Identity Terms Intent](https://docs.google.com/document/d/1K8tFjGneScuKiudpD3HfSpAd4eOe8012jn0Q3iDxEV0/edit#) and [Identity Readme](https://github.com/status-im/contracts/blob/develop/Identity.md)
- 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
<!-- Are there bugs or feature requests in other repositories that are part of this Idea? -->
<!-- There is no approval unless the idea requires to be reviewed by supporting organelles (Financial, Hiring, or Design). -->
<!-- The Swarm must develop a fully fleshed out Requirements document for the idea to proceed, to the satisfaction of participants. -->
- For finalizing this idea ERC725 and ERC735 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<!-- Date for evaluation in ISO 8601 (yyyy-mm-dd) format -->

Description:
- Working contracts system
- Basic UI for direct interaction with blockchain
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What does this mean?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Basic interface, you can use the contract but in a more "manual" way, UX would make this interface more automatic and safer to user.



### Minimal Viable Product
Goal Date: 2018-06-01<!-- Date for evaluation in ISO 8601 (yyyy-mm-dd) format -->
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: <!-- Days required at the end of development for testing -->


### Seamless Status Integration

Goal Date: 2018-06-15<!-- Date for evaluation in ISO 8601 (yyyy-mm-dd) format -->


- 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<!-- Date for evaluation in ISO 8601 (yyyy-mm-dd) format -->


- Recovery: Setup/Update/Cancel Update
- Request recovery to selected "friends".
- Confirm/reject other's recovery request

## Success Metrics
<!-- Assuming the idea ships, what would success look like? What are the most important metrics that you would move? -->

Users opt-in using an Identity to enhance interaction with decetranlize systems (such as Status itself)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can this be phrased more like the example?

Also would be good to mention how this idea supports OKR's

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's about decentralization.


<!-- Example: Onboarding conversion rate. Target >30% full funnel -->

## Exit criteria
<!-- Launch new onboarding UI flow -->
Community consensus in ERC725 and ERC735 interfaces, launched on Status.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can you clarify this further? What community? How is consensus achieved/measured? What form will it launch on Status?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, I will. Community is the ethereum developers.


## Supporting Role Communication
<!-- Once Requirements and Goals are fleshed out, then it should be communicated to supporting organelles if required -->

## Copyright
Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).