2025-10-07 10:59:52 +01:00
|
|
|
[package]
|
2026-02-04 01:02:18 +00:00
|
|
|
authors.workspace = true
|
2026-01-12 05:07:30 +00:00
|
|
|
categories = ["command-line-utilities", "development-tools"]
|
2025-10-07 10:59:52 +01:00
|
|
|
description = "Rust-native MCP server for Infrastructure Automation system"
|
2026-01-12 05:07:30 +00:00
|
|
|
edition.workspace = true
|
2025-10-07 10:59:52 +01:00
|
|
|
keywords = ["mcp", "rust", "infrastructure", "provisioning", "ai"]
|
2026-01-12 05:07:30 +00:00
|
|
|
license.workspace = true
|
2026-02-04 01:02:18 +00:00
|
|
|
name = "mcp-server"
|
2026-01-12 05:07:30 +00:00
|
|
|
repository.workspace = true
|
|
|
|
|
version.workspace = true
|
2025-10-07 10:59:52 +01:00
|
|
|
|
2026-02-04 01:02:18 +00:00
|
|
|
[[bin]]
|
|
|
|
|
name = "provisioning-mcp-server"
|
|
|
|
|
path = "src/simple_main.rs"
|
|
|
|
|
|
2025-10-07 10:59:52 +01:00
|
|
|
[dependencies]
|
|
|
|
|
# ============================================================================
|
|
|
|
|
# WORKSPACE DEPENDENCIES
|
|
|
|
|
# ============================================================================
|
|
|
|
|
|
|
|
|
|
# Async runtime
|
|
|
|
|
tokio = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# Serialization
|
|
|
|
|
serde = { workspace = true }
|
|
|
|
|
serde_json = { workspace = true }
|
|
|
|
|
toml = { workspace = true }
|
|
|
|
|
|
2026-01-08 21:32:59 +00:00
|
|
|
# Platform configuration
|
2026-02-04 01:02:18 +00:00
|
|
|
platform-config = { workspace = true }
|
2026-01-08 21:32:59 +00:00
|
|
|
|
feat(platform): control plane — NATS JetStream + SurrealDB + SOLID enforcement
New crates
- platform-nats: async_nats JetStream bridge; pull/push consumers, explicit ACK,
subject prefixing under provisioning.>, 6 stream definitions on startup
- platform-db: SurrealDB pool (embedded RocksDB solo, Surreal<Mem> tests,
WebSocket server multi-user); migrate() with DEFINE TABLE IF NOT EXISTS DDL
Service integrations
- orchestrator: NATS pub on task state transitions, execution_logs → SurrealDB,
webhook handler (HMAC-SHA256), AuditCollector (batch INSERT, 100-event/1s flush)
- control-center: solo_auth_middleware (intentional bypass, --mode solo only),
NATS session events, WebSocket bridge via JetStream subscription (no polling)
- vault-service: NATS lease flow; credentials over HTTPS only (lease_id in NATS);
SurrealDB storage backend with MVCC retry + exponential backoff
- secretumvault: complete SurrealDB backend replacing HashMap; 9 unit + 19 integration tests
- extension-registry: NATS lifecycle events, vault:// credential resolver with TTL cache,
cache invalidation via provisioning.workspace.*.deploy.done
Clippy workspace clean
cargo clippy --workspace -- -D warnings: 0 errors
Patterns fixed: derivable_impls (#[default] on enum variants), excessive_nesting
(let-else, boolean arithmetic in retain, extracted helpers), io_error_other,
redundant_closure, iter_kv_map, manual_range_contains, pathbuf_instead_of_path
2026-02-17 23:58:14 +00:00
|
|
|
# Centralized observability (logging, metrics, health, tracing)
|
|
|
|
|
observability = { workspace = true, features = ["logging", "metrics-prometheus", "health"] }
|
|
|
|
|
|
2025-10-07 10:59:52 +01:00
|
|
|
# Error handling
|
|
|
|
|
anyhow = { workspace = true }
|
|
|
|
|
thiserror = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# Logging
|
|
|
|
|
tracing = { workspace = true }
|
|
|
|
|
tracing-subscriber = { workspace = true, features = ["json"] }
|
|
|
|
|
|
|
|
|
|
# Configuration
|
|
|
|
|
clap = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# HTTP client (for API calls)
|
2026-01-08 21:32:59 +00:00
|
|
|
reqwest = { workspace = true, features = ["blocking"] }
|
2025-10-07 10:59:52 +01:00
|
|
|
|
|
|
|
|
# Validation
|
|
|
|
|
validator = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# UUID generation
|
|
|
|
|
uuid = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# ============================================================================
|
|
|
|
|
# ADDITIONAL WORKSPACE DEPENDENCIES
|
|
|
|
|
# ============================================================================
|
|
|
|
|
|
|
|
|
|
# Additional async utilities
|
|
|
|
|
tokio-util = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# Filesystem operations
|
|
|
|
|
walkdir = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# ============================================================================
|
|
|
|
|
# PROJECT-SPECIFIC DEPENDENCIES (not in workspace)
|
|
|
|
|
# ============================================================================
|
|
|
|
|
|
2026-01-08 21:32:59 +00:00
|
|
|
# MCP Protocol SDK - Disabled: incompatible API (main.rs binary disabled)
|
|
|
|
|
# rust-mcp-sdk = "0.7.0"
|
|
|
|
|
|
|
|
|
|
# RAG System (from provisioning-rag crate)
|
2026-02-04 01:02:18 +00:00
|
|
|
rag = { path = "../rag", features = [] }
|
2026-01-08 21:32:59 +00:00
|
|
|
|
|
|
|
|
# Date/time utilities
|
|
|
|
|
chrono = { workspace = true }
|
|
|
|
|
|
|
|
|
|
# YAML parsing
|
2026-02-04 01:02:18 +00:00
|
|
|
serde_yaml = { workspace = true }
|
2026-01-08 21:32:59 +00:00
|
|
|
|
|
|
|
|
# Directory utilities
|
|
|
|
|
dirs = { workspace = true }
|
2025-10-07 10:59:52 +01:00
|
|
|
|
|
|
|
|
[dev-dependencies]
|
|
|
|
|
criterion = { workspace = true, features = ["html_reports"] }
|
|
|
|
|
tempfile = { workspace = true }
|
2026-01-12 05:07:30 +00:00
|
|
|
tokio-test = { workspace = true }
|
2025-10-07 10:59:52 +01:00
|
|
|
|
|
|
|
|
[features]
|
|
|
|
|
debug = ["tracing-subscriber/json"]
|
2026-01-12 05:07:30 +00:00
|
|
|
default = []
|
2025-10-07 10:59:52 +01:00
|
|
|
|
2026-02-04 01:02:18 +00:00
|
|
|
# Note: simple_main.rs is the active entry point
|
|
|
|
|
# main.rs uses incompatible rust_mcp_sdk v0.7.0 API and is disabled
|
2025-10-07 10:59:52 +01:00
|
|
|
|
|
|
|
|
[lib]
|
|
|
|
|
name = "provisioning_mcp_server"
|
|
|
|
|
path = "src/lib.rs"
|
|
|
|
|
|
|
|
|
|
[[bench]]
|
2026-01-12 05:03:09 +00:00
|
|
|
harness = false
|
2026-01-12 05:07:30 +00:00
|
|
|
name = "performance"
|