mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* WIP: initial logging changes add several transports in ~/config/winston omit messages in logs, truncate long strings add short blurb in dotenv for debug logging GoogleClient: using logger OpenAIClient: using logger, handleOpenAIErrors Adding typedef for payload message bumped winston and using winston-daily-rotate-file moved config for server paths to ~/config dir Added `DEBUG_LOGGING=true` to .env.example * WIP: Refactor logging statements in code * WIP: Refactor logging statements and import configurations * WIP: Refactor logging statements and import configurations * refactor: broadcast Redis initialization message with `info` not `debug` * refactor: complete Refactor logging statements and import configurations * chore: delete unused tools * fix: circular dependencies due to accessing logger * refactor(handleText): handle booleans and write tests * refactor: redact sensitive values, better formatting * chore: improve log formatting, avoid passing strings to 2nd arg * fix(ci): fix jest tests due to logger changes * refactor(getAvailablePluginsController): cache plugins as they are static and avoids async addOpenAPISpecs call every time * chore: update docs * chore: update docs * chore: create separate meiliSync logger, clean up logs to avoid being unnecessarily verbose * chore: spread objects where they are commonly logged to allow string truncation * chore: improve error log formatting
76 lines
2 KiB
JavaScript
76 lines
2 KiB
JavaScript
const crypto = require('crypto');
|
|
const mongoose = require('mongoose');
|
|
const signPayload = require('~/server/services/signPayload');
|
|
const { logger } = require('~/config');
|
|
|
|
const { REFRESH_TOKEN_EXPIRY } = process.env ?? {};
|
|
const expires = eval(REFRESH_TOKEN_EXPIRY) ?? 1000 * 60 * 60 * 24 * 7;
|
|
|
|
const sessionSchema = mongoose.Schema({
|
|
refreshTokenHash: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
expiration: {
|
|
type: Date,
|
|
required: true,
|
|
expires: 0,
|
|
},
|
|
user: {
|
|
type: mongoose.Schema.Types.ObjectId,
|
|
ref: 'User',
|
|
required: true,
|
|
},
|
|
});
|
|
|
|
sessionSchema.methods.generateRefreshToken = async function () {
|
|
try {
|
|
let expiresIn;
|
|
if (this.expiration) {
|
|
expiresIn = this.expiration.getTime();
|
|
} else {
|
|
expiresIn = Date.now() + expires;
|
|
this.expiration = new Date(expiresIn);
|
|
}
|
|
|
|
const refreshToken = await signPayload({
|
|
payload: { id: this.user },
|
|
secret: process.env.JWT_REFRESH_SECRET,
|
|
expirationTime: Math.floor((expiresIn - Date.now()) / 1000),
|
|
});
|
|
|
|
const hash = crypto.createHash('sha256');
|
|
this.refreshTokenHash = hash.update(refreshToken).digest('hex');
|
|
|
|
await this.save();
|
|
|
|
return refreshToken;
|
|
} catch (error) {
|
|
logger.error(
|
|
'Error generating refresh token. Is a `JWT_REFRESH_SECRET` set in the .env file?\n\n',
|
|
error,
|
|
);
|
|
throw error;
|
|
}
|
|
};
|
|
|
|
sessionSchema.statics.deleteAllUserSessions = async function (userId) {
|
|
try {
|
|
if (!userId) {
|
|
return;
|
|
}
|
|
const result = await this.deleteMany({ user: userId });
|
|
if (result && result?.deletedCount > 0) {
|
|
logger.debug(
|
|
`[deleteAllUserSessions] Deleted ${result.deletedCount} sessions for user ${userId}.`,
|
|
);
|
|
}
|
|
} catch (error) {
|
|
logger.error('[deleteAllUserSessions] Error in deleting user sessions:', error);
|
|
throw error;
|
|
}
|
|
};
|
|
|
|
const Session = mongoose.model('Session', sessionSchema);
|
|
|
|
module.exports = Session;
|