Files
Yi.Admin/Yi.Abp.Net8/module/ai-hub/Yi.Framework.AiHub.Domain/AiChat/Impl/AzureChatService.cs

65 lines
2.0 KiB
C#
Raw Normal View History

2025-06-21 01:41:05 +08:00
using System.Runtime.CompilerServices;
using Azure;
2025-06-21 01:08:14 +08:00
using Azure.AI.OpenAI;
using OpenAI.Chat;
2025-06-25 17:12:09 +08:00
using Yi.Framework.AiHub.Domain.Shared.Dtos;
2025-06-21 01:08:14 +08:00
namespace Yi.Framework.AiHub.Domain.AiChat.Impl;
public class AzureChatService : IChatService
{
2025-06-25 17:12:09 +08:00
public AzureChatService()
2025-06-21 01:08:14 +08:00
{
}
2025-06-27 22:13:26 +08:00
public async IAsyncEnumerable<CompleteChatResponse> CompleteChatAsync(AiModelDescribe aiModelDescribe,
List<ChatMessage> messages,
2025-06-21 01:41:05 +08:00
[EnumeratorCancellation] CancellationToken cancellationToken)
2025-06-21 01:08:14 +08:00
{
2025-06-25 17:12:09 +08:00
var endpoint = new Uri(aiModelDescribe.Endpoint);
2025-06-21 01:08:14 +08:00
2025-06-25 17:12:09 +08:00
var deploymentName = aiModelDescribe.ModelId;
var apiKey = aiModelDescribe.ApiKey;
2025-06-21 01:08:14 +08:00
AzureOpenAIClient azureClient = new(
endpoint,
2025-07-01 16:11:41 +08:00
new AzureKeyCredential(apiKey), new AzureOpenAIClientOptions()
{
NetworkTimeout = TimeSpan.FromSeconds(600),
});
2025-06-21 01:08:14 +08:00
ChatClient chatClient = azureClient.GetChatClient(deploymentName);
2025-06-25 22:41:32 +08:00
var response = chatClient.CompleteChatStreamingAsync(messages, new ChatCompletionOptions()
{
2025-07-01 16:11:41 +08:00
// MaxOutputTokenCount = 2048
2025-06-25 22:41:32 +08:00
}, cancellationToken: cancellationToken);
2025-06-21 01:08:14 +08:00
await foreach (StreamingChatCompletionUpdate update in response)
{
2025-06-27 22:13:26 +08:00
var result = new CompleteChatResponse();
var isFinish = update.Usage?.OutputTokenCount is not null;
if (isFinish)
{
result.IsFinish = true;
result.TokenUsage = new TokenUsage
{
OutputTokenCount = update.Usage.OutputTokenCount,
InputTokenCount = update.Usage.InputTokenCount,
TotalTokenCount = update.Usage.TotalTokenCount
};
}
2025-06-21 01:08:14 +08:00
foreach (ChatMessageContentPart updatePart in update.ContentUpdate)
{
2025-06-27 22:13:26 +08:00
result.Content = updatePart.Text;
yield return result;
}
if (isFinish)
{
yield return result;
2025-06-21 01:08:14 +08:00
}
}
}
}