Web3 ecosystem is growing fast, along with it opportunities for the products built on blockchain. Datrics is the data analytics and data science partner for Web3, empowering blockchain teams with meaningful insights from on-chain and off-chain data. We have been building our expertise in blockchain and Web3 to help developers make better decisions and bring transparency to DeFi solutions.In this release we have focused on the features that would make it easier to build analytics for blockchain. So let’s see what is new in Datrics.
Content
- Connectors to NEAR blockchain
- REST API connector
- Convert the data frame to JSON
Build Web3 analytics with connectors to NEAR blockchain
Blockchains are packed with data and this information is open for everybody. It may seem that the case is solved, however, the next problem is insight. Datrics partners with developers to overcome challenges of Web3 analytics to derive useful information from blockchain.
We have added new bricks to Datrics.ai platform for analysts to fetch data and create transactions on NEAR blockchain. NEAR Fetch brick allows one to access the information of the specific smart contract and method. You may explore the methods on NEAR blocks. NEAR transaction allows analyst to call smart contract and record data on the blockchain.
data:image/s3,"s3://crabby-images/9c169/9c16973860430da91f41480afc07737112fe779e" alt=""
Let’s look at the example of how it works. For instance, we need to get a NEAR balance for the nearcrowd.near account. With our no code platform you may do it in 3 steps without writing code.
1. NEAR Fetch
Call account name on the NEAR blockchain to retrieve the information. To configure the brick you need to define:
- RPC - mainnet or testnet
- Contract / Account name - nearcrowd.near
- Request Type - View account
data:image/s3,"s3://crabby-images/c2ed1/c2ed100be2f74ebc35eaa6c6c81134af5ba0a524" alt=""
The result is represented as JSON:
data:image/s3,"s3://crabby-images/9225f/9225f251c5d1042dda8ac97af74f01f7e6db8477" alt=""
The information we requested is “amount". We may extract this using Flatten JSON and Math Formula bricks.
2. Flatten JSON to get the amount value from the smart contract response.
3. Math Formula to convert the value to NEAR coins. More on using Math formula.
data:image/s3,"s3://crabby-images/2bb0f/2bb0fcc85e803b223ffcb065fefc98f597f074b7" alt=""
Finally, we can see that the NEAR balance for nearcrowd.near account is 46’462 NEAR.
More examples on how to fetch NEAR smart contract information.
REST API connector
Every analytics pipeline starts with the data, therefore we take the data connectors seriously. There is a new API connector coming in the Datrics release 2.4.
Rest API Request brick currently supports GET requests. User may set up the logic for the request without writing any code. You can setup the brick to connect to multiple APIs, as a result, all the requests will be made in parallel to reduce the time to get the data. Out put of the brick is a data frame with the responses to all call.
How to set up the REST API Request brick?
1/ For each API provide the URL. Request parameters may be included in the url or added in the advanced settings.
2/ Additional settings:
- Alias - short name for the request. In the brick output request alias will be added as a separate column. Providing the short name help to identify the request results in a data frame
- Brick may retry the request in case of the failure. Retry after, sec - time before the retry will be made
- Number of retries - 0 by default
- Query parameters - key and value of the request parameters. You should add parameters either to the URL, or configure in the additional settings
data:image/s3,"s3://crabby-images/67c13/67c13e6442b16aa30a518034af7974eec8ad8d7d" alt=""
Here’s the example. Our goal is to retrieve the prices of the BNB and BTC tokens from Binance exchange. Binance provides the open apis to retrieve the latests data.
The output of the brick contains: alias, URL, request result and retrieval time.
data:image/s3,"s3://crabby-images/a46c2/a46c2bae47aec143b3bfe3e3a8d73db96b1f51e2" alt=""
We have also used Flatten JSON brick to parse the results.
data:image/s3,"s3://crabby-images/52a58/52a58847197cb957f9e9ba2883f63ca7ea5a0727" alt=""
Now we are ready to move forward with the data analysis!
Convert the data frame to JSON
Usually, the result of the pipeline is the data frame and/or a model. To work with smart contract and push the data on-chain, one would need to transform the data frame to json.
Here where new Prepare JSON becomes useful. Brick converts input data into a dictionary followed by JSON serialization format.
The transformation options we support:
data:image/s3,"s3://crabby-images/31006/31006db7e8baa111b94bc44f3343cf4ba91e9203" alt=""
Let’s go through an example.
The input dataset to the brick has the following structure:
data:image/s3,"s3://crabby-images/f40d9/f40d9aff003564ec7b205e95b77854ad208fba28" alt=""
We can form a JSON by connecting the dataset directly to the brick.
First, we select the ‘dict’ option with no key defined and run the pipeline.
data:image/s3,"s3://crabby-images/bb2a7/bb2a79a663b46023f9b3c228125deb085ebd565d" alt=""
As a result, we get the following output:
data:image/s3,"s3://crabby-images/4b7c3/4b7c3e08cc756d23f287c2ce5e151ce04083c80f" alt=""