feat: 提交

This commit is contained in:
cc
2025-06-20 18:06:33 +08:00
parent f16e1cd7a6
commit 6abcc49ed4
15 changed files with 138 additions and 118 deletions

View File

@@ -186,8 +186,6 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.Stock.Domain.S
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.Stock.SqlSugarCore", "module\ai-stock\Yi.Framework.Stock.SqlSugarCore\Yi.Framework.Stock.SqlSugarCore.csproj", "{5F49318F-E6C7-4194-BAE0-83D4FB8D1983}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.Stock.SqlSugarCore", "module\ai-stock\Yi.Framework.Stock.SqlSugarCore\Yi.Framework.Stock.SqlSugarCore.csproj", "{5F49318F-E6C7-4194-BAE0-83D4FB8D1983}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.SemanticKernel", "framework\Yi.Framework.SemanticKernel\Yi.Framework.SemanticKernel.csproj", "{2503116E-4D69-49E3-8ED7-A6CDD0C3B542}"
EndProject
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "ai-hub", "ai-hub", "{7AD5DBAE-44F9-474B-8F7B-837EDE908934}" Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "ai-hub", "ai-hub", "{7AD5DBAE-44F9-474B-8F7B-837EDE908934}"
EndProject EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.AiHub.Application", "module\ai-hub\Yi.Framework.AiHub.Application\Yi.Framework.AiHub.Application.csproj", "{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}" Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Yi.Framework.AiHub.Application", "module\ai-hub\Yi.Framework.AiHub.Application\Yi.Framework.AiHub.Application.csproj", "{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}"
@@ -482,10 +480,6 @@ Global
{5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Debug|Any CPU.Build.0 = Debug|Any CPU {5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Debug|Any CPU.Build.0 = Debug|Any CPU
{5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Release|Any CPU.ActiveCfg = Release|Any CPU {5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Release|Any CPU.ActiveCfg = Release|Any CPU
{5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Release|Any CPU.Build.0 = Release|Any CPU {5F49318F-E6C7-4194-BAE0-83D4FB8D1983}.Release|Any CPU.Build.0 = Release|Any CPU
{2503116E-4D69-49E3-8ED7-A6CDD0C3B542}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{2503116E-4D69-49E3-8ED7-A6CDD0C3B542}.Debug|Any CPU.Build.0 = Debug|Any CPU
{2503116E-4D69-49E3-8ED7-A6CDD0C3B542}.Release|Any CPU.ActiveCfg = Release|Any CPU
{2503116E-4D69-49E3-8ED7-A6CDD0C3B542}.Release|Any CPU.Build.0 = Release|Any CPU
{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Debug|Any CPU.ActiveCfg = Debug|Any CPU {1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Debug|Any CPU.Build.0 = Debug|Any CPU {1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Debug|Any CPU.Build.0 = Debug|Any CPU
{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Release|Any CPU.ActiveCfg = Release|Any CPU {1AD10DD2-535E-4EAB-A8A4-EC3FCA206895}.Release|Any CPU.ActiveCfg = Release|Any CPU
@@ -589,7 +583,6 @@ Global
{162821E4-8FE0-4A68-B3C0-49BD6596446F} = {DB46873F-981A-43D8-91B0-D464CCB65943} {162821E4-8FE0-4A68-B3C0-49BD6596446F} = {DB46873F-981A-43D8-91B0-D464CCB65943}
{10273544-715D-4BB3-893C-6F010D947BDD} = {DB46873F-981A-43D8-91B0-D464CCB65943} {10273544-715D-4BB3-893C-6F010D947BDD} = {DB46873F-981A-43D8-91B0-D464CCB65943}
{5F49318F-E6C7-4194-BAE0-83D4FB8D1983} = {DB46873F-981A-43D8-91B0-D464CCB65943} {5F49318F-E6C7-4194-BAE0-83D4FB8D1983} = {DB46873F-981A-43D8-91B0-D464CCB65943}
{2503116E-4D69-49E3-8ED7-A6CDD0C3B542} = {77B949E9-530E-45A5-9657-20F7D5C6875C}
{7AD5DBAE-44F9-474B-8F7B-837EDE908934} = {2317227D-7796-4E7B-BEDB-7CD1CAE7B853} {7AD5DBAE-44F9-474B-8F7B-837EDE908934} = {2317227D-7796-4E7B-BEDB-7CD1CAE7B853}
{1AD10DD2-535E-4EAB-A8A4-EC3FCA206895} = {7AD5DBAE-44F9-474B-8F7B-837EDE908934} {1AD10DD2-535E-4EAB-A8A4-EC3FCA206895} = {7AD5DBAE-44F9-474B-8F7B-837EDE908934}
{123D1C81-D667-4060-8E85-FFE7FB4584AD} = {7AD5DBAE-44F9-474B-8F7B-837EDE908934} {123D1C81-D667-4060-8E85-FFE7FB4584AD} = {7AD5DBAE-44F9-474B-8F7B-837EDE908934}

View File

@@ -11,27 +11,5 @@ public class YiFrameworkSemanticKernelModule : AbpModule
{ {
var configuration = context.Services.GetConfiguration(); var configuration = context.Services.GetConfiguration();
var services = context.Services; var services = context.Services;
// 配置绑定
var semanticKernelSection = configuration.GetSection("SemanticKernel");
services.Configure<SemanticKernelOptions>(configuration.GetSection("SemanticKernel"));
// 从配置中获取值
var options = semanticKernelSection.Get<SemanticKernelOptions>();
foreach (var optionsModelId in options.ModelIds)
{
services.AddKernel()
.AddAzureOpenAIChatCompletion(
deploymentName: optionsModelId,
endpoint: options.Endpoint,
apiKey: options.ApiKey,
serviceId: optionsModelId,
modelId: optionsModelId);
// .AddOpenAIChatCompletion(
// serviceId: optionsModelId,
// modelId: optionsModelId,
// endpoint: new Uri(options.Endpoint),
// apiKey: options.ApiKey);
}
} }
} }

View File

@@ -1,26 +1,19 @@
using System.Text; using Microsoft.AspNetCore.Http;
using Azure;
using Microsoft.AspNetCore.Http;
using Microsoft.SemanticKernel.ChatCompletion;
using Microsoft.SemanticKernel.Connectors.AzureOpenAI;
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
using Volo.Abp.Application.Services; using Volo.Abp.Application.Services;
using Yi.Framework.AiHub.Application.Contracts.Dtos; using Yi.Framework.AiHub.Application.Contracts.Dtos;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.AiHub.Application.Services; namespace Yi.Framework.AiHub.Application.Services;
public class AiService : ApplicationService public class AiService : ApplicationService
{ {
private readonly SemanticKernelClient _skClient; // private readonly SemanticKernelClient _skClient;
private IHttpContextAccessor httpContextAccessor; private IHttpContextAccessor httpContextAccessor;
public AiService(SemanticKernelClient skClient, IHttpContextAccessor httpContextAccessor) // public AiService(SemanticKernelClient skClient, IHttpContextAccessor httpContextAccessor)
{ // {
_skClient = skClient; // _skClient = skClient;
this.httpContextAccessor = httpContextAccessor; // this.httpContextAccessor = httpContextAccessor;
} // }
/// <summary> /// <summary>
/// 获取模型列表 /// 获取模型列表
@@ -62,59 +55,59 @@ public class AiService : ApplicationService
} }
/// <summary> // /// <summary>
/// 发送消息 // /// 发送消息
/// </summary> // /// </summary>
/// <param name="input"></param> // /// <param name="input"></param>
/// <param name="cancelToken"></param> // /// <param name="cancelToken"></param>
public async Task PostSendAsync(SendMessageInput input,CancellationToken cancelToken) // public async Task PostSendAsync(SendMessageInput input,CancellationToken cancelToken)
{ // {
var httpContext = this.httpContextAccessor.HttpContext; // var httpContext = this.httpContextAccessor.HttpContext;
var response = httpContext.Response; // var response = httpContext.Response;
// 设置响应头,声明是 SSE 流 // // 设置响应头,声明是 SSE 流
response.ContentType = "text/event-stream"; // response.ContentType = "text/event-stream";
response.Headers.Append("Cache-Control", "no-cache"); // response.Headers.Append("Cache-Control", "no-cache");
response.Headers.Append("Connection", "keep-alive"); // response.Headers.Append("Connection", "keep-alive");
//
//
var chatCompletionService = this._skClient.Kernel.GetRequiredService<IChatCompletionService>(input.Model); // var chatCompletionService = this._skClient.Kernel.GetRequiredService<IChatCompletionService>(input.Model);
var history = new ChatHistory(); // var history = new ChatHistory();
var openSettings = new AzureOpenAIPromptExecutionSettings() // var openSettings = new AzureOpenAIPromptExecutionSettings()
{ // {
MaxTokens = 3000 // MaxTokens = 3000
}; // };
foreach (var aiChatContextDto in input.Messages) // foreach (var aiChatContextDto in input.Messages)
{ // {
if (aiChatContextDto.Role == "ai") // if (aiChatContextDto.Role == "ai")
{ // {
history.AddAssistantMessage(aiChatContextDto.Content); // history.AddAssistantMessage(aiChatContextDto.Content);
} // }
else if (aiChatContextDto.Role == "user") // else if (aiChatContextDto.Role == "user")
{ // {
history.AddUserMessage(aiChatContextDto.Content); // history.AddUserMessage(aiChatContextDto.Content);
} // }
} // }
//
var results = chatCompletionService.GetStreamingChatMessageContentsAsync( // var results = chatCompletionService.GetStreamingChatMessageContentsAsync(
chatHistory: history, // chatHistory: history,
executionSettings: openSettings, // executionSettings: openSettings,
kernel: _skClient.Kernel, // kernel: _skClient.Kernel,
cancelToken); // cancelToken);
//
//
await using var writer = new StreamWriter(response.Body, Encoding.UTF8, leaveOpen: true); // await using var writer = new StreamWriter(response.Body, Encoding.UTF8, leaveOpen: true);
await foreach (var result in results) // await foreach (var result in results)
{ // {
var modle = GetMessage(input.Model, result.Content); // var modle = GetMessage(input.Model, result.Content);
var message = JsonConvert.SerializeObject(modle, new JsonSerializerSettings // var message = JsonConvert.SerializeObject(modle, new JsonSerializerSettings
{ // {
ContractResolver = new CamelCasePropertyNamesContractResolver() // ContractResolver = new CamelCasePropertyNamesContractResolver()
}); // });
//
await writer.WriteLineAsync($"data: {message}\n"); // await writer.WriteLineAsync($"data: {message}\n");
await writer.FlushAsync(cancelToken); // 确保立即推送数据 // await writer.FlushAsync(cancelToken); // 确保立即推送数据
} // }
} // }
private SendMessageOutputDto GetMessage(string modelId, string content) private SendMessageOutputDto GetMessage(string modelId, string content)

View File

@@ -0,0 +1,39 @@
using Azure;
using Azure.AI.OpenAI;
using OpenAI.Chat;
using Volo.Abp.Domain.Services;
namespace Yi.Framework.AiHub.Domain.Managers;
public class OpenAiManager : DomainService
{
public static async Task TestAsync()
{
var endpoint = new Uri("https://japan-ccnetcore-resource.cognitiveservices.azure.com/");
// var deploymentName = "gpt-4.1-mini";
var deploymentName = "o4-mini";
var apiKey = "FaccnRh7Zvz25OCGH07kHPe2z1aCXMliLdr3esgWHgXQ2aivwFgDJQQJ99BFACi0881XJ3w3AAAAACOGAJ2G";
AzureOpenAIClient azureClient = new(
endpoint,
new AzureKeyCredential(apiKey));
ChatClient chatClient = azureClient.GetChatClient(deploymentName);
List<ChatMessage> messages = new List<ChatMessage>()
{
new UserChatMessage("使用c#写一个贪吃蛇代码"),
};
var response = chatClient.CompleteChatStreamingAsync(messages);
await foreach (StreamingChatCompletionUpdate update in response)
{
foreach (ChatMessageContentPart updatePart in update.ContentUpdate)
{
System.Console.Write(updatePart.Text);
}
}
System.Console.WriteLine("结束");
}
}

View File

@@ -1,13 +1,13 @@
<Project Sdk="Microsoft.NET.Sdk"> <Project Sdk="Microsoft.NET.Sdk">
<Import Project="..\..\..\common.props" /> <Import Project="..\..\..\common.props" />
<ItemGroup> <ItemGroup>
<PackageReference Include="Azure.AI.OpenAI" Version="2.2.0-beta.4" />
<PackageReference Include="Volo.Abp.Ddd.Domain" Version="$(AbpVersion)" /> <PackageReference Include="Volo.Abp.Ddd.Domain" Version="$(AbpVersion)" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.SemanticKernel\Yi.Framework.SemanticKernel.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" />
<ProjectReference Include="..\Yi.Framework.AiHub.Domain.Shared\Yi.Framework.AiHub.Domain.Shared.csproj" /> <ProjectReference Include="..\Yi.Framework.AiHub.Domain.Shared\Yi.Framework.AiHub.Domain.Shared.csproj" />
</ItemGroup> </ItemGroup>

View File

@@ -1,18 +1,15 @@
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
using Microsoft.SemanticKernel;
using Volo.Abp.Caching; using Volo.Abp.Caching;
using Volo.Abp.Domain; using Volo.Abp.Domain;
using Yi.Framework.AiHub.Domain.Shared; using Yi.Framework.AiHub.Domain.Shared;
using Yi.Framework.Mapster; using Yi.Framework.Mapster;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.AiHub.Domain namespace Yi.Framework.AiHub.Domain
{ {
[DependsOn( [DependsOn(
typeof(YiFrameworkAiHubDomainSharedModule), typeof(YiFrameworkAiHubDomainSharedModule),
typeof(YiFrameworkMapsterModule), typeof(YiFrameworkMapsterModule),
typeof(AbpDddDomainModule), typeof(AbpDddDomainModule)
typeof(YiFrameworkSemanticKernelModule)
)] )]
public class YiFrameworkAiHubDomainModule : AbpModule public class YiFrameworkAiHubDomainModule : AbpModule
{ {
@@ -21,5 +18,10 @@ namespace Yi.Framework.AiHub.Domain
var configuration = context.Services.GetConfiguration(); var configuration = context.Services.GetConfiguration();
var services = context.Services; var services = context.Services;
} }
public override async Task OnApplicationInitializationAsync(ApplicationInitializationContext context)
{
await Yi.Framework.AiHub.Domain.Managers.OpenAiManager.Test2Async();
}
} }
} }

View File

@@ -5,7 +5,6 @@ using Yi.Framework.Stock.Domain.Managers.SemanticKernel;
using Yi.Framework.Stock.Domain.Managers.SemanticKernel.Plugins; using Yi.Framework.Stock.Domain.Managers.SemanticKernel.Plugins;
using System.Text; using System.Text;
using System.IO; using System.IO;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.Stock.Domain.Managers; namespace Yi.Framework.Stock.Domain.Managers;

View File

@@ -3,7 +3,7 @@ using Microsoft.SemanticKernel.ChatCompletion;
using Microsoft.SemanticKernel.Connectors.OpenAI; using Microsoft.SemanticKernel.Connectors.OpenAI;
using Volo.Abp.DependencyInjection; using Volo.Abp.DependencyInjection;
namespace Yi.Framework.SemanticKernel; namespace Yi.Framework.Stock.Domain.Managers.SemanticKernel;
public class SemanticKernelClient : ITransientDependency public class SemanticKernelClient : ITransientDependency
{ {

View File

@@ -1,4 +1,4 @@
namespace Yi.Framework.SemanticKernel namespace Yi.Framework.Stock.Domain.Managers.SemanticKernel
{ {
public class SemanticKernelOptions public class SemanticKernelOptions
{ {

View File

@@ -13,7 +13,6 @@ using Yi.Framework.Stock.Domain.Managers.SemanticKernel.Plugins;
using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Hosting;
using System.Text; using System.Text;
using System.IO; using System.IO;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.Stock.Domain.Managers namespace Yi.Framework.Stock.Domain.Managers
{ {

View File

@@ -3,12 +3,11 @@
<ItemGroup> <ItemGroup>
<PackageReference Include="Volo.Abp.Ddd.Domain" Version="$(AbpVersion)" /> <PackageReference Include="Volo.Abp.Ddd.Domain" Version="$(AbpVersion)" />
<PackageReference Include="Volo.Abp.Caching" Version="$(AbpVersion)" /> <PackageReference Include="Volo.Abp.Caching" Version="$(AbpVersion)" />
<PackageReference Include="Microsoft.SemanticKernel" Version="1.57.0" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.SemanticKernel\Yi.Framework.SemanticKernel.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" />
<ProjectReference Include="..\Yi.Framework.Stock.Domain.Shared\Yi.Framework.Stock.Domain.Shared.csproj" /> <ProjectReference Include="..\Yi.Framework.Stock.Domain.Shared\Yi.Framework.Stock.Domain.Shared.csproj" />
</ItemGroup> </ItemGroup>
@@ -17,5 +16,5 @@
<Folder Include="EventHandlers\" /> <Folder Include="EventHandlers\" />
<Folder Include="Repositories\" /> <Folder Include="Repositories\" />
</ItemGroup> </ItemGroup>
</Project> </Project>

View File

@@ -1,10 +1,11 @@
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.DependencyInjection;
using Microsoft.SemanticKernel; using Microsoft.SemanticKernel;
using Volo.Abp.Caching; using Volo.Abp.Caching;
using Volo.Abp.Domain; using Volo.Abp.Domain;
using Yi.Framework.Mapster; using Yi.Framework.Mapster;
using Yi.Framework.SemanticKernel;
using Yi.Framework.Stock.Domain.Managers; using Yi.Framework.Stock.Domain.Managers;
using Yi.Framework.Stock.Domain.Managers.SemanticKernel;
using Yi.Framework.Stock.Domain.Managers.SemanticKernel.Plugins; using Yi.Framework.Stock.Domain.Managers.SemanticKernel.Plugins;
using Yi.Framework.Stock.Domain.Shared; using Yi.Framework.Stock.Domain.Shared;
@@ -14,7 +15,6 @@ namespace Yi.Framework.Stock.Domain
typeof(YiFrameworkStockDomainSharedModule), typeof(YiFrameworkStockDomainSharedModule),
typeof(YiFrameworkMapsterModule), typeof(YiFrameworkMapsterModule),
typeof(AbpDddDomainModule), typeof(AbpDddDomainModule),
typeof(YiFrameworkSemanticKernelModule),
typeof(AbpCachingModule) typeof(AbpCachingModule)
)] )]
public class YiFrameworkStockDomainModule : AbpModule public class YiFrameworkStockDomainModule : AbpModule
@@ -24,6 +24,27 @@ namespace Yi.Framework.Stock.Domain
var configuration = context.Services.GetConfiguration(); var configuration = context.Services.GetConfiguration();
var services = context.Services; var services = context.Services;
// 配置绑定
var semanticKernelSection = configuration.GetSection("SemanticKernel");
services.Configure<SemanticKernelOptions>(configuration.GetSection("SemanticKernel"));
// 从配置中获取值
var options = semanticKernelSection.Get<SemanticKernelOptions>();
foreach (var optionsModelId in options.ModelIds)
{
services.AddKernel()
.AddAzureOpenAIChatCompletion(
deploymentName: optionsModelId,
endpoint: options.Endpoint,
apiKey: options.ApiKey,
serviceId: optionsModelId,
modelId: optionsModelId);
// .AddOpenAIChatCompletion(
// serviceId: optionsModelId,
// modelId: optionsModelId,
// endpoint: new Uri(options.Endpoint),
// apiKey: options.ApiKey);
}
// 添加插件 // 添加插件
services.AddSingleton<KernelPlugin>(sp => services.AddSingleton<KernelPlugin>(sp =>
KernelPluginFactory.CreateFromType<NewsPlugins>(serviceProvider: sp)); KernelPluginFactory.CreateFromType<NewsPlugins>(serviceProvider: sp));

View File

@@ -4,15 +4,14 @@ using Microsoft.SemanticKernel.Connectors.AzureOpenAI;
using Microsoft.SemanticKernel.Connectors.OpenAI; using Microsoft.SemanticKernel.Connectors.OpenAI;
using Volo.Abp.DependencyInjection; using Volo.Abp.DependencyInjection;
using Yi.Framework.ChatHub.Domain.Shared.Dtos; using Yi.Framework.ChatHub.Domain.Shared.Dtos;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.ChatHub.Domain.Managers namespace Yi.Framework.ChatHub.Domain.Managers
{ {
public class AiManager : ISingletonDependency public class AiManager : ISingletonDependency
{ {
private readonly SemanticKernelClient _client; private readonly Kernel _client;
public AiManager(SemanticKernelClient client) public AiManager(Kernel client)
{ {
_client = client; _client = client;
} }
@@ -30,7 +29,7 @@ namespace Yi.Framework.ChatHub.Domain.Managers
MaxTokens = 3000 MaxTokens = 3000
}; };
var chatCompletionService = this._client.Kernel.GetRequiredService<IChatCompletionService>(model); var chatCompletionService = this._client.GetRequiredService<IChatCompletionService>(model);
var history = new ChatHistory(); var history = new ChatHistory();
foreach (var aiChatContextDto in aiChatContextDtos) foreach (var aiChatContextDto in aiChatContextDtos)
@@ -48,7 +47,7 @@ namespace Yi.Framework.ChatHub.Domain.Managers
var results = chatCompletionService.GetStreamingChatMessageContentsAsync( var results = chatCompletionService.GetStreamingChatMessageContentsAsync(
chatHistory: history, chatHistory: history,
executionSettings: openSettings, executionSettings: openSettings,
kernel: _client.Kernel); kernel: _client);
await foreach (var result in results) await foreach (var result in results)
{ {

View File

@@ -2,7 +2,6 @@
<Import Project="..\..\..\common.props" /> <Import Project="..\..\..\common.props" />
<ItemGroup> <ItemGroup>
<ProjectReference Include="..\..\..\framework\Yi.Framework.SemanticKernel\Yi.Framework.SemanticKernel.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.SqlSugarCore.Abstractions\Yi.Framework.SqlSugarCore.Abstractions.csproj" />
<ProjectReference Include="..\Yi.Framework.ChatHub.Domain.Shared\Yi.Framework.ChatHub.Domain.Shared.csproj" /> <ProjectReference Include="..\Yi.Framework.ChatHub.Domain.Shared\Yi.Framework.ChatHub.Domain.Shared.csproj" />
</ItemGroup> </ItemGroup>
@@ -13,6 +12,7 @@
<PackageReference Include="Volo.Abp.Caching" Version="$(AbpVersion)" /> <PackageReference Include="Volo.Abp.Caching" Version="$(AbpVersion)" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.Caching.FreeRedis\Yi.Framework.Caching.FreeRedis.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.Caching.FreeRedis\Yi.Framework.Caching.FreeRedis.csproj" />
<ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" /> <ProjectReference Include="..\..\..\framework\Yi.Framework.Mapster\Yi.Framework.Mapster.csproj" />
<PackageReference Include="Microsoft.SemanticKernel" Version="1.57.0" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>

View File

@@ -2,14 +2,12 @@
using Volo.Abp.Domain; using Volo.Abp.Domain;
using Yi.Framework.Caching.FreeRedis; using Yi.Framework.Caching.FreeRedis;
using Yi.Framework.ChatHub.Domain.Shared; using Yi.Framework.ChatHub.Domain.Shared;
using Yi.Framework.SemanticKernel;
namespace Yi.Framework.ChatHub.Domain namespace Yi.Framework.ChatHub.Domain
{ {
[DependsOn( [DependsOn(
typeof(YiFrameworkChatHubDomainSharedModule), typeof(YiFrameworkChatHubDomainSharedModule),
typeof(YiFrameworkCachingFreeRedisModule), typeof(YiFrameworkCachingFreeRedisModule),
typeof(YiFrameworkSemanticKernelModule),
typeof(AbpDddDomainModule) typeof(AbpDddDomainModule)
)] )]
public class YiFrameworkChatHubDomainModule : AbpModule public class YiFrameworkChatHubDomainModule : AbpModule