[package]
edition = "2024"
name = "arbit"
version = "0.18.0"
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Security proxy for MCP (Model Context Protocol) — auth, rate limiting, payload filtering, and audit logging between AI agents and MCP servers"
readme = "README.md"
keywords = [
"mcp",
"proxy",
"security",
"ai",
"gateway",
]
categories = [
"network-programming",
"authentication",
]
license = "MIT"
repository = "https://github.com/nfvelten/arbit"
[lib]
name = "arbit"
path = "src/lib.rs"
[[bin]]
name = "arbit"
path = "src/bin/arbit.rs"
[[bin]]
name = "dummy-server"
path = "src/bin/dummy_server.rs"
[[test]]
name = "attack_scenarios"
path = "tests/attack_scenarios.rs"
[[test]]
name = "http_gateway"
path = "tests/http_gateway.rs"
[[test]]
name = "security_coverage"
path = "tests/security_coverage.rs"
[[test]]
name = "stdio_gateway"
path = "tests/stdio_gateway.rs"
[dependencies.anyhow]
version = "1"
[dependencies.async-trait]
version = "0.1"
[dependencies.axum]
version = "0.8"
[dependencies.axum-server]
version = "0.7"
features = ["tls-rustls"]
[dependencies.base64]
version = "0.22"
[dependencies.chrono]
version = "0.4"
features = ["clock"]
default-features = false
[dependencies.clap]
version = "4"
features = ["derive"]
[dependencies.futures-util]
version = "0.3"
[dependencies.hex]
version = "0.4"
[dependencies.jsonschema]
version = "0.18"
default-features = false
[dependencies.jsonwebtoken]
version = "10"
features = ["rust_crypto"]
[dependencies.lru]
version = "0.16.3"
[dependencies.opentelemetry]
version = "0.26"
features = ["trace"]
[dependencies.opentelemetry-otlp]
version = "0.26"
features = [
"trace",
"grpc-tonic",
]
[dependencies.opentelemetry_sdk]
version = "0.26"
features = ["rt-tokio"]
[dependencies.percent-encoding]
version = "2"
[dependencies.prometheus]
version = "0.14"
[dependencies.regex]
version = "1"
[dependencies.regorus]
version = "0.2"
[dependencies.reqwest]
version = "0.12"
features = [
"json",
"rustls-tls",
"stream",
]
default-features = false
[dependencies.rusqlite]
version = "0.31"
features = ["bundled"]
[dependencies.rustls]
version = "0.23"
features = ["ring"]
[dependencies.rustls-pemfile]
version = "2"
[dependencies.serde]
version = "1"
features = ["derive"]
[dependencies.serde_json]
version = "1"
[dependencies.serde_yaml]
version = "0.9"
[dependencies.sha2]
version = "0.10"
[dependencies.subtle]
version = "2"
[dependencies.tokio]
version = "1"
features = ["full"]
[dependencies.tokio-rustls]
version = "0.26"
[dependencies.tokio-stream]
version = "0.1"
[dependencies.tower]
version = "0.5"
[dependencies.tracing]
version = "0.1"
[dependencies.tracing-opentelemetry]
version = "0.27"
[dependencies.tracing-subscriber]
version = "0.3"
features = [
"env-filter",
"json",
]
[dependencies.unicode-normalization]
version = "0.1"
[dependencies.uuid]
version = "1"
features = ["v4"]
[dependencies.which]
version = "7"
[dependencies.x509-parser]
version = "0.16"
[dev-dependencies.axum]
version = "0.8"
[dev-dependencies.futures-util]
version = "0.3"
[dev-dependencies.reqwest]
version = "0.12"
features = [
"json",
"rustls-tls",
]
default-features = false
[dev-dependencies.rusqlite]
version = "0.31"
features = ["bundled"]
[dev-dependencies.serde_json]
version = "1"
[dev-dependencies.tempfile]
version = "3"
[dev-dependencies.tokio]
version = "1"
features = [
"full",
"test-util",
]