> Este documento é uma tradução de [README.md](../../README.md).
> A versão em inglês é a fonte autorizada e pode estar mais atualizada.
<div align="center">
# llm-kernel
> Biblioteca fundamental para aplicações AI-nativas em Rust — catálogo de providers, cliente LLM, servidor MCP, busca, telemetria e segurança
[](https://github.com/epicsagas/llm-kernel/actions/workflows/ci.yml)
[](https://crates.io/crates/llm-kernel)
[](https://docs.rs/llm-kernel)
[](LICENSE)
</div>
## Visão geral
llm-kernel fornece a camada fundamental para construir ferramentas, agentes e servidores baseados em LLM em Rust:
- **Catálogo de providers** — 16 providers integrados, 114 modelos com metadados, preços e capacidades
- **Cliente assíncrono** — cliente baseado em traits para OpenAI e Anthropic com streaming SSE
- **Descoberta de modelos** — descoberta dinâmica de modelos via models.dev, Ollama e endpoints compatíveis com OpenAI
- **Cofre de credenciais** — gerenciamento de chaves de API estilo dotenv com escritas atômicas
- **Carregador de config** — configuração TOML com criação automática a partir de template
- **Grafo de conhecimento** — grafo baseado em SQLite com busca FTS5, recall inteligente, travessia BFS, wrappers assíncronos
- **Servidor MCP** — framework de servidor JSON-RPC 2.0 com transporte stdio e autenticação Bearer
- **Embedding** — trait de provider + similaridade por cosseno, ONNX local (44 modelos), Qwen3 candle, Nomic V2 MoE candle, OpenAI remoto ([lista completa de modelos →](../../EMBEDDING_MODELS.md))
- **Busca** — Reciprocal Rank Fusion para fusão de resultados de busca híbrida
- **Estimativa de tokens** — contagem heurística de tokens por script Unicode sem dependências
- **Telemetria** — eventos com gate por enum sem PII, sinks de console e noop
- **Segurança** — mascaramento de segredos, classificação de erros, sanitização de saída
- **Assistente de instalação** — geração de configuração MCP para Claude Desktop, Cursor, Copilot, OpenCode, Cline
## Feature flags
Cada módulo é controlado por uma feature flag para que você só pague pelo que utiliza.
| `provider` | Catálogo de providers, descritores de modelos, preços | ✅ |
| `client-async` | Cliente LLM assíncrono (reqwest) com streaming | |
| `discovery` | Descoberta dinâmica de modelos (models.dev, Ollama, OpenAI-compat) | |
| `secrets` | Gerenciamento de credenciais SecretVault | |
| `store` | Helpers de inicialização SQLite (WAL, FTS5, versionamento de schema) | |
| `config` | Carregador de configuração TOML | |
| `graph` | Grafo de conhecimento — SQLite, FTS5, recall inteligente, travessia BFS | |
| `graph-async` | Wrappers assíncronos do grafo (requer tokio) | |
| `graph-pool` | Pool assíncrono multi-conexão do grafo (`AsyncPoolGraph`, concorrência WAL) | |
| `mcp` | Servidor MCP — JSON-RPC 2.0, transporte stdio, autenticação Bearer | |
| `tokens` | Estimativa de tokens com heurísticas de script Unicode | |
| `install` | Assistente de instalação de ferramentas AI | |
| `search` | Busca híbrida com Reciprocal Rank Fusion | |
| `embedding` | Trait de provider de embedding + similaridade por cosseno | |
| `embedding-openai` | Cliente de text-embedding do OpenAI (HTTP síncrono) | |
| `embedding-fastembed` | Embedding local via ONNX com fastembed-rs (44 modelos) | |
| `embedding-fastembed-qwen3` | Embedding Qwen3 via backend candle | |
| `embedding-fastembed-nomic-moe` | Embedding Nomic V2 MoE via backend candle | |
| `telemetry` | Eventos de telemetria com gate por enum, sem PII | |
| `safety` | Mascaramento de segredos, classificação de erros, sanitização de saída | |
| `full` | Todas as features | |
## Início rápido
Adicione ao seu `Cargo.toml`:
```toml
[dependencies]
llm-kernel = "0.1.0"
```
A feature `provider` é habilitada por padrão. Para o cliente assíncrono:
```toml
[dependencies]
llm-kernel = { version = "0.1.0", features = ["client-async"] }
```
Para o grafo de conhecimento com wrappers assíncronos:
```toml
[dependencies]
llm-kernel = { version = "0.1.0", features = ["graph", "graph-async"] }
```
Para embedding local (ONNX, sem chave de API):
```toml
[dependencies]
llm-kernel = { version = "0.1.0", features = ["embedding-fastembed"] }
```
## Uso
### Catálogo de providers
O catálogo embarcado contém 16 providers com 114 modelos alinhados ao schema do [models.dev](https://github.com/anomalyco/models.dev).
```rust
use llm_kernel::prelude::*;
let catalog = ProviderIndex::embedded();
// List all providers
for id in catalog.ids() {
let provider = catalog.get(&id).unwrap();
println!("{}", provider.display_name);
}
// Query models for a provider
for model in catalog.models_for("openai") {
println!(" {} — ${:.2}/1M in", model.id, model.cost.unwrap().input);
}
// Find a specific model
if let Some(model) = catalog.find_model("claude-sonnet-4-20250514") {
println!("Context: {} tokens", model.limit.unwrap().context);
}
```
### Chat completion assíncrono
```rust
use llm_kernel::prelude::*;
let config = ModelConfig {
provider: "openai".into(),
model: "gpt-4o".into(),
api_key_env: "OPENAI_API_KEY".into(),
base_url: None,
temperature: 0.7,
max_tokens: Some(1024),
};
let client = OpenAIClient::new(&config)?;
let response = client.complete(LLMRequest {
system: Some("You are a helpful assistant.".into()),
messages: vec![ChatMessage::user("Hello!")],
temperature: 0.7,
max_tokens: Some(1024),
model: None,
}).await?;
println!("{}", response.content);
println!("{} tokens used", response.usage.total_tokens);
```
### Streaming
```rust
use llm_kernel::prelude::*;
let config = ModelConfig {
provider: "anthropic".into(),
model: "claude-haiku-4-5-20251001".into(),
api_key_env: "ANTHROPIC_API_KEY".into(),
base_url: None,
temperature: 0.7,
max_tokens: Some(256),
};
let client = AnthropicClient::new(&config)?;
let stream = client.stream_complete(LLMRequest {
system: Some("Reply concisely.".into()),
messages: vec![ChatMessage::user("Explain Rust in one paragraph.")],
temperature: 0.7,
max_tokens: Some(256),
model: None,
}).await?;
// Stream yields Delta, Usage, and Done events
```
### Descoberta de modelos
```rust
use llm_kernel::discovery::{fetch_and_cache, load_cache, fetch_ollama_models};
// Fetch from models.dev (caches to disk)
let payload = fetch_and_cache("~/.cache/llm-kernel/models-dev.json")?;
for model in &payload.models {
println!("{} — {} (ctx: {:?})", model.id, model.provider_id, model.limits);
}
// Load from cache (no network)
if let Some(cached) = load_cache("~/.cache/llm-kernel/models-dev.json")? {
println!("{} models cached", cached.models.len());
}
// Discover local Ollama models
let ollama_models = fetch_ollama_models("http://localhost:11434")?;
for name in &ollama_models {
println!("Ollama: {}", name);
}
```
### Cofre de credenciais
```rust
use llm_kernel::prelude::*;
let vault = SecretVault::load_from("~/.config/myapp/.env")?;
vault.set("OPENAI_API_KEY", "sk-...");
vault.save_to("~/.config/myapp/.env")?;
// Redact credentials for logging
println!("{}", redact_credential("sk-abcdef1234567890"));
// → "sk-abcd...7890"
```
### Configuração TOML
```rust
use llm_kernel::config::load_toml_config;
use serde::Deserialize;
#[derive(Deserialize)]
struct AppConfig {
model: String,
temperature: f32,
}
let config: AppConfig = load_toml_config(
&path,
Some(&llm_kernel::config::default_config_template("myapp")),
)?;
```
### Store SQLite
```rust
use llm_kernel::store::init_schema;
let ddl = "CREATE TABLE items (id TEXT PRIMARY KEY, content TEXT);";
let conn = init_schema(&db_path, ddl, 1)?;
// WAL mode, busy timeout, and schema versioning applied automatically
```
### Grafo de conhecimento
```rust
use llm_kernel::prelude::*;
use rusqlite::Connection;
let conn = Connection::open_in_memory().unwrap();
init_graph_schema(&conn).unwrap();
// Create nodes
upsert_node(&conn, &GraphNode {
id: "rust-ownership".into(),
node_type: "concept".into(),
title: "Rust Ownership Model".into(),
body: "Ownership, borrowing, and lifetimes...".into(),
tags: vec!["rust".into(), "memory-safety".into()],
projects: vec!["my-project".into()],
agents: vec![],
created: "2026-01-01T00:00:00Z".into(),
updated: "2026-01-01T00:00:00Z".into(),
importance: 0.8,
access_count: 0,
accessed_at: String::new(),
}).unwrap();
// Connect with edges
append_edge(&conn, &GraphEdge {
id: "e1".into(),
source: "rust-ownership".into(),
target: "borrow-checker".into(),
relation: "related".into(),
weight: 1.5,
ts: "2026-01-01T00:00:00Z".into(),
}).unwrap();
// Smart recall with composite scoring
let results = smart_recall(&conn, Some("my-project"), Some("ownership"), 5).unwrap();
for scored in &results {
println!("{:.2} — {}", scored.score, scored.node.title);
}
// Lifecycle management
decay_importance(&conn, 30, 0.9, 0.05).unwrap();
tag_stale_nodes(&conn, 90).unwrap();
let stats = compute_stats(&conn).unwrap();
println!("{} nodes, {} edges", stats.total_nodes, stats.total_edges);
```
### Servidor MCP
```rust
use llm_kernel::mcp::{McpServer, Tool, JsonRpcRequest};
use serde_json::json;
let mut server = McpServer::new("my-server", "1.0.0");
server.register_tool(Tool {
name: "greet".into(),
description: "Say hello".into(),
input_schema: json!({
"type": "object",
"properties": { "name": { "type": "string" } },
"required": ["name"]
}),
});
// Runs JSON-RPC 2.0 over stdio with Bearer auth
server.run_stdio().await?;
```
### Estimativa de tokens
```rust
use llm_kernel::tokens::estimate_tokens;
let tokens = estimate_tokens("Hello, world! こんにちは世界 🌍");
println!("Estimated tokens: {}", tokens);
```
### Embedding + busca
```rust
use llm_kernel::embedding::{EmbeddingProvider, cosine_similarity};
use llm_kernel::search::{SearchResult, rrf_fuse};
// Cosine similarity between vectors
let sim = cosine_similarity(&[0.1, 0.2, 0.3], &[0.4, 0.5, 0.6]);
// Reciprocal Rank Fusion for hybrid search
let bm25 = vec![
SearchResult { id: "doc-a".into(), score: 0.9, text: "Rust guide".into() },
SearchResult { id: "doc-b".into(), score: 0.7, text: "Python basics".into() },
];
let vector = vec![
SearchResult { id: "doc-b".into(), score: 0.95, text: "Python basics".into() },
SearchResult { id: "doc-c".into(), score: 0.6, text: "Go concurrency".into() },
];
let merged = rrf_fuse(&[bm25, vector], 60);
```
#### Embedding local ONNX (fastembed-rs)
44 modelos via ONNX Runtime — sem chave de API, sem rede após o primeiro download.
```rust
use llm_kernel::embedding::{EmbeddingModel, FastembedProvider, EmbeddingProvider};
let provider = FastembedProvider::new(EmbeddingModel::BGESmallENV15, None)?;
let result = provider.embed("hello world")?;
assert_eq!(result.vector.len(), 384);
```
#### Embedding Qwen3 (candle)
Inferência GPU/CPU pura em Rust via candle-nn — sem ONNX Runtime.
```rust
use llm_kernel::embedding::{Qwen3Provider, EmbeddingProvider};
let provider = Qwen3Provider::new("Qwen/Qwen3-Embedding-0.6B")?;
let result = provider.embed("hello world")?;
```
#### Embedding Nomic V2 MoE (candle)
Modelo MoE leve — 8 especialistas, roteamento top-2, 305M parâmetros ativos.
```rust
use llm_kernel::embedding::{NomicMoeProvider, EmbeddingProvider};
let provider = NomicMoeProvider::new()?;
let result = provider.embed("hello world")?;
assert_eq!(result.vector.len(), 768);
```
### Utilitários de segurança
```rust
use llm_kernel::safety::{mask_secrets, classify_failure, sanitize_output};
// Mask secrets in logs
let safe = mask_secrets("Authorization: Bearer sk-abcdef123456");
// → "Authorization: Bearer [REDACTED]"
// Classify errors
let category = classify_failure("connection timed out after 30s");
// → ErrorCategory::Timeout
// Sanitize untrusted output
let clean = sanitize_output(user_input)?;
```
## Metadados dos modelos
Cada modelo no catálogo inclui:
| `cost` | Preços por milhão de tokens (input, output, cache_read, cache_write) |
| `limit` | Limites de tokens de contexto e saída |
| `modalities` | Modalidades de entrada/saída (texto, imagem, áudio) |
| `capabilities` | Flags: attachment, reasoning, temperature, tool_call, streaming |
| `knowledge` | Data de corte dos dados de treinamento |
## Por que llm-kernel?
| Catálogo de providers | ✅ 16 providers, 114 modelos integrados | Configuração manual | Configuração manual |
| Feature gates | ✅ 20 módulos independentes | Monolítico | Monolítico |
| Embedding local | ✅ 44 ONNX + Qwen3 + Nomic MoE | ❌ | ❌ |
| Servidor MCP | ✅ JSON-RPC 2.0 | ❌ | ❌ |
| Grafo de conhecimento | ✅ SQLite + FTS5 + recall inteligente | ❌ | ❌ |
| Dependências obrigatórias | Apenas `serde` | `reqwest`, `tokio`, … | Muitas |
| Chains / agentes | ❌ | ✅ | ✅ |
| Pipelines RAG | ❌ | ✅ | ✅ |
[rig]: https://github.com/0xPlaygrounds/rig
[langchain-rust]: https://github.com/Abraxas-365/langchain-rust
llm-kernel é uma **camada fundamental leve** — combine com rig ou langchain-rust quando precisar de chains, agentes ou RAG.
## Arquitetura
```
┌──────────────────────────────────────────┐
│ Your app │
├──────────────────────────────────────────┤
│ prelude │ ← use llm_kernel::prelude::*;
├───────────────┬──────────┬───────────────┤
│ provider │ client │ discovery │ ← catalog, async LLM, model discovery
│ catalog │ async │ │
├───────────────┴──────────┴───────────────┤
│ graph │ mcp │ embedding │ search │ ← graph, MCP, ONNX/Qwen3/Nomic embed, RRF
├──────────────────────────────────────────┤
│ tokens │ telemetry │ safety │ install │ ← token est., events, masking, wizard
├──────────────────────────────────────────┤
│ secrets │ config │ store │ ← vault, TOML, SQLite infra
└──────────────────────────────────────────┘
```
- **Trait `LLMClient`** — interface unificada para `OpenAIClient` e `AnthropicClient`
- **Trait `EmbeddingProvider`** — interface unificada para `FastembedProvider` (ONNX), `Qwen3Provider` (candle), `NomicMoeProvider` (candle), `OpenAIEmbeddingClient` (remoto)
- **`ProviderIndex`** — acesso zero-copy ao catálogo embarcado, consultável por provider ou modelo
- **`McpServer`** — servidor JSON-RPC 2.0 com transporte stdio, autenticação Bearer, registro de tools
- **`SecretVault`** — `HashMap<String, String>` com carregamento/salvamento dotenv e proteção contra symlinks
- **`graph`** — grafo de conhecimento SQLite com busca FTS5, recall por scoring composto, travessia BFS, decaimento de importância
- **`TelemetryEvent`** — variantes com gate por enum para observabilidade estruturada (sem PII)
- **`safety`** — mascaramento de segredos, classificação de erros, sanitização bidi/ANSI/null
## Benchmarks
Benchmarks Criterion no diretório `benches/`:
```bash
cargo bench # Run all benchmarks
cargo bench -- graph_bench # Graph: smart_recall, BFS, neighbors
cargo bench -- compute_bench # Token estimation, RRF fusion
```
## Exemplos
```bash
# List all providers and models (no API key needed)
cargo run --example provider_list
# OpenAI chat (requires OPENAI_API_KEY)
cargo run --example chat_openai --features client-async
# Anthropic streaming (requires ANTHROPIC_API_KEY)
cargo run --example stream_anthropic --features client-async
```
## Requisitos
- Rust 1.92+ (edition 2024)
## Contribuindo
Consulte [CONTRIBUTING.md](../../CONTRIBUTING.md). PRs são bem-vindos.
## Licença
[Apache-2.0](../../LICENSE) © 2026 EpicCounty