[package]
edition = "2024"
rust-version = "1.85"
name = "oxigdal-workflow"
version = "0.1.3"
authors = ["COOLJAPAN OU (Team Kitasan)"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "DAG-based workflow engine for complex geospatial processing pipelines"
homepage = "https://github.com/cool-japan/oxigdal"
documentation = "https://docs.rs/oxigdal-workflow"
readme = "README.md"
keywords = [
"science",
"workflow",
"dag",
"pipeline",
"orchestration",
]
categories = [
"science",
"asynchronous",
"data-structures",
]
license = "Apache-2.0"
repository = "https://github.com/cool-japan/oxigdal"
resolver = "2"
[features]
default = ["full"]
full = [
"integrations",
"server",
]
integrations = [
"reqwest",
"rdkafka",
]
server = [
"axum",
"tower",
"tower-http",
]
[lib]
name = "oxigdal_workflow"
path = "src/lib.rs"
[[example]]
name = "batch_processing_workflow"
path = "examples/batch_processing_workflow.rs"
[[example]]
name = "change_detection_workflow"
path = "examples/change_detection_workflow.rs"
[[example]]
name = "satellite_workflow"
path = "examples/satellite_workflow.rs"
[[bench]]
name = "workflow_bench"
path = "benches/workflow_bench.rs"
harness = false
[dependencies.ahash]
version = "0.8"
features = ["serde"]
[dependencies.async-trait]
version = "0.1"
[dependencies.axum]
version = "0.8"
optional = true
[dependencies.bytes]
version = "1"
features = ["serde"]
[dependencies.chrono]
version = "0.4"
features = [
"clock",
"serde",
]
default-features = false
[dependencies.cron]
version = "0.15"
[dependencies.crossbeam]
version = "0.8"
[dependencies.crossbeam-channel]
version = "0.5"
[dependencies.dashmap]
version = "6"
[dependencies.futures]
version = "0.3"
[dependencies.num_cpus]
version = "1"
[dependencies.oxigdal-core]
version = "0.1"
[dependencies.parking_lot]
version = "0.12"
[dependencies.petgraph]
version = "0.8"
features = ["serde-1"]
[dependencies.rdkafka]
version = "0.39"
features = ["tokio"]
optional = true
default-features = false
[dependencies.regex]
version = "1"
[dependencies.reqwest]
version = "0.13"
features = [
"rustls",
"blocking",
"json",
]
optional = true
default-features = false
[dependencies.serde]
version = "1"
features = [
"derive",
"alloc",
]
default-features = false
[dependencies.serde_json]
version = "1"
[dependencies.thiserror]
version = "2"
default-features = false
[dependencies.tokio]
version = "1"
features = ["full"]
[dependencies.toml]
version = "1.0"
[dependencies.tower]
version = "0.5"
features = [
"util",
"timeout",
"load-shed",
"limit",
]
optional = true
[dependencies.tower-http]
version = "0.6"
features = [
"fs",
"trace",
"cors",
"compression-full",
]
optional = true
[dependencies.tracing]
version = "0.1"
[dependencies.tracing-subscriber]
version = "0.3"
features = ["env-filter"]
[dependencies.uuid]
version = "1"
features = [
"v4",
"serde",
]
[dev-dependencies.criterion]
version = "0.8"
features = ["html_reports"]
[dev-dependencies.proptest]
version = "1"
[dev-dependencies.tempfile]
version = "3"
[dev-dependencies.tokio]
version = "1"
features = [
"full",
"test-util",
"macros",
]
[lints.clippy]
cast_lossless = "allow"
cast_possible_truncation = "allow"
cast_precision_loss = "allow"
cast_sign_loss = "allow"
doc_markdown = "allow"
expect_used = "warn"
manual_midpoint = "allow"
missing_errors_doc = "allow"
missing_panics_doc = "allow"
module_name_repetitions = "allow"
panic = "deny"
similar_names = "allow"
suboptimal_flops = "allow"
unwrap_used = "deny"
[lints.rust]
missing_docs = "warn"
unsafe_code = "warn"