🏃♂️Quick Start
Important
This guide references the mumbai
testnet chain.
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..
To kickstart your journey with the Phat Contract Starter Kit, install the @phala/fn
CLI tool.
You can do this using your node package manager (npm
) or use node package execute (npx
). For the purpose of this tutorial, we will be using npx
.
Once you have the CLI tool installed, you can create your first Phala Oracle template with the following command...
🛑 Not so fast! What is it exactly that we are building? 🛑
What are we building?
The artifact we are compiling is a JavaScript file, serving as the Phat Contract Oracle's tailored logic. This script is designed to respond to requests initiated from the Consumer Contract. The diagram provided above offers a visual representation of this request-response interaction.
Why is it important?
In the context of the off-chain environment, on-chain Smart Contracts are inherently limited. Their functionality is confined to the information available to them within the on-chain ecosystem. This limitation underscores the critical need for a secure off-chain oracle, such as the Phat Contract. This oracle is capable of fetching and transforming data, thereby enhancing the intelligence and awareness of Smart Contracts about on-chain activities. This is a pivotal step towards bridging the gap between the on-chain and off-chain worlds, making Smart Contracts not just smart, but also informed.
Let's continue by initializing a new project with @phala/fn
.
After creating a Phala Oracle template, cd
into the new project and install the package dependencies. You can do this with the following command:
Now, build the default Phala Oracle function with this command:
To simulate the expected result locally, run the Phala Oracle function now with this command.
Go to https://playground.ethers.org to
decode
andencode
the hexstring you want to pass into your Phat Contractmain
function.In this example, the hexstring
0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000
represents typesuint id
andstring reqData
Here is what you will enter in the playground:
utils.defaultAbiCoder.decode(['uint id', 'string reqData'], '0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000')
[ BigNumber { value: "1" }, "0x01", id: BigNumber { value: "1" }, reqData: "0x01" ]
You can easily validate this by encoding the types and data with the
utils.defaultAbiCoder.encode()
function like below.
utils.defaultAbiCoder.encode(['uint id', 'string reqData'], [1, "0x01"])
"0x0000000000000000000000000000000000000000000000000000000000000001000000000000000000000000000000000000000000000000000000000000004000000000000000000000000000000000000000000000000000000000000000043078303100000000000000000000000000000000000000000000000000000000"
What are the ingredients for the yarn run-function 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[uintCoder, bytesCoder]
. This serves as the entry function. The second parameter is astring
, embodying the configurable secrets fed into the main function.The
Coders.decode
function deciphers these parameters, yielding the decodedrequestId
andencodedReqStr
. These decoded elements then become the raw material for the rest of the custom logic within the script.
Finally, run the local end-to-end tests with this command. Here we will simulate locally the interaction between the Phat Contract and the Consumer Contract with hardhat.
🎉 Congratulations! You have successfully completed the quick start. For the next steps, you will learn how to deploy your Phala Oracle and connect to the consumer contract for the EVM testnet chain to start testing the request-response model live.
For a deeper dive into the details, click here, or continue reading to learn about the valuable features the Phala Oracle can offer to your on-chain consumer contract.
Last updated