agentkernel 0.15.0

Run AI coding agents in secure, isolated microVMs
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 = "agentkernel"
version = "0.15.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.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.34"
features = ["default-rustls"]
default-features = false

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