Merge pull request #493 from serprex/base64v22

update dependencies
This commit is contained in:
Sebastian Thiel
2024-04-26 14:47:04 +02:00
committed by GitHub
3 changed files with 15 additions and 10 deletions

View File

@@ -1,6 +1,6 @@
[package] [package]
name = "google-apis-common" name = "google-apis-common"
version = "6.0.3" version = "6.0.4"
authors = ["Sebastian Thiel <byronimo@gmail.com>"] authors = ["Sebastian Thiel <byronimo@gmail.com>"]
repository = "https://github.com/Byron/google-apis-rs" repository = "https://github.com/Byron/google-apis-rs"
homepage = "https://github.com/Byron/google-apis-rs/google-apis-common" homepage = "https://github.com/Byron/google-apis-rs/google-apis-common"
@@ -18,15 +18,16 @@ doctest = false
[dependencies] [dependencies]
mime = "^ 0.3" mime = "^ 0.3"
serde = { version = "^ 1.0", features = ["derive"] } serde = { version = "^ 1.0", features = ["derive"] }
serde_with = "2.0.1" serde_with = "3.0"
serde_json = "^ 1.0" serde_json = "^ 1.0"
base64 = "0.13.0" base64 = "0.22"
chrono = { version = "0.4.35", default-features = false, features = ["clock", "serde"] } chrono = { version = "0.4.35", default-features = false, features = ["clock", "serde"] }
url = "= 1.7" url = "2.0"
percent-encoding = "2.0"
yup-oauth2 = { version = "9", optional = true } yup-oauth2 = { version = "9", optional = true }
itertools = "^ 0.10" itertools = "^ 0.12"
hyper = { version = "^ 0.14", features = ["client", "http2"] } hyper = { version = "^ 0.14", features = ["client", "http2"] }
http = "^0.2" http = "^0.2"
tokio = { version = "^1.0", features = ["time"] } tokio = { version = "^1.0", features = ["time"] }

View File

@@ -144,6 +144,7 @@ pub mod duration {
} }
pub mod standard_base64 { pub mod standard_base64 {
use base64::Engine as _;
use serde::{Deserialize, Deserializer, Serializer}; use serde::{Deserialize, Deserializer, Serializer};
use serde_with::{DeserializeAs, SerializeAs}; use serde_with::{DeserializeAs, SerializeAs};
use std::borrow::Cow; use std::borrow::Cow;
@@ -151,7 +152,7 @@ pub mod standard_base64 {
pub struct Wrapper; pub struct Wrapper;
pub fn to_string(bytes: &Vec<u8>) -> String { pub fn to_string(bytes: &Vec<u8>) -> String {
base64::encode_config(bytes, base64::STANDARD) base64::prelude::BASE64_STANDARD.encode(bytes)
} }
impl SerializeAs<Vec<u8>> for Wrapper { impl SerializeAs<Vec<u8>> for Wrapper {
@@ -169,12 +170,13 @@ pub mod standard_base64 {
D: Deserializer<'de>, D: Deserializer<'de>,
{ {
let s: Cow<str> = Deserialize::deserialize(deserializer)?; let s: Cow<str> = Deserialize::deserialize(deserializer)?;
base64::decode_config(s.as_ref(), base64::STANDARD).map_err(serde::de::Error::custom) base64::prelude::BASE64_STANDARD.decode(s.as_ref()).map_err(serde::de::Error::custom)
} }
} }
} }
pub mod urlsafe_base64 { pub mod urlsafe_base64 {
use base64::Engine as _;
use serde::{Deserialize, Deserializer, Serializer}; use serde::{Deserialize, Deserializer, Serializer};
use serde_with::{DeserializeAs, SerializeAs}; use serde_with::{DeserializeAs, SerializeAs};
use std::borrow::Cow; use std::borrow::Cow;
@@ -182,7 +184,7 @@ pub mod urlsafe_base64 {
pub struct Wrapper; pub struct Wrapper;
pub fn to_string(bytes: &Vec<u8>) -> String { pub fn to_string(bytes: &Vec<u8>) -> String {
base64::encode_config(bytes, base64::URL_SAFE) base64::prelude::BASE64_URL_SAFE.encode(bytes)
} }
impl SerializeAs<Vec<u8>> for Wrapper { impl SerializeAs<Vec<u8>> for Wrapper {
@@ -200,7 +202,7 @@ pub mod urlsafe_base64 {
D: Deserializer<'de>, D: Deserializer<'de>,
{ {
let s: Cow<str> = Deserialize::deserialize(deserializer)?; let s: Cow<str> = Deserialize::deserialize(deserializer)?;
base64::decode_config(s.as_ref(), base64::URL_SAFE).map_err(serde::de::Error::custom) base64::prelude::BASE64_URL_SAFE.decode(s.as_ref()).map_err(serde::de::Error::custom)
} }
} }
} }
@@ -212,6 +214,7 @@ pub fn datetime_to_string(datetime: &chrono::DateTime<chrono::offset::Utc>) -> S
#[cfg(test)] #[cfg(test)]
mod test { mod test {
use super::{duration, standard_base64, urlsafe_base64}; use super::{duration, standard_base64, urlsafe_base64};
use base64::Engine as _;
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use serde_with::{serde_as, DisplayFromStr}; use serde_with::{serde_as, DisplayFromStr};

View File

@@ -1,6 +1,6 @@
use std::borrow::Cow; use std::borrow::Cow;
use ::url::percent_encoding::{percent_encode, DEFAULT_ENCODE_SET}; use ::percent_encoding::{percent_encode, AsciiSet, CONTROLS};
use ::url::Url; use ::url::Url;
pub struct Params<'a> { pub struct Params<'a> {
@@ -40,6 +40,7 @@ impl<'a> Params<'a> {
from: &str, from: &str,
url_encode: bool, url_encode: bool,
) -> String { ) -> String {
const DEFAULT_ENCODE_SET: &AsciiSet = &CONTROLS.add(b' ').add(b'"').add(b'#').add(b'<').add(b'>').add(b'`').add(b'?').add(b'{').add(b'}');
if url_encode { if url_encode {
let mut replace_with: Cow<str> = self.get(param).unwrap_or_default().into(); let mut replace_with: Cow<str> = self.get(param).unwrap_or_default().into();
if from.as_bytes()[1] == b'+' { if from.as_bytes()[1] == b'+' {