2021-05-10 00:30:06 +00:00
|
|
|
[![Documentation](https://docs.rs/reqwest_cookie_store/badge.svg)](https://docs.rs/reqwest_cookie_store)
|
2021-05-10 00:26:55 +00:00
|
|
|
|
2021-05-10 01:23:56 +00:00
|
|
|
`reqwest_cookie_store` provides implementations of `reqwest::cookie::CookieStore` for [cookie_store](https://crates.io/crates/cookie_store).
|
2021-05-10 00:26:55 +00:00
|
|
|
|
|
|
|
# Example
|
2022-08-29 21:50:26 +00:00
|
|
|
The following example demonstrates loading a `cookie_store::CookieStore` (re-exported in this crate) from disk, and using it within a
|
2021-05-10 01:05:00 +00:00
|
|
|
`CookieStoreMutex`. It then makes a series of requests, examining and modifying the contents
|
|
|
|
of the underlying `cookie_store::CookieStore` in between.
|
2021-05-10 00:26:55 +00:00
|
|
|
|
2021-05-10 01:05:00 +00:00
|
|
|
```rust
|
2021-05-10 00:26:55 +00:00
|
|
|
// Load an existing set of cookies, serialized as json
|
|
|
|
let cookie_store = {
|
|
|
|
let file = std::fs::File::open("cookies.json")
|
|
|
|
.map(std::io::BufReader::new)
|
|
|
|
.unwrap();
|
2022-08-29 21:50:26 +00:00
|
|
|
// use re-exported version of `CookieStore` for crate compatibility
|
|
|
|
reqwest_cookie_store::CookieStore::load_json(file).unwrap()
|
2021-05-10 00:26:55 +00:00
|
|
|
};
|
|
|
|
let cookie_store = reqwest_cookie_store::CookieStoreMutex::new(cookie_store);
|
|
|
|
let cookie_store = std::sync::Arc::new(cookie_store);
|
|
|
|
{
|
|
|
|
// Examine initial contents
|
|
|
|
println!("initial load");
|
|
|
|
let store = cookie_store.lock().unwrap();
|
|
|
|
for c in store.iter_any() {
|
|
|
|
println!("{:?}", c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Build a `reqwest` Client, providing the deserialized store
|
|
|
|
let client = reqwest::Client::builder()
|
|
|
|
.cookie_provider(std::sync::Arc::clone(&cookie_store))
|
|
|
|
.build()
|
|
|
|
.unwrap();
|
|
|
|
|
|
|
|
// Make a sample request
|
|
|
|
client.get("https://google.com").send().await.unwrap();
|
|
|
|
{
|
|
|
|
// Examine the contents of the store.
|
|
|
|
println!("after google.com GET");
|
|
|
|
let store = cookie_store.lock().unwrap();
|
|
|
|
for c in store.iter_any() {
|
|
|
|
println!("{:?}", c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make another request from another domain
|
|
|
|
println!("GET from msn");
|
|
|
|
client.get("https://msn.com").send().await.unwrap();
|
|
|
|
{
|
|
|
|
// Examine the contents of the store.
|
|
|
|
println!("after msn.com GET");
|
|
|
|
let mut store = cookie_store.lock().unwrap();
|
|
|
|
for c in store.iter_any() {
|
|
|
|
println!("{:?}", c);
|
|
|
|
}
|
|
|
|
// Clear the store, and examine again
|
|
|
|
store.clear();
|
|
|
|
println!("after clear");
|
|
|
|
for c in store.iter_any() {
|
|
|
|
println!("{:?}", c);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get some new cookies
|
|
|
|
client.get("https://google.com").send().await.unwrap();
|
|
|
|
{
|
|
|
|
// Write store back to disk
|
|
|
|
let mut writer = std::fs::File::create("cookies2.json")
|
|
|
|
.map(std::io::BufWriter::new)
|
|
|
|
.unwrap();
|
|
|
|
let store = cookie_store.lock().unwrap();
|
|
|
|
store.save_json(&mut writer).unwrap();
|
|
|
|
}
|
|
|
|
```
|