mirror of
https://codeberg.org/Toasterson/solstice-ci.git
synced 2026-04-10 21:30:41 +00:00
This commit introduces gRPC-based log streaming between the VM runner (`solstice-runner`) and orchestrator. Key updates include: - Implemented gRPC server in the orchestrator for receiving and processing runner logs. - Added log streaming and job result reporting in the `solstice-runner` client. - Defined `runner.proto` with messages (`LogItem`, `JobEnd`) and the `Runner` service. - Updated orchestrator to accept gRPC settings and start the server. - Modified cloud-init user data to include gRPC endpoint and request ID for runners. - Enhanced message queue logic to handle job results via `publish_job_result`. - Configured `Cross.toml` for cross-compilation of the runner.
41 lines
1.4 KiB
TOML
41 lines
1.4 KiB
TOML
[package]
|
|
name = "orchestrator"
|
|
version = "0.1.0"
|
|
edition = "2024"
|
|
|
|
[features]
|
|
# Enable libvirt backend on Linux hosts (uses virt crate on Linux)
|
|
libvirt = []
|
|
|
|
[dependencies]
|
|
common = { path = "../common" }
|
|
clap = { version = "4", features = ["derive", "env"] }
|
|
miette = { version = "7", features = ["fancy"] }
|
|
thiserror = "1"
|
|
tracing = "0.1"
|
|
tokio = { version = "1", features = ["rt-multi-thread", "macros", "signal", "fs", "io-util"] }
|
|
serde = { version = "1", features = ["derive"] }
|
|
serde_json = "1"
|
|
serde_yaml = "0.9"
|
|
config = { version = "0.14", default-features = false, features = ["yaml"] }
|
|
reqwest = { version = "0.12", default-features = false, features = ["rustls-tls-native-roots", "http2", "gzip", "brotli", "zstd"] }
|
|
bytes = "1"
|
|
path-absolutize = "3"
|
|
# gRPC server
|
|
tonic = { version = "0.12", features = ["transport"] }
|
|
# Compression/decompression
|
|
zstd = "0.13"
|
|
# DB (optional basic persistence)
|
|
sea-orm = { version = "0.12", default-features = false, features = ["sqlx-postgres", "sqlx-sqlite", "runtime-tokio-rustls", "macros", "with-uuid", "with-chrono" ] }
|
|
migration = { path = "../migration" }
|
|
sea-orm-migration = { version = "0.12" }
|
|
chrono = { version = "0.4", default-features = false, features = ["clock", "std", "serde"] }
|
|
# Utilities
|
|
once_cell = "1"
|
|
dashmap = "6"
|
|
async-trait = "0.1"
|
|
uuid = { version = "1", features = ["v4", "serde"] }
|
|
futures-util = "0.3.31"
|
|
|
|
[target.'cfg(target_os = "linux")'.dependencies]
|
|
virt = { version = "0.3" }
|