add logging to server
This commit is contained in:
parent
50aac161c4
commit
1a624f38b9
11
server/logger.ts
Normal file
11
server/logger.ts
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import { createWriteStream } from "fs";
|
||||||
|
import pino, { multistream } from "pino";
|
||||||
|
|
||||||
|
// const streams = [
|
||||||
|
// { stream: process.stdout },
|
||||||
|
// { stream: createWriteStream("/logs/logfile.log", { flags: "a" }) },
|
||||||
|
// ];
|
||||||
|
|
||||||
|
// export default pino({}, multistream(streams));
|
||||||
|
|
||||||
|
export default pino({});
|
1645
server/package-lock.json
generated
1645
server/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -7,17 +7,19 @@
|
|||||||
"test": "echo 'No tests set up for the server.'",
|
"test": "echo 'No tests set up for the server.'",
|
||||||
"coverage": "echo 'No coverage set up for the server.'",
|
"coverage": "echo 'No coverage set up for the server.'",
|
||||||
"build": "npx tsc",
|
"build": "npx tsc",
|
||||||
"dev": "npx nodemon ./server.ts"
|
"dev": "npx nodemon ./server.ts | npx pino-pretty"
|
||||||
},
|
},
|
||||||
"author": "Maxime Cannoodt (mcndt)",
|
"author": "Maxime Cannoodt (mcndt)",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@prisma/client": "^4.0.0",
|
"@prisma/client": "^4.0.0",
|
||||||
"cors": "^2.8.5",
|
|
||||||
"dotenv": "^16.0.1",
|
"dotenv": "^16.0.1",
|
||||||
"express": "^4.18.1",
|
"express": "^4.18.1",
|
||||||
"express-rate-limit": "^6.4.0",
|
"express-rate-limit": "^6.4.0",
|
||||||
"helmet": "^5.1.0",
|
"helmet": "^5.1.0",
|
||||||
|
"pino": "^8.1.0",
|
||||||
|
"pino-http": "^8.1.1",
|
||||||
|
"pino-pretty": "^8.1.0",
|
||||||
"sqlite3": "^5.0.8"
|
"sqlite3": "^5.0.8"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
@ -1,16 +1,25 @@
|
|||||||
import "dotenv/config";
|
import "dotenv/config";
|
||||||
import express, { Express, Request } from "express";
|
import express, { Express, Request } from "express";
|
||||||
import cors from "cors";
|
|
||||||
import { PrismaClient, EncryptedNote } from "@prisma/client";
|
import { PrismaClient, EncryptedNote } from "@prisma/client";
|
||||||
import { addDays } from "./util";
|
import { addDays } from "./util";
|
||||||
import helmet from "helmet";
|
import helmet from "helmet";
|
||||||
import rateLimit from "express-rate-limit";
|
import rateLimit from "express-rate-limit";
|
||||||
|
import pinoHttp from "pino-http";
|
||||||
|
import logger from "./logger";
|
||||||
|
|
||||||
// Initialize middleware clients
|
// Initialize middleware clients
|
||||||
const prisma = new PrismaClient();
|
const prisma = new PrismaClient();
|
||||||
|
|
||||||
const app: Express = express();
|
const app: Express = express();
|
||||||
app.use(express.json());
|
app.use(express.json());
|
||||||
|
|
||||||
|
// configure logging
|
||||||
|
app.use(
|
||||||
|
pinoHttp({
|
||||||
|
logger: logger,
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
|
// configure Helmet and CORS
|
||||||
app.use(
|
app.use(
|
||||||
helmet({
|
helmet({
|
||||||
crossOriginResourcePolicy: {
|
crossOriginResourcePolicy: {
|
||||||
@ -29,7 +38,7 @@ const postLimiter = rateLimit({
|
|||||||
|
|
||||||
// start the Express server
|
// start the Express server
|
||||||
app.listen(process.env.PORT, () => {
|
app.listen(process.env.PORT, () => {
|
||||||
console.log(`server started at port ${process.env.PORT}`);
|
logger.info(`server started at port ${process.env.PORT}`);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Post new encrypted note
|
// Post new encrypted note
|
||||||
@ -78,7 +87,7 @@ const interval =
|
|||||||
1000;
|
1000;
|
||||||
setInterval(async () => {
|
setInterval(async () => {
|
||||||
try {
|
try {
|
||||||
console.log("[Cleanup] Cleaning up expired notes...");
|
logger.info("[Cleanup] Cleaning up expired notes...");
|
||||||
const deleted = await prisma.encryptedNote.deleteMany({
|
const deleted = await prisma.encryptedNote.deleteMany({
|
||||||
where: {
|
where: {
|
||||||
expire_time: {
|
expire_time: {
|
||||||
@ -86,9 +95,9 @@ setInterval(async () => {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
console.log(`[Cleanup] Deleted ${deleted.count} expired notes.`);
|
logger.info(`[Cleanup] Deleted ${deleted.count} expired notes.`);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
console.error(`[Cleanup] Error cleaning expired notes:`);
|
logger.error(`[Cleanup] Error cleaning expired notes:`);
|
||||||
console.error(err);
|
logger.error(err);
|
||||||
}
|
}
|
||||||
}, interval);
|
}, interval);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user