mirror of
https://github.com/MindWorkAI/AI-Studio.git
synced 2025-10-24 08:20:21 +00:00
Refactored data service to handle different provider types
This commit is contained in:
parent
947b1f217a
commit
05e1c66330
@ -1,4 +1,6 @@
|
|||||||
using AIStudio.Assistants.ERI;
|
using AIStudio.Assistants.ERI;
|
||||||
|
using AIStudio.Provider;
|
||||||
|
using AIStudio.Provider.SelfHosted;
|
||||||
using AIStudio.Settings;
|
using AIStudio.Settings;
|
||||||
using AIStudio.Settings.DataModel;
|
using AIStudio.Settings.DataModel;
|
||||||
using AIStudio.Tools.ERIClient;
|
using AIStudio.Tools.ERIClient;
|
||||||
@ -41,6 +43,34 @@ public sealed class DataSourceService
|
|||||||
return new([], []);
|
return new([], []);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return await this.GetDataSources(selectedLLMProvider.IsSelfHosted, previousSelectedDataSources);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Returns a list of data sources that are allowed for the selected LLM provider.
|
||||||
|
/// It also returns the data sources selected before when they are still allowed.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="selectedLLMProvider">The selected LLM provider.</param>
|
||||||
|
/// <param name="previousSelectedDataSources">The data sources selected before.</param>
|
||||||
|
/// <returns>The allowed data sources and the data sources selected before -- when they are still allowed.</returns>
|
||||||
|
public async Task<AllowedSelectedDataSources> GetDataSources(IProvider selectedLLMProvider, IReadOnlyCollection<IDataSource>? previousSelectedDataSources = null)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Case: Somehow the selected LLM provider was not set. The default provider
|
||||||
|
// does not mean anything. We cannot filter the data sources by any means.
|
||||||
|
// We return an empty list. Better safe than sorry.
|
||||||
|
//
|
||||||
|
if (selectedLLMProvider is NoProvider)
|
||||||
|
{
|
||||||
|
this.logger.LogWarning("The selected LLM provider is the default provider. We cannot filter the data sources by any means.");
|
||||||
|
return new([], []);
|
||||||
|
}
|
||||||
|
|
||||||
|
return await this.GetDataSources(selectedLLMProvider is ProviderSelfHosted, previousSelectedDataSources);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async Task<AllowedSelectedDataSources> GetDataSources(bool usingSelfHostedProvider, IReadOnlyCollection<IDataSource>? previousSelectedDataSources = null)
|
||||||
|
{
|
||||||
var allDataSources = this.settingsManager.ConfigurationData.DataSources;
|
var allDataSources = this.settingsManager.ConfigurationData.DataSources;
|
||||||
var filteredDataSources = new List<IDataSource>(allDataSources.Count);
|
var filteredDataSources = new List<IDataSource>(allDataSources.Count);
|
||||||
var filteredSelectedDataSources = new List<IDataSource>(previousSelectedDataSources?.Count ?? 0);
|
var filteredSelectedDataSources = new List<IDataSource>(previousSelectedDataSources?.Count ?? 0);
|
||||||
@ -48,7 +78,7 @@ public sealed class DataSourceService
|
|||||||
|
|
||||||
// Start all checks in parallel:
|
// Start all checks in parallel:
|
||||||
foreach (var source in allDataSources)
|
foreach (var source in allDataSources)
|
||||||
tasks.Add(this.CheckOneDataSource(source, selectedLLMProvider));
|
tasks.Add(this.CheckOneDataSource(source, usingSelfHostedProvider));
|
||||||
|
|
||||||
// Wait for all checks and collect the results:
|
// Wait for all checks and collect the results:
|
||||||
foreach (var task in tasks)
|
foreach (var task in tasks)
|
||||||
@ -65,7 +95,7 @@ public sealed class DataSourceService
|
|||||||
return new(filteredDataSources, filteredSelectedDataSources);
|
return new(filteredDataSources, filteredSelectedDataSources);
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<IDataSource?> CheckOneDataSource(IDataSource source, AIStudio.Settings.Provider selectedLLMProvider)
|
private async Task<IDataSource?> CheckOneDataSource(IDataSource source, bool usingSelfHostedProvider)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// Unfortunately, we have to live-check any ERI source for its security requirements.
|
// Unfortunately, we have to live-check any ERI source for its security requirements.
|
||||||
@ -110,7 +140,7 @@ public sealed class DataSourceService
|
|||||||
// Case: The data source allows any provider type. We want to use a self-hosted provider.
|
// Case: The data source allows any provider type. We want to use a self-hosted provider.
|
||||||
// There is no issue with this source. Accept it.
|
// There is no issue with this source. Accept it.
|
||||||
//
|
//
|
||||||
if(selectedLLMProvider.IsSelfHosted)
|
if(usingSelfHostedProvider)
|
||||||
return source;
|
return source;
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -148,14 +178,14 @@ public sealed class DataSourceService
|
|||||||
// Case: The data source requires a self-hosted provider. We want to use a self-hosted provider.
|
// Case: The data source requires a self-hosted provider. We want to use a self-hosted provider.
|
||||||
// There is no issue with this source. Accept it.
|
// There is no issue with this source. Accept it.
|
||||||
//
|
//
|
||||||
case DataSourceSecurity.SELF_HOSTED when selectedLLMProvider.IsSelfHosted:
|
case DataSourceSecurity.SELF_HOSTED when usingSelfHostedProvider:
|
||||||
return source;
|
return source;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Case: The data source requires a self-hosted provider. We want to use a cloud provider.
|
// Case: The data source requires a self-hosted provider. We want to use a cloud provider.
|
||||||
// We skip this source.
|
// We skip this source.
|
||||||
//
|
//
|
||||||
case DataSourceSecurity.SELF_HOSTED when !selectedLLMProvider.IsSelfHosted:
|
case DataSourceSecurity.SELF_HOSTED when !usingSelfHostedProvider:
|
||||||
this.logger.LogWarning($"The data source '{source.Name}' (id={source.Id}) requires a self-hosted provider. We skip this source.");
|
this.logger.LogWarning($"The data source '{source.Name}' (id={source.Id}) requires a self-hosted provider. We skip this source.");
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user