Skip to content

Commit

Permalink
clippy
Browse files Browse the repository at this point in the history
  • Loading branch information
fundon committed May 26, 2024
1 parent 55de613 commit d364f7b
Show file tree
Hide file tree
Showing 33 changed files with 127 additions and 124 deletions.
4 changes: 2 additions & 2 deletions viz-core/src/body.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ use sync_wrapper::SyncWrapper;
use crate::{BoxError, Error, HttpBody, Result};

/// A body state.
#[derive(Clone, Debug, PartialEq)]
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum BodyState {
/// The body is inited.
Normal,
Expand Down Expand Up @@ -41,7 +41,7 @@ pub enum Body<D = Bytes> {
impl Body {
/// Creates an empty body.
#[must_use]
pub fn empty() -> Self {
pub const fn empty() -> Self {
Self::Empty
}

Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler.rs
Original file line number Diff line number Diff line change
Expand Up @@ -211,4 +211,4 @@ pub trait HandlerExt<I>: Handler<I> {
}
}

impl<I, T: ?Sized> HandlerExt<I> for T where T: Handler<I> {}
impl<I, T> HandlerExt<I> for T where T: ?Sized + Handler<I> {}
2 changes: 1 addition & 1 deletion viz-core/src/handler/after.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct After<H, F> {
impl<H, F> After<H, F> {
/// Creates an [`After`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/and_then.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct AndThen<H, F> {
impl<H, F> AndThen<H, F> {
/// Creates an [`AndThen`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/around.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ pub struct Around<H, F> {
impl<H, F> Around<H, F> {
/// Creates an [`Around`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/before.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct Before<H, F> {
impl<H, F> Before<H, F> {
/// Creates a [`Before`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/catch_unwind.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct CatchUnwind<H, F> {
impl<H, F> CatchUnwind<H, F> {
/// Creates an [`CatchUnwind`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/map.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct Map<H, F> {
impl<H, F> Map<H, F> {
/// Creates a [`Map`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/map_err.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct MapErr<H, F> {
impl<H, F> MapErr<H, F> {
/// Creates a [`MapErr`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/map_into_response.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ pub struct MapInToResponse<H>(pub(crate) H);
impl<H> MapInToResponse<H> {
/// Creates a [`MapInToResponse`] handler.
#[inline]
pub fn new(h: H) -> Self {
pub const fn new(h: H) -> Self {
Self(h)
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/or_else.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ pub struct OrElse<H, F> {
impl<H, F> OrElse<H, F> {
/// Creates an [`OrElse`] handler.
#[inline]
pub fn new(h: H, f: F) -> Self {
pub const fn new(h: H, f: F) -> Self {
Self { h, f }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/handler/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ pub struct ServiceHandler<S>(S);

impl<S> ServiceHandler<S> {
/// Creates a new [`ServiceHandler`].
pub fn new(s: S) -> Self {
pub const fn new(s: S) -> Self {
Self(s)
}
}
Expand Down
12 changes: 6 additions & 6 deletions viz-core/src/into_response.rs
Original file line number Diff line number Diff line change
Expand Up @@ -26,15 +26,15 @@ impl IntoResponse for Response {
impl IntoResponse for Error {
fn into_response(self) -> Response {
match self {
Error::Boxed(error) => {
Self::Boxed(error) => {
let body = error.to_string();
Response::builder()
.status(StatusCode::INTERNAL_SERVER_ERROR)
.header(CONTENT_LENGTH, body.len())
.body(Full::from(body).into())
.unwrap()
}
Error::Responder(resp) | Error::Report(_, resp) => resp,
Self::Responder(resp) | Self::Report(_, resp) => resp,
}
}
}
Expand Down Expand Up @@ -109,10 +109,10 @@ where
T: IntoResponse,
{
fn into_response(self) -> Response {
match self {
Some(r) => r.into_response(),
None => StatusCode::NOT_FOUND.into_response(),
}
self.map_or_else(
|| StatusCode::NOT_FOUND.into_response(),
|r| r.into_response(),
)
}
}

Expand Down
12 changes: 6 additions & 6 deletions viz-core/src/middleware/compression.rs
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ pub struct Compress<T> {

impl<T> Compress<T> {
/// Creates a compressed response with the specified algorithm.
pub fn new(inner: T, algo: ContentCoding) -> Self {
pub const fn new(inner: T, algo: ContentCoding) -> Self {
Self { inner, algo }
}
}
Expand Down Expand Up @@ -100,7 +100,7 @@ impl<T: IntoResponse> IntoResponse for Compress<T> {
/// [`ContentCoding`]
///
/// [`ContentCoding`]: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept-Encoding
#[derive(Debug, PartialEq)]
#[derive(Debug, PartialEq, Eq)]
pub enum ContentCoding {
/// gzip
Gzip,
Expand All @@ -117,13 +117,13 @@ impl FromStr for ContentCoding {

fn from_str(s: &str) -> Result<Self, Self::Err> {
if s.eq_ignore_ascii_case("deflate") {
Ok(ContentCoding::Deflate)
Ok(Self::Deflate)
} else if s.eq_ignore_ascii_case("gzip") {
Ok(ContentCoding::Gzip)
Ok(Self::Gzip)
} else if s.eq_ignore_ascii_case("br") {
Ok(ContentCoding::Brotli)
Ok(Self::Brotli)
} else if s == "*" {
Ok(ContentCoding::Any)
Ok(Self::Any)
} else {
Err(())
}
Expand Down
4 changes: 2 additions & 2 deletions viz-core/src/middleware/cors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ impl Config {
///
/// [MDN]: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Max-Age
#[must_use]
pub fn max_age(mut self, max_age: usize) -> Self {
pub const fn max_age(mut self, max_age: usize) -> Self {
self.max_age = max_age;
self
}
Expand All @@ -46,7 +46,7 @@ impl Config {
///
/// [MDN]: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Access-Control-Allow-Credentials
#[must_use]
pub fn credentials(mut self, credentials: bool) -> Self {
pub const fn credentials(mut self, credentials: bool) -> Self {
self.credentials = credentials;
self
}
Expand Down
43 changes: 19 additions & 24 deletions viz-core/src/middleware/csrf.rs
Original file line number Diff line number Diff line change
Expand Up @@ -86,23 +86,24 @@ where
pub fn get(&self, req: &Request) -> Result<Option<Vec<u8>>> {
let inner = self.as_ref();
match inner.store {
Store::Cookie => {
match self
.get_cookie(&req.cookies()?)
.map(|c| c.value().to_string())
{
None => Ok(None),
Some(raw_token) => base64::engine::general_purpose::URL_SAFE_NO_PAD
.decode(raw_token)
.ok()
.filter(|b| b.len() == 64)
.map(unmask::<32>)
.map(Option::Some)
.ok_or_else(|| {
(StatusCode::INTERNAL_SERVER_ERROR, "Invalid csrf token").into_error()
}),
}
}
Store::Cookie => self
.get_cookie(&req.cookies()?)
.map(|c| c.value().to_string())
.map_or_else(
|| Ok(None),
|raw_token| {
base64::engine::general_purpose::URL_SAFE_NO_PAD
.decode(raw_token)
.ok()
.filter(|b| b.len() == 64)
.map(unmask::<32>)
.map(Option::Some)
.ok_or_else(|| {
(StatusCode::INTERNAL_SERVER_ERROR, "Invalid csrf token")
.into_error()
})
},
),
#[cfg(feature = "session")]
Store::Session => req.session().get(inner.cookie_options.name),
}
Expand Down Expand Up @@ -262,13 +263,7 @@ pub fn verify(secret: &[u8], raw_token: String) -> bool {

/// Retures masked token
fn mask(secret: &[u8], mut otp: Vec<u8>) -> Vec<u8> {
otp.extend::<Vec<u8>>(
secret
.iter()
.enumerate()
.map(|(i, t)| *t ^ otp[i])
.collect(),
);
otp.extend::<Vec<u8>>(secret.iter().enumerate().map(|(i, t)| *t ^ otp[i]));
otp
}

Expand Down
6 changes: 3 additions & 3 deletions viz-core/src/middleware/helper.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ impl CookieOptions {

/// Creates new `CookieOptions` with `name`
#[must_use]
pub fn name(mut self, name: &'static str) -> Self {
pub const fn name(mut self, name: &'static str) -> Self {
self.name = name;
self
}
Expand All @@ -56,14 +56,14 @@ impl CookieOptions {

/// Creates new `CookieOptions` with `path`
#[must_use]
pub fn path(mut self, path: &'static str) -> Self {
pub const fn path(mut self, path: &'static str) -> Self {
self.path = path;
self
}

/// Creates new `CookieOptions` with `secure`
#[must_use]
pub fn secure(mut self, secure: bool) -> Self {
pub const fn secure(mut self, secure: bool) -> Self {
self.secure = secure;
self
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/middleware/otel/metrics.rs
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ impl Config {
.with_unit(Unit::new("By"))
.init();

Config {
Self {
active_requests,
duration,
request_size,
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/middleware/otel/tracing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -135,7 +135,7 @@ struct RequestHeaderCarrier<'a> {
}

impl<'a> RequestHeaderCarrier<'a> {
fn new(headers: &'a HeaderMap) -> Self {
const fn new(headers: &'a HeaderMap) -> Self {
RequestHeaderCarrier { headers }
}
}
Expand Down
2 changes: 1 addition & 1 deletion viz-core/src/middleware/session/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,6 @@ where
}
}

fn max_age() -> Duration {
const fn max_age() -> Duration {
Duration::from_secs(CookieOptions::MAX_AGE)
}
22 changes: 14 additions & 8 deletions viz-core/src/response.rs
Original file line number Diff line number Diff line change
Expand Up @@ -223,14 +223,20 @@ impl ResponseExt for Response {
where
T: AsRef<std::path::Path> + Send,
{
let value = if let Some(filename) = name {
filename
} else if let Some(filename) = path.as_ref().file_name().and_then(std::ffi::OsStr::to_str) {
filename
} else {
"download"
}
.escape_default();
let value = name
.map_or_else(
|| {
if let Some(filename) =
path.as_ref().file_name().and_then(std::ffi::OsStr::to_str)
{
filename
} else {
"download"
}
},
|filename| filename,
)
.escape_default();

let mut resp = Self::attachment(&format!("attachment; filename=\"{value}\""));
*resp.body_mut() = Body::from_stream(tokio_util::io::ReaderStream::new(
Expand Down
6 changes: 3 additions & 3 deletions viz-core/src/types/form.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ pub struct Form<T = ()>(pub T);
impl<T> Form<T> {
/// Create new `Form` instance.
#[inline]
pub fn new(data: T) -> Self {
Form(data)
pub const fn new(data: T) -> Self {
Self(data)
}

/// Consumes the Form, returning the wrapped value.
Expand All @@ -33,7 +33,7 @@ where
T: Clone,
{
fn clone(&self) -> Self {
Form(self.0.clone())
Self(self.0.clone())
}
}

Expand Down
6 changes: 3 additions & 3 deletions viz-core/src/types/json.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@ pub struct Json<T = ()>(pub T);
impl<T> Json<T> {
/// Create new `Json` instance.
#[inline]
pub fn new(data: T) -> Self {
Json(data)
pub const fn new(data: T) -> Self {
Self(data)
}

/// Consumes the JSON, returning the wrapped value.
Expand All @@ -31,7 +31,7 @@ where
T: Clone,
{
fn clone(&self) -> Self {
Json(self.0.clone())
Self(self.0.clone())
}
}

Expand Down
Loading

0 comments on commit d364f7b

Please sign in to comment.