From 90d8f0e04004469ea27d6d69bffda46ddd61ef87 Mon Sep 17 00:00:00 2001 From: Gian Lu Date: Tue, 22 Oct 2024 10:55:46 +0200 Subject: [PATCH] [COLIB-445]: Make bridge.rs support otel 26 (#171) * feat: support otel 0.26 * fix: add missing tests for 0.25 & 0.26 + required time bump * fix: add missing clippy-otel & deny-check tasks --- CHANGELOG.md | 12 ++++++++++-- Cargo.toml | 8 ++++++-- Makefile.toml | 44 +++++++++++++++++++++++++++++++++++++++++--- src/request/otel.rs | 14 ++++++++++++++ 4 files changed, 71 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e6b0088..d67f3ae 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,14 @@ and this project adheres to --- +## [0.18.0] - 2024-10-22 + +### Added + +- Support for opentelemetry 0.26, now the default version. + +--- + ## [0.17.0] - 2024-09-27 ### Added @@ -467,8 +475,8 @@ Request::rest(&bridge).send() The old API is still available but deprecated. It will be removed soon. - -[Unreleased]: https://github.com/primait/bridge.rs/compare/0.17.0...HEAD +[Unreleased]: https://github.com/primait/bridge.rs/compare/0.18.0...HEAD +[0.18.0]: https://github.com/primait/bridge.rs/compare/0.17.0...0.18.0 [0.17.0]: https://github.com/primait/bridge.rs/compare/0.16.6...0.17.0 [0.16.6]: https://github.com/primait/bridge.rs/compare/0.16.5...0.16.6 [0.16.5]: https://github.com/primait/bridge.rs/compare/0.16.4...0.16.5 diff --git a/Cargo.toml b/Cargo.toml index b36bff6..8a78db5 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -6,7 +6,7 @@ license = "MIT" name = "prima_bridge" readme = "README.md" repository = "https://github.com/primait/bridge.rs" -version = "0.17.0" +version = "0.18.0" # See https://github.com/rust-lang/rust/issues/107557 rust-version = "1.72" @@ -16,7 +16,7 @@ default = ["tracing_opentelemetry"] auth0 = ["rand", "redis", "jsonwebtoken", "chrono", "chacha20poly1305", "dashmap", "tracing"] gzip = ["reqwest/gzip"] redis-tls = ["redis/tls", "redis/tokio-native-tls-comp"] -tracing_opentelemetry = [ "tracing_opentelemetry_0_25" ] +tracing_opentelemetry = [ "tracing_opentelemetry_0_26" ] tracing_opentelemetry_0_20 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_21_pkg", "opentelemetry_0_20_pkg"] tracing_opentelemetry_0_21 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_22_pkg", "opentelemetry_0_21_pkg", "opentelemetry_sdk_0_21_pkg"] @@ -24,6 +24,7 @@ tracing_opentelemetry_0_22 = ["_any_otel_version", "tracing", "tracing-opentelem tracing_opentelemetry_0_23 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_24_pkg", "opentelemetry_0_23_pkg", "opentelemetry_sdk_0_23_pkg"] tracing_opentelemetry_0_24 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_25_pkg", "opentelemetry_0_24_pkg", "opentelemetry_sdk_0_24_pkg"] tracing_opentelemetry_0_25 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_26_pkg", "opentelemetry_0_25_pkg", "opentelemetry_sdk_0_25_pkg"] +tracing_opentelemetry_0_26 = ["_any_otel_version", "tracing", "tracing-opentelemetry_0_27_pkg", "opentelemetry_0_26_pkg", "opentelemetry_sdk_0_26_pkg"] _any_otel_version = [] @@ -55,17 +56,20 @@ opentelemetry_0_22_pkg = { package = "opentelemetry", version = "0.22", optional opentelemetry_0_23_pkg = { package = "opentelemetry", version = "0.23", optional = true } opentelemetry_0_24_pkg = { package = "opentelemetry", version = "0.24", optional = true } opentelemetry_0_25_pkg = { package = "opentelemetry", version = "0.25", optional = true } +opentelemetry_0_26_pkg = { package = "opentelemetry", version = "0.26", optional = true } opentelemetry_sdk_0_21_pkg = { package = "opentelemetry_sdk", version = "0.21", optional = true } opentelemetry_sdk_0_22_pkg = { package = "opentelemetry_sdk", version = "0.22", optional = true } opentelemetry_sdk_0_23_pkg = { package = "opentelemetry_sdk", version = "0.23", optional = true } opentelemetry_sdk_0_24_pkg = { package = "opentelemetry_sdk", version = "0.24", optional = true } opentelemetry_sdk_0_25_pkg = { package = "opentelemetry_sdk", version = "0.25", optional = true } +opentelemetry_sdk_0_26_pkg = { package = "opentelemetry_sdk", version = "0.26", optional = true } tracing-opentelemetry_0_21_pkg = { package = "tracing-opentelemetry", version = "0.21", optional = true } tracing-opentelemetry_0_22_pkg = { package = "tracing-opentelemetry", version = "0.22", optional = true } tracing-opentelemetry_0_23_pkg = { package = "tracing-opentelemetry", version = "0.23", optional = true } tracing-opentelemetry_0_24_pkg = { package = "tracing-opentelemetry", version = "0.24", optional = true } tracing-opentelemetry_0_25_pkg = { package = "tracing-opentelemetry", version = "0.25", optional = true } tracing-opentelemetry_0_26_pkg = { package = "tracing-opentelemetry", version = "0.26", optional = true } +tracing-opentelemetry_0_27_pkg = { package = "tracing-opentelemetry", version = "0.27", optional = true } [dev-dependencies] flate2 = "1.0" diff --git a/Makefile.toml b/Makefile.toml index 47112bd..58d7e37 100644 --- a/Makefile.toml +++ b/Makefile.toml @@ -25,7 +25,9 @@ dependencies = [ "test-otel-0_21", "test-otel-0_22", "test-otel-0_23", - "test-otel-0_24" + "test-otel-0_24", + "test-otel-0_25", + "test-otel-0_26" ] [tasks.test-base] @@ -58,6 +60,14 @@ args = ["test", "--no-default-features", "--features", "tracing_opentelemetry_0_ command = "cargo" args = ["test", "--no-default-features", "--features", "tracing_opentelemetry_0_24"] +[tasks.test-otel-0_25] +command = "cargo" +args = ["test", "--no-default-features", "--features", "tracing_opentelemetry_0_25"] + +[tasks.test-otel-0_26] +command = "cargo" +args = ["test", "--no-default-features", "--features", "tracing_opentelemetry_0_26"] + [tasks.clippy] dependencies = [ "clippy-base", @@ -66,7 +76,9 @@ dependencies = [ "clippy-otel-0_21", "clippy-otel-0_22", "clippy-otel-0_23", - "clippy-otel-0_24" + "clippy-otel-0_24", + "clippy-otel-0_25", + "clippy-otel-0_26", ] [tasks.clippy-base] @@ -99,12 +111,23 @@ args = ["clippy", "--no-default-features", "--features", "tracing_opentelemetry_ command = "cargo" args = ["clippy", "--no-default-features", "--features", "tracing_opentelemetry_0_24", "--all-targets", "--", "-D", "warnings"] +[tasks.clippy-otel-0_25] +command = "cargo" +args = ["clippy", "--no-default-features", "--features", "tracing_opentelemetry_0_25", "--all-targets", "--", "-D", "warnings"] + +[tasks.clippy-otel-0_26] +command = "cargo" +args = ["clippy", "--no-default-features", "--features", "tracing_opentelemetry_0_26", "--all-targets", "--", "-D", "warnings"] + [tasks.deny-check] dependencies = [ "deny-check-otel-0_20", "deny-check-otel-0_21", "deny-check-otel-0_22", - "deny-check-otel-0_23" + "deny-check-otel-0_23", + "deny-check-otel-0_24", + "deny-check-otel-0_25", + "deny-check-otel-0_26", ] [tasks.deny-check-otel-0_20] @@ -127,6 +150,21 @@ args = ["deny", "--no-default-features", "--features", "tracing_opentelemetry_0_ command = "cargo" description = "Run cargo-deny with tracing_opentelemetry_0_23 feature" +[tasks.deny-check-otel-0_24] +args = ["deny", "--no-default-features", "--features", "tracing_opentelemetry_0_24", "check"] +command = "cargo" +description = "Run cargo-deny with tracing_opentelemetry_0_24 feature" + +[tasks.deny-check-otel-0_25] +args = ["deny", "--no-default-features", "--features", "tracing_opentelemetry_0_25", "check"] +command = "cargo" +description = "Run cargo-deny with tracing_opentelemetry_0_25 feature" + +[tasks.deny-check-otel-0_26] +args = ["deny", "--no-default-features", "--features", "tracing_opentelemetry_0_26", "check"] +command = "cargo" +description = "Run cargo-deny with tracing_opentelemetry_0_26 feature" + [tasks.docs] description = "Build docs as they are rendered on docs.rs" command = "cargo" diff --git a/src/request/otel.rs b/src/request/otel.rs index 2b0a1fc..ea24fb3 100644 --- a/src/request/otel.rs +++ b/src/request/otel.rs @@ -66,6 +66,17 @@ mod otel_0_25 { } } +#[cfg(feature = "tracing_opentelemetry_0_26")] +mod otel_0_26 { + pub use opentelemetry_0_26_pkg::propagation::{Injector, TextMapPropagator}; + pub use opentelemetry_sdk_0_26_pkg::propagation::TraceContextPropagator; + pub use tracing_opentelemetry_0_27_pkg::OpenTelemetrySpanExt; + + pub fn inject_context(injector: &mut dyn Injector) { + TraceContextPropagator::new().inject_context(&tracing::Span::current().context(), injector); + } +} + #[cfg(feature = "tracing_opentelemetry_0_20")] pub use otel_0_20::inject_context; @@ -83,3 +94,6 @@ pub use otel_0_24::inject_context; #[cfg(feature = "tracing_opentelemetry_0_25")] pub use otel_0_25::inject_context; + +#[cfg(feature = "tracing_opentelemetry_0_26")] +pub use otel_0_26::inject_context;