2026-03-13 15:34:13 +00:00

268 lines
5.8 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 openaiRoutes = require('./routes/openai');
const usersRoutes = require('./routes/users');
const rolesRoutes = require('./routes/roles');
const permissionsRoutes = require('./routes/permissions');
const customersRoutes = require('./routes/customers');
const addressesRoutes = require('./routes/addresses');
const product_categoriesRoutes = require('./routes/product_categories');
const productsRoutes = require('./routes/products');
const product_variantsRoutes = require('./routes/product_variants');
const inventory_locationsRoutes = require('./routes/inventory_locations');
const inventory_itemsRoutes = require('./routes/inventory_items');
const inventory_movementsRoutes = require('./routes/inventory_movements');
const ordersRoutes = require('./routes/orders');
const order_itemsRoutes = require('./routes/order_items');
const shipmentsRoutes = require('./routes/shipments');
const paymentsRoutes = require('./routes/payments');
const refundsRoutes = require('./routes/refunds');
const discount_codesRoutes = require('./routes/discount_codes');
const order_status_eventsRoutes = require('./routes/order_status_events');
const testRoutes = require('./routes/test');
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: 'Store Ops Manager',
description:
'Store Ops Manager 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/customers',
passport.authenticate('jwt', { session: false }),
customersRoutes,
);
app.use(
'/api/addresses',
passport.authenticate('jwt', { session: false }),
addressesRoutes,
);
app.use(
'/api/product_categories',
passport.authenticate('jwt', { session: false }),
product_categoriesRoutes,
);
app.use(
'/api/products',
passport.authenticate('jwt', { session: false }),
productsRoutes,
);
app.use(
'/api/product_variants',
passport.authenticate('jwt', { session: false }),
product_variantsRoutes,
);
app.use(
'/api/inventory_locations',
passport.authenticate('jwt', { session: false }),
inventory_locationsRoutes,
);
app.use(
'/api/inventory_items',
passport.authenticate('jwt', { session: false }),
inventory_itemsRoutes,
);
app.use(
'/api/inventory_movements',
passport.authenticate('jwt', { session: false }),
inventory_movementsRoutes,
);
app.use(
'/api/orders',
passport.authenticate('jwt', { session: false }),
ordersRoutes,
);
app.use(
'/api/order_items',
passport.authenticate('jwt', { session: false }),
order_itemsRoutes,
);
app.use(
'/api/shipments',
passport.authenticate('jwt', { session: false }),
shipmentsRoutes,
);
app.use(
'/api/payments',
passport.authenticate('jwt', { session: false }),
paymentsRoutes,
);
app.use(
'/api/refunds',
passport.authenticate('jwt', { session: false }),
refundsRoutes,
);
app.use(
'/api/discount_codes',
passport.authenticate('jwt', { session: false }),
discount_codesRoutes,
);
app.use(
'/api/order_status_events',
passport.authenticate('jwt', { session: false }),
order_status_eventsRoutes,
);
app.use(
'/api/test',
passport.authenticate('jwt', { session: false }),
testRoutes,
);
app.use(
'/api/openai',
passport.authenticate('jwt', { session: false }),
openaiRoutes,
);
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;