Dione - decentralized oracle network for cross-chain interoperability
Go to file
2020-10-22 18:37:31 +04:00
assets/img fix: typo fixes and dione image upload 2020-10-20 21:58:24 +03:00
cmd/dione Change logger library to logrus 2020-10-22 00:36:05 +04:00
config Implement PBFT Consensus manager and rename the current module 2020-10-21 23:54:40 +04:00
consensus Add saving consensus result and make dropping commit messages which related to finished consensus 2020-10-22 18:37:31 +04:00
contracts fix: smart contracts build artifacts 2020-08-06 17:16:00 +03:00
eth-contracts fix: add Ownable.sol smart contract 2020-08-04 20:24:46 +02:00
models Do massive refactor - remove unneccessary stuff, refactor Node, rewrite EtheriumClient, implement PubSubRouter 2020-10-20 22:18:36 +04:00
node Add specifying consensusID when starting test consensus 2020-10-22 02:05:12 +04:00
pb Change from floodsub to gossipsub pubsub algorithm in pubsub route 2020-10-22 18:36:15 +04:00
rpc add: integrate raft consensus layer, ethereum and filecoin rpc into node 2020-08-07 05:42:09 +03:00
rpcclient Change logger library to logrus 2020-10-22 00:36:05 +04:00
.gitignore Update .gitignore 2020-10-22 00:57:07 +04:00
Dockerfile fix: changed Makefile build execution and Docker container 2020-10-22 00:30:08 +03:00
go.mod Add specifying consensusID when starting test consensus 2020-10-22 02:05:12 +04:00
go.sum Add specifying consensusID when starting test consensus 2020-10-22 02:05:12 +04:00
LICENCE.md add: MIT licence 2020-08-03 22:03:34 +02:00
Makefile fix: changed Makefile build execution and Docker container 2020-10-22 00:30:08 +03:00
README.md Implement PBFT Consensus manager and rename the current module 2020-10-21 23:54:40 +04:00

dione

Secured Finance - A protocol for financial transactions backed by crypto-assets.

badge

Table of Contents

Introduction

Dione oracle network is solving the interoperability problem between multiple blockchain networks. Blockchains themself could be describled as deterministic state machine replicated on full-nodes that retains consensus safety. And having the network that handles state changes validation across multiple protocols is crucial for Secured Finance first-layer transactions execution. Using Dione network Secured Finance could provide completely decentralized service for it's users.

Simple explanation for Dione is a blockchain that tracks the state of another blockchains. Dione network itself has fast-finality because of the pBFT (Practical Byzantine Fault Tolerance) consensus and has a role to establish finality for the blockchain it connects (Ethereum, Bitcoin networks has probabilistic-finality).

The networking layer of Dione node is based on libp2p, a flexible cross-platform network framework for peer-to-peer applications. Projects like ETH2 (Ethereum 2.0), Filecoin and Polkadot's Substrate is based on libp2p making it's the standard for future decentralized infrastructures.

Specifications

State validation

In order to validate the state from another blockchain in the Ethereum smart contract Dione users has to import OracleEmitter.sol in smart contract that has to access external data.

Connectors

Most of connections established via RPC requestresponse protocol meaning that Dione network has to meet all interface requirements and be customized for the particular chain it's connects to.

External adapters

Most of off-chain data use cases require external adapters and APIs for simple integration of custom data sources. However Dione network aiming to solve cross-chain interoperability external adapters would be implemented in the second phase using REST-based communication.

Consensus

Dione network uses Expected Consensus (EC) a probabilistic Byzantine fault-tolerant consensus protocol invented by Filecoin. At a high level, it operates by running a leader election every epoch in which, on expectation, a set number of participants may be eligible to submit a block. EC guarantees that these winners will be anonymous until they reveal themselves by submitting a proof that they have been elected.

A miners probability of being elected is roughly proportional to their share of the Dione networks total DIO tokens staked.

The randomness used in the proofs is generated from DRAND, an unbiasable randomness generator, through a beacon.

In order to identify which block has to be selected between multiple blocks proposed by multiple leaders other network operators has to vote up to 2/3 of total amount of nodes running in the network. This enforces Dione network as fast-finality chain.

DIONE token

DIONE token is a ERC20 token on Ethereum blockchain used as a staking token to run the Dione node and for decentralized governance.

Staking mechanism would encourage node operators to behave correctly as well as malicious nodes would lose their stakes. In order to run Dione node the operator has to stake at least 10,000 DIONE tokens.

Total supply of DIONE tokens is 2,000,000. By that the maximum amount of nodes participating in Dione is limited to 200 at the initial start of Dione network. 30% of DIONE tokens would be allocated to Secured Finance team.

Governance mechanism would take place on snapshot.page. The main application of governance descision is around required amount of DIONE tokens to stake in order to run Dione node. Additional governance descision could be proposed by DIONE token holders among the way.

Contribute

Dione core contributors:

Denis Davydov

Bach Adylbekov

We welcome every contributions big and small! Take a look at the community contributing notes. Please make sure to check the issues. Search the closed ones before reporting things, and help us with the open ones.

License

This project is licensed under the MIT license, Copyright (c) 2020 Secured Finance. For more information see LICENSE.md.