-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathserver.js
More file actions
94 lines (85 loc) · 3.07 KB
/
server.js
File metadata and controls
94 lines (85 loc) · 3.07 KB
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
const express = require('express');
const fs = require('fs').promises;
const path = require('path');
const config = require('config');
const app = express();
const port = 3000;
// Middleware to parse JSON bodies
app.use(express.json());
app.use(express.static('public'));
// Request logging middleware
app.use((req, res, next) => {
const timestamp = new Date().toISOString();
console.log(`[${timestamp}] ${req.method} ${req.url}`);
next();
});
// Error handling middleware
app.use((err, req, res, next) => {
console.error('Unhandled error:', err);
res.status(500).json({
error: 'Internal Server Error',
message: err.message,
stack: process.env.NODE_ENV === 'development' ? err.stack : undefined
});
});
// Routes
app.get('/', (req, res) => {
res.sendFile(path.join(__dirname, 'public', 'index.html'));
});
// Get the configured timezone
app.get('/api/timezone', (req, res) => {
res.json({ timezone: config.get('timezone') });
});
app.get('/api/visits', async (req, res) => {
try {
console.log('Fetching all scheduled visits...');
const visits = await require('./index.js').readScheduledVisits();
console.log(`Found ${visits.length} scheduled visits`);
res.json(visits);
} catch (error) {
console.error('Error fetching scheduled visits:', error);
res.status(500).json({
error: 'Failed to read scheduled visits',
message: error.message,
stack: process.env.NODE_ENV === 'development' ? error.stack : undefined
});
}
});
app.post('/api/visits', async (req, res) => {
try {
console.log('Adding new scheduled visit:', req.body);
const visit = await require('./index.js').addScheduledVisit(req.body);
console.log('Successfully added visit:', visit);
res.json(visit);
} catch (error) {
console.error('Error adding scheduled visit:', error);
res.status(500).json({
error: 'Failed to save scheduled visit',
message: error.message,
stack: process.env.NODE_ENV === 'development' ? error.stack : undefined
});
}
});
app.delete('/api/visits/:id', async (req, res) => {
try {
console.log(`Deleting scheduled visit with ID: ${req.params.id}`);
await require('./index.js').deleteScheduledVisit(req.params.id);
console.log('Successfully deleted visit');
res.json({ success: true });
} catch (error) {
console.error('Error deleting scheduled visit:', error);
res.status(500).json({
error: 'Failed to delete scheduled visit',
message: error.message,
stack: process.env.NODE_ENV === 'development' ? error.stack : undefined
});
}
});
// Start the server
const server = app.listen(port, '0.0.0.0', () => {
console.log(`Server running at:`);
console.log(`- Local: http://localhost:${port}`);
console.log(`- Network: http://0.0.0.0:${port}`);
console.log(`- Timezone: ${config.get('timezone')}`);
console.log(`- Environment: ${process.env.NODE_ENV || 'production'}`);
});