148 lines
4.2 KiB
JavaScript
148 lines
4.2 KiB
JavaScript
|
|
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;
|