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
114 lines
2.7 KiB
JavaScript
114 lines
2.7 KiB
JavaScript
require('dotenv').config();
|
|
const { KeyvFile } = require('keyv-file');
|
|
const { getUserKey, checkUserKeyExpiry } = require('~/server/services/UserService');
|
|
const { logger } = require('~/config');
|
|
|
|
const askBing = async ({
|
|
text,
|
|
parentMessageId,
|
|
conversationId,
|
|
jailbreak,
|
|
jailbreakConversationId,
|
|
context,
|
|
systemMessage,
|
|
conversationSignature,
|
|
clientId,
|
|
invocationId,
|
|
toneStyle,
|
|
key: expiresAt,
|
|
onProgress,
|
|
userId,
|
|
}) => {
|
|
const isUserProvided = process.env.BINGAI_TOKEN === 'user_provided';
|
|
|
|
let key = null;
|
|
if (expiresAt && isUserProvided) {
|
|
checkUserKeyExpiry(
|
|
expiresAt,
|
|
'Your BingAI Cookies have expired. Please provide your cookies again.',
|
|
);
|
|
key = await getUserKey({ userId, name: 'bingAI' });
|
|
}
|
|
|
|
const { BingAIClient } = await import('nodejs-gpt');
|
|
const store = {
|
|
store: new KeyvFile({ filename: './data/cache.json' }),
|
|
};
|
|
|
|
const bingAIClient = new BingAIClient({
|
|
// "_U" cookie from bing.com
|
|
// userToken:
|
|
// isUserProvided ? key : process.env.BINGAI_TOKEN ?? null,
|
|
// If the above doesn't work, provide all your cookies as a string instead
|
|
cookies: isUserProvided ? key : process.env.BINGAI_TOKEN ?? null,
|
|
debug: false,
|
|
cache: store,
|
|
host: process.env.BINGAI_HOST || null,
|
|
proxy: process.env.PROXY || null,
|
|
});
|
|
|
|
let options = {};
|
|
|
|
if (jailbreakConversationId == 'false') {
|
|
jailbreakConversationId = false;
|
|
}
|
|
|
|
if (jailbreak) {
|
|
options = {
|
|
jailbreakConversationId: jailbreakConversationId || jailbreak,
|
|
context,
|
|
systemMessage,
|
|
parentMessageId,
|
|
toneStyle,
|
|
onProgress,
|
|
clientOptions: {
|
|
features: {
|
|
genImage: {
|
|
server: {
|
|
enable: true,
|
|
type: 'markdown_list',
|
|
},
|
|
},
|
|
},
|
|
},
|
|
};
|
|
} else {
|
|
options = {
|
|
conversationId,
|
|
context,
|
|
systemMessage,
|
|
parentMessageId,
|
|
toneStyle,
|
|
onProgress,
|
|
clientOptions: {
|
|
features: {
|
|
genImage: {
|
|
server: {
|
|
enable: true,
|
|
type: 'markdown_list',
|
|
},
|
|
},
|
|
},
|
|
},
|
|
};
|
|
|
|
// don't give those parameters for new conversation
|
|
// for new conversation, conversationSignature always is null
|
|
if (conversationSignature) {
|
|
options.encryptedConversationSignature = conversationSignature;
|
|
options.clientId = clientId;
|
|
options.invocationId = invocationId;
|
|
}
|
|
}
|
|
|
|
logger.debug('bing options', options);
|
|
|
|
const res = await bingAIClient.sendMessage(text, options);
|
|
|
|
return res;
|
|
|
|
// for reference:
|
|
// https://github.com/waylaidwanderer/node-chatgpt-api/blob/main/demos/use-bing-client.js
|
|
};
|
|
|
|
module.exports = { askBing };
|