-
FVM - To deploy the Marketplace and Ticketing smart contracts.
-
ENS - To enable pilots/users to have a personalized avatar derived from the ENS Avatar as well as use their ENS name as their profile name on the platform
-
Ceramic + Lit - To allow private sharing of data let alone sensitive data through encryption and decryption in line with pre-defined conditions that are made possible with lit protocol. For example , only holders of the APE token would be able to decrypt flight data and other sensitive data.
-
ApeCoin- Used as the native currency of the platform to buy and sell NFTS or event tickets
-
Push Protocol - This makes chatting including group creation, subscribing to favorite pilots via push channels, receiving notifications on live flights and even peer to peer video calling.
-
Huddle01 - While Push Protocol is leveraged for peer to peer video calls, Huddle is used for live stream functionality, making taking a large audience on a virtual FPV expedition possible.
-
Lit Protocol - As most of the FPV community still live in the web2 world, onboarding them on to this new world is made easier and convenient to them by providing an option to sign in to the platform with Google accounts using lit protocol's PKP's.
First, run the development server:
npm run dev
# or
yarn dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying pages/index.js
. The page auto-updates as you edit the file.
Tailwind Typography is an official tailwind plugin that provides a set of prose
classes to add beautiful typographic defaults to any vanilla HTML you don't control (like HTML rendered from Markdown, or pulled from a CMS).
To customize the defaults provided by the plugin, add the overrides under the typography
key in the theme section of the tailwind.config.js
file. Refer to its default styles for more in-depth examples.
For more information, please check out Tailwind Typography's customization section.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!
To learn more about Tailwind CSS, take a look at the following resources:
- Tailwind Documentation - learn about Tailwind CSS features and API.
This will clone the hardhat kit onto your computer, switch directories into the newly installed kit, and install the dependencies the kit needs to work.
You can get a private key from a wallet provider such as Metamask.
Add your private key as an environment variable by running this command:
export PRIVATE_KEY='abcdef'
If you use a .env file, don't commit and push any changes to .env files that may contain sensitive information, such as a private key! If this information reaches a public GitHub repository, someone can use it to check if you have any Mainnet funds in that wallet address, and steal them!
Run this command:
yarn hardhat get-address
This will show you the ethereum-style address associated with that private key and the filecoin-style f4 address (also known as t4 address on testnets)! The Ethereum address can now be exclusively used for almost all FEVM tools, including the faucet.
Go to the Hyperspace testnet faucet, and paste in the Ethereum address from the previous step. This will send some hyperspace testnet FIL to the account.
Currently there are main types of contracts:
-
NFT Marketplace : Simple contracts to run marketplace
-
NFT Ticketing : Event tickets functionality.
-
Filecoin API Examples: Contracts that demo how to use the Filecoin APIs in Solidity to access storage deals and other Filecoin specific functions.
-
Basic Deal Client: A contract that demos how to create Filecoin storage deals within Solidity smart contracts. See below to learn more.
Type in the following command in the terminal to deploy all contracts:
yarn hardhat deploy
This will compile all the contracts in the contracts folder and deploy them to the Hyperspace test network automatically!
Keep note of the deployed contract addresses for the next step.
You can interact with contracts via hardhat tasks, found in the 'tasks' folder. For example, to interact with the SimpleCoin contract:
Type in the following command in the terminal:
yarn hardhat get-balance --contract 'THE DEPLOYED CONTRACT ADDRESS HERE' --account 'YOUR ETHEREUM ADDRESS HERE'
The console should read that your account has 12000 SimpleCoin!
The primary advantage of the FEVM over other EVM based chains is the ability to access and program around Filecoin storage deals. This can be done in the FEVM via the Filecoin.sol library maintained by Zondax. Note this library is currently in BETA. It is unaudited, and the APIs will likely be changing with time. This repo will be updated as soon as possible when a breaking change occurs.
The library is included in this kit as an NPM package and will automatically be downloaded when you perform the yarn
command (don't confuse these with the included mocks)!
Currently you will find a getter contract that calls the getter methods on the MarketAPI to get storage deal data and store that data. To do this you will need dealIDs which you can find here on FilFox.
As an example to store most of the data available for a deal run the store-all command with a specified dealID. Below is an example of using this command below with a deal on Hyperspace testnet with a dealID of 707.
yarn hardhat store-all --contract "DEPLOYED FILECOIN_MARKET_CONSUMER CONTRACT ADDRESS HERE" --dealid "707"