-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
38 lines (31 loc) · 1.15 KB
/
Copy pathserver.js
File metadata and controls
38 lines (31 loc) · 1.15 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
/**
* Express middleware example
* Run from repo root: npm run build && node example/express/server.js
*/
const express = require('express');
const { apiLoggerExpress, validateLoggerOptions } = require('../../dist');
const options = {
mongoUri: process.env.MONGO_URI || 'mongodb://localhost:27017',
databaseName: 'api_logger_example',
collectionName: 'express_logs',
maskFields: ['password', 'token'],
logResponseBody: true,
logRequestBody: true,
getUserInfo: (req) => (req.user ? { id: req.user.id, email: req.user.email } : undefined)
};
validateLoggerOptions(options);
const app = express();
app.use(express.json());
app.use(apiLoggerExpress(options));
app.get('/health', (req, res) => res.json({ ok: true }));
app.get('/api/users', (req, res) => {
res.json({ users: [{ id: 1, email: 'user@example.com' }] });
});
app.post('/api/login', (req, res) => {
// In real app you'd authenticate; here we just echo back
res.json({ message: 'ok', user: { email: req.body?.email || 'anonymous' } });
});
const port = Number(process.env.PORT) || 3000;
app.listen(port, () => {
console.log(`Express example listening on http://localhost:${port}`);
});