SlideShare una empresa de Scribd logo
1 de 45
Descargar para leer sin conexión
MozfestDecentralised
David Dias & Pedro Teixeira
Using IPFS, Y.js a Browser and some JavaScript
Decentralised collaborative
documents
a.k.a. Building Google Docs without
the “Google”
MozfestDecentralised
Warning
This is going to envolve some coding.
Probably pairing up!
MozfestDecentralised
Agenda
• Grouping
• Motivation for Decentralising Web Apps
• Goal
• Setup
• Code! (30 mins)
• Discussion: Decentralised Web Apps
• Quick Announcement
MozfestDecentralised
Motivation
Cloud-based software has taken the web a long way,
but lead us into centralisation.
DNS
a.com 30.30.30.30
b.com 40.40.40.40
c.com 50.50.50.50
cvs/svn
cvs/svn
cvs/svn
MozfestDecentralised
Goal
Create a
decentralised collaborative web-based real-time
Flipchart application
MozfestDecentralised
Materials
• Modern Browser
• JavaScript
• IPFS (js-ipfs)
• CRDT
• Code Editor
• Command line
MozfestDecentralised
Setup:

Install Node.js
MozfestDecentralised
Setup:

Download code
• Through git:
• or download zip file from
http://bit.ly/2xsCJfP
MozfestDecentralised
Setup:

Install dependencies
MozfestDecentralised
Setup:

Build and watch
MozfestDecentralised
Setup:

Start HTTP server
MozfestDecentralised
Setup:

Test flipchart app
MozfestDecentralised
MozfestDecentralised
The source
code
Open a code editor and take a peek
at
src/index.js
MozfestDecentralised
Add 1 IPFS
Let’s create an IPFS node
inside the browser app.
MozfestDecentralised
Wait for
IPFS to start
…by handling the IPFS
“start” event.
MozfestDecentralised
Print IPFS status
and IPFS Peer ID
MozfestDecentralised
• Content-addressable storage
• DAG formed by cryptographically
secure links
• Pub-sub network
• Naming (IPNS)
• Multi-transport
• Multi-discovery
• Multi-*
• Community-driven open-source
• Go, JS and more!
• Future-proof
MozfestDecentralised
Offline-first, real-time,
shared editing for data
structures
MozfestDecentralised
MozfestDecentralised
Add 1 CRDT
Let’s replace direct manipulation of
the line array with an array of lines.
Each line is (still) an array of points.
MozfestDecentralised
Y.js
step 1
Import Y.js dependencies
MozfestDecentralised
Y.js
step 2
Initialise Y.js
MozfestDecentralised
Y.js
step 3
Routine to draw a line
from a Y.js array
MozfestDecentralised
Y.js
step 4
Listen for changes in
drawing and act.
MozfestDecentralised
Y.js
step 5
Draw pre-existing lines
MozfestDecentralised
Y.js
step 6
Create new line on drag
MozfestDecentralised
Y.js
step 7
When user drags,
add points to
current line
MozfestDecentralised
Y.js
step 8
When user clears,
remove all lines
from CRDT
MozfestDecentralised
MozfestDecentralised
Under
the
hood
MozfestDecentralised
Homework
Challenge
• Allow user to take a snapshot
• Save the snapshot to IPFS
MozfestDecentralised
CRDTs
CRDTs will be the building block of
decentralised collaborative
applications.
This type of data structures allows
building conflict-free offline-first
reliable decentralised apps.
MozfestDecentralised
Discussion
CRDTs allow you to build a
decentralised collaborative store.
What other building blocks will be
necessary to build DApps?
• Identity
• Authentication
• Access Control
• Privacy
• Files
• non-local Key/Object
store
• Messaging
• … ?
MozfestDecentralised
PeerPad
PeerPad is a real-time collaborative
editing tool, powered by IPFS and
CRDTs.
https://peerpad.net
MozfestDecentralised

Más contenido relacionado

La actualidad más candente

La actualidad más candente (6)

.NET Core Previews - New Features in .NET Core and ASP.NET Core 2.1, Blazor a...
.NET Core Previews - New Features in .NET Core and ASP.NET Core 2.1, Blazor a....NET Core Previews - New Features in .NET Core and ASP.NET Core 2.1, Blazor a...
.NET Core Previews - New Features in .NET Core and ASP.NET Core 2.1, Blazor a...
 
Node.js In The Enterprise - A Primer
Node.js In The Enterprise - A PrimerNode.js In The Enterprise - A Primer
Node.js In The Enterprise - A Primer
 
TechDays 2015 The Azure Sightseeing Tour
TechDays 2015 The Azure Sightseeing TourTechDays 2015 The Azure Sightseeing Tour
TechDays 2015 The Azure Sightseeing Tour
 
Node.js for beginner
Node.js for beginnerNode.js for beginner
Node.js for beginner
 
Node.js - JavaScript Chicago Meetup
Node.js - JavaScript Chicago MeetupNode.js - JavaScript Chicago Meetup
Node.js - JavaScript Chicago Meetup
 
NodeJS Presentation
NodeJS PresentationNodeJS Presentation
NodeJS Presentation
 

Similar a Building Decentralised Realtime Collaborative Applications - Building Google Docs without Google

Similar a Building Decentralised Realtime Collaborative Applications - Building Google Docs without Google (20)

Introduction to node.js by jiban
Introduction to node.js by jibanIntroduction to node.js by jiban
Introduction to node.js by jiban
 
Sugarcoating your frontend one ViewModel at a time
Sugarcoating your frontend one ViewModel at a timeSugarcoating your frontend one ViewModel at a time
Sugarcoating your frontend one ViewModel at a time
 
Node.js for .NET Developers
Node.js for .NET DevelopersNode.js for .NET Developers
Node.js for .NET Developers
 
Intro to Node.js (for .NET Developers)
Intro to Node.js (for .NET Developers)Intro to Node.js (for .NET Developers)
Intro to Node.js (for .NET Developers)
 
Node js
Node jsNode js
Node js
 
Nodejs overview
Nodejs overviewNodejs overview
Nodejs overview
 
Node.js Crash Course
Node.js Crash CourseNode.js Crash Course
Node.js Crash Course
 
Introduction to Node.js
Introduction to Node.jsIntroduction to Node.js
Introduction to Node.js
 
Mini-Training: Node.js
Mini-Training: Node.jsMini-Training: Node.js
Mini-Training: Node.js
 
ReactJS.NET - Fast and Scalable Single Page Applications
ReactJS.NET - Fast and Scalable Single Page ApplicationsReactJS.NET - Fast and Scalable Single Page Applications
ReactJS.NET - Fast and Scalable Single Page Applications
 
Definitive Guide to Powerful Nodejs Development.pptx
Definitive Guide to Powerful Nodejs Development.pptxDefinitive Guide to Powerful Nodejs Development.pptx
Definitive Guide to Powerful Nodejs Development.pptx
 
Going offline with JS (DDD Sydney)
Going offline with JS (DDD Sydney)Going offline with JS (DDD Sydney)
Going offline with JS (DDD Sydney)
 
Node.js by Alex and Nalin
Node.js by Alex and NalinNode.js by Alex and Nalin
Node.js by Alex and Nalin
 
Production Ready Vue Apps With Nuxt.js
Production Ready Vue Apps With Nuxt.jsProduction Ready Vue Apps With Nuxt.js
Production Ready Vue Apps With Nuxt.js
 
Varna conf nodejs-oss-microsoft-azure[final]
Varna conf nodejs-oss-microsoft-azure[final]Varna conf nodejs-oss-microsoft-azure[final]
Varna conf nodejs-oss-microsoft-azure[final]
 
20120802 timisoara
20120802 timisoara20120802 timisoara
20120802 timisoara
 
Node
NodeNode
Node
 
Top 10 frameworks of node js
Top 10 frameworks of node jsTop 10 frameworks of node js
Top 10 frameworks of node js
 
Develop & Deploy Node.js app on Windows Azure
Develop & Deploy Node.js app on Windows AzureDevelop & Deploy Node.js app on Windows Azure
Develop & Deploy Node.js app on Windows Azure
 
You know what iMEAN? Using MEAN stack for application dev on Informix
You know what iMEAN? Using MEAN stack for application dev on InformixYou know what iMEAN? Using MEAN stack for application dev on Informix
You know what iMEAN? Using MEAN stack for application dev on Informix
 

Más de Pedro Teixeira

How to build a reliable checkout experience
How to build a reliable checkout experienceHow to build a reliable checkout experience
How to build a reliable checkout experience
Pedro Teixeira
 
Node.js a-deep-dive 2-final
Node.js a-deep-dive 2-finalNode.js a-deep-dive 2-final
Node.js a-deep-dive 2-final
Pedro Teixeira
 

Más de Pedro Teixeira (6)

Offline-first: Making your app resilient to network failures
Offline-first: Making your app resilient to network failuresOffline-first: Making your app resilient to network failures
Offline-first: Making your app resilient to network failures
 
How to build a reliable checkout experience
How to build a reliable checkout experienceHow to build a reliable checkout experience
How to build a reliable checkout experience
 
How to build a reliable checkout experience
How to build a reliable checkout experienceHow to build a reliable checkout experience
How to build a reliable checkout experience
 
Document-Driven transactions
Document-Driven transactionsDocument-Driven transactions
Document-Driven transactions
 
Node Anti-Patterns and Bad Practices
Node Anti-Patterns and Bad PracticesNode Anti-Patterns and Bad Practices
Node Anti-Patterns and Bad Practices
 
Node.js a-deep-dive 2-final
Node.js a-deep-dive 2-finalNode.js a-deep-dive 2-final
Node.js a-deep-dive 2-final
 

Último

VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
dharasingh5698
 
AKTU Computer Networks notes --- Unit 3.pdf
AKTU Computer Networks notes ---  Unit 3.pdfAKTU Computer Networks notes ---  Unit 3.pdf
AKTU Computer Networks notes --- Unit 3.pdf
ankushspencer015
 
result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college project
Tonystark477637
 
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Christo Ananth
 

Último (20)

UNIT-III FMM. DIMENSIONAL ANALYSIS
UNIT-III FMM.        DIMENSIONAL ANALYSISUNIT-III FMM.        DIMENSIONAL ANALYSIS
UNIT-III FMM. DIMENSIONAL ANALYSIS
 
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur EscortsCall Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
Call Girls in Nagpur Suman Call 7001035870 Meet With Nagpur Escorts
 
MANUFACTURING PROCESS-II UNIT-2 LATHE MACHINE
MANUFACTURING PROCESS-II UNIT-2 LATHE MACHINEMANUFACTURING PROCESS-II UNIT-2 LATHE MACHINE
MANUFACTURING PROCESS-II UNIT-2 LATHE MACHINE
 
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 BookingVIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
VIP Call Girls Ankleshwar 7001035870 Whatsapp Number, 24/07 Booking
 
AKTU Computer Networks notes --- Unit 3.pdf
AKTU Computer Networks notes ---  Unit 3.pdfAKTU Computer Networks notes ---  Unit 3.pdf
AKTU Computer Networks notes --- Unit 3.pdf
 
result management system report for college project
result management system report for college projectresult management system report for college project
result management system report for college project
 
Introduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptxIntroduction and different types of Ethernet.pptx
Introduction and different types of Ethernet.pptx
 
ONLINE FOOD ORDER SYSTEM PROJECT REPORT.pdf
ONLINE FOOD ORDER SYSTEM PROJECT REPORT.pdfONLINE FOOD ORDER SYSTEM PROJECT REPORT.pdf
ONLINE FOOD ORDER SYSTEM PROJECT REPORT.pdf
 
High Profile Call Girls Nagpur Isha Call 7001035870 Meet With Nagpur Escorts
High Profile Call Girls Nagpur Isha Call 7001035870 Meet With Nagpur EscortsHigh Profile Call Girls Nagpur Isha Call 7001035870 Meet With Nagpur Escorts
High Profile Call Girls Nagpur Isha Call 7001035870 Meet With Nagpur Escorts
 
Online banking management system project.pdf
Online banking management system project.pdfOnline banking management system project.pdf
Online banking management system project.pdf
 
Booking open Available Pune Call Girls Koregaon Park 6297143586 Call Hot Ind...
Booking open Available Pune Call Girls Koregaon Park  6297143586 Call Hot Ind...Booking open Available Pune Call Girls Koregaon Park  6297143586 Call Hot Ind...
Booking open Available Pune Call Girls Koregaon Park 6297143586 Call Hot Ind...
 
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
Call for Papers - African Journal of Biological Sciences, E-ISSN: 2663-2187, ...
 
DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINEDJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
DJARUM4D - SLOT GACOR ONLINE | SLOT DEMO ONLINE
 
Roadmap to Membership of RICS - Pathways and Routes
Roadmap to Membership of RICS - Pathways and RoutesRoadmap to Membership of RICS - Pathways and Routes
Roadmap to Membership of RICS - Pathways and Routes
 
Water Industry Process Automation & Control Monthly - April 2024
Water Industry Process Automation & Control Monthly - April 2024Water Industry Process Automation & Control Monthly - April 2024
Water Industry Process Automation & Control Monthly - April 2024
 
(ANVI) Koregaon Park Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANVI) Koregaon Park Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...(ANVI) Koregaon Park Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
(ANVI) Koregaon Park Call Girls Just Call 7001035870 [ Cash on Delivery ] Pun...
 
Glass Ceramics: Processing and Properties
Glass Ceramics: Processing and PropertiesGlass Ceramics: Processing and Properties
Glass Ceramics: Processing and Properties
 
University management System project report..pdf
University management System project report..pdfUniversity management System project report..pdf
University management System project report..pdf
 
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
Call Girls Pimpri Chinchwad Call Me 7737669865 Budget Friendly No Advance Boo...
 
Top Rated Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated  Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...Top Rated  Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
Top Rated Pune Call Girls Budhwar Peth ⟟ 6297143586 ⟟ Call Me For Genuine Se...
 

Building Decentralised Realtime Collaborative Applications - Building Google Docs without Google