Very WIP call ollama from user prompt.

This commit is contained in:
2026-02-07 10:36:14 +02:00
parent b5ae7c8550
commit dfa3f2dd75
3 changed files with 665 additions and 16 deletions

View File

@@ -4,7 +4,8 @@ version = "0.1.0"
edition = "2021"
[dependencies]
genai = "0.5.3"
shared = { path = "../shared" }
tokio = { version = "1.49.0", features = ["full"] }
tokio = { version = "1.49.0", features = ["full"] }
tonic = "0.14.2"
tonic-reflection = "0.14.2"

View File

@@ -1,6 +1,8 @@
use shared::ai::ai_daemon_server::{AiDaemonServer, AiDaemon};
use genai::chat::{ChatMessage, ChatRequest};
use genai::Client;
use shared::ai::ai_daemon_server::{AiDaemon, AiDaemonServer};
use shared::ai::{PromptRequest, PromptResponse};
use tonic::{transport::Server, Response, Request, Status};
use tonic::{transport::Server, Request, Response, Status};
#[derive(Default)]
pub struct DaemonServer {}
@@ -11,25 +13,46 @@ impl AiDaemon for DaemonServer {
&self,
request: Request<PromptRequest>,
) -> Result<Response<PromptResponse>, Status> {
println!("Request from {:?}: {:?}", request.remote_addr(), request.into_inner().prompt);
let reply = PromptResponse {
response: "Very nice!".to_string()
};
let remote_a = request.remote_addr();
let prompt_value = request.into_inner().prompt;
println!("Request from {:?}: {:?}", remote_a, prompt_value);
let client = Client::default();
let response = prompt_ollama(&client, "llama3.2", prompt_value.as_str())
.await
.unwrap_or_else(|err| format!("Prompt error: {}", err));
println!("Respone: {}", response);
let reply = PromptResponse { response: response };
Ok(Response::new(reply))
}
}
async fn prompt_ollama(
client: &Client,
model: &str,
prompt: &str,
) -> Result<String, Box<dyn std::error::Error>> {
let chat_req = ChatRequest::new(vec![ChatMessage::user(prompt)]);
let chat_res = client.exec_chat(model, chat_req, None).await?;
let output = chat_res
.first_text()
.unwrap_or("No response content!")
.to_string();
Ok(output)
}
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let addr = "[::1]:50051".parse().unwrap();
let addr_s = "[::1]:50051";
let addr = addr_s.parse().unwrap();
let daemon = DaemonServer::default();
let reflection_service = tonic_reflection::server::Builder::configure()
.register_encoded_file_descriptor_set(shared::ai::FILE_DESCRIPTOR_SET)
.build_v1()?;
println!("Started daemon at {}", addr_s);
Server::builder()
.add_service(AiDaemonServer::new(daemon))
.add_service(reflection_service)
.serve(addr)
.await?;
Ok(())
}
}