Adding
Decentralized IDs
and
User-Owned Storage
to a
React App
Friedger Müffke
Dev Day 2019
Berlin, 25 May 2019
slides.com/friedger/devday19-berlin/live
Friedger Müffke
PhD in Bristol, UK
Android/Web Developer
data:image/s3,"s3://crabby-images/bf8ff/bf8ff33fabf82706005b9e304dd18b3b7bb650cd" alt=""
friedger.id
@friedger
@social.nasqueron.org
@fmdroid@twitter
Engineering Partner
Blockstack
Founder Droidcon
Founder OpenIntents
1960
2020
2000
1980
2040
Mainframe era
IBM
Decentralized era
Blockstack ?
Cloud era
Google
Desktop era
Microsoft
Next Era in Computing
data:image/s3,"s3://crabby-images/34d46/34d46d4967da573dc708966ae8ebc4dd71894383" alt=""
data:image/s3,"s3://crabby-images/3f30d/3f30d3ca41e3a49ff8c881c0c85a25438e912e07" alt=""
All About
Data
Become a User
- Use decentralized app (app.co)
- Share your experience
Open source!
Contribute and get rewarded!
data:image/s3,"s3://crabby-images/0306f/0306ff3c3e714a0bf25c9b262c2a3e19d030cda1" alt=""
Decentralized Applications
Components
data:image/s3,"s3://crabby-images/9e706/9e7069ded817a68ddc822497eb1d990a232cd54d" alt=""
data:image/s3,"s3://crabby-images/c979e/c979ee425b01d98419d8a5a6244c7561070d6d65" alt=""
data:image/s3,"s3://crabby-images/89bea/89beae1c1435a62f722bc22e16887fdc3902e1f8" alt=""
Decentralized Applications
Verticals
data:image/s3,"s3://crabby-images/958e4/958e4e393120390c53b3edb83278a805023856c6" alt=""
data:image/s3,"s3://crabby-images/92a4a/92a4a671e86c0fadb3fccd0362b81b27cb61e0a6" alt=""
data:image/s3,"s3://crabby-images/47a65/47a65eea2b97fc4aad80478d8d475ce8563ff3b2" alt=""
Decentralized Applications
Components
data:image/s3,"s3://crabby-images/9e706/9e7069ded817a68ddc822497eb1d990a232cd54d" alt=""
data:image/s3,"s3://crabby-images/c979e/c979ee425b01d98419d8a5a6244c7561070d6d65" alt=""
data:image/s3,"s3://crabby-images/89bea/89beae1c1435a62f722bc22e16887fdc3902e1f8" alt=""
Decentralized Identity
data:image/s3,"s3://crabby-images/9e706/9e7069ded817a68ddc822497eb1d990a232cd54d" alt=""
You
You to Carol as sibling
You to PwC as employee
You to Germany as citizen
You to Bob as friend
Relationships
You
Your facts of birth
Your credit history
Your health records
Your education
Attributes
You
Your cloud service
Your mobile device
Your lawyer
Your broker
Agents
You
Relationships
Attributes
Agents
You are all
of these
Decentralized Identity
- Self-sovereign
- Cryptographically verifiable
- Person vs. profiles
- No more passwords, no more social logins
- W3C working group
- 27 identity provider methods
did:example:123456789abcdefghi
data:image/s3,"s3://crabby-images/9e706/9e7069ded817a68ddc822497eb1d990a232cd54d" alt=""
App
App
App
Authenticator
Network
Decentralized Identifier
Login Request
data:image/s3,"s3://crabby-images/fa481/fa48114c94772ebbe9e191591d66ea48a0c44167" alt=""
© microsoft.com/ownyouridentity
blockstack.org/install
browser.blockstack.org
data:image/s3,"s3://crabby-images/163dc/163dc1758a749b3aa4df2835dd16e463bdef19d5" alt=""
Create Blockstack ID
data:image/s3,"s3://crabby-images/f49ba/f49bac41c4defa41cb4bc15451b4c1c1e491a8a8" alt=""
Create Blockstack ID
data:image/s3,"s3://crabby-images/51574/51574c38d7d441c96ee17063f94796c703309c2f" alt=""
Protect Blockstack ID
data:image/s3,"s3://crabby-images/42ba6/42ba6e4073d76ac6abf08a3c3ceed3932ead5698" alt=""
Recover Blockstack ID
data:image/s3,"s3://crabby-images/562c4/562c496ae4568003b1799f95caba04fcbd5d528e" alt=""
Use Blockstack ID
data:image/s3,"s3://crabby-images/d4da3/d4da36ac2dcd77ece1af772310d86489eccc479c" alt=""
Sign In
data:image/s3,"s3://crabby-images/a5099/a5099e66e22df2852aab5fe150f3d3f89e990d29" alt=""
data:image/s3,"s3://crabby-images/3af29/3af29ee1f2329e190387c16e7025b21ed5473ee6" alt=""
Define your App Configuration:
- Scope
- App domain
- Redirect path
- Manifest path
Sign In
yarn add blockstack
import {UserSession} from 'blockstack' const userSession = new UserSession()
Provide a sign in button
data:image/s3,"s3://crabby-images/b3079/b30794426c3864894f7c3568b2a460d0f87e6762" alt=""
Sign In
document.getElementById('signin').onclick = () => { userSession.redirectToSignIn() }
And call redirectToSignIn()
data:image/s3,"s3://crabby-images/9ea61/9ea615cb9cbb7dbad1adedfdd0fc6b867b71faa9" alt=""
- The domain name your app is served from.
- The permissions and data your app is requesting.
- Your app's name.
- Your app's logo.
Sign In
Sign In
// Check for the auth response token in the URL,
// provided by the browser redirect.
if (userSession.isSignInPending()) {
// Decodes the token and retrieves user data.
userSession.handlePendingSignIn()
.then((userData) => {
// Refresh main page once signed in.
window.location = window.origin }) }
Sign In
if (userSession.isSignInPending()) {
...
} else if (userSession.isUserSignedIn()) {
var userData = userSession.loadUserData()
// Do something with user profile data..
showProfile(userData.profile)
}
Sign In
{
"username": "matt.id",
"profile": {
"name": "Matthew Little",
"image": [{
"name": "avatar",
"contentUrl": "https://gaia-matt.com/1159ZPz88pypemHP84SMacuJWa3XmFSKcv/avatar.png"
}]
},
"email": "matthew@blockstack.com",
"decentralizedID": "did:stack:1159ZPz88pypemHP84SMacuJWa3XmFSKcv",
"hubUrl": "https://gaia-matt.digitaloceanspaces.com/1QHGBN4d2WtnHgEFhsMpAqcJAL2Sy76zoK/",
"appPrivateKey": "6660d3ce7f79038aa5cadb7305897d9a20cfd95ed764c28bd3ffd2618c610553"
}
Example User Data
Sign In
{
"username": "matt.id",
"profile": {
"name": "Matthew Little",
"image": [{
"name": "avatar",
"contentUrl": "https://gaia-matt.example.com/1159ZPz88pypemHP84SMacuJWa3XmFSKcv/avatar.png"
}]
},
"email": "matthew@blockstack.com",
"decentralizedID": "did:stack:1159ZPz88pypemHP84SMacuJWa3XmFSKcv",
"hubUrl": "https://gaia-matt.digitaloceanspaces.com/1QHGBN4d2WtnHgEFhsMpAqcJAL2Sy76zoK/",
"appPrivateKey": "6660d3ce7f79038aa5cadb7305897d9a20cfd95ed764c28bd3ffd2618c610553"
}
Example User Data
App Key Generation
data:image/s3,"s3://crabby-images/adf72/adf72d9adeedff53a982138560d9e571efa19783" alt=""
© Cogarius, Brussels
data:image/s3,"s3://crabby-images/65176/65176dcab326cd6851fca76974095aa7023102cb" alt=""
data:image/s3,"s3://crabby-images/a555b/a555bad7c05364bc569518b7271d6c632bf7eab5" alt=""
data:image/s3,"s3://crabby-images/5faef/5faef679cec7ca3e4ecaa1905f52116118526e27" alt=""
More APIs
None for private key so far
Decentralized Storage
data:image/s3,"s3://crabby-images/89bea/89beae1c1435a62f722bc22e16887fdc3902e1f8" alt=""
Decentralized Storage
- Diversity in locations
- Distributed vs. self-controlled
Server-less apps
User based (S3, Azure,..)
Content based (IPFS, Storj, SSB, ..)
Address based (Gaia)
data:image/s3,"s3://crabby-images/89bea/89beae1c1435a62f722bc22e16887fdc3902e1f8" alt=""
Gaia Storage
data:image/s3,"s3://crabby-images/8595c/8595cf38b78bf2603c372ffeaea1742d7dbb7843" alt=""
Address-based access protocol
Apps for My Data
data:image/s3,"s3://crabby-images/702b4/702b465ec57cf3bcc8a63ac589c6a4866c3e8485" alt=""
data:image/s3,"s3://crabby-images/074ae/074aebd84e3ba32e42648bbb887f25353dc3dbb4" alt=""
data:image/s3,"s3://crabby-images/2f8e2/2f8e2f6b52f8fa07d307ffec4935f4a9221b2972" alt=""
My storage
Alice's storage
Apps for My Data
data:image/s3,"s3://crabby-images/702b4/702b465ec57cf3bcc8a63ac589c6a4866c3e8485" alt=""
data:image/s3,"s3://crabby-images/074ae/074aebd84e3ba32e42648bbb887f25353dc3dbb4" alt=""
data:image/s3,"s3://crabby-images/2f8e2/2f8e2f6b52f8fa07d307ffec4935f4a9221b2972" alt=""
My storage
data:image/s3,"s3://crabby-images/302aa/302aa7c1f5dde7d1a3645bdd26cac8fd421bf96d" alt=""
Write data
var statusMsg = 'Hello! 🚀' userSession.putFile('status.txt', statusMsg) .then(() => { console.log('file updated!') })
Gaia Storage
Read data
userSession.getFile('status.txt') .then((statusMsg) => { console.log('Status: ' + statusMsg) })
Gaia Storage
Console > Status: Hello! 🚀
Sharing Data/Multi-user apps
"apps": {
"https://app.graphitedocs.com": "https://gaia-matt.com/1QHGBN4d2WtnHgEFhsMpAqcJAL2Sy76zoK/",
"https://helloblockstack.com": "https://gaia-matt.com/1KBU9qxDg8xMgyFdwiVDGU4RZr16Z7TB2S/"
}
Gaia Storage
publish_data
scope in AppConfig:
Sharing Data/Multi-user apps
// Upload unencrypted, public file (logged in as friedger.id)
var options = { encrypt: false }
var statusMsg = 'Hello! 🚀'
userSession.putFile('status.txt', statusMsg, options).then(() => {
console.log('uploaded publicly accessible file!')
})
Gaia Storage
Sharing Data/Multi-user apps
// Get file for specific user (logged in as alice.id)
var options = {
username: 'friedger.id',
decrypt: false
}
userSession.getFile('status.txt', options).then((msg) => {
console.log(`Got status for ${options.username}: ${msg}`)
})
Gaia Storage
Sharing Data/Multi-user apps
// Upload unencrypted, public file (logged in as friedger.id)
var options = { encrypt: false }
var statusMsg = userSession.encryptContent('Hello! 🚀',
{ publicKey: alicePubKey })
userSession.putFile('status.txt', statusMsg, options).then(() => {
console.log('uploaded publicly accessible file!')
})
Gaia Storage
Sharing Data/Multi-user apps
// Get file for specific user (logged in as alice.id)
var options = {
username: 'friedger.id',
decrypt: false
}
userSession.getFile('status.txt', options).then((encMsg) => {
var msg = userSession.decryptContent(encMsg,
{ privateKey: myPrivKey})
console.log(`Got status for ${options.username}: ${msg}`)
})
Gaia Storage
data:image/s3,"s3://crabby-images/a30c5/a30c5e97e5a0504a9578afffe96c9c2e56853327" alt=""
Indexer
Data Flow
data:image/s3,"s3://crabby-images/b5168/b5168835b66a4a4b7d8c394df4f1e3ee88a5c557" alt=""
Share document privately
OI Calendar
cal.openintents.org
react-redux CRUD + bigcalendar
https://github.com/yasnaraj/react-calendar-events-example
data:image/s3,"s3://crabby-images/5486c/5486c0e150954e69fb2c085aa8308b9611f31804" alt=""
Add Auth Reducer
data:image/s3,"s3://crabby-images/21cc5/21cc53a3a0ce77f933e7db759602abe4b51b73d0" alt=""
data:image/s3,"s3://crabby-images/133dd/133dd27358cc8398e17883695c1c85e05b115980" alt=""
Update Event Reducer
Developer Tools
- Authentication
- Storage (Gaia)
- Files
- Collections
- Encryption
- In-app payment
Javascript
Android, iOS, React Native
Gatsby starter library
yeoman generator-blockstack
Client side
Developer Tools
Infrastructure
blockstack-core
gaia
Integrations
omniauth-blockstack
blockstack-ruby
Server side
App Mining
data:image/s3,"s3://crabby-images/99d8a/99d8ad2b877f5e101f7765239c1c5307756a5d59" alt=""
The better the app,
the more you earn.
- app.co/mining
- Monthly rating
- Monthly payout
currently: $100k
App Reviewers
- Product Hunt: Innovation
- TryMyUI: Usability
- New Internet Labs: Good Citizenship
- Awario: Awareness
Ranking
data:image/s3,"s3://crabby-images/c7c5b/c7c5b7ee27001ae53bb04f03a7c5b0dee4e4e9ce" alt=""
Rewards
data:image/s3,"s3://crabby-images/065ae/065aecbc692b9ac4c5f3f01ef76bb86bdcc1906f" alt=""
Review the reviewers
data:image/s3,"s3://crabby-images/fc92d/fc92dc628543a851ff3940d0b98e045c4f8cc80f" alt=""
Future
- Bigger monthly payout
- Long-tail
- Payout in STX
(mining reward distribution)
data:image/s3,"s3://crabby-images/62926/62926ab3190d6f0d4cc43a06a98c83ab9dbcdebe" alt=""
Hackathon
Adding Decentralized IDs and User-Owned Storage to a React App
By friedger
Adding Decentralized IDs and User-Owned Storage to a React App
DevDay 2019
- 1,236