OCI GenAI Cohere Chat
OCI GenAI Service offers generative AI chat with on-demand models, or dedicated AI clusters.
The OCI Chat Models Page and OCI Generative AI Playground provide detailed information about using and hosting chat models on OCI.
Prerequisites
You will need an active Oracle Cloud Infrastructure (OCI) account to use the OCI GenAI Cohere Chat client. The client offers four different ways to connect, including simple authentication with a user and private key, workload identity, instance principal, or OCI configuration file authentication.
Add Repositories and BOM
Spring AI artifacts are published in Maven Central and Spring Snapshot repositories. Refer to the Artifact Repositories section to add these repositories to your build system.
To help with dependency management, Spring AI provides a BOM (bill of materials) to ensure that a consistent version of Spring AI is used throughout the entire project. Refer to the Dependency Management section to add the Spring AI BOM to your build system.
Auto-configuration
| There has been a significant change in the Spring AI auto-configuration, starter modules' artifact names. Please refer to the upgrade notes for more information. | 
Spring AI provides Spring Boot auto-configuration for the OCI GenAI Cohere Chat Client.
To enable it add the following dependency to your project’s Maven pom.xml file:
<dependency>
    <groupId>org.springframework.ai</groupId>
    <artifactId>spring-ai-starter-model-oci-genai</artifactId>
</dependency>or to your Gradle build.gradle build file.
dependencies {
    implementation 'org.springframework.ai:spring-ai-starter-model-oci-genai'
}| Refer to the Dependency Management section to add the Spring AI BOM to your build file. | 
Chat Properties
Connection Properties
The prefix spring.ai.oci.genai is the property prefix to configure the connection to OCI GenAI.
| Property | Description | Default | 
|---|---|---|
| spring.ai.oci.genai.authenticationType | The type of authentication to use when authenticating to OCI. May be  | file | 
| spring.ai.oci.genai.region | OCI service region. | us-chicago-1 | 
| spring.ai.oci.genai.tenantId | OCI tenant OCID, used when authenticating with  | - | 
| spring.ai.oci.genai.userId | OCI user OCID, used when authenticating with  | - | 
| spring.ai.oci.genai.fingerprint | Private key fingerprint, used when authenticating with  | - | 
| spring.ai.oci.genai.privateKey | Private key content, used when authenticating with  | - | 
| spring.ai.oci.genai.passPhrase | Optional private key passphrase, used when authenticating with  | - | 
| spring.ai.oci.genai.file | Path to OCI config file. Used when authenticating with  | <user’s home directory>/.oci/config | 
| spring.ai.oci.genai.profile | OCI profile name. Used when authenticating with  | DEFAULT | 
| spring.ai.oci.genai.endpoint | Optional OCI GenAI endpoint. | - | 
Configuration Properties
| Enabling and disabling of the chat auto-configurations are now configured via top level properties with the prefix  | 
The prefix spring.ai.oci.genai.chat.cohere is the property prefix that configures the ChatModel implementation for OCI GenAI Cohere Chat.
| Property | Description | Default | 
|---|---|---|
| spring.ai.model.chat | Enable OCI GenAI Cohere chat model. | oci-genai | 
| spring.ai.oci.genai.chat.cohere.enabled (no longer valid) | Enable OCI GenAI Cohere chat model. | true | 
| spring.ai.oci.genai.chat.cohere.options.model | Model OCID or endpoint | - | 
| spring.ai.oci.genai.chat.cohere.options.compartment | Model compartment OCID. | - | 
| spring.ai.oci.genai.chat.cohere.options.servingMode | The model serving mode to be used. May be  | on-demand | 
| spring.ai.oci.genai.chat.cohere.options.preambleOverride | Override the chat model’s prompt preamble | - | 
| spring.ai.oci.genai.chat.cohere.options.temperature | Inference temperature | - | 
| spring.ai.oci.genai.chat.cohere.options.topP | Top P parameter | - | 
| spring.ai.oci.genai.chat.cohere.options.topK | Top K parameter | - | 
| spring.ai.oci.genai.chat.cohere.options.frequencyPenalty | Higher values will reduce repeated tokens and outputs will be more random. | - | 
| spring.ai.oci.genai.chat.cohere.options.presencePenalty | Higher values encourage generating outputs with tokens that haven’t been used. | - | 
| spring.ai.oci.genai.chat.cohere.options.stop | List of textual sequences that will end completions generation. | - | 
| spring.ai.oci.genai.chat.cohere.options.documents | List of documents used in chat context. | - | 
| All properties prefixed with spring.ai.oci.genai.chat.cohere.optionscan be overridden at runtime by adding a request specific Runtime Options to thePromptcall. | 
Runtime Options
The OCICohereChatOptions.java provides model configurations, such as the model to use, the temperature, the frequency penalty, etc.
On start-up, the default options can be configured with the OCICohereChatModel(api, options) constructor or the spring.ai.oci.genai.chat.cohere.options.* properties.
At run-time you can override the default options by adding new, request specific, options to the Prompt call.
For example to override the default model and temperature for a specific request:
ChatResponse response = chatModel.call(
    new Prompt(
        "Generate the names of 5 famous pirates.",
        OCICohereChatOptions.builder()
            .model("my-model-ocid")
            .compartment("my-compartment-ocid")
            .temperature(0.5)
        .build()
    ));Sample Controller
Create a new Spring Boot project and add the spring-ai-starter-model-oci-genai to your pom (or gradle) dependencies.
Add a application.properties file, under the src/main/resources directory, to enable and configure the OCI GenAI Cohere chat model:
spring.ai.oci.genai.authenticationType=file
spring.ai.oci.genai.file=/path/to/oci/config/file
spring.ai.oci.genai.cohere.chat.options.compartment=my-compartment-ocid
spring.ai.oci.genai.cohere.chat.options.servingMode=on-demand
spring.ai.oci.genai.cohere.chat.options.model=my-chat-model-ocid| replace the file,compartment, andmodelwith your values from your OCI account. | 
This will create a OCICohereChatModel implementation that you can inject into your class.
Here is an example of a simple @Controller class that uses the chat model for text generations.
@RestController
public class ChatController {
    private final OCICohereChatModel chatModel;
    @Autowired
    public ChatController(OCICohereChatModel chatModel) {
        this.chatModel = chatModel;
    }
    @GetMapping("/ai/generate")
    public Map generate(@RequestParam(value = "message", defaultValue = "Tell me a joke") String message) {
        return Map.of("generation", chatModel.call(message));
    }
    @GetMapping("/ai/generateStream")
	public Flux<ChatResponse> generateStream(@RequestParam(value = "message", defaultValue = "Tell me a joke") String message) {
        var prompt = new Prompt(new UserMessage(message));
        return chatModel.stream(prompt);
    }
}Manual Configuration
The OCICohereChatModel implements the ChatModel and uses the OCI Java SDK to connect to the OCI GenAI service.
Add the spring-ai-oci-genai dependency to your project’s Maven pom.xml file:
<dependency>
    <groupId>org.springframework.ai</groupId>
    <artifactId>spring-ai-oci-genai</artifactId>
</dependency>or to your Gradle build.gradle build file.
dependencies {
    implementation 'org.springframework.ai:spring-ai-oci-genai'
}| Refer to the Dependency Management section to add the Spring AI BOM to your build file. | 
Next, create a OCICohereChatModel and use it for text generations:
var CONFIG_FILE = Paths.get(System.getProperty("user.home"), ".oci", "config").toString();
var COMPARTMENT_ID = System.getenv("OCI_COMPARTMENT_ID");
var MODEL_ID = System.getenv("OCI_CHAT_MODEL_ID");
ConfigFileAuthenticationDetailsProvider authProvider = new ConfigFileAuthenticationDetailsProvider(
        CONFIG_FILE,
        "DEFAULT"
);
var genAi = GenerativeAiInferenceClient.builder()
        .region(Region.valueOf("us-chicago-1"))
        .build(authProvider);
var chatModel = new OCICohereChatModel(genAi, OCICohereChatOptions.builder()
        .model(MODEL_ID)
        .compartment(COMPARTMENT_ID)
        .servingMode("on-demand")
        .build());
ChatResponse response = chatModel.call(
        new Prompt("Generate the names of 5 famous pirates."));The OCICohereChatOptions provides the configuration information for the chat requests.
The OCICohereChatOptions.Builder is fluent options builder.