setCookie

The setCookie hook is triggered when sending a cookie to the browser. It passes a standard object with all cookie properties and expects the same as return value.

Using the setCookie hook has been deprecated and will no longer work in Contao 6.0. Implement a kernel.response listener instead.

Parameters

  1. object $cookie

    A stdClass instance that contains the properties of the cookie. See PHP’s setcookie documentation for detailed information.

    • $cookie->strName – the cookie name
    • $cookie->varValue – the cookie value
    • $cookie->intExpires – the expiration time (in seconds, from now)
    • $cookie->strPath – the relative path (if Contao is installed in a subfolder)
    • $cookie->strDomain – the current domain for the cookie
    • $cookie->blnSecure – if the cookie should only be stored for https access
    • $cookie->blnHttpOnly – if the httponly flag should be set

Return Values

Return $cookie or a custom object with all properties.

Example

// src/EventListener/SetCookieListener.php
namespace App\EventListener;

use Contao\CoreBundle\DependencyInjection\Attribute\AsHook;

#[AsHook('setCookie')]
class SetCookieListener
{
    public function __invoke($cookie)
    {
        // Make sure the cookie is also valid for the whole domain
        $cookie->strPath = '/';

        return $cookie;
    }
}

References