[package]
edition = "2024"
name = "agentkernel"
version = "0.17.0"
authors = ["Paul Thrasher <thrashr888@gmail.com>"]
build = false
include = [
"/src/**/*",
"/guest-agent/**/*",
"/claude-plugin/**/*",
"/plugins/**/*",
"/images/build/build-kernel.sh",
"/images/kernel/microvm.config",
"/templates/*.toml",
"/Cargo.toml",
"/Cargo.lock",
"/LICENSE",
"/README.md",
]
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Run AI coding agents in secure, isolated microVMs"
readme = "README.md"
keywords = [
"ai",
"agents",
"sandbox",
"firecracker",
"microvm",
]
categories = [
"command-line-utilities",
"development-tools",
]
license = "MIT"
repository = "https://github.com/thrashr888/agentkernel"
[features]
default = [
"kubernetes",
"nomad",
"enterprise",
]
enterprise = [
"dep:cedar-policy",
"dep:ed25519-dalek",
"dep:jsonwebtoken",
"dep:reqwest",
]
hyperlight = ["dep:hyperlight-wasm"]
kubernetes = [
"dep:kube",
"dep:k8s-openapi",
"dep:schemars",
"dep:serde_yaml",
"dep:futures",
]
nomad = ["dep:reqwest"]
[lib]
name = "agentkernel"
path = "src/lib.rs"
[[bin]]
name = "agentkernel"
path = "src/main.rs"
[dependencies.anyhow]
version = "1.0"
[dependencies.async-trait]
version = "0.1"
[dependencies.base64]
version = "0.22"
[dependencies.bytes]
version = "1.0"
[dependencies.cedar-policy]
version = "4"
optional = true
[dependencies.chrono]
version = "0.4"
features = ["serde"]
[dependencies.clap]
version = "4.0"
features = ["derive"]
[dependencies.clap_complete]
version = "4.0"
[dependencies.dirs]
version = "6.0.0"
[dependencies.ed25519-dalek]
version = "2"
features = ["rand_core"]
optional = true
[dependencies.futures]
version = "0.3"
optional = true
[dependencies.hex]
version = "0.4"
[dependencies.http-body-util]
version = "0.1"
[dependencies.hyper]
version = "1.5"
features = [
"client",
"http1",
"server",
]
[dependencies.hyper-util]
version = "0.1"
features = [
"client-legacy",
"tokio",
]
[dependencies.jsonwebtoken]
version = "10"
optional = true
[dependencies.k8s-openapi]
version = "0.24"
features = ["latest"]
optional = true
[dependencies.kube]
version = "0.98"
features = [
"client",
"runtime",
"ws",
"derive",
]
optional = true
[dependencies.mysql_async]
version = "0.36"
features = ["default-rustls"]
default-features = false
[dependencies.opentelemetry]
version = "0.28"
[dependencies.opentelemetry-otlp]
version = "0.28"
features = [
"http-proto",
"reqwest-client",
]
[dependencies.opentelemetry_sdk]
version = "0.28"
features = ["rt-tokio"]
[dependencies.prometheus]
version = "0.13"
default-features = false
[dependencies.rand]
version = "0.8"
[dependencies.rcgen]
version = "0.13"
[dependencies.redis]
version = "0.27"
[dependencies.reqwest]
version = "0.12"
features = [
"json",
"rustls-tls",
]
optional = true
[dependencies.ring]
version = "0.17"
[dependencies.rusqlite]
version = "0.33"
features = ["bundled"]
[dependencies.rustls]
version = "0.23"
features = ["ring"]
[dependencies.rustls-pemfile]
version = "2"
[dependencies.schemars]
version = "0.8"
optional = true
[dependencies.serde]
version = "1.0"
features = ["derive"]
[dependencies.serde_json]
version = "1.0"
[dependencies.serde_yaml]
version = "0.9"
optional = true
[dependencies.sha2]
version = "0.10"
[dependencies.ssh-key]
version = "0.6"
features = [
"ed25519",
"rand_core",
]
[dependencies.sysinfo]
version = "0.34"
[dependencies.tempfile]
version = "3.0"
[dependencies.thiserror]
version = "2"
[dependencies.tokio]
version = "1.0"
features = [
"full",
"process",
"net",
]
[dependencies.tokio-postgres]
version = "0.7"
features = ["with-serde_json-1"]
[dependencies.tokio-rustls]
version = "0.26"
[dependencies.toml]
version = "0.8"
[dependencies.urlencoding]
version = "2"
[dependencies.uuid]
version = "1.0"
features = [
"v4",
"v7",
]
[dependencies.wat]
version = "1.225"
[dependencies.webpki-roots]
version = "1.0.6"
[dev-dependencies.chrono]
version = "0.4"
[dev-dependencies.serde]
version = "1.0"
features = ["derive"]
[dev-dependencies.serde_json]
version = "1.0"
[dev-dependencies.tempfile]
version = "3.0"
[dev-dependencies.tokio]
version = "1.0"
features = [
"rt-multi-thread",
"macros",
]
[target.'cfg(target_os = "linux")'.dependencies.hyperlight-wasm]
version = "0.12"
optional = true
[target."cfg(unix)".dependencies.hyperlocal]
version = "0.9"
[target."cfg(unix)".dependencies.libc]
version = "0.2"
[target."cfg(unix)".dependencies.tokio-vsock]
version = "0.6"
[lints.clippy]
uninlined_format_args = "allow"
[profile.release]
opt-level = 3
lto = true
codegen-units = 1
strip = true