1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
//! Types for cookie state management.
//!
//! # Cookie jars
//!
//! By default HTTP is a mostly stateless protocol, but using cookies allow a
//! server to request a client to persist specific state between requests. Isahc
//! does not do this by default, but provides support for cookie state using a
//! _cookie jar_, which can store a list of cookies in memory between requests
//! and is responsible for keeping track of which cookies belong to which
//! domains.
//!
//! A cookie jar can be used on a per-request basis or for all requests sent via
//! a particular HTTP client. You can assign a cookie jar to a request or to a
//! client via the
//! [`Configurable::cookie_jar`](crate::config::Configurable::cookie_jar)
//! extension method. If different cookie jars are assigned on both a request
//! and the client sending the request, the one assigned to the individual
//! request will take precedence.
//!
//! The global default client instance does not have an assigned cookie jar.
//!
//! # Availability
//!
//! This module is only available when the [`cookies`](index.html#cookies)
//! feature is enabled.

mod cookie;
pub(crate) mod interceptor;
mod jar;

#[cfg(feature = "psl")]
mod psl;

pub use self::{
    cookie::{Cookie, CookieBuilder, ParseError},
    jar::{CookieJar, CookieRejectedError, CookieRejectedErrorKind},
};