[e3d4e0a] | 1 | <?php
|
---|
| 2 |
|
---|
| 3 | namespace GuzzleHttp\Cookie;
|
---|
| 4 |
|
---|
| 5 | use Psr\Http\Message\RequestInterface;
|
---|
| 6 | use Psr\Http\Message\ResponseInterface;
|
---|
| 7 |
|
---|
| 8 | /**
|
---|
| 9 | * Stores HTTP cookies.
|
---|
| 10 | *
|
---|
| 11 | * It extracts cookies from HTTP requests, and returns them in HTTP responses.
|
---|
| 12 | * CookieJarInterface instances automatically expire contained cookies when
|
---|
| 13 | * necessary. Subclasses are also responsible for storing and retrieving
|
---|
| 14 | * cookies from a file, database, etc.
|
---|
| 15 | *
|
---|
| 16 | * @see https://docs.python.org/2/library/cookielib.html Inspiration
|
---|
| 17 | *
|
---|
| 18 | * @extends \IteratorAggregate<SetCookie>
|
---|
| 19 | */
|
---|
| 20 | interface CookieJarInterface extends \Countable, \IteratorAggregate
|
---|
| 21 | {
|
---|
| 22 | /**
|
---|
| 23 | * Create a request with added cookie headers.
|
---|
| 24 | *
|
---|
| 25 | * If no matching cookies are found in the cookie jar, then no Cookie
|
---|
| 26 | * header is added to the request and the same request is returned.
|
---|
| 27 | *
|
---|
| 28 | * @param RequestInterface $request Request object to modify.
|
---|
| 29 | *
|
---|
| 30 | * @return RequestInterface returns the modified request.
|
---|
| 31 | */
|
---|
| 32 | public function withCookieHeader(RequestInterface $request): RequestInterface;
|
---|
| 33 |
|
---|
| 34 | /**
|
---|
| 35 | * Extract cookies from an HTTP response and store them in the CookieJar.
|
---|
| 36 | *
|
---|
| 37 | * @param RequestInterface $request Request that was sent
|
---|
| 38 | * @param ResponseInterface $response Response that was received
|
---|
| 39 | */
|
---|
| 40 | public function extractCookies(RequestInterface $request, ResponseInterface $response): void;
|
---|
| 41 |
|
---|
| 42 | /**
|
---|
| 43 | * Sets a cookie in the cookie jar.
|
---|
| 44 | *
|
---|
| 45 | * @param SetCookie $cookie Cookie to set.
|
---|
| 46 | *
|
---|
| 47 | * @return bool Returns true on success or false on failure
|
---|
| 48 | */
|
---|
| 49 | public function setCookie(SetCookie $cookie): bool;
|
---|
| 50 |
|
---|
| 51 | /**
|
---|
| 52 | * Remove cookies currently held in the cookie jar.
|
---|
| 53 | *
|
---|
| 54 | * Invoking this method without arguments will empty the whole cookie jar.
|
---|
| 55 | * If given a $domain argument only cookies belonging to that domain will
|
---|
| 56 | * be removed. If given a $domain and $path argument, cookies belonging to
|
---|
| 57 | * the specified path within that domain are removed. If given all three
|
---|
| 58 | * arguments, then the cookie with the specified name, path and domain is
|
---|
| 59 | * removed.
|
---|
| 60 | *
|
---|
| 61 | * @param string|null $domain Clears cookies matching a domain
|
---|
| 62 | * @param string|null $path Clears cookies matching a domain and path
|
---|
| 63 | * @param string|null $name Clears cookies matching a domain, path, and name
|
---|
| 64 | */
|
---|
| 65 | public function clear(?string $domain = null, ?string $path = null, ?string $name = null): void;
|
---|
| 66 |
|
---|
| 67 | /**
|
---|
| 68 | * Discard all sessions cookies.
|
---|
| 69 | *
|
---|
| 70 | * Removes cookies that don't have an expire field or a have a discard
|
---|
| 71 | * field set to true. To be called when the user agent shuts down according
|
---|
| 72 | * to RFC 2965.
|
---|
| 73 | */
|
---|
| 74 | public function clearSessionCookies(): void;
|
---|
| 75 |
|
---|
| 76 | /**
|
---|
| 77 | * Converts the cookie jar to an array.
|
---|
| 78 | */
|
---|
| 79 | public function toArray(): array;
|
---|
| 80 | }
|
---|