"Minable Oracle Contract" (MOC) is an oracle schema that implements a mineable proof of work (POW) competiton. Once aggregated, validated, and processed into a consumable output - these oracle data entries will be internally referred to as 'truthpoints'.
This project draws high-level inspiration from the EIP918 Mineable Token as an abstract standard that uses a challenge-driven keccak256 Proof of Work algorithm for token minting and distribution.
MOC leverages a proven game-theoretical competition to disintermediate and decentralize the existing 3rd party trust layer associated with centralized oracle services like Oraclize, which use basic API getters to provide smart-contracts with off-chain data. This reduces the implicit cost of risk associated with third parties. For more information, see:
"Trusted third parites are security holes" ~ Nick Szabo, 2001 (https://nakamotoinstitute.org/trusted-third-parties/)
To summarize, by creating an oracle schema that uses an incented construct to derive the validity of off-chain data, we:
- Reduce the risks associated with single-party oracle providers, who can cut access to API data, forge message data, etc
- Lay the foundation for a superior oracle system where truth data is derived from a distributed set of participants which have both economic interest and 'stake' in the validity and success of the oracle data
- Create an effective, secure, and incentivized system for off-chain data which ingests inputs from a signifigant sample of parties and disincentives dispersion and adversarial submissions
Users engage in a POW competition to find a nonce which satisfies the requirement of the challenge. The users who find a nonce which correctly solves the POW puzzle input data for the POW Oracle contract and receive native tokens in exchange for their work. The oracle data submissions are stored in contract memory as an array - which is subsequently operated upon to derive the median for the sample. In this implementation the amount of samples recorded may be stated as N=5.
Each input value is expressed as an integer with a median timestamp describing the point in time that the oracle truth corresponds to. On average, these oracle truths are mined and recorded at an interval dynamically adjusted to correspond to the total work inputted - so that truthpoints (represented as values stored for P sub n variables) may be expressed in a timeseries array fed into another contract, or visualized in a front-end through an event (see UX section for an example).
To ensure scalability and maximize usage potential, the smart-contract has been designed ground-up using the principle of 'gas-minimization'. The contract is currently deployed on the both the Kovan and Rinkeby Ethereum testnets. We encourage testing, security auditing, and UX critiques.
MOC implements a quadriphasic approach to token mining and minting. The current challenge, adjusted difficulty, count, and proof since last timestamp are all called during the 'proofOfWork' operation.
As explained in the initial section, MOC uses a native token as a reward for miners who solve the POW challenge and subsequently input data for the contract. Thistoken inherets from the ERC-20 contract standard for fungible tokens, as may be seen in the 'contracts' hierarchy.
The mining process is formally expressed as:
function proofOfWork(bytes nonce, uint value) returns (uint256) {
bytes32 n = sha3(currentChallenge,msg.sender,nonce); // generate random hash based on input
if (uint(n) % difficulty !=0) revert();
uint timeSinceLastProof = (now - timeOfLastProof); // Calculate time since last reward
if (timeSinceLastProof < 5 seconds) revert(); // Do not reward too quickly
difficulty = difficulty * 10 minutes / timeSinceLastProof + 1; // Adjusts the difficulty
timeOfLastProof = now - (now % 60);
if (count<5) {
first_five[count] = Details({
value: value,
miner: msg.sender
});
emit NewValue(msg.sender,value);
}
if(count==5) {
pushValue(timeOfLastProof);
emit Mine(msg.sender, value); // execute an event reflecting the change
}
else {
currentChallenge = sha3(nonce, currentChallenge, block.blockhash(block.number - 1)); // Save hash for next proof
}
count++;
return (count);
}
An implementation of the miner is descrbed in python in the 'miner' sub directory. In 'miner.py', the script imports the web3 library, pandas, and various other dependencies to solve the keccak256 puzzle. In submitter.js, the nonce value inputs are submitted to the smart contract on chain. To examine the mining script, navigate here.
The Reward schema is an essential component of MOC. The schema is designed to incentivize miners to input valid truthpoints - as outlying datapoints in the sample receive proportionally less reward than the median input.
This Reward schema is expressed in the contract, here:
function pushValue(uint _time) internal {
quickSort(first_five,0,4);
transfer(first_five[2].miner, 10); // reward to winner grows over time
transfer(first_five[1].miner, 5); // reward to winner grows over time
transfer(first_five[3].miner, 5); // reward to winner grows over time
transfer(first_five[0].miner, 1); // reward to winner grows over time
transfer(first_five[4].miner, 1); // reward to winner grows over time
values[_time] = first_five[2].value;
It may be visualized as so:
Within the context of ethereum, oracles can be thought of as authoritative sources of off-chain data (called truthpoints) These truthpoints allow smart contracts to receive and condition executional instructions using extrinsic information. This is highly useful for a wide-array of derivitive scenarios.
As MOC is a contract mechanism that allows oracle data to be derived in a comeptitive, decentralized manner - we envision a wide array of use cases for the OracleToken smart-contract. Namely:
- Exchange-rate data: interval based exchange-rate truthpoints may be used to create trustless financial derivatives ala Decentralized Derivitives
- Weather data logs: for example, we may calculate insurance premium calculation based on a weather forecast
- Static/pseudo-static data: logging and indexing various identifiers, country codes, currency codes
- Prediction Market Probability/Odds: i.e. "What is the likelyhood that X event will happen"
- Prediction Market Resolution: i.e. determining who won the most recent presidential election or sporting event
- Damage verification: What were the net total results in damage for insurance contracts
- Pseudorandom number generation: to select a winner in a distributed-lottery smart contract, etc.
To create a proper web UX for MOC, we have created a basic web3 portal which includes a project description coupled with live contract getters and visualizations. Our current build leverages Truffle and Web3.js to interface with the Rinkeby and Kovan testnets through remote procedure calls (RPC). In addition, we have elected to use React Framework to style and visualize the state attributes within an enabled web3 browser.
The MOC website is currently hosted (here)[localhost:8548], and may be deployed locally by building the repositry.
The web portal provides a way for users to pull state data from the MOC. In this example, users can check the data for a sample distribution of miners who input the Bitcoin/USD exchange rate. They may also view the current POW challenge level (as well as the difficulty). Below this, the web portal arranges the set of truthpoints for the USD/BTC exchange rate into a graph visual.
To interact with the smart-contract, we reccomend using an ingested web3 environment (like MetaMask). Data is pulled from the Rinkeby contract address listed below.
For reference purposes, we have included a few sample loops for the UX below.
Rinkeby Contract Address: '0x34f65d2d9da5022592ba7e921783b9f5b1697333'
To view transaction history, see Etherscan
We are happy to report that a successful MOC build has successfully compiled and been deployed to the Rinkeby and Kovan Ethereum testnets.
This project was a submission to Angel Hack's Washington DC Hackathon hosted on July 7th - 8th. It was designed, spec'ed, built, and deployed in a 24-hour agile sprint.
We invite you to audit and test our project - and submit any issues to the repo directly.
Nicholas Fett ([email protected]), Kevin Leffew ([email protected]), Sam Everett ([email protected]), Brenda Loya ([email protected]), Lucian Stroie ([email protected])
MIT License link.