Skip to content

Commit

Permalink
Merge pull request #1720 from solliancenet/cj-new-openai-client-081
Browse files Browse the repository at this point in the history
(0.8.1) Create new Azure OpenAI client for each call
  • Loading branch information
joelhulen authored Sep 12, 2024
2 parents bdff8be + 8a5730e commit 6222b4e
Showing 1 changed file with 23 additions and 13 deletions.
36 changes: 23 additions & 13 deletions src/dotnet/Gateway/Services/GatewayCore.cs
Original file line number Diff line number Diff line change
Expand Up @@ -232,17 +232,9 @@ private async Task<Dictionary<string, object>> CreateOpenAIAgentCapability(strin
StringComparison.OrdinalIgnoreCase) == 0)
?? throw new GatewayException($"The Gateway service is not configured to use the {endpoint} endpoint.");

var azureOpenAIClient = new AzureOpenAIClient(
new Uri(azureOpenAIAccount.Endpoint),
DefaultAuthentication.AzureCredential,
new AzureOpenAIClientOptions
{
NetworkTimeout = TimeSpan.FromSeconds(1000)
});

if (createAssistant)
{
var assistantClient = azureOpenAIClient.GetAssistantClient();
var assistantClient = GetAzureOpenAIAssistantClient(azureOpenAIAccount.Endpoint);

var prompt = GetRequiredParameterValue<string>(parameters, OpenAIAgentCapabilityParameterNames.AssistantPrompt);
var modelDeploymentName = GetRequiredParameterValue<string>(parameters, OpenAIAgentCapabilityParameterNames.ModelDeploymentName);
Expand Down Expand Up @@ -270,8 +262,8 @@ private async Task<Dictionary<string, object>> CreateOpenAIAgentCapability(strin

if (createAssistantThread)
{
var assistantClient = azureOpenAIClient.GetAssistantClient();
var vectorStoreClient = azureOpenAIClient.GetVectorStoreClient();
var assistantClient = GetAzureOpenAIAssistantClient(azureOpenAIAccount.Endpoint);
var vectorStoreClient = GetAzureOpenAIVectorStoreClient(azureOpenAIAccount.Endpoint);

var vectorStoreResult = await vectorStoreClient.CreateVectorStoreAsync(new VectorStoreCreationOptions
{
Expand Down Expand Up @@ -303,7 +295,7 @@ private async Task<Dictionary<string, object>> CreateOpenAIAgentCapability(strin

if (createAssistantFile)
{
var fileClient = azureOpenAIClient.GetFileClient();
var fileClient = GetAzureOpenAIFileClient(azureOpenAIAccount.Endpoint);

var attachmentObjectId = GetRequiredParameterValue<string>(parameters, OpenAIAgentCapabilityParameterNames.AttachmentObjectId);
var attachmentFile = await _attachmentResourceProvider.GetResource<AttachmentFile>(attachmentObjectId, userIdentity, new ResourceProviderOptions { LoadContent = true });
Expand All @@ -319,7 +311,7 @@ private async Task<Dictionary<string, object>> CreateOpenAIAgentCapability(strin

if (addAssistantFileToVectorStore)
{
var vectorStoreClient = azureOpenAIClient.GetVectorStoreClient();
var vectorStoreClient = GetAzureOpenAIVectorStoreClient(azureOpenAIAccount.Endpoint);
var vectorStoreId = GetRequiredParameterValue<string>(parameters, OpenAIAgentCapabilityParameterNames.AssistantVectorStoreId);

var vectorizationResult = await vectorStoreClient.AddFileToVectorStoreAsync(vectorStoreId, fileId);
Expand Down Expand Up @@ -365,5 +357,23 @@ private T GetRequiredParameterValue<T>(Dictionary<string, object> parameters, st
? ((JsonElement)parameterValueObject!).Deserialize<T>()
?? throw new GatewayException($"Could not load required parameter {parameterName}.", StatusCodes.Status400BadRequest)
: throw new GatewayException($"The required parameter {parameterName} was not found.");

private AzureOpenAIClient GetAzureOpenAIClient(string endpoint) =>
new AzureOpenAIClient(
new Uri(endpoint),
DefaultAuthentication.AzureCredential,
new AzureOpenAIClientOptions
{
NetworkTimeout = TimeSpan.FromSeconds(1000)
});

private AssistantClient GetAzureOpenAIAssistantClient(string endpoint) =>
GetAzureOpenAIClient(endpoint).GetAssistantClient();

private VectorStoreClient GetAzureOpenAIVectorStoreClient(string endpoint) =>
GetAzureOpenAIClient(endpoint).GetVectorStoreClient();

private FileClient GetAzureOpenAIFileClient(string endpoint) =>
GetAzureOpenAIClient(endpoint).GetFileClient();
}
}

0 comments on commit 6222b4e

Please sign in to comment.