39950-vm/backend/src/index.js
2026-05-11 09:55:08 +00:00

213 lines
6.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 sqlRoutes = require('./routes/sql');
const pexelsRoutes = require('./routes/pexels');
const openaiRoutes = require('./routes/openai');
const usersRoutes = require('./routes/users');
const rolesRoutes = require('./routes/roles');
const permissionsRoutes = require('./routes/permissions');
const practice_groupsRoutes = require('./routes/practice_groups');
const matter_typesRoutes = require('./routes/matter_types');
const data_classificationsRoutes = require('./routes/data_classifications');
const ai_toolsRoutes = require('./routes/ai_tools');
const vendorsRoutes = require('./routes/vendors');
const ai_use_casesRoutes = require('./routes/ai_use_cases');
const approval_stepsRoutes = require('./routes/approval_steps');
const vendor_risk_assessmentsRoutes = require('./routes/vendor_risk_assessments');
const policiesRoutes = require('./routes/policies');
const human_review_checklistsRoutes = require('./routes/human_review_checklists');
const checklist_itemsRoutes = require('./routes/checklist_items');
const training_coursesRoutes = require('./routes/training_courses');
const training_requirementsRoutes = require('./routes/training_requirements');
const user_training_recordsRoutes = require('./routes/user_training_records');
const tool_entitlementsRoutes = require('./routes/tool_entitlements');
const workflow_runsRoutes = require('./routes/workflow_runs');
const review_exceptionsRoutes = require('./routes/review_exceptions');
const integrationsRoutes = require('./routes/integrations');
const roles_catalogRoutes = require('./routes/roles_catalog');
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: "Legal AI Governance Hub",
description: "Legal AI Governance Hub 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/roles', passport.authenticate('jwt', {session: false}), rolesRoutes);
app.use('/api/permissions', passport.authenticate('jwt', {session: false}), permissionsRoutes);
app.use('/api/practice_groups', passport.authenticate('jwt', {session: false}), practice_groupsRoutes);
app.use('/api/matter_types', passport.authenticate('jwt', {session: false}), matter_typesRoutes);
app.use('/api/data_classifications', passport.authenticate('jwt', {session: false}), data_classificationsRoutes);
app.use('/api/ai_tools', passport.authenticate('jwt', {session: false}), ai_toolsRoutes);
app.use('/api/vendors', passport.authenticate('jwt', {session: false}), vendorsRoutes);
app.use('/api/ai_use_cases', passport.authenticate('jwt', {session: false}), ai_use_casesRoutes);
app.use('/api/approval_steps', passport.authenticate('jwt', {session: false}), approval_stepsRoutes);
app.use('/api/vendor_risk_assessments', passport.authenticate('jwt', {session: false}), vendor_risk_assessmentsRoutes);
app.use('/api/policies', passport.authenticate('jwt', {session: false}), policiesRoutes);
app.use('/api/human_review_checklists', passport.authenticate('jwt', {session: false}), human_review_checklistsRoutes);
app.use('/api/checklist_items', passport.authenticate('jwt', {session: false}), checklist_itemsRoutes);
app.use('/api/training_courses', passport.authenticate('jwt', {session: false}), training_coursesRoutes);
app.use('/api/training_requirements', passport.authenticate('jwt', {session: false}), training_requirementsRoutes);
app.use('/api/user_training_records', passport.authenticate('jwt', {session: false}), user_training_recordsRoutes);
app.use('/api/tool_entitlements', passport.authenticate('jwt', {session: false}), tool_entitlementsRoutes);
app.use('/api/workflow_runs', passport.authenticate('jwt', {session: false}), workflow_runsRoutes);
app.use('/api/review_exceptions', passport.authenticate('jwt', {session: false}), review_exceptionsRoutes);
app.use('/api/integrations', passport.authenticate('jwt', {session: false}), integrationsRoutes);
app.use('/api/roles_catalog', passport.authenticate('jwt', {session: false}), roles_catalogRoutes);
app.use(
'/api/openai',
passport.authenticate('jwt', { session: false }),
openaiRoutes,
);
app.use(
'/api/ai',
passport.authenticate('jwt', { session: false }),
openaiRoutes,
);
app.use(
'/api/search',
passport.authenticate('jwt', { session: false }),
searchRoutes);
app.use(
'/api/sql',
passport.authenticate('jwt', { session: false }),
sqlRoutes);
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;
app.listen(PORT, () => {
console.log(`Listening on port ${PORT}`);
});
module.exports = app;