[package]
edition = "2021"
rust-version = "1.78"
name = "atomr-telemetry"
version = "0.1.0"
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Tracing, metrics, and exporter probes for atomr — actors, dead letters, cluster, sharding, persistence, remote, streams, and distributed data."
homepage = "https://github.com/rustakka/atomr"
documentation = "https://docs.rs/atomr-telemetry"
readme = "README.md"
keywords = [
"actor",
"telemetry",
"metrics",
"tracing",
"observability",
]
categories = [
"development-tools::profiling",
"concurrency",
]
license = "Apache-2.0"
repository = "https://github.com/rustakka/atomr"
[package.metadata.docs.rs]
all-features = true
rustdoc-args = [
"--cfg",
"docsrs",
]
[features]
cluster = ["dep:atomr-cluster"]
cluster-metrics = ["dep:atomr-cluster-metrics"]
ddata = ["dep:atomr-distributed-data"]
default = [
"cluster",
"persistence",
"remote",
"streams",
"ddata",
"sharding",
"cluster-metrics",
]
otel = [
"dep:opentelemetry",
"dep:opentelemetry_sdk",
]
otel-otlp-grpc = [
"otel",
"dep:opentelemetry-otlp",
"opentelemetry-otlp/grpc-tonic",
]
otel-otlp-http = [
"otel",
"dep:opentelemetry-otlp",
"opentelemetry-otlp/http-proto",
"opentelemetry-otlp/reqwest-client",
]
otel-stdout = [
"otel",
"dep:opentelemetry-stdout",
]
persistence = ["dep:atomr-persistence"]
prometheus = ["dep:prometheus"]
remote = ["dep:atomr-remote"]
sharding = ["dep:atomr-cluster-sharding"]
streams = ["dep:atomr-streams"]
[lib]
name = "atomr_telemetry"
path = "src/lib.rs"
[[test]]
name = "actor_registry_integration"
path = "tests/actor_registry_integration.rs"
[[test]]
name = "cluster_integration"
path = "tests/cluster_integration.rs"
[[test]]
name = "dead_letters_integration"
path = "tests/dead_letters_integration.rs"
[[test]]
name = "exporters_integration"
path = "tests/exporters_integration.rs"
[[test]]
name = "persistence_integration"
path = "tests/persistence_integration.rs"
[[test]]
name = "remote_streams_ddata_integration"
path = "tests/remote_streams_ddata_integration.rs"
[[test]]
name = "sharding_integration"
path = "tests/sharding_integration.rs"
[dependencies.async-trait]
version = "0.1"
[dependencies.atomr-cluster]
version = "0.1.0"
optional = true
[dependencies.atomr-cluster-metrics]
version = "0.1.0"
optional = true
[dependencies.atomr-cluster-sharding]
version = "0.1.0"
optional = true
[dependencies.atomr-config]
version = "0.1.0"
[dependencies.atomr-core]
version = "0.1.0"
[dependencies.atomr-distributed-data]
version = "0.1.0"
optional = true
[dependencies.atomr-persistence]
version = "0.1.0"
optional = true
[dependencies.atomr-remote]
version = "0.1.0"
optional = true
[dependencies.atomr-streams]
version = "0.1.0"
optional = true
[dependencies.chrono]
version = "0.4"
features = [
"clock",
"serde",
]
default-features = false
[dependencies.dashmap]
version = "6"
[dependencies.opentelemetry]
version = "0.24"
features = [
"metrics",
"trace",
]
optional = true
default-features = false
[dependencies.opentelemetry-otlp]
version = "0.17"
features = [
"metrics",
"trace",
]
optional = true
default-features = false
[dependencies.opentelemetry-stdout]
version = "0.5"
features = [
"metrics",
"trace",
]
optional = true
default-features = false
[dependencies.opentelemetry_sdk]
version = "0.24"
features = [
"metrics",
"trace",
"rt-tokio",
]
optional = true
default-features = false
[dependencies.parking_lot]
version = "0.12"
[dependencies.prometheus]
version = "0.13"
optional = true
default-features = false
[dependencies.serde]
version = "1"
features = ["derive"]
[dependencies.serde_json]
version = "1"
[dependencies.thiserror]
version = "1"
[dependencies.tokio]
version = "1.39"
features = ["full"]
[dependencies.tracing]
version = "0.1"
[dev-dependencies.async-trait]
version = "0.1"
[dev-dependencies.tokio]
version = "1.39"
features = [
"full",
"full",
"test-util",
]
[dev-dependencies.toml]
version = "0.8"
[lints.clippy]
todo = "deny"
unimplemented = "deny"