This repository contains a sample project that you can use as the starting point for your Fhenix project. It's also a great fit for learning the basics of Fhenix smart contract development.
This project is intended to be used with the
Fhenix Hardhat Beginners Tutorial, but you should be
able to follow it by yourself by reading the README and exploring its
contracts, tests, deploy and tasks directories.
It comes with two fhenix-specific hardhat plugins:
fhenix-hardhat-plugin: The main plugin for fhenix development in hardhat. It injectsfhenixjsinto the hardhat runtime environment, which allows you to interact with encrypted data in your tests and tasks.fhenix-hardhat-docker: A plugin that allows you to run a local Fhenix testnet in a docker container. This is useful for testing your contracts in a sandbox before deploying them on a testnet or on mainnet.
The first things you need to do are cloning this repository and installing its dependencies:
git clone https://github.com/FhenixProtocol/fhenix-hardhat-example.git
cd fhenix-hardhat-example
pnpm installNext, you need an .env file containing your mnemonics or keys. You can use .env.example that comes with a predefined mnemonic, or use your own
cp .env.example .envOnce the file exists, let's run a LocalFhenix instance:
pnpm localfhenix:startThis will start a LocalFhenix instance in a docker container. If this worked you should see a Started LocalFhenix successfully message in your console.
If not, please make sure you have docker installed and running on your machine. You can find instructions on how to install docker here.
Now that we have a LocalFhenix instance running, we can deploy our contracts to it:
npx hardhat deployNote that this template defaults to use the localfhenix network, which is injected into the hardhat configuration.
Finally, we can run the tasks with:
pnpm task:getCount # => 0
pnpm task:addCount
pnpm task:getCount # => 1
pnpm task:addCount --amount 5
pnpm task:getCount # => 6This template contains experimental support for testing using Hardhat Network. By importing the fhenix-hardhat-network plugin in hardhat.config.ts we add support for simulated operations using Hardhat Network. These do not perform the full FHE computations, and are menant to serve as development tools to verify contract logic.
Note that in order to use the hardhat network in tasks with --network hardhat the tasks need to deploy the contract themselves, as the network is ephemeral. Alternatively you can use the stand-alone hardhat network by setting it as the default network in hardhat.config.ts.
If you have any issues or feature requests regarding this support please open a ticket in this repository
If Localfhenix doesn't start this could indicate an error with docker. Please verify that docker is running correctly using the docker run hello-world command, which should run a basic container and verify that everything is plugged in.
For example, if the docker service is installed but not running, it might indicate you need to need to start it manually.
To learn more about the Fhenix Hardhat plugin, check out the Fhenix Hardhat Plugin Repository.