io.quarkiverse.langchain4j.ollama.OllamaClient Maven / Gradle / Ivy
package io.quarkiverse.langchain4j.ollama;
import java.net.URI;
import java.net.URISyntaxException;
import java.time.Duration;
import java.util.Optional;
import java.util.concurrent.TimeUnit;
import org.jboss.resteasy.reactive.client.api.LoggingScope;
import io.quarkiverse.langchain4j.auth.ModelAuthProvider;
import io.quarkus.rest.client.reactive.QuarkusRestClientBuilder;
import io.smallrye.mutiny.Multi;
public class OllamaClient {
private final OllamaRestApi restApi;
public OllamaClient(String baseUrl, Duration timeout, boolean logRequests, boolean logResponses, String configName) {
try {
// TODO: cache?
QuarkusRestClientBuilder builder = QuarkusRestClientBuilder.newBuilder()
.baseUri(new URI(baseUrl))
.connectTimeout(timeout.toSeconds(), TimeUnit.SECONDS)
.readTimeout(timeout.toSeconds(), TimeUnit.SECONDS);
if (logRequests || logResponses) {
builder.loggingScope(LoggingScope.REQUEST_RESPONSE);
builder.clientLogger(new OllamaRestApi.OllamaLogger(logRequests, logResponses));
}
Optional maybeModelAuthProvider = ModelAuthProvider.resolve(configName);
if (maybeModelAuthProvider.isPresent()) {
builder.register(new OllamaRestApi.OllamaRestAPIFilter(maybeModelAuthProvider.get()));
}
restApi = builder.build(OllamaRestApi.class);
} catch (URISyntaxException e) {
throw new RuntimeException(e);
}
}
public ChatResponse chat(ChatRequest request) {
return restApi.chat(request);
}
public Multi streamingChat(ChatRequest request) {
return restApi.streamingChat(request);
}
public EmbeddingResponse embedding(EmbeddingRequest request) {
return restApi.embeddings(request);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy