This is a template for integrating Openfort into a NextJS project using Firebase as for authentication. Check out the deployed app here!
This demo uses NextJS's Pages Router.
1. Clone and configure the sample
Copy the .env.local.example file into a file named .env.local in the folder of the server you want to use. For example:
You will need an Openfort account in order to run the demo. Once you set up your account, go to the Openfort developer dashboard to find your API keys.
To enable your embedded signer, you can follow the instructions here.
# In your terminal, create .env.local from .env.example
cp .env.example .env.local
NEXTAUTH_SHIELD_ENCRYPTION_SHARE=
NEXTAUTH_SHIELD_SECRET_KEY=
NEXT_PUBLIC_SHIELD_API_KEY=
NEXT_PUBLIC_OPENFORT_PUBLIC_KEY=
2. Create a Policy
If you want to sponsor transactions, you can add policies to your .env.local
file. You can create gas sponsorship policies from your Openfort dashboard.
NEXT_PUBLIC_POLICY_ID=
3. Get your Firebase Config
First go to Firebase config: Console > Project settings > General adn create an app for your prohject if you still don't have one.
data:image/s3,"s3://crabby-images/8520f/8520fda256d5bd3c05f96fac44c5c496c06b506c" alt="image"
Copy the FirebaseConfig and continue
data:image/s3,"s3://crabby-images/eaf72/eaf725507bc4538df04602866d642726cd47c932" alt="image"
Then go to Firebase-Admin config: Console > Project settings > Service accounts and generate a "New Private Key"
data:image/s3,"s3://crabby-images/e36c0/e36c0f68ed807efd00dfd3f777fccefb14023c07" alt="image"
Update .env
4. Set up Firebase Auth in Openfort
To set up Firebase to authenticate players with Openfort, visit your dashboard provider settings. You can follow a guide on how to set up Firebase Auth in Openfort here.
5. Follow the server instructions on how to run
Install & Run:
npm install
npm run dev
In your project directory, run npm run dev
. You can now visit http://localhost:3000 to see your app and login with Openfort!
If you have questions, comments, or need help with code, we're here to help:
- on Discord
- on Twitter at @openfortxyz
- by email