Setup
This is a step-by-step guide to setting up your own NIIIFTY instance using Firebase and Vercel.
data:image/s3,"s3://crabby-images/14795/14795099352aece54c59bbff87d1a3f9f28d0960" alt="fig 1"
First, fork the NIIIFTY github repository to your own github profile.
data:image/s3,"s3://crabby-images/4ff8e/4ff8e2bddb33abeacfb9a351c0da16b1bc1dfd2f" alt="fig 2"
git clone
your NIIIFTY fork to your local filesystem
data:image/s3,"s3://crabby-images/d6976/d69767a0e985cd3b81f53be9f6e451f52f587212" alt="fig 3"
Go to your Firebase console and click Add project.
data:image/s3,"s3://crabby-images/1cfa5/1cfa5fe7abb8dcf8de51b1f15cfaca099290ab11" alt="fig 4"
Give your project a name and click Continue
Leave Google Analytics enabled.
Click Create Project.
Once your project is created, click Continue.
data:image/s3,"s3://crabby-images/5c9d9/5c9d9f0b7cf96758bfcea597eb7dbfd2f11cd21e" alt="fig 5"
In your firebase console, click the cog icon next to Project Overview and select Usage and Billing.
Under the Details and Settings tab, select Modify Plan. Select the Blaze Plan.
data:image/s3,"s3://crabby-images/c8784/c87846971cffbb10361b3cdf7fc37ed65244e3de" alt="fig 6"
Click the cog icon next to Project Overview and select Project settings. Scroll down to Your apps, and select Web App.
data:image/s3,"s3://crabby-images/62688/626889a5ae97774e19d89b9f7791d41b5c5e0312" alt="fig 7"
Give your app a nickname and click Register app. We'll be using Vercel for hosting, so leave Firebase Hosting unchecked.
data:image/s3,"s3://crabby-images/d0edd/d0edd35ff5acf6f3e480fce2a06479ae2cc83341" alt="fig 8"
Copy the firebaseConfig
object values to your clipboard and click Continue to console.
data:image/s3,"s3://crabby-images/eb2db/eb2dba832fb3e9de23f52f55c71e6301f8cc9dcc" alt="fig 9"
Open your locally-cloned NIIIFTY project in VSCode.
Find the niiifty.config.ts
file and paste in your Firebase config values.
data:image/s3,"s3://crabby-images/6a37c/6a37c9317df99b43127948ed5ac637e61efdf1c3" alt="fig 10"
Set basicAuthDisabled
to true
data:image/s3,"s3://crabby-images/7d777/7d7770959951c58268d54f647e5e8bd65bfde370" alt="fig 11"
Browse to Web3.storage and create an account. Once your account is created, navigate to Account and Create an API Token.
data:image/s3,"s3://crabby-images/46f29/46f29161f6dc91fef705b6ae32f67fda542b9d40" alt="fig 12"
Give your token a name, e.g. NIIIFTY Tutorial
and click Create.
Copy your newly created API token to the clipboard.
data:image/s3,"s3://crabby-images/61680/61680b014ded08523c07760bbbcf3a837c122a7d" alt="fig 13"
In vscode, add a .env
file to your functions folder. Add WEB3_STORAGE_API_KEY=[pasted key from clipboard]
data:image/s3,"s3://crabby-images/4f4ca/4f4ca214209eeea0bf5f4386d27a405ee28c0f64" alt="fig 14"
In your firebase console, click the cog icon next to Project Overview and select Project settings.
Under the General tab, find the Project ID and copy it.
data:image/s3,"s3://crabby-images/9dc26/9dc2641b65be0ae42cb04daf104dea598e47dbad" alt="fig 15"
In vscode, open the .firebaserc
file.
Paste your project ID into the default
value.
If you do not already have the Firebase CLI installed, please install it.
Once installed, open a command prompt in the root of your firebase project and type:
firebase use default
You should see a message similar to Now using alias default (niiifty-tutorial)
In your command prompt, now type:
cd functions
npm i
Once the node modules are installed, type:
cd ../
npm run deploy
Once deployed to Firebase, you should see a success message.
data:image/s3,"s3://crabby-images/54cfc/54cfc1d5634d90cfbbd325c50e276f3e2954b2e6" alt="fig 16"
In your Vercel account, select Add New then Project.
data:image/s3,"s3://crabby-images/dc354/dc35495aef3ade91ddaae18f0e6c35ccdee8c6da" alt="fig 17"
Find your NIIIFTY fork and select Import
data:image/s3,"s3://crabby-images/d66c6/d66c64a54e4eaa8b709dcdb66573831c4ac46171" alt="fig 18"
Name your project e.g. niiifty-tutorial
and select Deploy.
Once deployed, select Continue to Dashboard.
Here you can see the domain assigned to your project e.g.niiifty-tutorial.vercel.app
In vscode, add this domain to the site section of your niiifty.config.ts
file.
data:image/s3,"s3://crabby-images/c6b57/c6b57b806fa9393d5d32d033fe0f6b7f059f8473" alt="fig 19"
In your Firebase console, expand Build in the left-hand menu and select Authentication.
Under Additional providers, select Google.
Select enable.
Under Project public-facing name, enter niiifty-tutorial
(or another name of your choice).
Under Project support email, enter an email address (e.g. your gmail address).
Click Save.
data:image/s3,"s3://crabby-images/3f54c/3f54c60686b0407b1abef2952708d6c2be90293e" alt="fig 20"
Under Authentication > Settings, select Authorised domains
Add your vercel project domain, e.g. niiifty-tutorial.vercel.app
(this can be found on your vercel project dashboard).
data:image/s3,"s3://crabby-images/5c19d/5c19d199a2b5f4b0c79f315252c9040fc2d5c860" alt="fig 21"
In your Firebase console, expand Build in the left-hand menu and select Firestore Database.
Select Create Database.
Leave the settings on their default values and click Next.
Choose a region for your database and click Enable.
data:image/s3,"s3://crabby-images/07bff/07bff74c6a89659579ad2306ff408c9179f69b84" alt="fig 22"
In your Firebase console, expand Build in the left-hand menu and select Firestore Database.
Select Create Database.
Leave the settings on their default values and click Next.
Choose a region for your database and click Enable
data:image/s3,"s3://crabby-images/a7fbb/a7fbbc878e85fad5b02df9f562cfbaeead29546a" alt="fig 23"
In your Firebase console, expand Build in the left-hand menu and select Storage.
Click Get Started.
Leave the settings on their default values and click Next, then Done.
data:image/s3,"s3://crabby-images/aa075/aa075bbd5dead68f3adebef816dc175aebb38d22" alt="fig 24"
In your Firebase console, expand Build in the left-hand menu and select Functions.
Click Get Started, Continue, and Finish.
data:image/s3,"s3://crabby-images/38b71/38b714d8d70794baea07cec72b92098739967f85" alt="fig 25"
Browse to your Google Cloud console
Select your project in the drop down menu at the top.
Expand the left menu and select Cloud Storage.
Select your project's public bucket, e.g. niiifty-tutorial.appspot.com
data:image/s3,"s3://crabby-images/153de/153de16f3e81e0ef109c598de4b080bdb9d27f49" alt="fig 26"
Select the Permission tab, then Grant Access.
data:image/s3,"s3://crabby-images/453c5/453c546f6ef3ec1af6f089bc0b1e17ed4f11e384" alt="fig 27"
In the expanded side panel, add New principles allUsers
, with a Role of Storage Object Viewer
.
Click Save.
Confirm Allow Public Access.
data:image/s3,"s3://crabby-images/faf80/faf806c12b3eebbb53436a392f13b01cfd5250f7" alt="fig 28"
Now select the Configuration tab in your bucket settings and copy the gsUtil
vale.
data:image/s3,"s3://crabby-images/9e15d/9e15d9e6362557584fd4d218ac1bd60d9200cace" alt="fig 29"
Activate Cloud Shell and type in
printf '[{"origin": ["*"],"responseHeader": ["*"],"method": ["GET","POST","HEAD"],"maxAgeSeconds": 86400}]' > cors.json
gsutil cors set cors.json [gsUtil]
replacing [gsUtil]
with your gsUtil
value.
You may be prompted to authorise Cloud Shell, click Authorise.
You can now access the files generated by NIIIFTY via CORS.
Setup Complete
Congratulations! If you now visit your Vercel project's URL e.g. https://niiifty-tutorial.vercel.app
you will be able to create an account associated with your Gmail address and start uploading files!