Skip to content

Latest commit

 

History

History
165 lines (128 loc) · 4.26 KB

README.md

File metadata and controls

165 lines (128 loc) · 4.26 KB

BruinSquads

BruinSquads is a web application that connects UCLA students for sports activities. This README provides detailed instructions for setting up and running the application locally.

Prerequisites

Before you begin, ensure you have the following:

  • Node.js (v20 or higher)
  • npm (Node Package Manager)
  • MongoDB account
  • Clerk account
  • ngrok account and CLI installed

Project Structure

bruinsquads/
├── backend/         # Express server and API endpoints
├── frontend/        # Next.js frontend application
├── package.json     # Root package.json for scripts
└── README.md       # This file

Initial Setup

  1. Clone the repository:
git clone https://github.com/ryan8269/BruinSquad.git
cd BruinSquad
  1. Install dependencies for both frontend and backend:
# Install backend dependencies, the package.json for it is in root
npm install

# Install frontend dependencies
cd frontend
npm install

Environment Configuration

root (.env)

Create a .env file in the root directory with the following variables:

PORT=4000
MONGODB_URI=your_mongodb_connection_string
WEBHOOK_SECRET=your_clerk_webhook_secret

Frontend (.env.local)

Create a .env.local file in the frontend directory with the following variables:

NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=your_clerk_publishable_key
CLERK_SECRET_KEY=your_clerk_secret_key
NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_SIGN_UP_FORCE_REDIRECT_URL=/user/profile

Database Setup

  1. Create a MongoDB account at MongoDB Atlas
  2. Create a new cluster and get your connection string
  3. Seed the database with initial location data:
cd backend
node seed.js

Clerk Authentication Setup

  1. Create a Clerk account at Clerk.dev
  2. Set up a new application in Clerk dashboard
  3. Configure webhook:
    • In Clerk Dashboard, go to Webhooks
    • Create a new webhook for "User Created" event
    • Set the endpoint URL to your ngrok public domain + /api/webhook
    • Save the webhook secret for your backend .env file

ngrok Setup

  1. Install ngrok:
# macOS (using Homebrew)
brew install ngrok

# Windows (using Chocolatey)
choco install ngrok
  1. Sign up at ngrok.com and get your auth token
  2. Configure ngrok:
ngrok config add-authtoken your_auth_token
  1. Update the root package.json dev script with your ngrok domain:
{
  "scripts": {
    "dev": "ngrok http --domain=your-domain.ngrok-free.app 4000"
  }
}

Running the Application

  1. Start the backend server:
cd backend
npm run dev
  1. In a new terminal, start the frontend:
cd frontend
npm run dev
  1. In a third terminal, start ngrok:
# From project root
npm run dev
  1. Access the application:

Webhook Configuration

The webhook system synchronizes user data between Clerk and MongoDB. When a user is created in Clerk, it sends a POST request to your backend endpoint:

POST https://your-domain.ngrok-free.app/api/webhook

For more information about setting up the webhook, refer to Clerk's documentation on database sync.

Troubleshooting

Common issues and solutions:

  1. MongoDB Connection Issues

    • Ensure your IP address is whitelisted in MongoDB Atlas
    • Verify your connection string in the backend .env file
  2. Webhook Not Receiving Data

    • Confirm ngrok is running and the domain is correct
    • Verify the webhook secret in both Clerk dashboard and backend .env
    • Check webhook logs in Clerk dashboard
  3. Frontend Authentication Issues

    • Verify all Clerk environment variables are set correctly
    • Ensure the Clerk publishable key matches your application

Additional Resources