Parity Development Stack

Tomasz Drwięga

@tomusdrw

Parity Technologies

6th Dec, Tech Deep Dive

What we do in Parity Tech?

Core & Protocol Development
(Rust)

Second Layer / Middleware
(Node.js / Rust)

Dapps/UI
& Dev. Libraries (JavaScript)

Core & Protocol Development

  • Ethereum
  • Bitcoin
  • IPFS
  • Polkadot
  • Light Client
  • Whisper
  • Secret Store

Parity Ethereum Client

Pluggable consensus

  • Ethash
  • AuRa (PoA)
  • Tendermint (PBFT)
  • InstantSeal (Dev)

Standards compliant

  • JSON-RPC
    (http, ws, ipc)
  • PUB-SUB
  • Custom extensions

Unique features of Parity

  • Warp-Sync
  • State-trie pruning
  • Tracing API
  • FatDB
  • Generic Pub-Sub
  • Secure Transaction Signer
  • Parity Light Protocol
  • On-Chain Auto-Updating
  • Network Permissions
  • Private transactions

Middlewares

  • SMS Verification
  • E-mail Verification
  • PICOPS
  • Transaction Scheduler
  • Network Bridges

Certifier Interface

  • All certifiers using a common ABI
  • Easy to integrate new Certifiers (Registry)
  • Easy to use existing certifiers

ID Service APIs

  • Regular ReSTful API for ID
  • Easy to integrate without touching the chain
  • Open-Source you can setup your own

 id.parity.io, sms-verification.parity.io, email-verification.parity.io

Dapps & UI tools

  • Parity 1.9 contains a revamped Wallet
  • Thin Kernel (Shell) + Dapps
  • Each part of the Wallet can be customized
  • Dapp Store

Mobile Signer

Parity Wallet

Chrome Extension

  • Integrate with web3-enabled websites
  • Connects to your local node
  • Future plans:
    • augment identities

Contract IDE

Dapp

Development Libraries

  • @parity/api
  • oo7 toolchain

@parity/api

  • Web3 replacement
  • Smaller, simpler and promise-based
  • PubSub support
  • Support for parity-specific RPCs
  • For Node.js & Browser

oo7 & oo7-parity

  • Reactive bonds for Ethereum
  • No need to poll - you subscribe for updates
  • Easily composable

oo7 & oo7-parity

// npm i oo7-parity
import {Bonds, hexToAscii} from 'oo7-parity'

const bonds = Bonds()

// A bond for latest block number
bonds.blockNumber
    .tie(console.log) // 5971971

// A bond for latest block extra data
bonds.blocks[bonds.blockNumber]
    .extraData
    .map(hexToAscii)
    .tie(console.log) // Parity.1.7

oo7 & oo7-parity

// npm i oo7-parity
import {Bonds, formatBalance} from 'oo7-parity'

const bonds = Bonds()

bonds.balance(bonds.me)
    .map(formatBalance)
    .tie(console.log) // 4.45 ETH

Bonds also work for contract queries and transactions

oo7-react

// Import reactive element
import {Rspan} from 'oo7-react'
import {Bonds, formatBalance} from 'oo7-parity'

const bond = new Bond()

class App extends Component {
  render() {
    return (
      <Rspan>
        {bonds.me} has 
        {bonds.balance(bonds.me).map(formatBalance)}
      </Rspan>
    );
  }
}

parity-reactive-ui

import {Bonds} from 'oo7-parity'
import {AccountIcon} from 'parity-reactive-ui'

const bonds = Bonds();

class App extends React.Component {
  render () {
    return (
        <AccountIcon address={bonds.me} />
    )
  }
}

Thank you!

Tomasz Drwięga

@tomusdrw

Parity Technologies

Parity Development Stack

By Tomasz Drwięga

Parity Development Stack

  • 666