From 6a4825bb2211b1e58f38e170c062c3af45c6067c Mon Sep 17 00:00:00 2001 From: David Pedersen Date: Fri, 24 Feb 2023 21:40:42 +0100 Subject: [PATCH] Rename `ProtoBuf` to `Protobuf` (#1763) Co-authored-by: Allan --- axum-extra/CHANGELOG.md | 4 ++- axum-extra/src/lib.rs | 2 +- axum-extra/src/protobuf.rs | 72 +++++++++++++++++++------------------- 3 files changed, 40 insertions(+), 38 deletions(-) diff --git a/axum-extra/CHANGELOG.md b/axum-extra/CHANGELOG.md index f4b547c7..67503b9b 100644 --- a/axum-extra/CHANGELOG.md +++ b/axum-extra/CHANGELOG.md @@ -7,7 +7,9 @@ and this project adheres to [Semantic Versioning]. # Unreleased -- None. +- **breaking:** Change casing of `ProtoBuf` to `Protobuf` ([#1595]) + +[#1595]: https://github.com/tokio-rs/axum/pull/1595 # 0.5.0 (12. February, 2022) diff --git a/axum-extra/src/lib.rs b/axum-extra/src/lib.rs index d98df1bb..b8152c59 100644 --- a/axum-extra/src/lib.rs +++ b/axum-extra/src/lib.rs @@ -17,7 +17,7 @@ //! `erased-json` | Enables the `ErasedJson` response | No //! `form` | Enables the `Form` extractor | No //! `json-lines` | Enables the `JsonLines` extractor and response | No -//! `protobuf` | Enables the `ProtoBuf` extractor and response | No +//! `protobuf` | Enables the `Protobuf` extractor and response | No //! `query` | Enables the `Query` extractor | No //! `spa` | Enables the `Spa` router | No //! `typed-routing` | Enables the `TypedPath` routing utilities | No diff --git a/axum-extra/src/protobuf.rs b/axum-extra/src/protobuf.rs index ddb70122..6748dc82 100644 --- a/axum-extra/src/protobuf.rs +++ b/axum-extra/src/protobuf.rs @@ -19,13 +19,13 @@ use std::ops::{Deref, DerefMut}; /// # As extractor /// /// When used as an extractor, it can decode request bodies into some type that -/// implements [`prost::Message`]. The request will be rejected (and a [`ProtoBufRejection`] will +/// implements [`prost::Message`]. The request will be rejected (and a [`ProtobufRejection`] will /// be returned) if: /// /// - The body couldn't be decoded into the target Protocol Buffer message type. /// - Buffering the request body fails. /// -/// See [`ProtoBufRejection`] for more details. +/// See [`ProtobufRejection`] for more details. /// /// The extractor does not expect a `Content-Type` header to be present in the request. /// @@ -33,7 +33,7 @@ use std::ops::{Deref, DerefMut}; /// /// ```rust,no_run /// use axum::{routing::post, Router}; -/// use axum_extra::protobuf::ProtoBuf; +/// use axum_extra::protobuf::Protobuf; /// /// #[derive(prost::Message)] /// struct CreateUser { @@ -43,7 +43,7 @@ use std::ops::{Deref, DerefMut}; /// password: String, /// } /// -/// async fn create_user(ProtoBuf(payload): ProtoBuf) { +/// async fn create_user(Protobuf(payload): Protobuf) { /// // payload is `CreateUser` /// } /// @@ -69,7 +69,7 @@ use std::ops::{Deref, DerefMut}; /// routing::get, /// Router, /// }; -/// use axum_extra::protobuf::ProtoBuf; +/// use axum_extra::protobuf::Protobuf; /// /// #[derive(prost::Message)] /// struct User { @@ -77,9 +77,9 @@ use std::ops::{Deref, DerefMut}; /// username: String, /// } /// -/// async fn get_user(Path(user_id) : Path) -> ProtoBuf { +/// async fn get_user(Path(user_id) : Path) -> Protobuf { /// let user = find_user(user_id).await; -/// ProtoBuf(user) +/// Protobuf(user) /// } /// /// async fn find_user(user_id: String) -> User { @@ -94,10 +94,10 @@ use std::ops::{Deref, DerefMut}; /// ``` #[derive(Debug, Clone, Copy, Default)] #[cfg_attr(docsrs, doc(cfg(feature = "protobuf")))] -pub struct ProtoBuf(pub T); +pub struct Protobuf(pub T); #[async_trait] -impl FromRequest for ProtoBuf +impl FromRequest for Protobuf where T: Message + Default, B: HttpBody + Send + 'static, @@ -105,19 +105,19 @@ where B::Error: Into, S: Send + Sync, { - type Rejection = ProtoBufRejection; + type Rejection = ProtobufRejection; async fn from_request(req: Request, state: &S) -> Result { let mut bytes = Bytes::from_request(req, state).await?; match T::decode(&mut bytes) { - Ok(value) => Ok(ProtoBuf(value)), - Err(err) => Err(ProtoBufDecodeError::from_err(err).into()), + Ok(value) => Ok(Protobuf(value)), + Err(err) => Err(ProtobufDecodeError::from_err(err).into()), } } } -impl Deref for ProtoBuf { +impl Deref for Protobuf { type Target = T; fn deref(&self) -> &Self::Target { @@ -125,19 +125,19 @@ impl Deref for ProtoBuf { } } -impl DerefMut for ProtoBuf { +impl DerefMut for Protobuf { fn deref_mut(&mut self) -> &mut Self::Target { &mut self.0 } } -impl From for ProtoBuf { +impl From for Protobuf { fn from(inner: T) -> Self { Self(inner) } } -impl IntoResponse for ProtoBuf +impl IntoResponse for Protobuf where T: Message + Default, { @@ -150,13 +150,13 @@ where } } -/// Rejection type for [`ProtoBuf`]. +/// Rejection type for [`Protobuf`]. /// /// This rejection is used if the request body couldn't be decoded into the target type. #[derive(Debug)] -pub struct ProtoBufDecodeError(pub(crate) axum::Error); +pub struct ProtobufDecodeError(pub(crate) axum::Error); -impl ProtoBufDecodeError { +impl ProtobufDecodeError { pub(crate) fn from_err(err: E) -> Self where E: Into, @@ -165,53 +165,53 @@ impl ProtoBufDecodeError { } } -impl std::fmt::Display for ProtoBufDecodeError { +impl std::fmt::Display for ProtobufDecodeError { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { write!(f, "Failed to decode the body: {:?}", self.0) } } -impl std::error::Error for ProtoBufDecodeError { +impl std::error::Error for ProtobufDecodeError { fn source(&self) -> Option<&(dyn std::error::Error + 'static)> { Some(&self.0) } } -impl IntoResponse for ProtoBufDecodeError { +impl IntoResponse for ProtobufDecodeError { fn into_response(self) -> Response { StatusCode::UNPROCESSABLE_ENTITY.into_response() } } -/// Rejection used for [`ProtoBuf`]. +/// Rejection used for [`Protobuf`]. /// -/// Contains one variant for each way the [`ProtoBuf`] extractor +/// Contains one variant for each way the [`Protobuf`] extractor /// can fail. #[derive(Debug)] #[non_exhaustive] -pub enum ProtoBufRejection { +pub enum ProtobufRejection { #[allow(missing_docs)] - ProtoBufDecodeError(ProtoBufDecodeError), + ProtobufDecodeError(ProtobufDecodeError), #[allow(missing_docs)] BytesRejection(BytesRejection), } -impl From for ProtoBufRejection { - fn from(inner: ProtoBufDecodeError) -> Self { - Self::ProtoBufDecodeError(inner) +impl From for ProtobufRejection { + fn from(inner: ProtobufDecodeError) -> Self { + Self::ProtobufDecodeError(inner) } } -impl From for ProtoBufRejection { +impl From for ProtobufRejection { fn from(inner: BytesRejection) -> Self { Self::BytesRejection(inner) } } -impl IntoResponse for ProtoBufRejection { +impl IntoResponse for ProtobufRejection { fn into_response(self) -> Response { match self { - Self::ProtoBufDecodeError(inner) => inner.into_response(), + Self::ProtobufDecodeError(inner) => inner.into_response(), Self::BytesRejection(inner) => inner.into_response(), } } @@ -234,7 +234,7 @@ mod tests { let app = Router::new().route( "/", - post(|input: ProtoBuf| async move { input.foo.to_owned() }), + post(|input: Protobuf| async move { input.foo.to_owned() }), ); let input = Input { @@ -263,7 +263,7 @@ mod tests { test: i32, } - let app = Router::new().route("/", post(|_: ProtoBuf| async {})); + let app = Router::new().route("/", post(|_: Protobuf| async {})); let input = Input { foo: "bar".to_owned(), @@ -291,12 +291,12 @@ mod tests { let app = Router::new().route( "/", - post(|input: ProtoBuf| async move { + post(|input: Protobuf| async move { let output = Output { result: input.foo.to_owned(), }; - ProtoBuf(output) + Protobuf(output) }), );