Dione - decentralized oracle network for cross-chain interoperability
Go to file
2021-04-16 00:01:27 +03:00
assets/img
beacon
cache Integrate DioneOracle contract, cherry-pick event cache implementation from master branch 2021-03-05 22:29:09 +03:00
cmd/dione Change node initialization process: implement manual dependency injection to prevent NPE issues 2020-11-27 22:47:58 +04:00
config Implement deriving eth private key from mnemonic phrase 2021-04-15 00:04:21 +03:00
consensus Fix some consensus code which was broken by refactoring 2021-04-16 00:01:27 +03:00
contracts Implement basic version of dispute manager, slightly refactor consensus package 2021-03-15 23:39:52 +03:00
docs
drand Integrate DioneOracle contract, cherry-pick event cache implementation from master branch 2021-03-05 22:29:09 +03:00
eth-contracts Cleanup eth-contracts 2021-04-15 02:14:13 +03:00
ethclient Fix some consensus code which was broken by refactoring 2021-04-16 00:01:27 +03:00
lib
node Fix some consensus code which was broken by refactoring 2021-04-16 00:01:27 +03:00
pubsub Fix ordering of pubsub subsystem initialization 2020-12-07 19:22:47 +04:00
rpc Fix filecoin tx unmarshalling 2020-12-12 16:44:01 +04:00
sigs add: filecoin message validation, secp signature 2020-12-02 17:03:39 +03:00
store
types Implement basic version of dispute manager, slightly refactor consensus package 2021-03-15 23:39:52 +03:00
wallet
.gitignore
docker-compose.yml Integrate DioneOracle contract, cherry-pick event cache implementation from master branch 2021-03-05 22:29:09 +03:00
Dockerfile
go.mod Implement deriving eth private key from mnemonic phrase 2021-04-15 00:04:21 +03:00
go.sum Implement deriving eth private key from mnemonic phrase 2021-04-15 00:04:21 +03:00
LICENCE.md
Makefile
README.md

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 distributed network that tracks the state of another blockchains by computing cross-chain tasks. 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 PBFT a practical Byzantine fault-tolerant consensus protocol invented by Miguel Castro and Barbara Liskov at MIT. At a high level, it operates by running a leader election in every block in which, on expectation, a set number of participants may be eligible to submit a block.

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.

Initial 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. On every block Dione miners would get 50 DIONE tokens as the mining reward.

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.

Operations diagram

dione

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.