mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-01-29 05:36:13 +01:00
🔌 feat: MCP OAuth Integration in Chat UI
- **Real-Time Connection Status**: New backend APIs and React Query hooks provide live MCP server connection monitoring with automatic UI updates - **OAuth Flow Components**: Complete MCPConfigDialog, ServerInitializationSection, and CustomUserVarsSection with OAuth URL handling and polling-based completion - **Enhanced Server Selection**: MCPSelect component with connection-aware filtering, visual status indicators, and better credential management UX (still needs a lot of refinement since there is bloat/unused vars and functions leftover from the ideation phase on how to approach OAuth and connection statuses)
This commit is contained in:
parent
b39b60c012
commit
63140237a6
27 changed files with 1760 additions and 286 deletions
|
|
@ -61,15 +61,28 @@ export function createPluginAuthMethods(mongoose: typeof import('mongoose')) {
|
|||
}: UpdatePluginAuthParams): Promise<IPluginAuth> {
|
||||
try {
|
||||
const PluginAuth: Model<IPluginAuth> = mongoose.models.PluginAuth;
|
||||
const existingAuth = await PluginAuth.findOne({ userId, pluginKey, authField }).lean();
|
||||
|
||||
// First try to find existing record by { userId, authField } (for backward compatibility)
|
||||
let existingAuth = await PluginAuth.findOne({ userId, authField }).lean();
|
||||
|
||||
// If not found and pluginKey is provided, try to find by { userId, pluginKey, authField }
|
||||
if (!existingAuth && pluginKey) {
|
||||
existingAuth = await PluginAuth.findOne({ userId, pluginKey, authField }).lean();
|
||||
}
|
||||
|
||||
if (existingAuth) {
|
||||
// Update existing record, preserving the original structure
|
||||
const updateQuery = existingAuth.pluginKey
|
||||
? { userId, pluginKey: existingAuth.pluginKey, authField }
|
||||
: { userId, authField };
|
||||
|
||||
return await PluginAuth.findOneAndUpdate(
|
||||
{ userId, pluginKey, authField },
|
||||
updateQuery,
|
||||
{ $set: { value } },
|
||||
{ new: true, upsert: true },
|
||||
).lean();
|
||||
} else {
|
||||
// Create new record
|
||||
const newPluginAuth = await new PluginAuth({
|
||||
userId,
|
||||
authField,
|
||||
|
|
@ -109,7 +122,16 @@ export function createPluginAuthMethods(mongoose: typeof import('mongoose')) {
|
|||
throw new Error('authField is required when all is false');
|
||||
}
|
||||
|
||||
return await PluginAuth.deleteOne({ userId, authField });
|
||||
// Build the filter based on available parameters
|
||||
const filter: { userId: string; authField: string; pluginKey?: string } = {
|
||||
userId,
|
||||
authField,
|
||||
};
|
||||
if (pluginKey) {
|
||||
filter.pluginKey = pluginKey;
|
||||
}
|
||||
|
||||
return await PluginAuth.deleteOne(filter);
|
||||
} catch (error) {
|
||||
throw new Error(
|
||||
`Failed to delete plugin auth: ${error instanceof Error ? error.message : 'Unknown error'}`,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue