210 lines
4.5 KiB
JavaScript
210 lines
4.5 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 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 usersRoutes = require('./routes/users');
|
|
|
|
const accountsRoutes = require('./routes/accounts');
|
|
|
|
const billsRoutes = require('./routes/bills');
|
|
|
|
const communicationsRoutes = require('./routes/communications');
|
|
|
|
const equipmentRoutes = require('./routes/equipment');
|
|
|
|
const issuesRoutes = require('./routes/issues');
|
|
|
|
const maintenance_tasksRoutes = require('./routes/maintenance_tasks');
|
|
|
|
const meter_readingsRoutes = require('./routes/meter_readings');
|
|
|
|
const paymentsRoutes = require('./routes/payments');
|
|
|
|
const rolesRoutes = require('./routes/roles');
|
|
|
|
const permissionsRoutes = require('./routes/permissions');
|
|
|
|
const tenantsRoutes = require('./routes/tenants');
|
|
|
|
const options = {
|
|
definition: {
|
|
openapi: '3.0.0',
|
|
info: {
|
|
version: '1.0.0',
|
|
title: 'bms',
|
|
description:
|
|
'bms Online REST API for Testing and Prototyping application. You can perform all major operations with your entities - create, delete and etc.',
|
|
},
|
|
servers: [
|
|
{
|
|
url: 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 = 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/accounts',
|
|
passport.authenticate('jwt', { session: false }),
|
|
accountsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/bills',
|
|
passport.authenticate('jwt', { session: false }),
|
|
billsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/communications',
|
|
passport.authenticate('jwt', { session: false }),
|
|
communicationsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/equipment',
|
|
passport.authenticate('jwt', { session: false }),
|
|
equipmentRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/issues',
|
|
passport.authenticate('jwt', { session: false }),
|
|
issuesRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/maintenance_tasks',
|
|
passport.authenticate('jwt', { session: false }),
|
|
maintenance_tasksRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/meter_readings',
|
|
passport.authenticate('jwt', { session: false }),
|
|
meter_readingsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/payments',
|
|
passport.authenticate('jwt', { session: false }),
|
|
paymentsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/roles',
|
|
passport.authenticate('jwt', { session: false }),
|
|
rolesRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/permissions',
|
|
passport.authenticate('jwt', { session: false }),
|
|
permissionsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/tenants',
|
|
passport.authenticate('jwt', { session: false }),
|
|
tenantsRoutes,
|
|
);
|
|
|
|
app.use(
|
|
'/api/openai',
|
|
passport.authenticate('jwt', { session: false }),
|
|
openaiRoutes,
|
|
);
|
|
|
|
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;
|