Issue #2273385 by damiankloip: Use a container parameter for the user tempstore expire time.

8.0.x
Alex Pott 2014-07-10 10:56:06 +01:00
parent 4f8cf7086f
commit f0d8d3f8ac
4 changed files with 22 additions and 9 deletions

View File

@ -65,11 +65,8 @@ class TempStore {
* By default, data is stored for one week (604800 seconds) before expiring.
*
* @var int
*
* @todo Currently, this property is not exposed anywhere, and so the only
* way to override it is by extending the class.
*/
protected $expire = 604800;
protected $expire;
/**
* Constructs a new object for accessing data from a key/value store.
@ -82,11 +79,14 @@ class TempStore {
* The lock object used for this data.
* @param mixed $owner
* The owner key to store along with the data (e.g. a user or session ID).
* @param int $expire
* The time to live for items, in seconds.
*/
public function __construct(KeyValueStoreExpirableInterface $storage, LockBackendInterface $lockBackend, $owner) {
public function __construct(KeyValueStoreExpirableInterface $storage, LockBackendInterface $lockBackend, $owner, $expire = 604800) {
$this->storage = $storage;
$this->lockBackend = $lockBackend;
$this->owner = $owner;
$this->expire = $expire;
}
/**

View File

@ -38,6 +38,13 @@ class TempStoreFactory {
*/
protected $lockBackend;
/**
* The time to live for items in seconds.
*
* @var int
*/
protected $expire;
/**
* Constructs a Drupal\user\TempStoreFactory object.
*
@ -47,11 +54,14 @@ class TempStoreFactory {
* The connection object used for this data.
* @param \Drupal\Core\Lock\LockBackendInterface $lockBackend
* The lock object used for this data.
* @param int $expire
* The time to live for items, in seconds.
*/
function __construct(SerializationInterface $serializer, Connection $connection, LockBackendInterface $lockBackend) {
function __construct(SerializationInterface $serializer, Connection $connection, LockBackendInterface $lockBackend, $expire = 604800) {
$this->serializer = $serializer;
$this->connection = $connection;
$this->lockBackend = $lockBackend;
$this->expire = $expire;
}
/**
@ -77,7 +87,7 @@ class TempStoreFactory {
// Store the data for this collection in the database.
$storage = new DatabaseStorageExpirable($collection, $this->serializer, $this->connection);
return new TempStore($storage, $this->lockBackend, $owner);
return new TempStore($storage, $this->lockBackend, $owner, $this->expire);
}
}

View File

@ -82,7 +82,7 @@ class TempStoreTest extends UnitTestCase {
$this->keyValue = $this->getMock('Drupal\Core\KeyValueStore\KeyValueStoreExpirableInterface');
$this->lock = $this->getMock('Drupal\Core\Lock\LockBackendInterface');
$this->tempStore = new TempStore($this->keyValue, $this->lock, $this->owner);
$this->tempStore = new TempStore($this->keyValue, $this->lock, $this->owner, 604800);
$this->ownObject = (object) array(
'data' => 'test_data',

View File

@ -54,4 +54,7 @@ services:
arguments: ['@entity.manager', '@password']
user.tempstore:
class: Drupal\user\TempStoreFactory
arguments: ['@serialization.phpserialize', '@database', '@lock']
arguments: ['@serialization.phpserialize', '@database', '@lock', '%user.tempstore.expire%']
parameters:
user.tempstore.expire: 604800