The official tech community platform for GL Bajaj Group of Institutions, Mathura. Built by students, for students β featuring events, activities, team management, portfolios, and more.
- β¨ Stack
- π Project Structure
- π Quick Start
- π§ͺ Testing
- π’ Deployment
- π€ Contributing
- π Documentation
- π₯ Contributors
- π License
| Layer | Technology |
|---|---|
| Website (Frontend) | React 18 + Vite 5 + React Router v6 |
| Admin Dashboard | React 18 + Vite 5 |
| Backend API | Node.js 20 + Express 4 (ESM) |
| Database | PostgreSQL via Supabase (JSON file fallback for offline) |
| Real-time | Socket.IO |
| Emails | Nodemailer / Resend / SendGrid |
| Auth | Session-based admin auth with timing-safe comparison |
| Deployment | Frontend β Vercel Β· Backend β Render Β· Docker supported |
NexaSphere/
βββ website/ # Main public website (React + Vite)
β βββ src/
β β βββ assets/ # Images, fonts, icons
β β βββ components/ # Reusable UI components
β β βββ context/ # React context providers
β β βββ data/ # Static data (events, activities)
β β βββ hooks/ # Custom React hooks
β β βββ pages/ # Route-level page components
β β βββ shared/ # Shared UI primitives (Navbar, Footer, etc.)
β β βββ styles/ # Global CSS + theme tokens
β β βββ utils/ # API client, helpers, PWA utils
β βββ .env.example # Required environment variables
β βββ vite.config.js
β βββ vercel.json # Website-specific Vercel overrides
β
βββ admin-dashboard/ # Admin UI (React + Vite, separate deploy)
β βββ src/
β βββ .env.example
β βββ vite.config.js
β
βββ server/ # Express.js REST API + Socket.IO
β βββ config/ # DB, socket, and service config
β βββ controllers/ # Route handler functions
β βββ middleware/ # Auth, rate limiting, error handling
β βββ migrations/ # Database migration files
β βββ repositories/ # DB access layer (repository pattern)
β βββ routes/ # Express route definitions
β βββ services/ # Business logic
β βββ utils/ # Helpers (Sentry, email, etc.)
β βββ validators/ # Zod schema validators
β βββ index.js # Entry point
β βββ .env.example # All required environment variables
β βββ Dockerfile # Production Docker image
β
βββ server-python/ # FastAPI ML/AI microservice (optional)
βββ server-java/ # Spring Boot alternative (experimental)
βββ google-apps-script/ # Google Sheets / Forms integration scripts
βββ docs/ # Deep-dive documentation
βββ e2e/ # Playwright end-to-end tests
β
βββ vercel.json # Root Vercel config (deploys website/)
βββ render.yaml # Render config (deploys server/)
βββ docker-compose.yml # Local dev with Docker
βββ package.json # Monorepo root (npm workspaces)
βββ .github/workflows/ # CI/CD GitHub Actions
Consistent development environments are crucial for the stability, performance, and scaling of NexaSphere. To prevent compatibility issues among contributors, this project supports Node.js versions v20.x (LTS) or v22.x (LTS).
- LTS (Long Term Support) Stability: Using LTS versions ensures the NexaSphere platform is built on a rock-solid foundation with long-term security updates.
- Modern Runtime Features: Node.js 20 includes native features such as the stable
fetchAPI, a built-in test runner, and refined ESM (ECMAScript Modules) support, which are heavily utilized across our backend services. - Dependency Compatibility: Our modern toolchain (including React 18, Vite 5, Express 4, and ESLint) is optimized and tested against Node.js 20. Running older or newer versions might result in unexpected compilation or runtime errors.
- Production Alignment: Since our backend is deployed on Render and Docker containers configured for Node 20, using the exact same version locally prevents environment-specific bugs.
We recommend using NVM (Node Version Manager) to manage Node versions. NVM allows you to switch between different Node versions effortlessly.
-
Install NVM: Run the installation script in your terminal using either
curlorwget:curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bashOR
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash -
Load NVM into the Shell: The installer script should automatically append the loading code to your profile file (such as
~/.zshrc,~/.bashrc, or~/.bash_profile). If it doesn't, manually append the following block:export NVM_DIR="$([ -z "${XDG_CONFIG_HOME-}" ] && echo "$HOME/.nvm" || echo "$XDG_CONFIG_HOME/nvm")" [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
-
Reload your Profile: Apply the changes by running:
source ~/.zshrc # Or for bash source ~/.bashrc
Windows does not natively support the UNIX nvm script. Instead, use nvm-windows:
-
Download the Installer: Go to the nvm-windows releases page and download the latest
nvm-setup.exeinstaller. -
Run the Installer: Follow the wizard to complete the installation. Ensure that the installation paths do not contain spaces to prevent issues with Node binaries.
-
Verify Installation: Open a new command prompt or PowerShell window and run:
nvm version
NexaSphere includes a .nvmrc file in the root directory. When you navigate to the project root, you can configure your shell to automatically switch to the correct version, or you can do it manually.
Run the following commands in the project root:
# Install the Node.js version specified in .nvmrc (v20)
nvm install 20
# Switch your current terminal session to Node.js v20
nvm use
# Verify that the active version is correct
node -vYou can configure your shell to automatically call nvm use whenever you change directories (cd) into a folder containing a .nvmrc file.
-
Zsh (~/.zshrc): Append the following function to your
~/.zshrcfile:# Place this at the end of your ~/.zshrc autoload -U add-zsh-hook load-nvmrc() { local nvmrc_path="$(nvm_find_nvmrc)" if [ -n "$nvmrc_path" ]; then local nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")") if [ "$nvmrc_node_version" = "N/A" ]; then nvm install elif [ "$nvmrc_node_version" != "$(nvm current)" ]; then nvm use fi elif [ "$(nvm current)" != "$(nvm version default)" ]; then echo "Reverting to nvm default..." nvm use default fi } add-zsh-hook chpwd load-nvmrc load-nvmrc
-
Bash (~/.bashrc): Append the following block to your
~/.bashrc:cdnvm() { cd "$@" || return if [ -f .nvmrc ]; then nvm use fi } alias cd="cdnvm"
If you find NVM slow during shell startup, you can use FNM, a fast, Rust-based alternative:
-
Installation:
- macOS (via Homebrew):
brew install fnm - Linux/macOS (via Curl):
curl -fsSL https://fnm.vercel.app/install | bash - Windows (via Scoop):
scoop install fnm
- macOS (via Homebrew):
-
Shell Integration: Add the following to your shell profile configuration (
~/.zshrc,~/.bashrc, or PowerShell profile):eval "$(fnm env --use-on-cd)"
This automatically checks for the
.nvmrcfile and switches the version seamlessly whenever you navigate into the project directory.
This occurs when NVM is installed, but your shell profile has not been reloaded or does not load NVM automatically.
- Fix: Verify that your profile file (
~/.zshrcfor Zsh or~/.bash_profile/~/.bashrcfor Bash) contains the NVM loading script. Then runsource ~/.zshrcorsource ~/.bashrcto reload.
This happens if you run nvm use but haven't installed Node v20 locally.
- Fix: Run
nvm install 20first, then runnvm use.
In PowerShell, running NVM or executing global node scripts may fail due to restricted execution policies.
-
Fix: Run PowerShell as an Administrator and execute:
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser
If you find yourself needing to run sudo npm install, stop immediately. Using sudo causes permission mismatches on your project directories.
- Fix: Since NVM installs Node.js and global packages under your user directory (
~/.nvm), it completely avoids permission issues. Discard thesudocommand and simply runnpm installinside the project root with the NVM-managed Node runtime active.
Some dependencies compile native C/C++ code. If compilation fails:
- macOS Fix: Install Xcode Command Line Tools:
xcode-select --install - Linux Fix: Install development tools:
sudo apt install build-essential - Windows Fix: Run
npm install --global --production windows-build-toolsfrom an elevated PowerShell command.
3 steps to get NexaSphere running locally.
git clone https://github.com/Ayushh-Sharmaa/NexaSphere.git
cd NexaSphere
npm installcp website/.env.example website/.env.local
cp admin-dashboard/.env.example admin-dashboard/.env.local
cp server/.env.example server/.envMinimum values needed in server/.env:
PORT=8787
NODE_ENV=development
CORS_ORIGIN=http://localhost:5175,http://localhost:5001
ADMIN_USERNAME=your-admin
ADMIN_PASSWORD=YourPass123!
ADMIN_EVENT_PASSWORD=EventPass456!npm run dev:all # Start website + admin + API togetherOr start services individually:
| Command | Service | URL |
|---|---|---|
npm run dev:website |
Website | http://localhost:5175 |
npm run dev:admin |
Admin Dashboard | http://localhost:5001 |
npm run dev:server |
Backend API | http://localhost:8787 |
| β | API Health Check | http://localhost:8787/health |
Tip: The website works in offline mode when
VITE_API_BASEis empty. All data comes from localStorage / static JSON files β no backend needed.
npm test # Website unit tests (Vitest)
npm run test:server # Server unit tests (Node test runner)
npx playwright test # End-to-end tests (Playwright)| Target | Config File | Notes |
|---|---|---|
| Vercel (frontend) | vercel.json |
Connect repo, set VITE_API_BASE env var |
| Render (backend) | render.yaml |
Set sync: false env vars in Render dashboard |
| Docker (backend) | server/Dockerfile |
docker build -t nexasphere-api ./server |
| Docker Compose | docker-compose.yml |
docker-compose up --build |
For full deployment instructions see docs/deployment.md.
See CONTRIBUTING.md for full guidelines.
This project is part of GSSoC 2026 β check the open issues for tasks labelled good first issue.
Deep-dive references live in the /docs directory:
| Document | Description |
|---|---|
| docs/architecture.md | System architecture & component overview |
| docs/api-reference.md | REST API endpoint reference |
| docs/deployment.md | Full deployment guide (Vercel / Render / Docker) |
| docs/database-backups.md | Database backup & restore procedures |
| docs/DATABASE_MIGRATIONS.md | Running & writing DB migrations |
Thanks to all contributors β€οΈ
MIT Β© NexaSphere Core Team