Pollen Solutions - Cookie Component - HTTP Request cookie manager

v1.0.0 2021-08-13 00:00 UTC

This package is auto-updated.

Last update: 2024-03-01 00:20:35 UTC


README

Latest Stable Version MIT Licensed PHP Supported Versions

Pollen Solutions Cookie Component is HTTP Request cookie manager.

Installation

composer require pollen-solutions/cookie

Basic Usage

use Pollen\Cookie\CookieJar;

$cookieJar = new CookieJar();

$cookieJar->make('cookie.test.1', ['value' => 'test1']);
$cookieJar->make(
    'cookie.test.2',
    [
        'name'      => 'cookie_test_2',
        'salt'      => '_' . md5('cookie.test.2.salt'),
        'value'     => [
            'test2-value1',
            'test2-value2'
        ],
        'encrypted' => true,
        'prefix'    => 'testprefix_',
        'lifetime'  => 3600,
        //'path'      => 'site-base_path',
        //'domain'    => 'site-domaine.ltd',
        'secure'    => false,
        'httpOnly'  => false,
        'raw'       => true,
        'sameSite'  => 'strict',
    ]
);

// Get the cookie instances.
$cookie1 = $cookieJar->get('cookie.test.1');
$cookie2 = $cookieJar->get('cookie.test.2');

var_dump((string)$cookie1);
var_dump((string)$cookie2);
exit;

Send Cookie

PSR-7 environnement

use Laminas\Diactoros\Response;
use Laminas\HttpHandlerRunner\Emitter\SapiEmitter;

/** @var \Pollen\Cookie\CookieJarInterface $cookieJar */
$cookie = $cookieJar->make('cookie.test', ['value' => 'test']);

$response = new Response();
$response = $response->withAddedHeader('Set-Cookie', (string)$cookie);
(new SapiEmitter())->emit($response);
exit;

Pollen Solutions Http environnement

use Pollen\Http\Response as HttpResponse;

/** @var \Pollen\Cookie\CookieJarInterface $cookieJar */
$cookie = $cookieJar->make('cookie.test', ['value' => 'test']);

$httpResponse = new HttpResponse();
$httpResponse->headers->setCookie($cookie);
$httpResponse->send();

Get HTTP Request cookie value

use Pollen\Cookie\CookieInterface;
use Pollen\Http\Request as HttpRequest;

// In this example, we consider :
// - Global $cookieJar as an implemented instance of CookieJar.
// - An HTTP Response was already sent with cookie1 and cookie2. @see "Send Cookie" above.

/** @var \Pollen\Cookie\CookieJarInterface $cookieJar */
$cookie1 = $cookieJar->get('cookie1');
$cookie1 = $cookieJar->get('cookie2');

$httpValue1 = $cookie1->httpValue();
$httpValue2 = $cookie2->httpValue(HttpRequest::createFromGlobals());

var_dump($httpValue1, $httpValue2);

Check HTTP Request cookie value

use Pollen\Http\Request as HttpRequest;

// In this example, we consider :
// - Global $cookieJar as an implemented instance of CookieJar.
// - An HTTP Response was already sent with cookie.test with the value 'test'. @see "Send Cookie" above.

/** @var \Pollen\Cookie\CookieJarInterface $cookieJar */
$cookie = $cookieJar->make('cookie.test', ['value' => 'test']);

var_dump($cookie->checkRequestValue());

Queued Cookie and QueuedCookiesMiddleware (Pollen Routing example)

use Pollen\Cookie\CookieJar;
use Pollen\Cookie\Middleware\QueuedCookiesMiddleware;
use Pollen\Http\Request;
use Pollen\Http\Response;
use Pollen\Http\ResponseInterface;
use Pollen\Routing\Router;

// Create the Request object
$request = Request::createFromGlobals();

// CookieJar instantiation
$cookieJar = (new CookieJar())->setDefaults($request->getBasePath());

// CookieJar hydratation
$cookie = $cookieJar->make('cookie.test', ['value' => 'test2'])->queue();

// Router instantiation
$router = new Router();

// Setting QueuedCookiesMiddleware
$router->middleware(new QueuedCookiesMiddleware($cookieJar));

// Map a route
$router->map('GET', '/', function (): ResponseInterface {
    return new Response('<h1>Hello, World!</h1>');
});

// Catch HTTP Response
$response = $router->handleRequest($request);

// Send the response to the browser
$router->sendResponse($response);

// Trigger the terminate event
$router->terminateEvent($request, $response);