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 searchRoutes = require('./routes/search'); const contactFormRoutes = require('./routes/contactForm'); const usersRoutes = require('./routes/users'); const analytics_reportsRoutes = require('./routes/analytics_reports'); const customersRoutes = require('./routes/customers'); const data_sourcesRoutes = require('./routes/data_sources'); const finance_accountsRoutes = require('./routes/finance_accounts'); const hr_employeesRoutes = require('./routes/hr_employees'); const inventory_itemsRoutes = require('./routes/inventory_items'); const projectsRoutes = require('./routes/projects'); const sales_ordersRoutes = require('./routes/sales_orders'); const suppliersRoutes = require('./routes/suppliers'); const transactionsRoutes = require('./routes/transactions'); 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: "AdaptiveEdge ERP", description: "AdaptiveEdge ERP 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.enable('trust proxy'); app.use('/api/users', passport.authenticate('jwt', {session: false}), usersRoutes); app.use('/api/analytics_reports', passport.authenticate('jwt', {session: false}), analytics_reportsRoutes); app.use('/api/customers', passport.authenticate('jwt', {session: false}), customersRoutes); app.use('/api/data_sources', passport.authenticate('jwt', {session: false}), data_sourcesRoutes); app.use('/api/finance_accounts', passport.authenticate('jwt', {session: false}), finance_accountsRoutes); app.use('/api/hr_employees', passport.authenticate('jwt', {session: false}), hr_employeesRoutes); app.use('/api/inventory_items', passport.authenticate('jwt', {session: false}), inventory_itemsRoutes); app.use('/api/projects', passport.authenticate('jwt', {session: false}), projectsRoutes); app.use('/api/sales_orders', passport.authenticate('jwt', {session: false}), sales_ordersRoutes); app.use('/api/suppliers', passport.authenticate('jwt', {session: false}), suppliersRoutes); app.use('/api/transactions', passport.authenticate('jwt', {session: false}), transactionsRoutes); app.use('/api/contact-form', contactFormRoutes); app.use( '/api/search', passport.authenticate('jwt', { session: false }), searchRoutes); 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;