Prerequisites | Database Setup | Firebase Setup | Setup for Images | Setup for Contact Page | Creating Admins
Please make sure to follow the instructions in order. You may run into errors if you follow them out of order.
- Install PostgreSQL 15.8. (Uncheck 'Stack builder' and 'pgAdmin' when installing, we don't need those.)
- After installation, open your Command Prompt and type
psql
.
- If
psql
is not recognized, then open your environment variables, and addC:\Program Files\PostgreSQL\15\lib
andC:\Program Files\PostgreSQL\15\bin
to your system variables PATH. (If you don't know how to access the environment variables, see the link below.) - Follow this tutorial to access and edit the environment variables.
- Open and close Command Prompt, try
psql
again. (If issues persist, message Soraya if you need help.)
- In cmd, type
psql -U postgres
. Press enter, then enter your password. If this all works, you're good to go!
- Install PostgreSQL 16.4. (Uncheck 'Stack builder' and 'pgAdmin' when installing, we don't need those.)
- After installation, open a terminal window and type
psql
to ensure that PostgreSQL is added to your system’s PATH.
- If
psql
is not recognized, then open your .zshrc or .bash_profile file in a text editor (depending on which shell you’re using): -
- code ~/.zshrc # For zsh users
-
- nano ~/.bash_profile # For bash users
-
-
- Instead of using the nano text editor you could use VS Code using: code ~/.bash_profile
-
- Add the following line (adjust the path if needed):
-
- export PATH="/Library/PostgreSQL/16/bin:$PATH"
- Save and close the file, then reload your terminal by running:
-
- source ~/.zshrc # For zsh users
-
- source ~/.bash_profile # For bash users
- Open a new terminal window and type
psql --version
. If you seepsql(PostgreSQL)16.4
, then it worked!
After cloning the repo:
- Navigate to EatsInReach in terminal by typing
cd EatsInReach
. - Install packages by typing
npm install
in terminal. You can also typenpm i
. - Create a file named
.env
in the base folder. Add the following contents inside:
DB_HOST=localhost
DB_PORT=5432
DB_USER=postgres
DB_PASSWORD=[your postgreSQL password here]
DB_NAME=eats_in_reach_db
DATABASE_URL=postgres://postgres:[your postgreSQL password here]@localhost:5432/eats_in_reach_db
Do not include the brackets when adding in the password.
- In terminal, type
psql -U postgres -f src/app/data/database.sql
. This creates the database for you. - Install the PostgreSQL Explorer by Chris Kolkman on VS Code.
- Once you install this, follow the instructions in this Youtube video to create a connection to the database. The instruction ends at 13:20.
- Run the program using
npm run dev
. - Go to http://localhost:3000 to view the website.
- Kill the program by pressing
CTRL+C
in the terminal.
Before setting up Firebase, ensure you have the following:
- A Firebase account: Sign up here.
- Node.js version 14 or later
- Go to the Firebase Console.
- Click on Add Project and follow the steps to create your project.
- After the project is created, navigate to the Project Overview.
- Firestore: Go to the Firestore Database section in the Firebase Console and enable it.
- Authentication: Navigate to the Authentication section, then enable Email/Password authentication.
- In the Firebase Console, go to Project Overview > Add App.
- Choose the Web option and register your app with a name.
- After registering the app, Firebase will provide you with a config object containing keys like
apiKey
,authDomain
, etc. This will end up going in the.env
file as follows:
NEXT_PUBLIC_FIREBASE_API_KEY=your-api-key
NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN=your-app.firebaseapp.com
NEXT_PUBLIC_FIREBASE_PROJECT_ID=your-project-id
NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET=your-app.appspot.com
NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID=your-sender-id
NEXT_PUBLIC_FIREBASE_APP_ID=your-app-id
- By default the rules will allow anyone to read/write to the Firebase
- Update these rules based on the roles of the users
- Under the project overview in firebase click the gear icon
- Click project settings
- Click the services account tab
- Click the button generate new private key
- Temporarily add the downloaded json file to the root of your directory for the Create Admins section
- Once that is done add the JSON file in your
.env
file asFIREBASE_SERVICE_ACCOUNT_KEY = '<Copy of JSON file>'
The service we used for storing images and file hosting is called UploadThing.
UploadThing is a file upload solution for full stack applications that offers a balance of ownership, flexibility, and safety.
In your .env
file you will need to include this token for UploadThing.
UPLOADTHING_TOKEN='[your uploadthing token here]'
Add this to the .env
file to setup the email used for users to contact.
EMAIL_USER=eatsinreach@gmail.com
EMAIL_PASS=utxm xlhx iiiy olgq
Follow the steps outlined in Firebase Setup.
-
Create a file named
admin.js
in the base folder. -
Paste the following code into that file:
// Import the Firebase Admin SDK
const admin = require('firebase-admin');
const path = require('path');
// Path to your service account key JSON file
const serviceAccountPath = './<path of json file>'; // Use relative path if in the same folder
// Initialize Firebase Admin SDK
admin.initializeApp({
credential: admin.credential.cert(require(serviceAccountPath)),
});
// Firestore instance
const db = admin.firestore();
// Function to create the first admin
const createFirstAdmin = async (email, password) => {
try {
// Create the admin user
const userRecord = await admin.auth().createUser({
email,
password,
emailVerified: true, // Optional: set this to true if you want to skip email verification
});
console.log('Successfully created new admin user:', userRecord.uid);
// Store the admin's information in the 'admins' collection
await db.collection('admins').doc(userRecord.uid).set({
email: userRecord.email,
role: 'admin', // Add the role field and set it to 'admin'
// Add any additional admin-related data here
});
console.log('Admin information successfully stored in the "admins" collection.');
} catch (error) {
console.error('Error creating admin user:', error);
}
};
// Replace these with your admin email and password
const adminEmail = 'admin@example.com';
const adminPassword = '123456';
// Create the first admin
createFirstAdmin(adminEmail, adminPassword);
- Add your service account key JSON file in line 6.
const serviceAccountPath = './<path of json file>'; // Use relative path if in the same folder
- Replace
adminEmail
andadminPassword
with your admin email and password in line 42-43.
const adminEmail = 'admin@example.com';
const adminPassword = '123456';
Ensure you are in the root of your directory not src/app
.
To run this script type this command in the terminal:
node admin.js
Nathan Duncan
LinkedIn: https://www.linkedin.com/in/nathan-duncan-4292b2310/
GitHub: NathanDuncan-coder | https://github.com/NathanDuncan-coder
Ruben Villagomez
LinkedIn: https://www.linkedin.com/in/ruben-villagomez-511933263/
GitHub: Rudone2 | https://github.com/Rudone2
Soraya Boza
LinkedIn: https://www.linkedin.com/in/soraya-boza/
GitHub: sorayaboza | https://github.com/sorayaboza
Khatelyne Geda
LinkedIn: https://www.linkedin.com/in/khatelyne
GitHub: kxtmg | https://github.com/kxtmg
Jason Yuen
LinkedIn: https://www.linkedin.com/in/jason-s-yuen/
GitHub: JasonSYuen | https://github.com/JasonSYuen
Eric Ladd
LinkedIn: https://www.linkedin.com/in/eladd416/
GitHub: eLadd416 | https://github.com/eLadd416
Hans Guillen
linkedIn: https://www.linkedin.com/in/hans-guillen/
github: GuiH823 | https://github.com/GuiH823
Alisson Ross
LinkedIn: https://www.linkedin.com/in/alisson-ross/
Github: AlissonRoss | https://github.com/AlissonRoss
Vianca Reynoso
LinkedIn: https://www.linkedin.com/in/vianca-reynoso/
Github: vrey2 | https://github.com/vrey2
Javier Miranda
LinkedIn: http://linkedin.com/in/javier-miranda-tech
GitHub: jm2601 | https://github.com/jm2601
Kimberly Encinas
Linkedin: https://www.linkedin.com/in/kimberly-encinas/
GitHub: Kimberly Encinas | https://github.com/kimbencinas
David Xiong
LinkedIn: https://www.linkedin.com/in/david-xiong-27b339324/
GitHub: davidxiong117 | https://github.com/davidxiong117
Misael Bolainez
LinkedIn: https://www.linkedin.com/in/misael-bolainez/
GitHub: missile720 | https://github.com/missile720