mirror of
				https://github.com/MindWorkAI/AI-Studio.git
				synced 2025-10-26 09:40:21 +00:00 
			
		
		
		
	Added the retrieval process section for ERI data sources (#318)
This commit is contained in:
		
							parent
							
								
									030990ee90
								
							
						
					
					
						commit
						032c7ee56e
					
				| @ -42,16 +42,13 @@ | |||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             <MudExpansionPanels Class="mb-3"> |             <MudExpansionPanels Class="mb-3"> | ||||||
|                 @for (var index = 0; index < this.retrievalInfoformation.Count; index++) |                 <ExpansionPanel HeaderText="@this.RetrievalName(this.selectedRetrievalInfo)" HeaderIcon="@Icons.Material.Filled.Info"> | ||||||
|                 { |                     <TextInfoLines Label="Description" MaxLines="14" Value="@this.selectedRetrievalInfo.Description" ClipboardTooltipSubject="the retrieval description"/> | ||||||
|                     var info = this.retrievalInfoformation[index]; |                     <TextInfoLines Label="Parameters" MaxLines="14" Value="@this.RetrievalParameters(this.selectedRetrievalInfo)" ClipboardTooltipSubject="the retrieval parameters"/> | ||||||
|                     <ExpansionPanel HeaderText="@this.RetrievalName(info)" HeaderIcon="@Icons.Material.Filled.Info" IsExpanded="index == 0"> |  | ||||||
|                         <TextInfoLines Label="Description" MaxLines="14" Value="@info.Description" ClipboardTooltipSubject="the retrieval description"/> |  | ||||||
|                         <TextInfoLines Label="Parameters" MaxLines="14" Value="@this.RetrievalParameters(info)" ClipboardTooltipSubject="the retrieval parameters"/> |  | ||||||
| 
 | 
 | ||||||
|                         @if (!string.IsNullOrWhiteSpace(info.Link)) |                     @if (!string.IsNullOrWhiteSpace(this.selectedRetrievalInfo.Link)) | ||||||
|                     { |                     { | ||||||
|                             <MudButton Href="@info.Link" Target="_blank" Class="mt-3" Color="Color.Primary" StartIcon="@Icons.Material.Filled.OpenInNew"> |                         <MudButton Href="@this.selectedRetrievalInfo.Link" Target="_blank" Class="mt-3" Color="Color.Primary" StartIcon="@Icons.Material.Filled.OpenInNew"> | ||||||
|                             Open web link, show more information |                             Open web link, show more information | ||||||
|                         </MudButton> |                         </MudButton> | ||||||
|                     } |                     } | ||||||
| @ -60,7 +57,7 @@ | |||||||
|                         Embeddings |                         Embeddings | ||||||
|                     </MudText> |                     </MudText> | ||||||
|                     @* ReSharper disable once ConditionIsAlwaysTrueOrFalseAccordingToNullableAPIContract *@ |                     @* ReSharper disable once ConditionIsAlwaysTrueOrFalseAccordingToNullableAPIContract *@ | ||||||
|                         @if (info.Embeddings is null || !info.Embeddings.Any()) |                     @if (this.selectedRetrievalInfo.Embeddings is null || !this.selectedRetrievalInfo.Embeddings.Any()) | ||||||
|                     { |                     { | ||||||
|                         <MudJustifiedText Typo="Typo.body1" Color="Color.Info" Class="mb-3"> |                         <MudJustifiedText Typo="Typo.body1" Color="Color.Info" Class="mb-3"> | ||||||
|                             The data source does not provide any embedding information. |                             The data source does not provide any embedding information. | ||||||
| @ -69,9 +66,9 @@ | |||||||
|                     else |                     else | ||||||
|                     { |                     { | ||||||
|                         <MudExpansionPanels> |                         <MudExpansionPanels> | ||||||
|                                 @for (var embeddingIndex = 0; embeddingIndex < info.Embeddings.Count; embeddingIndex++) |                             @for (var embeddingIndex = 0; embeddingIndex < this.selectedRetrievalInfo.Embeddings.Count; embeddingIndex++) | ||||||
|                             { |                             { | ||||||
|                                     var embedding = info.Embeddings[embeddingIndex]; |                                 var embedding = this.selectedRetrievalInfo.Embeddings[embeddingIndex]; | ||||||
|                                 <ExpansionPanel HeaderText="@embedding.EmbeddingName" HeaderIcon="@Icons.Material.Filled.Info" IsExpanded="embeddingIndex == 0"> |                                 <ExpansionPanel HeaderText="@embedding.EmbeddingName" HeaderIcon="@Icons.Material.Filled.Info" IsExpanded="embeddingIndex == 0"> | ||||||
|                                     <TextInfoLine Icon="@Icons.Material.Filled.FormatShapes" Label="Type" Value="@embedding.EmbeddingType" ClipboardTooltipSubject="the embedding type"/> |                                     <TextInfoLine Icon="@Icons.Material.Filled.FormatShapes" Label="Type" Value="@embedding.EmbeddingType" ClipboardTooltipSubject="the embedding type"/> | ||||||
|                                     <TextInfoLines Label="Description" MaxLines="14" Value="@embedding.Description" ClipboardTooltipSubject="the embedding description"/> |                                     <TextInfoLines Label="Description" MaxLines="14" Value="@embedding.Description" ClipboardTooltipSubject="the embedding description"/> | ||||||
| @ -88,7 +85,6 @@ | |||||||
|                         </MudExpansionPanels> |                         </MudExpansionPanels> | ||||||
|                     } |                     } | ||||||
|                 </ExpansionPanel> |                 </ExpansionPanel> | ||||||
|                 } |  | ||||||
|             </MudExpansionPanels> |             </MudExpansionPanels> | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -42,6 +42,7 @@ public partial class DataSourceERI_V1InfoDialog : ComponentBase, IAsyncDisposabl | |||||||
|     private string serverDescription = string.Empty; |     private string serverDescription = string.Empty; | ||||||
|     private ProviderType securityRequirements = ProviderType.NONE; |     private ProviderType securityRequirements = ProviderType.NONE; | ||||||
|     private IReadOnlyList<RetrievalInfo> retrievalInfoformation = []; |     private IReadOnlyList<RetrievalInfo> retrievalInfoformation = []; | ||||||
|  |     private RetrievalInfo selectedRetrievalInfo; | ||||||
|      |      | ||||||
|     private bool IsOperationInProgress { get; set; } = true; |     private bool IsOperationInProgress { get; set; } = true; | ||||||
|      |      | ||||||
| @ -130,6 +131,7 @@ public partial class DataSourceERI_V1InfoDialog : ComponentBase, IAsyncDisposabl | |||||||
|             } |             } | ||||||
|              |              | ||||||
|             this.retrievalInfoformation = retrievalInfoResult.Data ?? []; |             this.retrievalInfoformation = retrievalInfoResult.Data ?? []; | ||||||
|  |             this.selectedRetrievalInfo = this.retrievalInfoformation.FirstOrDefault(x => x.Id == this.DataSource.SelectedRetrievalId); | ||||||
|             this.StateHasChanged(); |             this.StateHasChanged(); | ||||||
|         } |         } | ||||||
|         catch (Exception e) |         catch (Exception e) | ||||||
|  | |||||||
| @ -110,10 +110,24 @@ | |||||||
|                     UserAttributes="@SPELLCHECK_ATTRIBUTES"/> |                     UserAttributes="@SPELLCHECK_ATTRIBUTES"/> | ||||||
|             } |             } | ||||||
|              |              | ||||||
|  |             @if (this.availableRetrievalProcesses.Count > 0) | ||||||
|  |             { | ||||||
|  |                 <MudSelect @bind-Value="@this.dataSelectedRetrievalProcess" Text="@this.dataSelectedRetrievalProcess.Name" Label="Select one retrieval process" Class="mb-3" OpenIcon="@Icons.Material.Filled.ExpandMore" AdornmentColor="Color.Info" Adornment="Adornment.Start" Validation="@this.dataSourceValidation.ValidateRetrievalProcess"> | ||||||
|  |                     @foreach (var retrievalProcess in this.availableRetrievalProcesses) | ||||||
|  |                     { | ||||||
|  |                         <MudSelectItem Value="@retrievalProcess"> | ||||||
|  |                             @retrievalProcess.Name | ||||||
|  |                         </MudSelectItem> | ||||||
|  |                     } | ||||||
|  |                 </MudSelect> | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|             <MudSelect @bind-Value="@this.dataSecurityPolicy" Text="@this.dataSecurityPolicy.ToSelectionText()" Label="Your security policy" Class="mb-3" OpenIcon="@Icons.Material.Filled.ExpandMore" AdornmentColor="Color.Info" Adornment="Adornment.Start" Validation="@this.dataSourceValidation.ValidateSecurityPolicy"> |             <MudSelect @bind-Value="@this.dataSecurityPolicy" Text="@this.dataSecurityPolicy.ToSelectionText()" Label="Your security policy" Class="mb-3" OpenIcon="@Icons.Material.Filled.ExpandMore" AdornmentColor="Color.Info" Adornment="Adornment.Start" Validation="@this.dataSourceValidation.ValidateSecurityPolicy"> | ||||||
|                 @foreach (var policy in Enum.GetValues<DataSourceSecurity>()) |                 @foreach (var policy in Enum.GetValues<DataSourceSecurity>()) | ||||||
|                 { |                 { | ||||||
|                     <MudSelectItem Value="@policy">@policy.ToSelectionText()</MudSelectItem> |                     <MudSelectItem Value="@policy"> | ||||||
|  |                         @policy.ToSelectionText() | ||||||
|  |                     </MudSelectItem> | ||||||
|                 } |                 } | ||||||
|             </MudSelect> |             </MudSelect> | ||||||
|              |              | ||||||
|  | |||||||
| @ -8,6 +8,8 @@ using AIStudio.Tools.Validation; | |||||||
| 
 | 
 | ||||||
| using Microsoft.AspNetCore.Components; | using Microsoft.AspNetCore.Components; | ||||||
| 
 | 
 | ||||||
|  | using RetrievalInfo = AIStudio.Tools.ERIClient.DataModel.RetrievalInfo; | ||||||
|  | 
 | ||||||
| // ReSharper disable InconsistentNaming | // ReSharper disable InconsistentNaming | ||||||
| namespace AIStudio.Dialogs; | namespace AIStudio.Dialogs; | ||||||
| 
 | 
 | ||||||
| @ -59,6 +61,8 @@ public partial class DataSourceERI_V1Dialog : ComponentBase, ISecretId | |||||||
|     private int dataPort; |     private int dataPort; | ||||||
|     private AuthMethod dataAuthMethod; |     private AuthMethod dataAuthMethod; | ||||||
|     private string dataUsername = string.Empty; |     private string dataUsername = string.Empty; | ||||||
|  |     private List<RetrievalInfo> availableRetrievalProcesses = []; | ||||||
|  |     private RetrievalInfo dataSelectedRetrievalProcess; | ||||||
|      |      | ||||||
|     // We get the form reference from Blazor code to validate it manually: |     // We get the form reference from Blazor code to validate it manually: | ||||||
|     private MudForm form = null!; |     private MudForm form = null!; | ||||||
| @ -91,6 +95,9 @@ public partial class DataSourceERI_V1Dialog : ComponentBase, ISecretId | |||||||
|         // When editing, we need to load the data: |         // When editing, we need to load the data: | ||||||
|         if(this.IsEditing) |         if(this.IsEditing) | ||||||
|         { |         { | ||||||
|  |             // | ||||||
|  |             // Assign the data to the form fields: | ||||||
|  |             // | ||||||
|             this.dataEditingPreviousInstanceName = this.DataSource.Name.ToLowerInvariant(); |             this.dataEditingPreviousInstanceName = this.DataSource.Name.ToLowerInvariant(); | ||||||
|             this.dataNum = this.DataSource.Num; |             this.dataNum = this.DataSource.Num; | ||||||
|             this.dataId = this.DataSource.Id; |             this.dataId = this.DataSource.Id; | ||||||
| @ -114,6 +121,12 @@ public partial class DataSourceERI_V1Dialog : ComponentBase, ISecretId | |||||||
|                     await this.form.Validate(); |                     await this.form.Validate(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |              | ||||||
|  |             // Load the data: | ||||||
|  |             await this.TestConnection(); | ||||||
|  |              | ||||||
|  |             // Select the retrieval process: | ||||||
|  |             this.dataSelectedRetrievalProcess = this.availableRetrievalProcesses.FirstOrDefault(n => n.Id == this.DataSource.SelectedRetrievalId); | ||||||
|         } |         } | ||||||
|          |          | ||||||
|         await base.OnInitializedAsync(); |         await base.OnInitializedAsync(); | ||||||
| @ -153,6 +166,7 @@ public partial class DataSourceERI_V1Dialog : ComponentBase, ISecretId | |||||||
|             Username = this.dataUsername, |             Username = this.dataUsername, | ||||||
|             Type = DataSourceType.ERI_V1, |             Type = DataSourceType.ERI_V1, | ||||||
|             SecurityPolicy = this.dataSecurityPolicy, |             SecurityPolicy = this.dataSecurityPolicy, | ||||||
|  |             SelectedRetrievalId = this.dataSelectedRetrievalProcess.Id, | ||||||
|         }; |         }; | ||||||
|     } |     } | ||||||
|      |      | ||||||
| @ -224,6 +238,18 @@ public partial class DataSourceERI_V1Dialog : ComponentBase, ISecretId | |||||||
|              |              | ||||||
|             this.dataSourceSecurityRequirements = securityRequirementsRequest.Data; |             this.dataSourceSecurityRequirements = securityRequirementsRequest.Data; | ||||||
|              |              | ||||||
|  |             var retrievalInfoRequest = await client.GetRetrievalInfoAsync(cts.Token); | ||||||
|  |             if (!retrievalInfoRequest.Successful) | ||||||
|  |             { | ||||||
|  |                 await this.form.Validate(); | ||||||
|  |                  | ||||||
|  |                 Array.Resize(ref this.dataIssues, this.dataIssues.Length + 1); | ||||||
|  |                 this.dataIssues[^1] = retrievalInfoRequest.Message; | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             this.availableRetrievalProcesses = retrievalInfoRequest.Data ?? []; | ||||||
|  |              | ||||||
|             this.connectionTested = true; |             this.connectionTested = true; | ||||||
|             this.connectionSuccessfulTested = true; |             this.connectionSuccessfulTested = true; | ||||||
|             this.Logger.LogInformation("Connection to the ERI v1 server was successful tested."); |             this.Logger.LogInformation("Connection to the ERI v1 server was successful tested."); | ||||||
|  | |||||||
| @ -51,6 +51,9 @@ public readonly record struct DataSourceERI_V1 : IERIDataSource | |||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public ERIVersion Version { get; init; } = ERIVersion.V1; |     public ERIVersion Version { get; init; } = ERIVersion.V1; | ||||||
|      |      | ||||||
|  |     /// <inheritdoc /> | ||||||
|  |     public string SelectedRetrievalId { get; init; } | ||||||
|  |      | ||||||
|     /// <inheritdoc /> |     /// <inheritdoc /> | ||||||
|     public async Task<IReadOnlyList<IRetrievalContext>> RetrieveDataAsync(IContent lastPrompt, ChatThread thread, CancellationToken token = default) |     public async Task<IReadOnlyList<IRetrievalContext>> RetrieveDataAsync(IContent lastPrompt, ChatThread thread, CancellationToken token = default) | ||||||
|     { |     { | ||||||
| @ -74,7 +77,7 @@ public readonly record struct DataSourceERI_V1 : IERIDataSource | |||||||
|                  |                  | ||||||
|                 Thread = await thread.ToERIChatThread(token), |                 Thread = await thread.ToERIChatThread(token), | ||||||
|                 MaxMatches = 10, |                 MaxMatches = 10, | ||||||
|                 RetrievalProcessId = null, // The ERI server selects the retrieval process when multiple processes are available |                 RetrievalProcessId = string.IsNullOrWhiteSpace(this.SelectedRetrievalId) ? null : this.SelectedRetrievalId, | ||||||
|                 Parameters = null, // The ERI server selects useful default parameters |                 Parameters = null, // The ERI server selects useful default parameters | ||||||
|             }; |             }; | ||||||
|              |              | ||||||
|  | |||||||
| @ -29,4 +29,9 @@ public interface IERIDataSource : IExternalDataSource | |||||||
|     /// The ERI specification to use. |     /// The ERI specification to use. | ||||||
|     /// </summary> |     /// </summary> | ||||||
|     public ERIVersion Version { get; init; } |     public ERIVersion Version { get; init; } | ||||||
|  |      | ||||||
|  |     /// <summary> | ||||||
|  |     /// The ID of the selected retrieval process. | ||||||
|  |     /// </summary> | ||||||
|  |     public string SelectedRetrievalId { get; init; } | ||||||
| } | } | ||||||
| @ -93,6 +93,14 @@ public sealed class DataSourceValidation | |||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public string? ValidateRetrievalProcess(RetrievalInfo retrievalInfo) | ||||||
|  |     { | ||||||
|  |         if(retrievalInfo == default) | ||||||
|  |             return "Please select one retrieval process."; | ||||||
|  |          | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |      | ||||||
|     public string? ValidatingName(string dataSourceName) |     public string? ValidatingName(string dataSourceName) | ||||||
|     { |     { | ||||||
|         if(string.IsNullOrWhiteSpace(dataSourceName)) |         if(string.IsNullOrWhiteSpace(dataSourceName)) | ||||||
|  | |||||||
| @ -1,5 +1,6 @@ | |||||||
| # v0.9.32, build 207 (2025-03-xx xx:xx UTC) | # v0.9.32, build 207 (2025-03-xx xx:xx UTC) | ||||||
| - Added the "Community & Code" section to the about page. It includes links to the GitHub repositories and the project website. | - Added the "Community & Code" section to the about page. It includes links to the GitHub repositories and the project website. | ||||||
|  | - Added the retrieval process section for ERI data sources in the configuration dialog. Like all RAG functions, this is hidden behind the RAG feature flag in the app settings due to its preview status. | ||||||
| - Improved data security by preventing the use of cloud LLMs after confidential data has been retrieved previously. | - Improved data security by preventing the use of cloud LLMs after confidential data has been retrieved previously. | ||||||
| - Improved the ERI client to expect JSON responses and send JSON requests using camel case. | - Improved the ERI client to expect JSON responses and send JSON requests using camel case. | ||||||
| - Improved the ERI client to raise an error when the server responds with additional JSON data that is not expected. | - Improved the ERI client to raise an error when the server responds with additional JSON data that is not expected. | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user