2023-04-30 22:04:13 +02:00
|
|
|
import { Signale } from 'signale';
|
|
|
|
import ConfigHandler from './assets/configHandler';
|
|
|
|
import express, { Request, Response } from 'express';
|
2023-05-02 18:23:47 +02:00
|
|
|
import fileUpload from 'express-fileupload';
|
2023-04-30 22:04:13 +02:00
|
|
|
import { PrismaClient } from '@prisma/client';
|
2023-05-01 22:15:35 +02:00
|
|
|
import * as eta from 'eta';
|
2023-05-08 23:30:19 +02:00
|
|
|
import bodyParser from 'body-parser';
|
2023-05-01 22:15:35 +02:00
|
|
|
|
2023-05-01 00:07:13 +02:00
|
|
|
import routes from './routes/index.js';
|
2023-04-30 22:04:13 +02:00
|
|
|
|
|
|
|
// Get app directory.
|
2023-05-01 00:14:16 +02:00
|
|
|
export const __path = process.argv[1];
|
2023-04-30 22:04:13 +02:00
|
|
|
|
|
|
|
const logger_settings = {
|
|
|
|
disabled: false,
|
|
|
|
logLevel: 'info',
|
|
|
|
scope: 'Core',
|
|
|
|
stream: process.stdout,
|
|
|
|
displayFilename: true
|
|
|
|
};
|
|
|
|
|
|
|
|
const coreLogger = new Signale(logger_settings);
|
2023-05-01 00:07:13 +02:00
|
|
|
export const log = {
|
2023-04-30 22:04:13 +02:00
|
|
|
core: coreLogger,
|
|
|
|
db: coreLogger.scope('DB'),
|
|
|
|
web: coreLogger.scope('WEB')
|
|
|
|
};
|
|
|
|
|
|
|
|
// Create a new config instance.
|
2023-05-01 22:15:35 +02:00
|
|
|
export const config = new ConfigHandler(__path + '/config.json', {
|
2023-04-30 22:04:13 +02:00
|
|
|
db_connection_string: 'mysql://USER:PASSWORD@HOST:3306/DATABASE',
|
|
|
|
http_listen_address: '127.0.0.1',
|
2023-05-01 22:15:35 +02:00
|
|
|
http_port: 3000,
|
|
|
|
debug: false
|
2023-04-30 22:04:13 +02:00
|
|
|
});
|
|
|
|
|
2023-05-01 00:07:13 +02:00
|
|
|
export const prisma = new PrismaClient({
|
2023-04-30 22:04:13 +02:00
|
|
|
datasources: {
|
|
|
|
db: {
|
|
|
|
url: config.global.db_connection_string
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-05-01 00:07:13 +02:00
|
|
|
export const app = express();
|
2023-05-04 20:21:10 +02:00
|
|
|
app.set('x-powered-by', false);
|
|
|
|
app.engine('html', eta.renderFile);
|
2023-05-08 23:30:19 +02:00
|
|
|
|
|
|
|
// app.use(cors());
|
|
|
|
app.use(bodyParser.urlencoded({ extended: false }));
|
|
|
|
|
|
|
|
// Using bodyParser to parse JSON bodies into JS objects
|
|
|
|
app.use(bodyParser.json());
|
|
|
|
|
2023-05-02 18:23:47 +02:00
|
|
|
app.use(fileUpload());
|
2023-05-04 20:21:10 +02:00
|
|
|
app.use(express.static(__path + '/static'));
|
2023-05-15 02:08:43 +02:00
|
|
|
|
2023-05-04 20:21:10 +02:00
|
|
|
app.use(routes);
|
2023-04-30 22:04:13 +02:00
|
|
|
|
|
|
|
app.listen(config.global.http_port, config.global.http_listen_address, () => {
|
|
|
|
log.web.info(`Listening at http://${config.global.http_listen_address}:${config.global.http_port}`);
|
|
|
|
});
|