Skip to main content

oxios_kernel/tools/builtin/
mod.rs

1//! Kernel tools — AgentTool wrappers for KernelHandle API domains.
2//!
3//! These tools expose kernel system calls to the agent's tool-calling loop.
4//! Each tool wraps a specific domain API and uses an action-based parameter
5//! schema to dispatch operations.
6//!
7//! ## Tools
8//!
9//! - [`ProjectTool`] — Project management (list, get, link_memory, unlink_memory)
10//! - [`AgentTool`] — Agent lifecycle (list, kill, budget)
11//! - [`PersonaTool`] — Persona management (list, set_active, get)
12//! - [`CronTool`] — Cron scheduling (list, add, remove, trigger)
13//! - [`SecurityTool`] — Security audit (verify_chain, query_audit, audit_count)
14//! - [`BudgetTool`] — Budget management (check, set, reserve, reset)
15//! - [`ResourceTool`] — Resource monitoring (snapshot, history, overloaded)
16//! - [`CalendarTool`] — Calendar events (create, update, delete, list, search, freebusy)
17
18pub mod agent_tool;
19pub mod budget_tool;
20pub mod calendar_tool;
21pub mod cron_tool;
22pub mod email_tool;
23pub mod knowledge_tool;
24pub mod marketplace_tool;
25pub mod mount_tool;
26pub mod persona_tool;
27pub mod project_tool;
28pub mod resource_tool;
29pub mod security_tool;
30
31pub use agent_tool::AgentTool as KernelAgentTool;
32pub use budget_tool::BudgetTool;
33pub use calendar_tool::CalendarTool;
34pub use cron_tool::CronTool;
35pub use email_tool::EmailTool;
36pub use knowledge_tool::KnowledgeTool;
37pub use marketplace_tool::MarketplaceTool;
38pub use mount_tool::MountTool;
39pub use persona_tool::PersonaTool;
40pub use project_tool::ProjectTool;
41pub use resource_tool::ResourceTool;
42pub use security_tool::SecurityTool;
43
44use crate::KernelHandle;
45use crate::types::AgentId;
46use oxi_sdk::ToolRegistry;
47
48/// Register all kernel domain tools into the registry.
49///
50/// Called by [`super::kernel_bridge::OxiosKernelBridge`] during agent build.
51/// This is the canonical list of kernel tools available in oxios agents.
52pub fn register_all_kernel_tools(registry: &ToolRegistry, kernel: &KernelHandle, _agent_id: &str) {
53    let agent_uuid = AgentId::new_v4();
54
55    // ExecTool (stores Arc<KernelHandle>)
56    registry.register(crate::tools::ExecTool::from_kernel(kernel));
57
58    // Memory tools (each stores Arc<KernelHandle>)
59    registry.register(crate::tools::MemoryReadTool::from_kernel(kernel));
60    registry.register(crate::tools::MemorySearchTool::from_kernel(kernel));
61
62    // Kernel domain tools (take &KernelHandle)
63    registry.register(ProjectTool::from_kernel(kernel));
64    registry.register(MountTool::from_kernel(kernel));
65    registry.register(KernelAgentTool::from_kernel(kernel));
66    registry.register(PersonaTool::from_kernel(kernel));
67    registry.register(CronTool::from_kernel(kernel));
68    registry.register(SecurityTool::from_kernel(kernel));
69    registry.register(BudgetTool::from_kernel(kernel));
70    registry.register(ResourceTool::from_kernel(kernel));
71
72    // A2A tools (each stores Arc<KernelHandle>)
73    registry.register(crate::tools::A2aDelegateTool::from_kernel(
74        kernel, agent_uuid,
75    ));
76    registry.register(crate::tools::A2aSendTool::from_kernel(kernel, agent_uuid));
77    registry.register(crate::tools::A2aQueryTool::from_kernel(kernel));
78
79    // MCP tool wrapper (stores Arc<KernelHandle>)
80    registry.register(crate::tools::McpToolWrapper::from_kernel(
81        kernel,
82        "",
83        "",
84        "MCP tools via bridge".into(),
85        serde_json::json!({"type": "object", "properties": {}}),
86    ));
87
88    // KnowledgeTool (markdown note management)
89    registry.register(KnowledgeTool::from_kernel(kernel));
90
91    // Browser (optional feature, stores Arc<KernelHandle>)
92    #[cfg(feature = "native-browser")]
93    {}
94
95    // Marketplace (ClawHub — search, install, update)
96    registry.register(MarketplaceTool::from_kernel(kernel));
97
98    // Calendar (optional — only if [calendar] is enabled)
99    if let Some(calendar_tool) = CalendarTool::try_from_kernel(kernel) {
100        registry.register(calendar_tool);
101    }
102
103    // Email (optional — only if [email] is enabled)
104    if let Some(email_tool) = EmailTool::try_from_kernel(kernel) {
105        registry.register(email_tool);
106    }
107}