Files
swiftadmin/vendor/symfony/http-foundation/Session/Storage/Handler/MemcachedSessionHandler.php

109 lines
2.8 KiB
PHP
Raw Normal View History

2022-08-19 19:48:37 +08:00
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\HttpFoundation\Session\Storage\Handler;
/**
* Memcached based session storage handler based on the Memcached class
* provided by the PHP memcached extension.
*
* @see https://php.net/memcached
*
* @author Drak <drak@zikula.org>
*/
class MemcachedSessionHandler extends AbstractSessionHandler
{
private $memcached;
/**
2022-11-28 19:11:12 +08:00
* Time to live in seconds.
2022-08-19 19:48:37 +08:00
*/
2022-11-28 19:11:12 +08:00
private ?int $ttl;
2022-08-19 19:48:37 +08:00
/**
2022-11-28 19:11:12 +08:00
* Key prefix for shared environments.
2022-08-19 19:48:37 +08:00
*/
2022-11-28 19:11:12 +08:00
private string $prefix;
2022-08-19 19:48:37 +08:00
/**
* Constructor.
*
* List of available options:
* * prefix: The prefix to use for the memcached keys in order to avoid collision
* * ttl: The time to live in seconds.
*
* @throws \InvalidArgumentException When unsupported options are passed
*/
public function __construct(\Memcached $memcached, array $options = [])
{
$this->memcached = $memcached;
if ($diff = array_diff(array_keys($options), ['prefix', 'expiretime', 'ttl'])) {
throw new \InvalidArgumentException(sprintf('The following options are not supported "%s".', implode(', ', $diff)));
}
$this->ttl = $options['expiretime'] ?? $options['ttl'] ?? null;
$this->prefix = $options['prefix'] ?? 'sf2s';
}
2022-11-28 19:11:12 +08:00
public function close(): bool
2022-08-19 19:48:37 +08:00
{
return $this->memcached->quit();
}
/**
* {@inheritdoc}
*/
2022-11-28 19:11:12 +08:00
protected function doRead(string $sessionId): string
2022-08-19 19:48:37 +08:00
{
return $this->memcached->get($this->prefix.$sessionId) ?: '';
}
2022-11-28 19:11:12 +08:00
public function updateTimestamp(string $sessionId, string $data): bool
2022-08-19 19:48:37 +08:00
{
$this->memcached->touch($this->prefix.$sessionId, time() + (int) ($this->ttl ?? \ini_get('session.gc_maxlifetime')));
return true;
}
/**
* {@inheritdoc}
*/
2022-11-28 19:11:12 +08:00
protected function doWrite(string $sessionId, string $data): bool
2022-08-19 19:48:37 +08:00
{
return $this->memcached->set($this->prefix.$sessionId, $data, time() + (int) ($this->ttl ?? \ini_get('session.gc_maxlifetime')));
}
/**
* {@inheritdoc}
*/
2022-11-28 19:11:12 +08:00
protected function doDestroy(string $sessionId): bool
2022-08-19 19:48:37 +08:00
{
$result = $this->memcached->delete($this->prefix.$sessionId);
return $result || \Memcached::RES_NOTFOUND == $this->memcached->getResultCode();
}
2022-11-28 19:11:12 +08:00
public function gc(int $maxlifetime): int|false
2022-08-19 19:48:37 +08:00
{
// not required here because memcached will auto expire the records anyhow.
return 0;
}
/**
* Return a Memcached instance.
*/
2022-11-28 19:11:12 +08:00
protected function getMemcached(): \Memcached
2022-08-19 19:48:37 +08:00
{
return $this->memcached;
}
}