Next step in requesting data from your deployed LensAPI Oracle. Deploy a Polygon Consumer Smart Contract.
Overview
This project represents a basic Polygon Consumer Contract that is compatible with a deployed LensAPI Oracle via Phat Contract 2.0 UI. This tutorial assumes the developer is familiar with executing commands in a terminal.
Prerequisites
Active deployed LensAPI Oracle Blueprint via Phala Dashboard
First you will need to install the @phala/fn CLI tool using your node package manager (npm) or use node package execute (npx). In this tutorial we use npx.
Now create your first template with the CLI tool command:
npx@phala/fninitexample
We currently have only one template. Just press enter to see something similar to the example below:
npx@phala/fn@latestinitexample? Please select one of the templates for your "example" project: phat-contract-starter-kit:SenddatafromanyAPItoyoursmartcontractwithJavascript.❯lensapi-oracle-consumer-contract:SenddatafromLensAPItoyoursmartcontracttoempoweryourWeb3SocialdApp.vrf-oracle:TEE-guardedVerifiableRandomFunctiontemplatetobringrandomnesstoyoursmartcontract. airstack-phat-contract: Request an account’s data from Airstack’s API to compute trust score and send to your Web3 dApp on-chain.
thegraph-phat-contract:ConnectyoursubgraphsfromTheGraphtoyouron-chaindAppsviaPhatContract.
cd into the newly created template and ls the directory which will look similar to below.
Here is what your Bricks Profile account overview should look like:
After creating your Bricks Profile, set your .env variable POLKADOT_WALLET_SURI to the mnemonic phrase from generating the new Polkadot Account.
Here is a screenshot of how to set POLKADOT_WALLET_SURI:
Testing Locally
Test Default Function Locally
With a template created and a basic default function example ready to test, let’s step through the process of preparing your repo to execute the test locally.
First step is to install the package dependencies with the following command:
npm install
Everything should go smoothly and produce similar output below:
Now that the package dependencies are installed, lets build the default function which is located in ./src/index.ts.
View file ./src/index.ts
// *** YOU ARE LIMITED TO THE FOLLOWING IMPORTS TO BUILD YOUR PHAT CONTRACT ***// *** ADDING ANY IMPORTS WILL RESULT IN ERRORS & UPLOADING YOUR CODE TO PHALA ***// *** NETWORK WILL FAIL. IF YOU WANT TO KNOW MORE, JOIN OUR DISCORD TO SPEAK ***// *** WITH THE PHALA TEAM AT https://discord.gg/5HfmWQNX THANK YOU ***// *** FOR DOCS ON HOW TO CUSTOMIZE YOUR PC 2.0 https://bit.ly/customize-pc-2-0 ***import"@phala/pink-env";import {decodeAbiParameters, encodeAbiParameters, parseAbiParameters} from"viem";typeHexString=`0x${string}`;constencodeReplyAbiParams='uint respType, uint id, uint256 data';constdecodeRequestAbiParams='uint id, string reqData';functionencodeReply(abiParams:string, reply:any):HexString {returnencodeAbiParameters(parseAbiParameters(abiParams), reply );}functiondecodeRequest(abiParams:string, request:HexString):any {returndecodeAbiParameters(parseAbiParameters(abiParams), request );}// Defined in OracleConsumerContract.solconstTYPE_RESPONSE=0;constTYPE_ERROR=2;enumError { BadRequestString ="BadRequestString", FailedToFetchData ="FailedToFetchData", FailedToDecode ="FailedToDecode", MalformedRequest ="MalformedRequest",}functionerrorToCode(error:Error):number {switch (error) {caseError.BadRequestString:return1;caseError.FailedToFetchData:return2;caseError.FailedToDecode:return3;caseError.MalformedRequest:return4;default:return0; }}functionstringToHex(str:string):string {var hex ="";for (var i =0; i <str.length; i++) { hex +=str.charCodeAt(i).toString(16); }return"0x"+ hex;}functionfetchApiStats(apiUrl:string, requestStr:string):any {let headers = {"Content-Type":"application/json","User-Agent":"phat-contract", };let query =JSON.stringify({ query:` query Profile { profile(request: { forProfileId: "${requestStr}" }) { stats { followers following comments countOpenActions posts quotes mirrors publications reacted reactions } } } `, });let body =stringToHex(query);//// In Phat Contract runtime, we not support async/await, you need use `pink.batchHttpRequest` to// send http request. The Phat Contract will return an array of response.//let response =pink.batchHttpRequest( [ { url: apiUrl, method:"POST", headers, body, returnTextBody:true, }, ],10000// Param for timeout in milliseconds. Your Phat Contract script has a timeout of 10 seconds )[0]; // Notice the [0]. This is important bc the `pink.batchHttpRequest` function expects an array of up to 5 HTTP requests.
if (response.statusCode !==200) { console.log(`Fail to read Lens api with status code: ${response.statusCode}, error: ${response.error ||response.body}}` ); throw Error.FailedToFetchData; } let respBody = response.body; if (typeof respBody !== "string") { throw Error.FailedToDecode; } return JSON.parse(respBody);}//// Here is what you need to implemented for Phat Contract, you can customize your logic with// JavaScript here.//// The Phat Contract will be called with two parameters://// - request: The raw payload from the contract call `request` (check the `request` function in TestLensApiConsumerConract.sol).
// In this example, it's a tuple of two elements: [requestId, profileId]// - secrets: The custom secrets you set with the `config_core` function of the Action Offchain Rollup Phat Contract. In
// this example, it just a simple text of the lens api url prefix. For more information on secrets, checkout the SECRETS.md file.
//// Your returns value MUST be a hex string, and it will send to your contract directly. Check the `_onMessageReceived` function in
// OracleConsumerContract.sol for more details. We suggest a tuple of three elements: [successOrNotFlag, requestId, data] as
// the return value.//export default function main(request: HexString, secrets: string): HexString { console.log(`handle req: ${request}`);// Uncomment to debug the `secrets` passed in from the Phat Contract UI configuration.// console.log(`secrets: ${secrets}`); let requestId, encodedReqStr; try { [requestId, encodedReqStr] = decodeRequest(decodeRequestAbiParams, request); console.log(`[${requestId}]: ${encodedReqStr}`); } catch (error) { console.info("Malformed request received"); return encodeReply(encodeReplyAbiParams, [BigInt(TYPE_ERROR), 0n, BigInt(errorToCode(error as Error))]); } console.log(`Request received for profile ${encodedReqStr}`); try { const respData = fetchApiStats(secrets, encodedReqStr); let stats = respData.data.profile.stats.posts; console.log("response:", [TYPE_RESPONSE, requestId, stats]); return encodeReply(encodeReplyAbiParams, [TYPE_RESPONSE, requestId, stats]); } catch (error) { if (error === Error.FailedToFetchData) { throw error; } else {// otherwise tell client we cannot process it console.log("error:", [TYPE_ERROR, requestId, error]); return encodeReply(encodeReplyAbiParams, [TYPE_ERROR, requestId,errorToCode(error asError)]); } }}
Build the default function with this command:
npx@phala/fnbuild
You will see output similar to the example below. and a file in ./dist/index.js will be generated.
npx@phala/fnbuild# Creating an optimized build... done# Compiled successfully.## 17.66 KB dist/index.js# ✨ Done in 3.48s.
With our default function built, we can run some initial tests. First test will be simple.
Notice that the test fails and reports that a Malformed request received was emitted and the request was undefined. This is expected as you will need to define the parameters by adding a -a abi.encode(requestId, profileId) https://api-v2-mumbai-live.lens.dev to your command.
To simulate the expected result locally, run the Phala Oracle function now with this command:
Go to https://playground.ethers.org to decode and encode the hexstring you want to pass into your Phat Contract main function.
In this example, the hexstring 0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000 represents types uint id and string reqData
npx @phala/fn run dist/index.js -a 0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000 https://api-v2-mumbai-live.lens.dev
What are the ingredients for the npx @phala/fn run command?
Our Phat Contract script, now fully constructed, is ready for a trial run. This simulation mirrors the live script's operation when deployed on the Phala Network.
The command's first parameter is a HexString, representing a tuple of types [uint, bytes]. This serves as the entry function. The second parameter is a string, embodying the configurable secrets fed into the main function.
The Coders.decode function deciphers these parameters, yielding the decoded requestId and encodedReqStr. These decoded elements then become the raw material for the rest of the custom logic within the script.
npx @phala/fn run dist/index.js -a 0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000 https://api-v2-mumbai-live.lens.dev/
> lensapi-oracle-consumer-contract@0.0.1 run-function> phat-fn run dist/index.js -a 0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000 https://api-v2-mumbai-live.lens.dev/
handle req: 0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000
[1]: 0x01Requestreceivedforprofile0x01response:0,1,14{"output":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000000e"}
We have now successfully tested the default function and ran a test to verify the function returns a response as expected.
Testing Default Function with Local Hardhat Node
Previously we showed how to test the default function locally without a running node, but we can also run two other tests.
Run the default mocha e2e tests.
Run local hardhat node and watch the requests that are pushed and see how the function transforms the data.
Run the default mocha e2e tests
Lets’s start with the first test case.
Note: You will need to ensure you configure your local vars POLYGON_RPC_URL and MUMBAI_RPC_URL.env file. You can do this with cp .env.local .env then edit the .env with your information.
Expected error if .env not configured.
npmrunlocalhost-test# Error HH8: There's one or more errors in your config file:# * Invalid value undefined for HardhatConfig.networks.polygon.url - Expected a value of type string.# * Invalid value undefined for HardhatConfig.networks.mumbai.url - Expected a value of type string.# To learn more about Hardhat's configuration, please go to https://hardhat.org/config/# For more info go to https://hardhat.org/HH8 or run Hardhat with --show-stack-traces# error Command failed with exit code 1.
npmrunlocalhost-test
You will now see that all test cases have passed.
npmrunlocalhost-test# Compiled 14 Solidity files successfully## TestLensApiConsumerContract# ✔ Push and receive message (1664ms)## 1 passing (2s)## ✨ Done in 3.29s.
This is how the e2e mocha test will look like. You can customize this file at ./test/TestLensApiConsumerContract.ts.
View file TestLensApiConsumerContract.ts
import { expect } from"chai";import { type Contract,type Event } from"ethers";import { ethers } from"hardhat";import { execSync } from"child_process";asyncfunctionwaitForResponse(consumer:Contract, event:Event) {const [,data] =event.args!;// Run Phat Functionconstresult=execSync(`phat-fn run --json dist/index.js -a ${data} https://api-mumbai.lens.dev/`).toString();constjson=JSON.parse(result);constaction=ethers.utils.hexlify(ethers.utils.concat([newUint8Array([0]),json.output, ]));// Make a responseconsttx=awaitconsumer.rollupU256CondEq(// cond [], [],// updates [], [],// actions [action], );constreceipt=awaittx.wait();returnreceipt.events;}describe("TestLensApiConsumerContract",function () {it("Push and receive message",asyncfunction () {// Deploy the contractconst [deployer] =awaitethers.getSigners();constTestLensApiConsumerContract=awaitethers.getContractFactory("TestLensApiConsumerContract");constconsumer=awaitTestLensApiConsumerContract.deploy(deployer.address);// Make a requestconstprofileId="0x01";consttx=awaitconsumer.request(profileId);constreceipt=awaittx.wait();constreqEvents=receipt.events;expect(reqEvents![0]).to.have.property("event","MessageQueued");// Wait for Phat Function responseconstrespEvents=awaitwaitForResponse(consumer, reqEvents![0])// Check response dataexpect(respEvents[0]).to.have.property("event","ResponseReceived");const [reqId,input,value] = respEvents[0].args;expect(ethers.BigNumber.isBigNumber(reqId)).to.be.true;expect(input).to.equal(profileId);expect(ethers.BigNumber.isBigNumber(value)).to.be.true; });});
Run local hardhat node and watch the requests that are pushed and see how the function transforms the data
First we will start a local hardhat node.
npm run localhost-node
Example output
npmrunlocalhost-node# Started HTTP and WebSocket JSON-RPC server at http://127.0.0.1:8545/# Accounts# ========# WARNING: These accounts, and their private keys, are publicly known.# Any funds sent to them on Mainnet or any other live network WILL BE LOST.
With our hardhat node running locally, we can now deploy the LensApiConsumerContract.sol contract to the local hardhat network.
Make sure to copy the deployed contract address when you deploy your own contract locally. Note you contract address will be different than 0x0165878A594ca255338adfa4d48449f69242Eb8F. We will now start watching the hardhat node deployed contract for any new requests.
npx @phala/fn watch 0x0165878A594ca255338adfa4d48449f69242Eb8F artifacts/contracts/TestLensApiConsumerContract.sol/TestLensApiConsumerContract.json dist/index.js -a https://api-mumbai.lens.dev/
npx @phala/fn watch 0x0165878A594ca255338adfa4d48449f69242Eb8F artifacts/contracts/TestLensApiConsumerContract.sol/TestLensApiConsumerContract.json dist/index.js -a https://api-v2-mumbai-live.lens.dev/
# $ phat-fn watch 0x0165878A594ca255338adfa4d48449f69242Eb8F artifacts/contracts/TestLensApiConsumerContract.sol/TestLensApiConsumerContract.json dist/index.js -a https://api-v2-mumbai-live.lens.dev/
# Listening for TestLensApiConsumerContract MessageQueued events...
Let’s now make a new request and see what happens with the listener’s output. In separate tab, you will push a request with the following.
Themumbai testnet is deprecated since 2024/04/08, meaning the steps to deploy to a testnet will no longer work out of the box.
You can opt to use the amoy testnet or any other EVM testnet instead.
With the contracts successfully compiled, now we can begin deploying first to Polygon Mumbai Testnet. If you have not gotten MATIC for Mumbai Testnet then get MATIC from a faucet. Ensure to save the address after deploying the Consumer Contract because this address will be use in the "Configure Client" section of Phat Bricks UI. The deployed address will also be set to the environment variable MUMBAI_CONSUMER_CONTRACT_ADDRESS.
npmruntest-deploy
# deploy contracts to testnet mumbainpmruntest-deploy# Deploying...## 🎉 Your Consumer Contract has been deployed, check it out here: https://mumbai.polygonscan.com/address/0x10FA409109E073C15b77A8352cB6A89C12CD1605
## You also need to set up the consumer contract address in your .env file:## MUMBAI_CONSUMER_CONTRACT_ADDRESS=0x10FA409109E073C15b77A8352cB6A89C12CD1605## Configuring...# Done# ✨ Done in 8.20s.
(Optional) Verify Contract on Polygon Mumbai Testnet
Ensure to update the mumbai.arguments.ts file with the constructor arguments used to instantiate the Consumer Contract. If you add additional parameters to the constructor function then make sure to update the mumbai.arguments.ts file.
Note: Your contract address will be different than 0x090E8fDC571d65459569BC87992C1026121DB955 when verifying your contract. Make sure to get your actual contract address from the console log output after executing npm run test-deploy.
npmruntest-verify--0x090E8fDC571d65459569BC87992C1026121DB955# $ hardhat verify --network mumbai --constructor-args mumbai.arguments.ts 0x090E8fDC571d65459569BC87992C1026121DB955# Nothing to compile# No need to generate any newer typings.# Successfully submitted source code for contract# contracts/TestLensApiConsumerContract.sol:TestLensApiConsumerContract at 0x090E8fDC571d65459569BC87992C1026121DB955# for verification on the block explorer. Waiting for verification result...## Successfully verified contract TestLensApiConsumerContract on Etherscan.# https://mumbai.polygonscan.com/address/0x090E8fDC571d65459569BC87992C1026121DB955#code# ✨ Done in 5.91s.
Deploy Phat Contract to PoC6 Testnet
For customizing your Phat Contract, checkout Phat Contract custom configurations in JS_API_DOC.md to learn more before deploying to PoC6 testnet.
Now that are Phat Contract has built successfully, let's deploy to Phala PoC6 Testnet with the following command:
# If you did not export your Polkadot account in a # polkadot-account.json file in the root of projectnpx@phala/fnupload--coreSettings=https://api-v2-mumbai-live.lens.dev/# If polkadot-account.json is in the root of projectnpx@phala/fnupload--coreSettings=https://api-v2-mumbai-live.lens.dev/-a./polkadot-account.json
Here is the expected output:
Note: your contract IDs will vary and not be the same as the IDs below.
npx@phala/fnupload--coreSettings=https://api-v2-mumbai-live.lens.dev/-a./polkadot-account.json# ? Please enter your client RPC URL https://polygon-mumbai.g.alchemy.com/v2/JLjOfWJycWFOA0kK_SJ4jLGjtXkMN1wc# ? Please enter your consumer address 0xA4Be456Fd0d41968a52b34Cdb8Ba875F2281134a# ? Please Enter hahaha account password [hidden]# Creating an optimized build... done# Compiled successfully.## 17.64 KB dist/index.js# Connecting to the endpoint: wss://poc6.phala.network/ws... ⡿# (node:25497) ExperimentalWarning: buffer.Blob is an experimental feature. This feature could change at any time# Connecting to the endpoint: wss://poc6.phala.network/ws... done# Querying your Brick Profile contract ID... done# Your Brick Profile contract ID: 0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd# Instantiating the ActionOffchainRollup contract... done# The ActionOffchainRollup contract has been instantiated: 0x9c777c16b0a185caa895835b8f3b9e8d67be9f5e30197f71b4d32d2b8fde4b3b
# Setting up the actions... done# 🎉 Your workflow has been added, you can check it out here: https://bricks-poc6.phala.network/workflows/0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd/3
# Your Attestor address: 0x2b5fe2920cce2f522d69613adaa9378ba43b687d# Your WORKFLOW_ID: 3# ✨ Done in 73.22s.
Go to the PoC6 Testnet Bricks UI Dashboard and you can see your newly deployed Phat Contract.
Interact with Consumer Contract on Polygon Mumbai
Test Consumer Contract on Mumbai with a few tests to check for malformed requests failures, successful requests, and set the attestor.
Please make sure your have set your attestor address in .env file MUMBAI_PHALA_ORACLE_ATTESTOR
npmruntest-set-attestor
npmruntest-set-attestor# $ hardhat run --network mumbai ./scripts/mumbai/set-attestor.ts# Setting attestor...# 🚨NOTE🚨# Make sure to set the Consumer Contract Address in your Phat Bricks 🧱 UI dashboard (https://bricks-poc6.phala.network)
# - Go to 'Configure Client' section where a text box reads 'Add Consumer Smart Contract'# - Set value to 0x090E8fDC571d65459569BC87992C1026121DB955# Done# ✨ Done in 2.69s.
Test pushing a malform request.
npmruntest-push-malformed-request
npmruntest-push-malformed-request# $ hardhat run --network mumbai ./scripts/mumbai/push-malformed-request.ts# Pushing a malformed request...# Done# ✨ Done in 2.48s.
Test pushing a valid request.
npmruntest-push-request
npmruntest-push-request# Pushing a request...# Done# ✨ Done in 2.97s.
Update Phat Contract on Phala PoC6 Testnet
Sometimes you may have had a bug in your script or you want to test things out on the fly without deploying a whole new Phat Contract. We now allow you to update your Phat Contract easily in the commandline. Now let's update the Phat Contract with the following command:
# If you did not export your Polkadot account in a # polkadot-account.json file in the root of projectnpx@phala/fnupdate# If polkadot-account.json is in the root of projectnpx@phala/fnupdate-a./polkadot-account.json
npx@phala/fnupdate-a./polkadot-account.json# ? Please Enter hahaha account password [hidden]# Creating an optimized build... done# Compiled successfully.## 17.64 KB dist/index.js# Connecting to the endpoint: wss://poc6.phala.network/ws... ⡿# (node:25392) ExperimentalWarning: buffer.Blob is an experimental feature. This feature could change at any time# Connecting to the endpoint: wss://poc6.phala.network/ws... done# Querying your Brick Profile contract ID... done# Your Brick Profile contract ID: 0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd# Checking your workflow settings... done# Updating... done# The Phat Function for workflow 1 has been updated.# ✨ Done in 10.82s.
Congrats! You've now successfully updated your Phat Contract!
Deploy to Polygon Mainnet
Ensure to save the address after deploying the Consumer Contract because this address will be used in the "Configure Client" section of Phat Bricks UI. The deployed address will also be set to the environment variable POLYGON_CONSUMER_CONTRACT_ADDRESS.
Note: Your contract address will be different than 0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4 when verifying your contract. Make sure to get your actual contract address from the console log output after executing npm run main-deploy.
npmrunmain-deploy# Deploying...## 🎉 Your Consumer Contract has been deployed, check it out here: https://polygonscan.com/address/0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4
## You also need to set up the consumer contract address in your .env file:## POLYGON_CONSUMER_CONTRACT_ADDRESS=0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4## Configuring...# Done# ✨ Done in 8.20s.
(Optional) Verify Contract on Polygon Mainnet
Ensure to update the polygon.arguments.ts file with the constructor arguments used to instantiate the Consumer Contract. If you add additional parameters to the constructor function then make sure to update the polygon.arguments.ts file.
npmrunmain-verify--0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4# Nothing to compile# No need to generate any newer typings.# Successfully submitted source code for contract# contracts/TestLensApiConsumerContract.sol.sol:TestLensApiConsumerContract.sol.sol at 0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4
# for verification on the block explorer. Waiting for verification result...## Successfully verified contract TestLensApiConsumerContract.sol on Etherscan.# https://polygonscan.com/address/0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4#code# Done in 8.88s.
Deploy Phat Contract to Phala Mainnet
For customizing your Phat Contract, Phat Contract custom configurations can be found here in JS_API_DOC.md to learn more before deploying to Phala Mainnet.
Now that are Phat Contract has built successfully, let's deploy to Phala Mainnet with the following command:
# If you did not export your Polkadot account in a # polkadot-account.json file in the root of projectnpx@phala/fnupload--mode=production--coreSettings=https://api-v2.lens.dev/# If polkadot-account.json is in the root of projectnpx@phala/fnupload--mode=production--coreSettings=https://api-v2.lens.dev/-a./polkadot-account.json
Here is the expected output:
Note: your contract IDs will vary and not be the same as the IDs below.
npx@phala/fnupload--mode=production--coreSettings=https://api-v2.lens.dev/-a./polkadot-account.json# ? Please enter your client RPC URL https://polygon.g.alchemy.com/v2/JLjOfWJycWFOA0kK_SJ4jLGjtXkMN1wc# ? Please enter your consumer address 0xA4Be456Fd0d41968a52b34Cdb8Ba875F2281134a# ? Please Enter hahaha account password [hidden]# Creating an optimized build... done# Compiled successfully.## 17.64 KB dist/index.js# Connecting to the endpoint: wss://api.phala.network/ws... ⡿# (node:25497) ExperimentalWarning: buffer.Blob is an experimental feature. This feature could change at any time# Connecting to the endpoint: wss://api.phala.network/ws... done# Querying your Brick Profile contract ID... done# Your Brick Profile contract ID: 0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd# Instantiating the ActionOffchainRollup contract... done# The ActionOffchainRollup contract has been instantiated: 0x9c777c16b0a185caa895835b8f3b9e8d67be9f5e30197f71b4d32d2b8fde4b3b
# Setting up the actions... done# 🎉 Your workflow has been added, you can check it out here: https://bricks-poc6.phala.network/workflows/0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd/3
# Your Attestor address: 0x2b5fe2920cce2f522d69613adaa9378ba43b687d# Your WORKFLOW_ID: 2# ✨ Done in 73.22s.
Interact with Consumer Contract on Polygon Mainnet
Execute Scripts to Consumer Contract on Polygon Mainnet. The Consumer Contract on Polygon Mainnet with a few actions to mimic a malformed request, successful requests, and set the attestor.
npmrunmain-set-attestor# Setting attestor...# 🚨NOTE🚨# Make sure to set the Consumer Contract Address in your Phat Bricks 🧱 UI dashboard (https://bricks-poc6.phala.network)
# - Go to 'Configure Client' section where a text box reads 'Add Consumer Smart Contract'# - Set value to 0xbb0d733BDBe151dae3cEf8D7D63cBF74cCbf04C4# Done# ✨ Done in 1.56s.# execute push-malformed-requestnpmrunmain-push-malformed-request# Pushing a malformed request...# Done# execute push-requestnpmrunmain-push-request# Pushing a request...# Done
Update Phat Contract on Phala Mainnet
Sometimes you may have had a bug in your script or you want to test things out on the fly without deploying a whole new Phat Contract. We now allow you to update your Phat Contract easily in the command-line. Now let's update the Phat Contract with the following command:
# If you did not export your Polkadot account in a # polkadot-account.json file in the root of projectnpx@phala/fnupdate--mode=production# If polkadot-account.json is in the root of projectnpx@phala/fnupdate--mode=production-a./polkadot-account.json
npx @phala/fn update --mode=production -a ./polkadot-account.json
# ? Please Enter hahaha account password [hidden]
# Creating an optimized build... done
# Compiled successfully.
#
# 17.64 KB dist/index.js
# Connecting to the endpoint: wss://api.phala.network/ws... ⡿
# (node:25392) ExperimentalWarning: buffer.Blob is an experimental feature. This feature could change at any time
# Connecting to the endpoint: wss://api.phala.network/ws... done
# Querying your Brick Profile contract ID... done
# Your Brick Profile contract ID: 0x4071788a8ce6fbab0cacea0cb1aa52853b5537db7955643e5010c22913c2b1dd
# Checking your workflow settings... done
# Updating... done
# The Phat Function for workflow 1 has been updated.
# ✨ Done in 10.82s.
Closing
Once you have stored, the deployed address of the Consumer Contract and set the value in the "Configure Client" section of the deployed LensAPI Oracle, you will now have a basic boilerplate example of how to connect your Polygon dApp to a LensAPI Oracle Blueprint. Execute a new requests and check if your configuration is correct like below: