using AIStudio.Components; using AIStudio.Agents.AssistantAudit; using AIStudio.Tools.PluginSystem; using AIStudio.Tools.PluginSystem.Assistants; using Microsoft.AspNetCore.Components; namespace AIStudio.Pages; public partial class Assistants : MSGComponentBase { private bool isAutoAuditing; [Inject] private AssistantPluginAuditService AssistantPluginAuditService { get; init; } = null!; protected override async Task OnInitializedAsync() { this.ApplyFilters([], [ Event.CONFIGURATION_CHANGED, Event.PLUGINS_RELOADED ]); await base.OnInitializedAsync(); } protected override async Task OnAfterRenderAsync(bool firstRender) { if (firstRender) await this.TryAutoAuditAssistantsAsync(); } private IReadOnlyCollection AssistantPlugins => PluginFactory.RunningPlugins.OfType() .Where(plugin => this.SettingsManager.IsPluginEnabled(plugin)) .ToList(); private async Task TryAutoAuditAssistantsAsync() { if (this.isAutoAuditing || !this.SettingsManager.ConfigurationData.AssistantPluginAudit.AutomaticallyAuditAssistants) return; this.isAutoAuditing = true; try { var wasConfigurationChanged = false; var assistantPlugins = PluginFactory.RunningPlugins.OfType().ToList(); foreach (var assistantPlugin in assistantPlugins) { var securityState = PluginAssistantSecurityResolver.Resolve(this.SettingsManager, assistantPlugin); if (!securityState.RequiresAudit) continue; var audit = await this.AssistantPluginAuditService.RunAuditAsync(assistantPlugin); if (audit.Level is AssistantAuditLevel.UNKNOWN) { await MessageBus.INSTANCE.SendError(new (Icons.Material.Filled.SettingsSuggest, string.Format(this.T("The automatic security audit for the assistant plugin '{0}' failed. Please run it manually from the plugins page."), assistantPlugin.Name))); continue; } this.UpsertAuditCard(audit); wasConfigurationChanged = true; } if (!wasConfigurationChanged) return; await this.SettingsManager.StoreSettings(); await this.MessageBus.SendMessage(this, Event.CONFIGURATION_CHANGED); } finally { this.isAutoAuditing = false; await this.InvokeAsync(this.StateHasChanged); } } private void UpsertAuditCard(PluginAssistantAudit audit) { var audits = this.SettingsManager.ConfigurationData.AssistantPluginAudits; var existingIndex = audits.FindIndex(x => x.PluginId == audit.PluginId); if (existingIndex >= 0) audits[existingIndex] = audit; else audits.Add(audit); } protected override async Task ProcessIncomingMessage(ComponentBase? sendingComponent, Event triggeredEvent, T? data) where T : default { if (triggeredEvent is Event.PLUGINS_RELOADED) await this.TryAutoAuditAssistantsAsync(); if (triggeredEvent is Event.CONFIGURATION_CHANGED or Event.PLUGINS_RELOADED) await this.InvokeAsync(this.StateHasChanged); } }