If you need to enable a session in an alternative bundle, require composer package spiral/session and add
bootloader Spiral\Bootloader\Http\SessionBootloader into your app.
A user session can be accessed using context specific object Spiral\Session\SessionInterface:
use Spiral\Session\SessionInterface;
// ...
public function index(SessionInterface $session): void
{
    $session->resume();
    dump($session->getID());
}
Note
You are not allowed to store session reference in singleton objects. See the workaround below.
By default, you are not allowed to work with session directly, but rather allocate the isolated and named section
which provides classing set, get, delete or any different functionality. Use getSection of session object for
these
purposes:
public function index(SessionInterface $session): void
{
    $cart = $session->getSection('cart');
    $cart->set('items', ['my-items']);
    dump($cart->getAll());
}
To simplify the usage of a session in singleton services and controllers, use Spiral\Session\SessionScope. This
component is also available via prototype property session. The component can be used within singleton services and
always point to an active session context:
use Spiral\Prototype\Traits\PrototypeTrait;
class HomeController
{
    use PrototypeTrait;
    public function index(): void
    {
        dump($this->session->getSection('cart')->getAll());
    }
}
The session will be automatically started on first data access and committed when the request
leaves SessionMiddleware. To control the session manually, use methods of Spiral\Session\SessionInterface object.
Note
SessionScope fully implements SessionInterface.
To manually resume/create a session:
$this->session->resume();
To manually commit and close a session:
$this->session->commit();
To discard all the changes and close a session:
$this->session->abort();
To get a session ID (only when the session is resumed):
dump($this->session->getID());
To check if the session has started:
dump($this->session->isStarted());
To destroy a session and all the content:
$this->session->destroy();
To issue a new session ID without affecting the session content:
$this->session->regenerateID();
To alter session configuration, create file app/config/session.php to change needed values.
The session component is based on native PHP session implementation. By default, the session content is stored in the
file system in the runtime/session directory. If your application will be load balanced across multiple web servers,
you should choose a centralized store that all servers can access, such as Redis.
The session handler configuration option defines where session data will be stored for each request.
Spiral ships with several drivers out of the box:
Sessions are stored in runtime/session folder.
use Spiral\Core\Container\Autowire;
use Spiral\Session\Handler\FileHandler;
return [
    'lifetime' => 86400,
    'cookie' => 'sid',
    'secure' => false,
    'handler' => new Autowire(
        FileHandler::class,
        [
            'directory' => directory('runtime') . 'session',
            'lifetime'  => 86400
        ]
    )
];
Sessions are stored in one of cache based storages configured in Cache component.
use Spiral\Core\Container\Autowire;
use Spiral\Session\Handler\CacheHandler;
$ttl = 86400;
return [
    'lifetime' => $ttl,
    'cookie' => 'sid',
    'secure' => false,
    'handler' => new Autowire(
        CacheHandler::class,
        [
            'storage' => 'my-storage', // (Optional)  Cache storage name. Default - current cache storage
            'ttl' => $ttl,
            'prefix' => 'foo:' // (Optional) By default, session:
        ]
    )
];
If none of the existing session drivers fit your application's needs, Spiral makes it possible to write your own session
handler. Your custom session driver should implement PHP's
built-in SessionHandlerInterface.
return [
    'handler' => new Autowire(
        MemoryHandler::class,
        [
            'driver' => 'redis',
            'database' => 1,
            'lifetime' => 86400
        ]
    )
];
Note
You can use Autowire instead of the class name to configure additional parameters.
The session is initialized using a special factory Spiral\Session\SessionFactoryInterface.
namespace Spiral\Session;
interface SessionFactoryInterface
{
    /**
     * @param string $clientSignature User specific token, does not provide full security but
     *                                     hardens session transfer.
     * @param string|null $id When null - expect php to create session automatically.
     */
    public function initSession(string $clientSignature, string $id = null): SessionInterface;
}
You can replace the default implementation of Spiral\Session\SessionFactoryInterface in the container with your own.
$container->bindSingleton(\Spiral\Session\SessionFactoryInterface::class, CustomSessionFactory::class);