mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00

* ci(backend-review.yml): add linter step to the backend review workflow * chore(backend-review.yml): remove prettier from lint-action configuration * chore: apply new linting workflow * chore(lint-staged.config.js): reorder lint-staged tasks for JavaScript and TypeScript files * chore(eslint): update ignorePatterns in .eslintrc.js chore(lint-action): remove prettier option in backend-review.yml chore(package.json): add lint and lint:fix scripts * chore(lint-staged.config.js): remove prettier --write command for js, jsx, ts, tsx files * chore(titleConvo.js): remove unnecessary console.log statement chore(titleConvo.js): add missing comma in options object * chore: apply linting to all files * chore(lint-staged.config.js): update lint-staged configuration to include prettier formatting
83 lines
1.9 KiB
JavaScript
83 lines
1.9 KiB
JavaScript
const PluginAuth = require('../../models/schema/pluginAuthSchema');
|
|
const { encrypt, decrypt } = require('../../utils/');
|
|
|
|
const getUserPluginAuthValue = async (user, authField) => {
|
|
try {
|
|
const pluginAuth = await PluginAuth.findOne({ user, authField });
|
|
if (!pluginAuth) {
|
|
return null;
|
|
}
|
|
const decryptedValue = decrypt(pluginAuth.value);
|
|
return decryptedValue;
|
|
} catch (err) {
|
|
console.log(err);
|
|
return err;
|
|
}
|
|
};
|
|
|
|
// const updateUserPluginAuth = async (userId, authField, pluginKey, value) => {
|
|
// try {
|
|
// const encryptedValue = encrypt(value);
|
|
|
|
// const pluginAuth = await PluginAuth.findOneAndUpdate(
|
|
// { userId, authField },
|
|
// {
|
|
// $set: {
|
|
// value: encryptedValue,
|
|
// pluginKey
|
|
// }
|
|
// },
|
|
// {
|
|
// new: true,
|
|
// upsert: true
|
|
// }
|
|
// );
|
|
|
|
// return pluginAuth;
|
|
// } catch (err) {
|
|
// console.log(err);
|
|
// return err;
|
|
// }
|
|
// };
|
|
|
|
const updateUserPluginAuth = async (userId, authField, pluginKey, value) => {
|
|
try {
|
|
const encryptedValue = encrypt(value);
|
|
const pluginAuth = await PluginAuth.findOne({ userId, authField });
|
|
if (pluginAuth) {
|
|
const pluginAuth = await PluginAuth.updateOne(
|
|
{ userId, authField },
|
|
{ $set: { value: encryptedValue } },
|
|
);
|
|
return pluginAuth;
|
|
} else {
|
|
const newPluginAuth = await new PluginAuth({
|
|
userId,
|
|
authField,
|
|
value: encryptedValue,
|
|
pluginKey,
|
|
});
|
|
newPluginAuth.save();
|
|
return newPluginAuth;
|
|
}
|
|
} catch (err) {
|
|
console.log(err);
|
|
return err;
|
|
}
|
|
};
|
|
|
|
const deleteUserPluginAuth = async (userId, authField) => {
|
|
try {
|
|
const response = await PluginAuth.deleteOne({ userId, authField });
|
|
return response;
|
|
} catch (err) {
|
|
console.log(err);
|
|
return err;
|
|
}
|
|
};
|
|
|
|
module.exports = {
|
|
getUserPluginAuthValue,
|
|
updateUserPluginAuth,
|
|
deleteUserPluginAuth,
|
|
};
|