Dione - decentralized oracle network for cross-chain interoperability
Go to file
2021-06-05 00:19:45 +03:00
assets/img readme: added dione operations diagram into README.md 2020-11-27 04:26:23 +03:00
beacon Fix LatestBeaconRound in Drand 2021-06-05 00:14:24 +03:00
blockchain Rename BlockPool to BlockChain 2021-06-05 00:19:45 +03:00
cache Implement GetAllTxs function in mempool 2021-05-31 22:24:07 +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 Add blockchain config to Config struct 2021-05-26 23:59:05 +03:00
consensus Refactor pubsub package again, make it more flexible 2021-06-04 00:15:32 +03:00
contracts Remove callback address/method id from NewOracleRequest event properties 2021-04-27 01:01:04 +03:00
docs add: solana rpc, solana program subscription, miner beacon entries usage, fixed DioneStaking smart contract 2020-11-13 17:04:10 +03:00
eth-contracts Update .gitignore 2021-05-14 23:53:32 +03:00
ethclient Remove callback address/method id from NewOracleRequest event properties 2021-04-27 01:01:04 +03:00
lib fix: changed aggregator contract logic, dioneStaking contract, filecoin client 2020-11-14 14:25:14 +03:00
node Rename BlockPool to BlockChain 2021-06-05 00:19:45 +03:00
pubsub Refactor pubsub package again, make it more flexible 2021-06-04 00:15:32 +03: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 fix: solana subscription jsonParsed mode, program data scheme, update miner stake in MinerBase 2020-11-13 18:36:01 +03:00
types Add watching new DRAND entries and fix drand entry validation 2021-06-05 00:07:04 +03:00
wallet Implement block and transaction primitives 2021-05-12 22:34:14 +03:00
.gitignore Fix pubsub issues 2020-11-15 14:11:07 +04:00
docker-compose.yml Integrate DioneOracle contract, cherry-pick event cache implementation from master branch 2021-03-05 22:29:09 +03:00
Dockerfile fix: changed Makefile build execution and Docker container 2020-10-22 00:30:08 +03:00
go.mod Implement mempool synchronization 2021-06-02 22:45:55 +03:00
go.sum Implement mempool synchronization 2021-06-02 22:45:55 +03: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 readme: added dione operations diagram into README.md 2020-11-27 04:26:23 +03: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 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.