Code review fixes, Docker, and deployment config
- Fix tsconfig: switch to ESNext/Bundler module resolution (tsx compatible) - Sanitize file extensions against path traversal (^.[a-zA-Z0-9]+$ only) - Sanitize Content-Disposition filename to prevent header injection - Extract tokenCookieOptions helper to eliminate duplication across auth handlers - Remove unused baseUrl param from fileListPage - Add Dockerfile (multi-stage build with alpine + native tools for bcrypt) - Add docker-compose.yml with named volume for data persistence - Add .env.example with all environment variables documented Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -34,7 +34,8 @@ export const filesApiRoutes: FastifyPluginAsync<{ deps: Deps }> = async (app, {
|
||||
|
||||
const fileBuffer = await data.toBuffer();
|
||||
const id = nanoid();
|
||||
const ext = extname(data.filename);
|
||||
const rawExt = extname(data.filename);
|
||||
const ext = /^\.[a-zA-Z0-9]+$/.test(rawExt) ? rawExt : '';
|
||||
const storedName = `${id}${ext}`;
|
||||
|
||||
await saveFile(config.uploadDir, storedName, fileBuffer);
|
||||
|
||||
Reference in New Issue
Block a user