// This is an automatically generated code sample.
// To make this code sample work in your Oracle Cloud tenancy,
// please replace the values for any parameters whose current values do not fit
// your use case (such as resource IDs, strings containing ‘EXAMPLE’ or ‘unique_id’, and
// boolean, number, and enum parameters with values not fitting your use case).
using System;
using System.Collections.Generic;
using System.Threading.Tasks;
using Oci.GenerativeaiagentruntimeService;
using Oci.Common;
using Oci.Common.Auth;
namespace Oci.Sdk.DotNet.Example.Generativeaiagentruntime
{
public class ChatExample
{
public static async Task Main()
{
// Create a request and dependent object(s).
var chatDetails = new Oci.GenerativeaiagentruntimeService.Models.ChatDetails
{
UserMessage = "EXAMPLE-userMessage-Value",
ShouldStream = false,
SessionId = "ocid1.test.oc1..<unique_ID>EXAMPLE-sessionId-Value",
ToolParameters = new Dictionary<string, string>()
{
{
"EXAMPLE_KEY_rNvri",
"EXAMPLE_VALUE_pACBMJjrMOoXtKuAvNd2"
}
},
ToolInputs = new List<Oci.GenerativeaiagentruntimeService.Models.ToolInput>
{
new Oci.GenerativeaiagentruntimeService.Models.GenericToolInput
{
Input = "EXAMPLE-input-Value",
ToolId = "ocid1.test.oc1..<unique_ID>EXAMPLE-toolId-Value"
}
},
PerformedActions = new List<Oci.GenerativeaiagentruntimeService.Models.PerformedAction>
{
new Oci.GenerativeaiagentruntimeService.Models.FunctionCallingPerformedAction
{
FunctionCallOutput = "EXAMPLE-functionCallOutput-Value",
ActionId = "ocid1.test.oc1..<unique_ID>EXAMPLE-actionId-Value"
}
}
};
var chatRequest = new Oci.GenerativeaiagentruntimeService.Requests.ChatRequest
{
AgentEndpointId = "ocid1.test.oc1..<unique_ID>EXAMPLE-agentEndpointId-Value",
ChatDetails = chatDetails,
OpcRequestId = "IMUPM9DDVAB54CK8RST2<unique_ID>",
IfMatch = "EXAMPLE-ifMatch-Value",
OpcRetryToken = "EXAMPLE-opcRetryToken-Value"
};
// Create a default authentication provider that uses the DEFAULT
// profile in the configuration file.
// Refer to <see href="https://docs.cloud.oracle.com/en-us/iaas/Content/API/Concepts/sdkconfig.htm#SDK_and_CLI_Configuration_File>the public documentation</see> on how to prepare a configuration file.
var provider = new ConfigFileAuthenticationDetailsProvider("DEFAULT");
try
{
// Create a service client and send the request.
using (var client = new GenerativeAiAgentRuntimeClient(provider, new ClientConfiguration()))
{
var response = await client.Chat(chatRequest);
// Retrieve value from the response.
var messageValue = response.ChatResult.Message;
}
}
catch (Exception e)
{
Console.WriteLine($"Chat Failed with {e.Message}");
throw e;
}
}
}
}