const express = require('express'); const cors = require('cors'); const app = express(); const passport = require('passport'); const path = require('path'); const fs = require('fs'); const bodyParser = require('body-parser'); const db = require('./db/models'); const config = require('./config'); const swaggerUI = require('swagger-ui-express'); const swaggerJsDoc = require('swagger-jsdoc'); const authRoutes = require('./routes/auth'); const fileRoutes = require('./routes/file'); const searchRoutes = require('./routes/search'); const pexelsRoutes = require('./routes/pexels'); const organizationForAuthRoutes = require('./routes/organizationLogin'); const openaiRoutes = require('./routes/openai'); const contactFormRoutes = require('./routes/contactForm'); const usersRoutes = require('./routes/users'); const calendar_eventsRoutes = require('./routes/calendar_events'); const casesRoutes = require('./routes/cases'); const donors_suppliersRoutes = require('./routes/donors_suppliers'); const injuriesRoutes = require('./routes/injuries'); const medication_remindersRoutes = require('./routes/medication_reminders'); const permits_licensesRoutes = require('./routes/permits_licenses'); const rehabilitation_facilitiesRoutes = require('./routes/rehabilitation_facilities'); const rescue_reportsRoutes = require('./routes/rescue_reports'); const resourcesRoutes = require('./routes/resources'); const speciesRoutes = require('./routes/species'); const treatment_plansRoutes = require('./routes/treatment_plans'); const triage_notesRoutes = require('./routes/triage_notes'); const volunteersRoutes = require('./routes/volunteers'); const rolesRoutes = require('./routes/roles'); const permissionsRoutes = require('./routes/permissions'); const rehabilitationfacilityRoutes = require('./routes/rehabilitationfacility'); const getBaseUrl = (url) => { if (!url) return ''; return url.endsWith('/api') ? url.slice(0, -4) : url; }; const options = { definition: { openapi: '3.0.0', info: { version: '1.0.0', title: 'WildTrackr', description: 'WildTrackr Online REST API for Testing and Prototyping application. You can perform all major operations with your entities - create, delete and etc.', }, servers: [ { url: getBaseUrl(process.env.NEXT_PUBLIC_BACK_API) || config.swaggerUrl, description: 'Development server', }, ], components: { securitySchemes: { bearerAuth: { type: 'http', scheme: 'bearer', bearerFormat: 'JWT', }, }, responses: { UnauthorizedError: { description: 'Access token is missing or invalid', }, }, }, security: [ { bearerAuth: [], }, ], }, apis: ['./src/routes/*.js'], }; const specs = swaggerJsDoc(options); app.use( '/api-docs', function (req, res, next) { swaggerUI.host = getBaseUrl(process.env.NEXT_PUBLIC_BACK_API) || req.get('host'); next(); }, swaggerUI.serve, swaggerUI.setup(specs), ); app.use(cors({ origin: true })); require('./auth/auth'); app.use(bodyParser.json()); app.use('/api/auth', authRoutes); app.use('/api/file', fileRoutes); app.use('/api/pexels', pexelsRoutes); app.enable('trust proxy'); app.use( '/api/users', passport.authenticate('jwt', { session: false }), usersRoutes, ); app.use( '/api/calendar_events', passport.authenticate('jwt', { session: false }), calendar_eventsRoutes, ); app.use( '/api/cases', passport.authenticate('jwt', { session: false }), casesRoutes, ); app.use( '/api/donors_suppliers', passport.authenticate('jwt', { session: false }), donors_suppliersRoutes, ); app.use( '/api/injuries', passport.authenticate('jwt', { session: false }), injuriesRoutes, ); app.use( '/api/medication_reminders', passport.authenticate('jwt', { session: false }), medication_remindersRoutes, ); app.use( '/api/permits_licenses', passport.authenticate('jwt', { session: false }), permits_licensesRoutes, ); app.use( '/api/rehabilitation_facilities', passport.authenticate('jwt', { session: false }), rehabilitation_facilitiesRoutes, ); app.use( '/api/rescue_reports', passport.authenticate('jwt', { session: false }), rescue_reportsRoutes, ); app.use( '/api/resources', passport.authenticate('jwt', { session: false }), resourcesRoutes, ); app.use( '/api/species', passport.authenticate('jwt', { session: false }), speciesRoutes, ); app.use( '/api/treatment_plans', passport.authenticate('jwt', { session: false }), treatment_plansRoutes, ); app.use( '/api/triage_notes', passport.authenticate('jwt', { session: false }), triage_notesRoutes, ); app.use( '/api/volunteers', passport.authenticate('jwt', { session: false }), volunteersRoutes, ); app.use( '/api/roles', passport.authenticate('jwt', { session: false }), rolesRoutes, ); app.use( '/api/permissions', passport.authenticate('jwt', { session: false }), permissionsRoutes, ); app.use( '/api/rehabilitationfacility', passport.authenticate('jwt', { session: false }), rehabilitationfacilityRoutes, ); app.use( '/api/openai', passport.authenticate('jwt', { session: false }), openaiRoutes, ); app.use('/api/contact-form', contactFormRoutes); app.use( '/api/search', passport.authenticate('jwt', { session: false }), searchRoutes, ); app.use('/api/org-for-auth', organizationForAuthRoutes); const publicDir = path.join(__dirname, '../public'); if (fs.existsSync(publicDir)) { app.use('/', express.static(publicDir)); app.get('*', function (request, response) { response.sendFile(path.resolve(publicDir, 'index.html')); }); } const PORT = process.env.NODE_ENV === 'dev_stage' ? 3000 : 8080; db.sequelize.sync().then(function () { app.listen(PORT, () => { console.log(`Listening on port ${PORT}`); }); }); module.exports = app;