arbit 0.17.0

Security proxy for MCP (Model Context Protocol) — auth, rate limiting, payload filtering, and audit logging between AI agents and MCP servers
Documentation
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
#
# When uploading crates to the registry Cargo will automatically
# "normalize" Cargo.toml files for maximal compatibility
# with all versions of Cargo and also rewrite `path` dependencies
# to registry (e.g., crates.io) dependencies.
#
# If you are reading this file be aware that the original Cargo.toml
# will likely look very different (and much more reasonable).
# See Cargo.toml.orig for the original contents.

[package]
edition = "2024"
name = "arbit"
version = "0.17.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.reqwest]
version = "0.12"
features = [
    "json",
    "rustls-tls",
    "stream",
]
default-features = false

[dependencies.rusqlite]
version = "0.31"
features = ["bundled"]

[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-stream]
version = "0.1"

[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"

[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",
]