Private
Public Access
1
0
Files
linux_patch_api/Cargo.toml
Echo b615a5639e v1.0.0 Release - All Phases Complete
Phase 2: Core API Development
- 15 REST API endpoints (packages, patches, system, jobs, websocket)
- mTLS authentication layer (src/auth/mtls.rs)
- IP whitelist enforcement (src/auth/whitelist.rs)
- Job manager with async operation support
- WebSocket streaming for job status

Phase 3: Security Hardening
- Security testing: 16/16 tests passing
- Fuzz testing: 21 tests, all findings resolved
- Threat model validation (STRIDE matrix)
- TLS binding fix (critical vulnerability resolved)
- Security documentation complete

Phase 4: Production Readiness
- Performance benchmarking (all targets met)
- Package creation (.deb/.rpm structures)
- Documentation (README, API docs, deployment guide)
- Security hardening (6 vulnerabilities fixed)

Deliverables:
- API_DOCUMENTATION.md (889 lines)
- DEPLOYMENT_GUIDE.md (733 lines)
- SECURITY.md (346 lines)
- README.md (525 lines)
- debian/ package structure
- linux-patch-api.spec (RPM)
- install.sh installer script
- benches/api_benchmarks.rs
- Multiple security/performance reports

Security Status: 0 vulnerabilities remaining
Test Coverage: 31 unit tests, 21 integration tests
Build Status: Release optimized
2026-04-10 01:41:19 +00:00

98 lines
1.9 KiB
TOML

[package]
name = "linux-patch-api"
version = "0.1.0"
edition = "2021"
authors = ["Echo <echo@moon-dragon.us>"]
description = "Secure remote package management API for Linux systems"
license = "MIT"
repository = "https://gitea.moon-dragon.us/echo/linux_patch_api"
rust-version = "1.75"
[dependencies]
# Web framework (Actix-web for HTTP API)
actix-web = { version = "4", features = ["rustls-0_23"] }
actix-rt = "2"
actix-web-actors = "4"
actix = "0.13"
actix-tls = { version = "3", features = ["rustls-0_23"] }
# Async runtime
tokio = { version = "1", features = ["full"] }
# TLS/mTLS (rustls for modern TLS 1.3)
rustls = "0.23"
rustls-pemfile = "2"
tokio-rustls = "0.26"
x509-parser = "0.16"
# WebSocket support (actix-web-actors provides WebSocket for Actix-web)
tokio-tungstenite = "0.21"
futures-util = "0.3"
# Serialization
serde = { version = "1", features = ["derive"] }
serde_json = "1"
serde_yaml = "0.9"
# Configuration
config = "0.14"
notify = "6"
# Logging
tracing = "0.1"
tracing-subscriber = { version = "0.3", features = ["env-filter", "json"] }
tracing-appender = "0.2"
# UUID for request IDs and job IDs
uuid = { version = "1", features = ["v4", "serde"] }
# Time/Date
chrono = { version = "0.4", features = ["serde"] }
# Error handling
thiserror = "1"
anyhow = "1"
# Async channels
async-channel = "2"
# Process management (for package operations)
sysinfo = "0.30"
# Network utilities
addr = "0.15"
# Clap for CLI arguments
clap = { version = "4", features = ["derive", "env"] }
# Systemd integration
systemd = "0.10"
pidlock = "0.2"
[dev-dependencies]
actix-rt = "2"
tokio-test = "0.4"
wiremock = "0.6"
serial_test = "3"
tempfile = "3"
criterion = { version = "0.5", features = ["html_reports"] }
[[bench]]
name = "api_benchmarks"
harness = false
[profile.release]
lto = true
codegen-units = 1
panic = "abort"
strip = true
opt-level = 3
[profile.dev]
opt-level = 0
debug = true
[[bin]]
name = "linux-patch-api"
path = "src/main.rs"