DIA has a dedicated WASM-based oracle. It can be universally deployed on any chain that supports substrate WASM environment.
get
: Gets the latest value of the asset symbol with timestamp. Can be called by anyone.
set
: Sets latest value of asset, requires price and timestamp. Can be called only by the owner of contract.
To access values from DIA wasm oracles you need to copy the diadata
directory to your contract so that you can access DIA structs, that contain the oracle data.
Create storage with DiaDataref, this is used to access values from oracle
This struct can be used to access data from pub functions from the oracle contract.
To instantiate a contract's access to the oracle you need to pass the DIA oracle address, either using the constructor or by creating a separate write function to update with the value of oracle at a later stage.
Example using constructor:
Here, oracle_address
refers to the DIA oracle address of a deployed oracle contract.
Next, to access an oracle value you can simple call the get()
function
This gives the ETH price value time given by the oracle.
Make sure you add diadata/std in you config
Make sure the version of ink you are on is v3.0.1
See the entire oracle code and instructions on how to run and oracle service by yourself in our github repo:
See deployed WASM demo oracles in action:
If you want a custom WASM oracle for your dapp, request a custom oracle:
Network | Contract Address |
---|
Astar Shibuya Testnet |
Astar Shiden |