From b84f1df2e4e86b9f338be35c785b5e25b68be023 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pepe=20M=C3=A1rquez=20Romero?= Date: Mon, 21 Aug 2023 19:43:03 +0200 Subject: [PATCH] serde feature --- Cargo.toml | 5 +++++ src/lib.rs | 4 ++++ 2 files changed, 9 insertions(+) diff --git a/Cargo.toml b/Cargo.toml index e311c3d..3f4f941 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -16,11 +16,16 @@ categories = ["web-programming::http-client", "web-programming"] # https://crat all-features = true rustdoc-args = ["--cfg", "docsrs"] +[features] +serde = ["dep:serde" , "dep:serde_derive"] + [dependencies] bytes = "1.0.1" cookie_store = "^0.20" reqwest = { version = "^0.11", default-features = false, features = ["cookies"] } url = "2.2.2" +serde = {version = "1.0.147", features = ["rc"], optional = true} +serde_derive = {version = "1.0.147" , optional = true } [dev-dependencies] tokio-test = "0.4.1" diff --git a/src/lib.rs b/src/lib.rs index d841965..7c04b41 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -87,6 +87,8 @@ use std::{ use bytes::Bytes; pub use cookie_store::{CookieStore, RawCookie, RawCookieParseError}; use reqwest::header::HeaderValue; +#[cfg(feature = "serde")] +use serde_derive::{Deserialize, Serialize}; use url; fn set_cookies( @@ -121,6 +123,7 @@ fn cookies(cookie_store: &CookieStore, url: &url::Url) -> Option { /// A [`cookie_store::CookieStore`] wrapped internally by a [`std::sync::Mutex`], suitable for use in /// async/concurrent contexts. #[derive(Debug)] +#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))] pub struct CookieStoreMutex(Mutex); impl Default for CookieStoreMutex { @@ -164,6 +167,7 @@ impl reqwest::cookie::CookieStore for CookieStoreMutex { /// A [`cookie_store::CookieStore`] wrapped internally by a [`std::sync::RwLock`], suitable for use in /// async/concurrent contexts. #[derive(Debug)] +#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))] pub struct CookieStoreRwLock(RwLock); impl Default for CookieStoreRwLock {