# ============================================================= # Pelagia Portal — Environment Variables # Copy this file to .env.local and fill in your values # # DEVELOPMENT (NODE_ENV=development, i.e. `pnpm dev`): # - File uploads are stored locally in .dev-uploads/ — no R2 needed # - Emails are logged to the terminal — no Resend key needed # - Only AUTH + DATABASE vars are required to run the app locally # # PRODUCTION (NODE_ENV=production, i.e. `pnpm build && pnpm start`): # - All sections below must be filled in # ============================================================= # ── Auth ───────────────────────────────────────────────────── NEXTAUTH_SECRET=your-32-char-secret-here-generate-with-openssl NEXTAUTH_URL=http://localhost:3000 # ── Database ────────────────────────────────────────────────── # Local PostgreSQL or Supabase DATABASE_URL="postgresql://postgres:postgres@localhost:5432/pelagia_portal" # Supabase connection pooling URL (use for serverless deployments) # DATABASE_POOL_URL= # ── Cloudflare R2 Storage (production only) ────────────────── # Not required in development — files are stored in .dev-uploads/ R2_ACCOUNT_ID=your-cloudflare-account-id R2_ACCESS_KEY_ID=your-r2-access-key-id R2_SECRET_ACCESS_KEY=your-r2-secret-access-key R2_BUCKET_NAME=pelagia-portal R2_PUBLIC_URL=https://your-bucket.your-account.r2.cloudflarestorage.com # ── Email / Resend (production only) ───────────────────────── # Not required in development — emails are printed to the terminal RESEND_API_KEY=re_xxxxxxxxxxxxxxxxxxxx EMAIL_FROM=noreply@pelagiaportal.com EMAIL_FROM_NAME="Pelagia Portal" # ── GST Lookup microservice ─────────────────────────────────── # Run the GstService/ microservice alongside the app. # Development default (localhost:3002) is used if this is unset. # Start the service with: cd GstService && npm run dev GST_SERVICE_URL=http://localhost:3003