mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-17 08:50:15 +01:00
* chore: replace violation cache accessors with enum * chore: fix test * chore(fileSchema): index timestamps * fix(ActionService): use encoding/caching strategy for handling assistant function character length limit * refactor(actions): async `domainParser` also resolve retrieved model (which is deployment name) to user-defined model * style(AssistantAction): add `whitespace-nowrap` for ellipsis * refactor(ActionService): if domain is less than or equal to encoded domain fixed length, return domain with replacement of separator * refactor(actions): use sessions/transactions for updating Assistant Action database records * chore: remove TTL from ENCODED_DOMAINS cache * refactor(domainParser): minor optimization and add tests * fix(spendTokens): use txData.user for token usage logging * refactor(actions): add helper function `withSession` for database operations with sessions/transactions * fix(PluginsClient): logger debug `message` field edge case
25 lines
798 B
JavaScript
25 lines
798 B
JavaScript
const mongoose = require('mongoose');
|
|
/**
|
|
* Executes a database operation within a session.
|
|
* @param {() => Promise<any>} method - The method to execute. This method must accept a session as its first argument.
|
|
* @param {...any} args - Additional arguments to pass to the method.
|
|
* @returns {Promise<any>} - The result of the executed method.
|
|
*/
|
|
async function withSession(method, ...args) {
|
|
const session = await mongoose.startSession();
|
|
session.startTransaction();
|
|
try {
|
|
const result = await method(...args, session);
|
|
await session.commitTransaction();
|
|
return result;
|
|
} catch (error) {
|
|
if (session.inTransaction()) {
|
|
await session.abortTransaction();
|
|
}
|
|
throw error;
|
|
} finally {
|
|
await session.endSession();
|
|
}
|
|
}
|
|
|
|
module.exports = { withSession };
|