This step-by-step guide will help you understand how to effectively utilize data feeds from the Sybil module. This module is a data fetcher that can be integrated as a pull-based oracle. Additionally, it can be used in conjunction with the Pythia automation module for push-based implementations.
Top Up Wallet and Generate API Key: Follow the portal instructions to top up your wallet and generate an API key for enhanced access. Optionally, you can whitelist your app domain to streamline the process.
Dynamic Link Calculation: Utilize the dynamic link calculation feature for custom data requests.
Step 2: Fetch Data from Sybil
Construct Your Data Request: Define the endpoint to fetch the latest data with proof. Example request format:
Utilize the Orally Solidity SDK to implement verification in your dApp's smart contracts:
// SPDX-License-Identifier: MITpragmasolidity ^0.8.20;import"@orally-network/solidity-sdk/IOrallyVerifierOracle.sol";import"@orally-network/solidity-sdk/OrallyStructs.sol";contract YourDappContract { IOrallyVerifierOracle oracle;constructor(address orallyVerifierOracleAddress) { oracle =IOrallyVerifierOracle(orallyVerifierOracleAddress); }// price data from // https://tysiw-qaaaa-aaaak-qcikq-cai.icp0.io/get_xrc_data_with_proof?id=DOGE/SHIB&bytes=true&api_key={YOUR_API_KEY}
functioninteract(bytesmemory priceFeedData ) publicviewreturns (OrallyStructs.PriceFeedmemory) {// Verify the price feed data and get the price, decimals, and timestamp. OrallyStructs.PriceFeed priceFeed = oracle.verifyPriceFeed(priceFeedData);// priceFeed.price is the price of DOGE/SHIB// priceFeed.decimals is the number of decimals in the price// priceFeed.timestamp is the timestamp when price feed was aggregatedreturn priceFeed; }// -- or --// with cache // https://tysiw-qaaaa-aaaak-qcikq-cai.icp0.io/get_xrc_data_with_proof?id=DOGE/SHIB&bytes=true&API_KEY={YOUR_API_KEY}
functioninteract(bytesmemory priceFeedData ) publicreturns (OrallyStructs.PriceFeedmemory) {// Verify the price feed data and get the price, decimals, and timestamp. oracle.updatePriceFeed(priceFeedData);// Get the price feed data from the cache. OrallyStructs.PriceFeed priceFeed = oracle.getPriceFeed("DOGE/SHIB");// priceFeed.price is the price of DOGE/SHIB// priceFeed.decimals is the number of decimals in the price// priceFeed.timestamp is the timestamp when price feed was aggregatedreturn priceFeed; }// -- or --// without API key// https://tysiw-qaaaa-aaaak-qcikq-cai.icp0.io/get_xrc_data_with_proof?id=DOGE/SHIB&bytes=truefunctioninteract(bytesmemory priceFeedData ) publicpayablereturns (OrallyStructs.PriceFeedmemory) {// Get the update fee for the price feed data.uint256 fee = oracle.getUpdateFee(priceFeedData);// Verify the price feed data and get the price, decimals, and timestamp. OrallyStructs.PriceFeed priceFeed = oracle.verifyPriceFeedWithFee{ value: fee }(priceFeedData); // if this price feed will be needed for later usage you can use `updatePriceFeedWithFee` instead (+90k to gas) and access as `oracle.getPriceFeed("DOGE/SHIB")`
// priceFeed.price is the price of DOGE/SHIB// priceFeed.decimals is the number of decimals in the price// priceFeed.timestamp is the timestamp when price feed was aggregatedreturn priceFeed; }// -- or verifying chain data example --// chain data from // https://tysiw-qaaaa-aaaak-qcikq-cai.icp0.io/read_contract_with_proof?chain_id=42161&function_signature="function balanceOf(address account) external view returns (uint256)"&contract_addr=0xA533f744B179F2431f5395978e391107DC76e103&method=balanceOf¶ms=(0x654DFF41D51c230FA400205A633101C5C1f1969C)&bytes=true
functiongetSideChainUserTokenBalance(bytescalldata chainData ) publicviewreturns (uint256) {// Verify the chain data and get the balance of the user. (bytesmemory dataBytes,bytesmemory metaBytes) = oracle.verifyReadContractData(chainData);// `verifyReadContractDataWithFee` for paying fee in the same transaction instead of API key (uint256 balance) = abi.decode(dataBytes, (uint256)); (OrallyStructs.ReadContractMetadata memory meta) = abi.decode(metaBytes, (OrallyStructs.ReadContractMetadata));// balance is the balance of the user of the requested token// meta.chainId is the chain id of the side chain// meta.contractAddr is the address of the contract on the side chain// meta.method is the method that was called on the contract// meta.params is the parameters that were passed to the methodreturn balance; }}
This Solidity snippet demonstrates how your dApp's contract can interact with the OrallyVerifierOracle contract to verify the data received from Sybil.
Conclusion
This guide outlines the steps to effectively integrate and utilize the Sybil data feeds in your decentralized applications. By following these steps, you can enhance the functionality and reliability of your dApps with secure and verified data from multiple external sources.
Orally's Sybil provides existing price feeds and allows you to create your custom price feed pair. The process is straightforward and user-friendly:
Navigate to the Front-End App: Visit the Orally front-end app at Sybil dApp.
Initiate the Custom Pair Creation Flow: Locate and click the button on the main page to initiate the Custom pair creation flow. This will open a modal where you will input details about your custom pair.
Input Pair Details: Provide the necessary details for your custom pair in the modal. These will include the symbol name, the frequency of updates, and the endpoints from which to fetch the price feed for your token. Ensure that these details are accurate, as they will directly influence the behaviour and accuracy of your custom pair's price feed.
Authenticate with SIWE: After inputting the necessary details, authenticate yourself using SIWE (Signing with Ethereum). This step is necessary for security and accountability reasons.
Top Up Balance: After authentication, top up the balance with the specified token. This balance is necessary to cover the execution costs associated with your custom pair's price feed.
Run Your Custom Pair: After completing all the previous steps, you can run your custom pair. Congratulations—you now have your own token price feed!
Following these steps, you can create a custom price feed pair for any token you choose. Orally's Sybil's power truly shines in its versatility and adaptability, making it a highly valuable tool for all developers in the blockchain space.