Thank you for considering contributing to herocast. We welcome any contributions that can help improve the project, including bug reports, feature requests, and code changes.
- Clone the repo:
git clone https://github.com/hellno/herocast.git
- Install Supabase CLI:
- For Linux or macOS with Homebrew installed:
brew install supabase/tap/supabase
- For other platforms, download the .deb/.apk/.rpm from here and install it.
- Install dependencies:
- Install NVM (Node Version Manager) by following the instructions here.
- Switch to the appropriate Node version:
If the version is not installed, use the following command to install it:
nvm use
nvm install
- Install Yarn (if not already installed for this Node version):
npm -g install yarn
- Install packages:
yarn
- Create a file
.env.local
:
- For macOS or Linux:
cp .env.example .env.local
- For Windows:
xcopy .env.example .env.local
- Set up your environment variables:
- Go to Neynar's Dev Portal and sign up for the cheapest plan.
- Once you have access to the dashboard, copy the API Key from the main page at the top.
NEXT_PUBLIC_NEYNAR_API_KEY = 'neynar-api-key-here'
- Go to Alchemy's website and get your API Key.
- Create a new account and select the "Free" option.
- Select the "Optimism" chain and fill out the necessary information.
- In the "Apps" section, find your Optimism App and click the "API Key" button.
- Copy the API Key to your
.env.local
.NEXT_PUBLIC_ALCHEMY_API_KEY = 'alchemy-api-key-here'
- Get a dev account for Farcaster and save your main account's mnemonic phrase.
- To find the mnemonic phrase, go to the mobile app: Settings (gear icon) -> Advanced -> Recovery Phrase.
NEXT_PUBLIC_APP_MNEMONIC = 'candy maple cake sugar honey ... potato blue'
- Find your FID in your account's About information. It is labeled as
FID
, e.g.,FID: 1234
.NEXT_PUBLIC_APP_FID = '123'
- If you don't have Docker installed, you can download it from here.
- Once installed, make sure Docker daemon is running. You can test it by running
docker ps
in your terminal. If it fails, you will need to start the Docker daemon.
- Start your local Supabase instance:
This may take a while to download all the containers and get started.
supabase start
- Once it's done, find the 'API KEY' and 'anon key' by running the command:
Save them as:
supabase status
NEXT_PUBLIC_SUPABASE_URL = '<API URL>' NEXT_PUBLIC_SUPABASE_ANON_KEY = '<anon key>'
- Set up accounts table signer encryption in your SQL Editor:
- Open the Studio URL in the browser and navigate to the SQL Editor tab
- Generate a private encryption key:
SELECT * FROM pgsodium.create_key();
- Get the key ID (copy the id obtained, as it is needed in the next command):
SELECT id FROM pgsodium.valid_key LIMIT 1;
- Run the following command (replace <PG_SODIUM_KEY> with the id from the previous command):
You should get the response "Success. No rows returned" indicating that the command was successful and returned no rows.
SECURITY LABEL FOR "pgsodium" ON COLUMN "public"."accounts"."private_key" IS 'ENCRYPT WITH KEY ID <PG_SODIUM_KEY> SECURITY INVOKER';
- Run the local app in development mode:
yarn dev
This will output:
$ next dev
- Local: http://localhost:3000
- Environments: .env.local, .env.development
...
✓ Ready in 2.4s
Click the localhost link to open the app in your browser. If the compilation fails due to missing .env variables, double-check the spelling of the variable names.
Congratulations! You now have a local version of herocast working.
- Create a new migration:
supabase migration new <migration-name>
- Edit the migration file in the
migrations
folder. - Run the migration:
supabase migration up --local
More info in the supabase docs: https://supabase.com/docs/reference/cli/supabase-migration
- Create a new function:
supabase functions new <Function name>
- Edit the function file in the
functions
folder. - Serve the function locally:
supabase functions serve
- Call the function locally via curl (see bottom of the function file for curl CLI command)
More info in the supabase docs: https://supabase.com/docs/reference/cli/supabase-functions
- Create a new migration file with:
supabase migration new <migration_name>
- Fill in the created sql file with your migration logic
- Apply the migration locally with
supabase migration up --local
- Get the updated database types for the supabase typescript client (make sure to not remove the custom types at the bottom):
supabase gen types --local --lang typescript -s public > src/common/types/database.types.ts
More info in the supabase docs: https://supabase.com/docs/reference/cli/supabase-migration
- Create a new function:
supabase functions new <Function name>
- Edit the function file in the
functions
folder. - Serve the function locally:
supabase functions serve
- Call the function locally via curl (see bottom of the function file for curl CLI command)
More info in the supabase docs: https://supabase.com/docs/reference/cli/supabase-functions
- Create a new migration file with:
supabase migration new <migration_name>
- Fill in the created sql file with your migration logic
- Apply the migration locally with
supabase migration up --local
- Get the updated database types for the supabase typescript client (make sure to not remove the custom types at the bottom):
supabase gen types --local --lang typescript -s public > src/common/types/database.types.ts
...coming back soon via tauri...
Reminder: The key is an edcsa key, not a 'normal' EVM address.
Running transaction testing on a test network is critical for making sure transactions work as intended before they are used on live servers.
If you have any questions or need assistance with contributing to herocast, please feel free to reach out to the project maintainers. Contact information can be found in the README file.
Thank you for your contributions!