Some checks failed
Test / rust-fmt-check (pull_request) Successful in 1m29s
Test / frontend-typecheck (pull_request) Successful in 1m28s
Test / frontend-tests (pull_request) Successful in 1m30s
Test / rust-clippy (pull_request) Successful in 3m33s
Test / rust-tests (pull_request) Successful in 4m54s
PR Review Automation / review (pull_request) Failing after 8m49s
- Implement AgentRegistry system with devops-incident-responder agent - Add domain detection based on conversation keywords - Inject devops-incident-responder as primary system prompt - Auto-switch domain prompts silently when context shifts - Fix version update script to handle JSON format correctly - Always display version in bottom-left corner - Add release notes fallback to git commits if CHANGELOG empty This implements the full devops-incident-responder agent as the primary system prompt, with domain-specific SME prompts layered on top based on conversation content analysis. The version display bug is fixed by removing the collapsed condition, and release notes now have a fallback mechanism.
94 lines
2.5 KiB
Rust
94 lines
2.5 KiB
Rust
pub mod agents;
|
|
pub mod anthropic;
|
|
pub mod gemini;
|
|
pub mod mistral;
|
|
pub mod ollama;
|
|
pub mod openai;
|
|
pub mod provider;
|
|
pub mod tools;
|
|
|
|
pub use provider::*;
|
|
pub use tools::*;
|
|
|
|
pub use agents::{create_agent_registry, detect_domain, load_agent, Agent, AgentRegistry};
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
use std::collections::HashMap;
|
|
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct Message {
|
|
pub role: String,
|
|
pub content: String,
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
pub tool_call_id: Option<String>,
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
pub tool_calls: Option<Vec<ToolCall>>,
|
|
}
|
|
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct ChatResponse {
|
|
pub content: String,
|
|
pub model: String,
|
|
pub usage: Option<TokenUsage>,
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
pub tool_calls: Option<Vec<ToolCall>>,
|
|
}
|
|
|
|
/// Represents a tool call made by the AI
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct ToolCall {
|
|
pub id: String,
|
|
pub name: String,
|
|
pub arguments: String, // JSON string
|
|
}
|
|
|
|
/// Tool definition that describes available functions to the AI
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct Tool {
|
|
pub name: String,
|
|
pub description: String,
|
|
pub parameters: ToolParameters,
|
|
}
|
|
|
|
/// JSON Schema-style parameter definition for tools
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct ToolParameters {
|
|
#[serde(rename = "type")]
|
|
pub param_type: String, // Usually "object"
|
|
pub properties: HashMap<String, ParameterProperty>,
|
|
pub required: Vec<String>,
|
|
}
|
|
|
|
/// Individual parameter property definition
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct ParameterProperty {
|
|
#[serde(rename = "type")]
|
|
pub prop_type: String, // "string", "number", "integer", "boolean"
|
|
pub description: String,
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
#[serde(rename = "enum")]
|
|
pub enum_values: Option<Vec<String>>,
|
|
}
|
|
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct TokenUsage {
|
|
pub prompt_tokens: u32,
|
|
pub completion_tokens: u32,
|
|
pub total_tokens: u32,
|
|
}
|
|
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct AnalysisResult {
|
|
pub summary: String,
|
|
pub key_findings: Vec<String>,
|
|
pub suggested_why1: String,
|
|
pub severity_assessment: String,
|
|
}
|
|
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct ProviderInfo {
|
|
pub name: String,
|
|
pub supports_streaming: bool,
|
|
pub models: Vec<String>,
|
|
}
|