-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
121 lines (102 loc) · 3.43 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
const express = require('express');
const dotenv = require('dotenv');
const cors = require('cors');
const swaggerUi = require('swagger-ui-express');
const os = require('os');
const compression = require('compression');
const sequelize = require('./src/config/database');
const routes = require('./src/routes/index');
const authRoutes = require('./src/routes/auth');
const { rateLimiter } = require('./src/middleware/rateLimiter');
const { errorHandler } = require('./src/middleware/errorHandler');
const { swaggerSpec } = require('./src/config/swagger');
const { initializeApiClients } = require('./src/utils/apiClientInitializer');
const {
initializeUserPreferences,
getUserPreferences,
} = require('./src/utils/userPreferencesManager');
dotenv.config();
const app = express();
// Middleware
app.set('trust proxy', 1);
app.use(rateLimiter);
app.use(cors());
app.use(compression());
app.use(express.json());
// Swagger
app.use('/api-docs', swaggerUi.serve, swaggerUi.setup(swaggerSpec));
// Routes
app.use('/api/auth', authRoutes);
app.use('/api', routes);
// Error handling
app.use(errorHandler);
async function startServer() {
try {
// Initialize SQLite database
await sequelize.sync();
console.log(('Connected to SQLite database'));
await initializeUserPreferences();
const userPreferences = await getUserPreferences();
await initializeApiClients(userPreferences);
console.log(
(`
Welcome to ArtyLLaMa!
Say hello contact@artyllama.com
Report bugs to https://github.com/kroonen/ArtyLLaMa/issues
`)
);
console.log(('ArtyLLaMa Server Starting...'));
const PORT = process.env.PORT || 3001;
const HOST = '0.0.0.0';
const server = app.listen(PORT, HOST, () => {
console.log((`Server running on http://${HOST}:${PORT}`));
console.log((`Local access: http://localhost:${PORT}`));
console.log(
(`Swagger UI available at http://localhost:${PORT}/api-docs`)
);
const networkInterfaces = os.networkInterfaces();
Object.keys(networkInterfaces).forEach((interfaceName) => {
const interfaces = networkInterfaces[interfaceName];
interfaces.forEach((iface) => {
if (iface.family === 'IPv4' && !iface.internal) {
console.log(
(
`Network access (${interfaceName}): http://${iface.address}:${PORT}`
)
);
console.log(
(
`Swagger UI network access (${interfaceName}): http://${iface.address}:${PORT}/api-docs`
)
);
}
});
});
});
server.timeout = 120000; // Set to 2 minutes (120,000 ms)
process.on('exit', () => {
console.log(('Generating session summary...'));
// artifactManager.generateSessionSummary(); Not implemented yet
console.log(('Session summary generated. Goodbye!'));
});
process.on('unhandledRejection', (reason, promise) => {
console.error(
('Unhandled Rejection at:'),
promise,
('reason:'),
reason
);
});
process.on('uncaughtException', (error) => {
console.error(('Uncaught Exception:'), error);
process.exit(1);
});
} catch (error) {
console.error('Error during server initialization:', error);
process.exit(1);
}
}
startServer().catch((error) => {
console.error('Failed to start the server:', error);
process.exit(1);
});