Skip to content

Latest commit

 

History

History
131 lines (77 loc) · 7.16 KB

dapps.asciidoc

File metadata and controls

131 lines (77 loc) · 7.16 KB

Decentralized Applications (DApps)

What is a DApp?

DApp stands for Decentralized Application. Unlike a traditional Application, a DApp does not belong only to one single provider or server, but the whole stack would be deployed and operated in a distributed fashion on a peer-to-peer network.

A typical Decentralized application stack would consist of Front-end, Back-end and Data Storage. There are many advantages to creating a decentralized application that a typical centralized architecture could not provide:

1) Resiliency: Having the business logic written on a smart contract means that a DApp backend will be fully distributed and managed on the Blockchain. Unlike deploying an application on a centralized server, a DApp will have no downtime and will continue to persist as long as the Blockchain is still operating.

2) Transparency: The open source nature of a DApp allows anybody to fork the code and have the same application running on the Blockchain. On the same note, any interaction with the Blockchain will be stored forever and anyone with a copy of the Blockchain can gain access to it.

3) Censorship Resistance: As long as a user has access to an Ethereum node, he/she will always be able to interact with a DApp without interference from a centralized control. No service provider or even the owner of the smart contract could alter the code once it is deployed on the network.

Components of a DApp

Blockchain (Smart Contracts)

The smart contract is used to store the business logic, the state and the computation of your decentralized application, think of it as a server side component in a regular application.

One advantage of deploying server side logic on Ethereum smart contracts is that you could build a more complex architecture where a smart contract could read and write data off one another. After deploying your smart contract, your business logic could well be used by many other developers in the future, without ever requiring you to manage and maintain the code.

One major problem of running smart contract as core business logic functionality is the inability to change the code once it is deployed. Furthermore a really large monolithic smart contract may cost a lot of gas to deploy and function. Therefore some applications may choose to have off chain computation and external data source. Keep in mind however, that having core business logic of the DApp be dependent on external data or server would mean your users will have to trust these externalities.

Front End (Web UI)

Unlike the business logic of the DApp that requires a developer to understand EVM and new languages such as Solidity, the Client side interface of a DApp uses basic web front end technologies (HTML, CSS, JavaScript). This allows a regular web developer to utilize tools, libraries and frameworks they are used to. Interactions with the DApp such as signing messages, sending transactions and key management are often done through the browser itself using tools such as Mist Browser or the Metamask browser extension.

Although it is possible to create a mobile DApp as well, currently there are no best practices to create mobile DApps due to the lack of mobile clients that can serve as a light client with key management functionality.

Data Storage

Due to high gas costs, smart contracts are currently not suited to store large amounts of data. Hence, most DApps will utilize decentralized storages such as IPFS or Swarm for storing and distributing large static assets such as images, videos, and client side application (HTML, CSS, JavaScript).

The hashes of the content are often stored as bytes within the smart contract, using key value mapping. The asset would then be retrieved through your front end applications calling on the smart contract for urls of each asset.

On Chain vs. Off Chain data

IPFS

Swarm

Swarm developer’s onboarding guide; https://github.com/ethersphere/swarm/wiki/swarm

Similarities/differences between Ethereum’s Swarm and IPFS; https://github.com/ethersphere/go-ethereum/wiki/IPFS-&-SWARM

Centralized dB

Oracle

DApp Frameworks

There are many different Development frameworks and libraries written in many languages which allows for better Developer experience in creating and deploying a DApp.

Truffle

Truffle is a popular choice and provides a manageable development environment, testing framework and asset pipeline for Ethereum.

With Truffle, you get:

  • Built-in smart contract compilation, linking, deployment and binary management.

  • Automated contract testing with Mocha and Chai.

  • Configurable build pipeline with support for custom build processes.

  • Scriptable deployment & migrations framework.

  • Network management for deploying to many public & private networks.

  • Interactive console for direct contract communication.

  • Instant rebuilding of assets during development.

  • External script runner that executes scripts within a Truffle environment.

Getting Started & Documentation; http://truffleframework.com/docs

Embark

The Embark Framework focuses on serverless Decentralized Applications using Ethereum, IPFS and other platforms. Embark currently integrates with EVM blockchains (Ethereum), Decentralized Storages (IPFS), and Decentralized communication platforms (Whisper and Orbit).

With Embark you can:

  • Blockchain (Ethereum)

    • Automatically deploy contracts and make them available in your JS code. Embark watches for changes, and if you update a contract, Embark will automatically redeploy the contracts (if needed) and the DApp.

    • Contracts are available in JS with Promises.

    • Do Test Driven Development with Contracts using Javascript.

    • Keep track of deployed contracts; deploy only when truly needed.

    • Manage different chains (e.g testnet, private net, livenet)

    • Easily manage complex systems of interdependent contracts.

  • Decentralized Storage (IPFS)

    • Easily Store & Retrieve Data on the DApp through EmbarkJS. Including uploading and retrieving files.

    • Deploy the full application to IPFS or Swarm.

  • Decentralized Communication (Whisper, Orbit)

    • Easily send/receive messages through channels in P2P through Whisper or Orbit.

  • Web Technologies

    • Integrate with any web technology including React, Foundation, etc..

    • Use any build pipeline or tool you wish, including grunt, gulp and webpack.

Getting Started & Documentation; https://embark.readthedocs.io

Dapp (development tool)

Dapp is a simple command line tool for smart contract development. It supports these common usecases:

  • Package management

  • Source code building

  • Unit testing

  • Simple contract deployments

Getting Started & Documentation; https://dapp.readthedocs.io/en/latest/

Populous