Skip to content

Commit

Permalink
Merge pull request #121 from TogetherCrew/120-integrate-pino-logging-…
Browse files Browse the repository at this point in the history
…framework-for-enhanced-application-monitoring

[FEATURE]: refactor codes and add logger
cyri113 authored Aug 29, 2023

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
2 parents 7c3e1eb + 4ca6a61 commit 0eead5f
Showing 29 changed files with 762 additions and 460 deletions.
215 changes: 211 additions & 4 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -26,7 +26,7 @@
"homepage": "https://github.com/Behzad-rabiei/tc-discordBot#readme",
"dependencies": {
"@sentry/node": "^7.51.2",
"@togethercrew.dev/db": "^2.4.95",
"@togethercrew.dev/db": "^2.4.96",
"@togethercrew.dev/tc-messagebroker": "^0.0.40",
"babel-jest": "^29.5.0",
"bullmq": "^3.14.0",
@@ -36,6 +36,7 @@
"mongodb": "^5.4.0",
"mongoose": "^6.11.1",
"node-fetch": "^2.6.7",
"pino": "^8.15.0",
"redis": "^4.6.6"
},
"devDependencies": {
4 changes: 4 additions & 0 deletions src/config/index.ts
Original file line number Diff line number Diff line change
@@ -20,6 +20,7 @@ const envVarsSchema = Joi.object()
REDIS_HOST: Joi.string().required().description('Reids host'),
REDIS_PORT: Joi.string().required().description('Reids port'),
REDIS_PASSWORD: Joi.string().required().description('Reids password').allow(''),
LOG_LEVEL: Joi.string().required().description('Min allowed log level'),
})
.unknown();

@@ -51,4 +52,7 @@ export default {
dsn: envVars.SENTRY_DSN,
env: envVars.SENTRY_ENV,
},
logger: {
level: envVars.LOG_LEVEL,
},
};
18 changes: 18 additions & 0 deletions src/config/logger.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import pino, { Bindings } from 'pino';
import config from './index';

export default pino({
level: config.logger.level,
formatters: {
level: label => {
return { level: label.toUpperCase() };
},
},
timestamp: () => `,"timestamp":"${new Date(Date.now()).toISOString()}"`,
bindings: (bindings: Bindings) => {
return {
pid: bindings.pid,
host: bindings.hostname,
};
},
});
10 changes: 7 additions & 3 deletions src/database/connection.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import { Connection } from 'mongoose';
import parentLogger from '../config/logger';

const logger = parentLogger.child({ module: 'Connection' });

/**
* Closes a given Mongoose connection.
* @param {Connection} connection - The Mongoose connection object to be closed.
@@ -8,8 +12,8 @@ import { Connection } from 'mongoose';
export async function closeConnection(connection: Connection) {
try {
await connection.close();
console.log('The connection to the database has been successfully closed.');
} catch (err) {
console.log('Error closing connection to the database:', err);
logger.info({ database: connection.name }, 'The connection to database has been successfully closed');
} catch (error) {
logger.fatal({ database: connection.name, error }, 'Failed to close the connection to the database');
}
}
Loading

0 comments on commit 0eead5f

Please sign in to comment.