- Backend: GET /api/export/{tasks,users,activities}?month=YYYY-MM
- Frontend: Export panel on Reports page (CEO/CTO/Manager only)
- API: apiExportCsv helper for browser download
45 lines
1.1 KiB
JavaScript
45 lines
1.1 KiB
JavaScript
import express from 'express';
|
|
import cors from 'cors';
|
|
import { initDB } from './db.js';
|
|
import authRoutes from './routes/auth.js';
|
|
import taskRoutes from './routes/tasks.js';
|
|
import exportRoutes from './routes/export.js';
|
|
|
|
const app = express();
|
|
const PORT = process.env.PORT || 3001;
|
|
|
|
app.use(cors());
|
|
app.use(express.json());
|
|
|
|
// Routes
|
|
app.use('/api/auth', authRoutes);
|
|
app.use('/api/tasks', taskRoutes);
|
|
app.use('/api/export', exportRoutes);
|
|
|
|
// Health check
|
|
app.get('/api/health', (_req, res) => {
|
|
res.json({ status: 'ok', timestamp: new Date().toISOString() });
|
|
});
|
|
|
|
// Initialize DB and start server
|
|
// Initialize DB and start server
|
|
async function start() {
|
|
try {
|
|
await initDB();
|
|
if (process.env.NODE_ENV !== 'test') {
|
|
app.listen(PORT, () => {
|
|
console.log(`🚀 Backend server running on port ${PORT}`);
|
|
});
|
|
}
|
|
} catch (err) {
|
|
console.error('❌ Failed to start server:', err);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
if (process.env.NODE_ENV !== 'test') {
|
|
start();
|
|
}
|
|
|
|
export { app, start };
|