From 86a7dce1e5af44186e3b52cf72aa238c182e5496 Mon Sep 17 00:00:00 2001 From: tottoto Date: Fri, 15 Sep 2023 05:49:34 +0900 Subject: [PATCH] chore(tonic): Deprecate API when they only return None --- tonic/src/request.rs | 21 +++++++++++++++++++++ tonic/src/transport/tls.rs | 21 +++++++++++++++++++++ 2 files changed, 42 insertions(+) diff --git a/tonic/src/request.rs b/tonic/src/request.rs index e0295be59..e6a487dc0 100644 --- a/tonic/src/request.rs +++ b/tonic/src/request.rs @@ -207,6 +207,13 @@ impl Request { /// This will return `None` if the `IO` type used /// does not implement `Connected` or when using a unix domain socket. /// This currently only works on the server side. + #[cfg_attr( + not(feature = "transport"), + deprecated( + since = "0.10.1", + note = "`remote_addr` only returns `None` without transport feature. This API will require transport feature.", + ) + )] pub fn local_addr(&self) -> Option { #[cfg(feature = "transport")] { @@ -241,6 +248,13 @@ impl Request { /// This will return `None` if the `IO` type used /// does not implement `Connected` or when using a unix domain socket. /// This currently only works on the server side. + #[cfg_attr( + not(feature = "transport"), + deprecated( + since = "0.10.1", + note = "`remote_addr` only returns `None` without transport feature. This API will require transport feature.", + ) + )] pub fn remote_addr(&self) -> Option { #[cfg(feature = "transport")] { @@ -277,6 +291,13 @@ impl Request { /// `Some` on the server side of the `transport` server with /// TLS enabled connections. #[cfg(feature = "transport")] + #[cfg_attr( + all(feature = "transport", not(feature = "tls")), + deprecated( + since = "0.10.1", + note = "`peer_certs` only returns `None` without tls feature. This API will require tls feature.", + ) + )] #[cfg_attr(docsrs, doc(cfg(feature = "transport")))] pub fn peer_certs(&self) -> Option>> { #[cfg(feature = "tls")] diff --git a/tonic/src/transport/tls.rs b/tonic/src/transport/tls.rs index a4151c748..b78530c26 100644 --- a/tonic/src/transport/tls.rs +++ b/tonic/src/transport/tls.rs @@ -1,4 +1,11 @@ /// Represents a X509 certificate. +#[cfg_attr( + not(feature = "tls"), + deprecated( + since = "0.10.1", + note = "`Certificate` is used only by deprecated API without tls feature.", + ) +)] #[derive(Debug, Clone)] pub struct Certificate { pub(crate) pem: Vec, @@ -13,6 +20,13 @@ pub struct Identity { pub(crate) key: Vec, } +#[cfg_attr( + not(feature = "tls"), + deprecated( + since = "0.10.1", + note = "`Certificate` is used only by deprecated API without tls feature.", + ) +)] impl Certificate { /// Parse a PEM encoded X509 Certificate. /// @@ -38,6 +52,13 @@ impl Certificate { } } +#[cfg_attr( + not(feature = "tls"), + deprecated( + since = "0.10.1", + note = "`Certificate` is used only by deprecated API without tls feature.", + ) +)] impl AsRef<[u8]> for Certificate { fn as_ref(&self) -> &[u8] { self.pem.as_ref()