Files
GPI/src/server/routes/inspectionRoutes.ts
2026-03-12 19:36:34 +00:00

57 lines
1.9 KiB
TypeScript

import { Router } from 'express';
import * as inspectionController from '../controllers/inspectionController.js';
import { extractUser, requireUser } from '../middleware/roleMiddleware.js';
import multer from 'multer';
import path from 'path';
import { v4 as uuidv4 } from 'uuid';
import os from 'os';
const router = Router();
// Configure Multer for uploads
// In serverless environments (Netlify), we must use /tmp or memory
// We use /tmp but be aware files are ephemeral in serverless
const uploadsDir = path.join(os.tmpdir(), 'uploads');
// Ensure uploads directory exists (safe in /tmp)
import fs from 'fs';
if (!fs.existsSync(uploadsDir)) {
fs.mkdirSync(uploadsDir, { recursive: true });
}
const storage = multer.diskStorage({
destination: (req, file, cb) => {
cb(null, uploadsDir);
},
filename: (req, file, cb) => {
const uniqueSuffix = `${Date.now()}-${uuidv4()}`;
cb(null, `${uniqueSuffix}${path.extname(file.originalname)}`);
}
});
const upload = multer({
storage,
limits: { fileSize: 500 * 1024 }, // 500KB limit
fileFilter: (req, file, cb) => {
if (file.mimetype === 'image/jpeg' || file.mimetype === 'image/jpg') {
cb(null, true);
} else {
cb(new Error('Only JPG/JPEG images are allowed'));
}
}
});
// Upload route
router.post('/upload', extractUser, requireUser, upload.single('photo'), inspectionController.uploadPhoto);
// Public routes (read-only)
router.get('/', extractUser, inspectionController.getAllInspections);
router.get('/project/:projectId', extractUser, inspectionController.getInspectionsByProject);
// Protected routes (require user permission)
router.post('/', extractUser, requireUser, inspectionController.createInspection);
router.put('/:id', extractUser, requireUser, inspectionController.updateInspection);
router.delete('/:id', extractUser, requireUser, inspectionController.deleteInspection);
export default router;