Upload source code
This commit is contained in:
56
src/server/routes/inspectionRoutes.ts
Normal file
56
src/server/routes/inspectionRoutes.ts
Normal file
@@ -0,0 +1,56 @@
|
||||
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;
|
||||
Reference in New Issue
Block a user