From 01ce9e2bc96832586386f964b8612296be1c215b Mon Sep 17 00:00:00 2001 From: Padmasree Gade Date: Tue, 1 Oct 2024 10:01:23 -0400 Subject: [PATCH 1/4] initial commit --- .../src/VuFind/Db/Row/ExternalSession.php | 142 ------------------ .../src/VuFind/Db/Row/PluginManager.php | 4 +- .../Db/Service/ExternalSessionService.php | 38 +++-- .../src/VuFind/Db/Table/ExternalSession.php | 132 ---------------- .../src/VuFind/Db/Table/PluginManager.php | 4 +- 5 files changed, 33 insertions(+), 287 deletions(-) delete mode 100644 module/VuFind/src/VuFind/Db/Row/ExternalSession.php delete mode 100644 module/VuFind/src/VuFind/Db/Table/ExternalSession.php diff --git a/module/VuFind/src/VuFind/Db/Row/ExternalSession.php b/module/VuFind/src/VuFind/Db/Row/ExternalSession.php deleted file mode 100644 index ad46955a5fa..00000000000 --- a/module/VuFind/src/VuFind/Db/Row/ExternalSession.php +++ /dev/null @@ -1,142 +0,0 @@ - - * @author Ere Maijala - * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License - * @link https://vufind.org Main Site - */ - -namespace VuFind\Db\Row; - -use DateTime; -use VuFind\Db\Entity\ExternalSessionEntityInterface; - -/** - * Row Definition for external_session - * - * @category VuFind - * @package Db_Row - * @author Demian Katz - * @author Ere Maijala - * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License - * @link https://vufind.org Main Site - * - * @property int $id - * @property string $session_id - * @property string $external_session_id - * @property string $created - */ -class ExternalSession extends RowGateway implements ExternalSessionEntityInterface -{ - /** - * Constructor - * - * @param \Laminas\Db\Adapter\Adapter $adapter Database adapter - */ - public function __construct($adapter) - { - parent::__construct('id', 'external_session', $adapter); - } - - /** - * Get identifier (returns null for an uninitialized or non-persisted object). - * - * @return ?int - */ - public function getId(): ?int - { - return $this->id ?? null; - } - - /** - * Get PHP session id string. - * - * @return string - */ - public function getSessionId(): string - { - return $this->session_id ?? ''; - } - - /** - * Set PHP session id string. - * - * @param string $sessionId PHP session id string - * - * @return static - */ - public function setSessionId(string $sessionId): static - { - $this->session_id = $sessionId; - return $this; - } - - /** - * Get PHP external session id string. - * - * @return string - */ - public function getExternalSessionId(): string - { - return $this->external_session_id ?? ''; - } - - /** - * Set external session id string. - * - * @param string $externalSessionId External session id string - * - * @return static - */ - public function setExternalSessionId(string $externalSessionId): static - { - $this->external_session_id = $externalSessionId; - return $this; - } - - /** - * Get created date. - * - * @return DateTime - */ - public function getCreated(): DateTime - { - return DateTime::createFromFormat('Y-m-d H:i:s', $this->created); - } - - /** - * Set created date. - * - * @param DateTime $dateTime Created date - * - * @return static - */ - public function setCreated(DateTime $dateTime): static - { - $this->created = $dateTime->format('Y-m-d H:i:s'); - return $this; - } -} diff --git a/module/VuFind/src/VuFind/Db/Row/PluginManager.php b/module/VuFind/src/VuFind/Db/Row/PluginManager.php index d2ca7cb318c..f4c63805032 100644 --- a/module/VuFind/src/VuFind/Db/Row/PluginManager.php +++ b/module/VuFind/src/VuFind/Db/Row/PluginManager.php @@ -46,7 +46,7 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $aliases = [ - 'externalsession' => ExternalSession::class, + //'externalsession' => ExternalSession::class, 'logintoken' => LoginToken::class, 'ratings' => Ratings::class, 'search' => Search::class, @@ -61,7 +61,7 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $factories = [ - ExternalSession::class => RowGatewayFactory::class, + //ExternalSession::class => RowGatewayFactory::class, LoginToken::class => RowGatewayFactory::class, Ratings::class => RowGatewayFactory::class, Search::class => RowGatewayFactory::class, diff --git a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php index 88f29186900..300bdaa46b0 100644 --- a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php +++ b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php @@ -30,9 +30,8 @@ namespace VuFind\Db\Service; use DateTime; +use VuFind\Db\Entity\ExternalSession; use VuFind\Db\Entity\ExternalSessionEntityInterface; -use VuFind\Db\Table\DbTableAwareInterface; -use VuFind\Db\Table\DbTableAwareTrait; /** * Database service for external_session table. @@ -45,10 +44,8 @@ */ class ExternalSessionService extends AbstractDbService implements ExternalSessionServiceInterface, - Feature\DeleteExpiredInterface, - DbTableAwareInterface + Feature\DeleteExpiredInterface { - use DbTableAwareTrait; /** * Create a new external session entity. @@ -57,7 +54,8 @@ class ExternalSessionService extends AbstractDbService implements */ public function createEntity(): ExternalSessionEntityInterface { - return $this->getDbTable('ExternalSession')->createRow(); + $class = $this->getEntityClass(ExternalSession::class); + return new $class(); } /** @@ -90,7 +88,13 @@ public function addSessionMapping( */ public function getAllByExternalSessionId(string $sid): array { - return iterator_to_array($this->getDbTable('ExternalSession')->select(['external_session_id' => $sid])); + $dql = 'SELECT es ' + . 'FROM ' . $this->getEntityClass(ExternalSession::class) . ' es ' + . 'WHERE es.externalSessionId = :esid '; + $query = $this->entityManager->createQuery($dql); + $query->setParameter('esid', $sid); + $result = $query->getArrayResult(); + return $result[0] ?? null; } /** @@ -102,7 +106,11 @@ public function getAllByExternalSessionId(string $sid): array */ public function destroySession(string $sid): void { - $this->getDbTable('ExternalSession')->delete(['session_id' => $sid]); + $dql = 'DELETE FROM ' . $this->getEntityClass(ExternalSession::class) . ' es ' + . 'WHERE es.externalSessionId = :esid'; + $query = $this->entityManager->createQuery($dql); + $query->setParameter('esid', $sid); + $query->execute(); } /** @@ -115,6 +123,18 @@ public function destroySession(string $sid): void */ public function deleteExpired(DateTime $dateLimit, ?int $limit = null): int { - return $this->getDbTable('ExternalSession')->deleteExpired($dateLimit->format('Y-m-d H:i:s'), $limit); + $subQueryBuilder = $this->entityManager->createQueryBuilder(); + $subQueryBuilder->select('es.externalSessionId') + ->from($this->getEntityClass(ExternalSession::class), 'es') + ->where('es.created < :dateLimit') + ->setParameter('dateLimit', $dateLimit->format('Y-m-d H:i:s')); + if ($limit) { + $subQueryBuilder->setMaxResults($limit); + } + $queryBuilder = $this->entityManager->createQueryBuilder(); + $queryBuilder->delete($this->getEntityClass(ExternalSessionEntityInterface::class), 'es') + ->where('es.externalSessionId IN (:esids)') + ->setParameter('esids', $subQueryBuilder->getQuery()->getResult()); + return $queryBuilder->getQuery()->execute(); } } diff --git a/module/VuFind/src/VuFind/Db/Table/ExternalSession.php b/module/VuFind/src/VuFind/Db/Table/ExternalSession.php deleted file mode 100644 index 856da4ec020..00000000000 --- a/module/VuFind/src/VuFind/Db/Table/ExternalSession.php +++ /dev/null @@ -1,132 +0,0 @@ - - * @author Ere Maijala - * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License - * @link https://vufind.org Main Page - */ - -namespace VuFind\Db\Table; - -use Laminas\Db\Adapter\Adapter; -use VuFind\Db\Row\RowGateway; -use VuFind\Db\Service\DbServiceAwareInterface; -use VuFind\Db\Service\DbServiceAwareTrait; -use VuFind\Db\Service\ExternalSessionServiceInterface; - -/** - * Table Definition for external_session - * - * @category VuFind - * @package Db_Table - * @author Demian Katz - * @author Ere Maijala - * @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License - * @link https://vufind.org Main Site - */ -class ExternalSession extends Gateway implements DbServiceAwareInterface -{ - use DbServiceAwareTrait; - use ExpirationTrait; - - /** - * Constructor - * - * @param Adapter $adapter Database adapter - * @param PluginManager $tm Table manager - * @param array $cfg Laminas configuration - * @param RowGateway $rowObj Row prototype object (null for default) - * @param string $table Name of database table to interface with - */ - public function __construct( - Adapter $adapter, - PluginManager $tm, - $cfg, - ?RowGateway $rowObj = null, - $table = 'external_session' - ) { - parent::__construct($adapter, $tm, $cfg, $rowObj, $table); - } - - /** - * Add a mapping between local and external session id's - * - * @param string $localSessionId Local (VuFind) session id - * @param string $externalSessionId External session id - * - * @return void - * - * @deprecated Use ExternalSessionServiceInterface::addSessionMapping() - */ - public function addSessionMapping($localSessionId, $externalSessionId) - { - $this->getDbService(ExternalSessionServiceInterface::class) - ->addSessionMapping($localSessionId, $externalSessionId); - } - - /** - * Retrieve an object from the database based on an external session ID - * - * @param string $sid External session ID to retrieve - * - * @return ?\VuFind\Db\Row\ExternalSession - * - * @deprecated Use ExternalSessionServiceInterface::getAllByExternalSessionId() - */ - public function getByExternalSessionId($sid) - { - $sessions = $this->getDbService(ExternalSessionServiceInterface::class)->getAllByExternalSessionId($sid); - return $sessions[0] ?? null; - } - - /** - * Destroy data for the given session ID. - * - * @param string $sid Session ID to erase - * - * @return void - * - * @deprecated Use ExternalSessionServiceInterface::destroySession() - */ - public function destroySession($sid) - { - $this->getDbService(ExternalSessionServiceInterface::class)->destroySession($sid); - } - - /** - * Update the select statement to find records to delete. - * - * @param Select $select Select clause - * @param string $dateLimit Date threshold of an "expired" record in format - * 'Y-m-d H:i:s'. - * - * @return void - */ - protected function expirationCallback($select, $dateLimit) - { - $select->where->lessThan('created', $dateLimit); - } -} diff --git a/module/VuFind/src/VuFind/Db/Table/PluginManager.php b/module/VuFind/src/VuFind/Db/Table/PluginManager.php index df3a4399b0f..c7cf20e2dc2 100644 --- a/module/VuFind/src/VuFind/Db/Table/PluginManager.php +++ b/module/VuFind/src/VuFind/Db/Table/PluginManager.php @@ -46,7 +46,7 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $aliases = [ - 'externalsession' => ExternalSession::class, + //'externalsession' => ExternalSession::class, 'logintoken' => LoginToken::class, 'ratings' => Ratings::class, 'search' => Search::class, @@ -61,7 +61,7 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $factories = [ - ExternalSession::class => GatewayFactory::class, + //ExternalSession::class => GatewayFactory::class, LoginToken::class => GatewayFactory::class, Ratings::class => GatewayFactory::class, Search::class => GatewayFactory::class, From ec8bfa9b2e04662f267e7c9597984acc7d064212 Mon Sep 17 00:00:00 2001 From: Padmasree Gade Date: Mon, 7 Oct 2024 11:54:55 -0400 Subject: [PATCH 2/4] delete commented code --- module/VuFind/src/VuFind/Db/Row/PluginManager.php | 2 -- .../VuFind/src/VuFind/Db/Service/ExternalSessionService.php | 6 +++--- module/VuFind/src/VuFind/Db/Table/PluginManager.php | 2 -- 3 files changed, 3 insertions(+), 7 deletions(-) diff --git a/module/VuFind/src/VuFind/Db/Row/PluginManager.php b/module/VuFind/src/VuFind/Db/Row/PluginManager.php index f4c63805032..1c097f91622 100644 --- a/module/VuFind/src/VuFind/Db/Row/PluginManager.php +++ b/module/VuFind/src/VuFind/Db/Row/PluginManager.php @@ -46,7 +46,6 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $aliases = [ - //'externalsession' => ExternalSession::class, 'logintoken' => LoginToken::class, 'ratings' => Ratings::class, 'search' => Search::class, @@ -61,7 +60,6 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $factories = [ - //ExternalSession::class => RowGatewayFactory::class, LoginToken::class => RowGatewayFactory::class, Ratings::class => RowGatewayFactory::class, Search::class => RowGatewayFactory::class, diff --git a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php index 300bdaa46b0..f69ebf7404a 100644 --- a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php +++ b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php @@ -106,10 +106,10 @@ public function getAllByExternalSessionId(string $sid): array */ public function destroySession(string $sid): void { - $dql = 'DELETE FROM ' . $this->getEntityClass(ExternalSession::class) . ' es ' - . 'WHERE es.externalSessionId = :esid'; + $dql = 'DELETE FROM ' . $this->getEntityClass(ExternalSession::class) . ' es' + . ' WHERE es.sessionId = :sid'; $query = $this->entityManager->createQuery($dql); - $query->setParameter('esid', $sid); + $query->setParameter('sid', $sid); $query->execute(); } diff --git a/module/VuFind/src/VuFind/Db/Table/PluginManager.php b/module/VuFind/src/VuFind/Db/Table/PluginManager.php index c7cf20e2dc2..5cec766ef9b 100644 --- a/module/VuFind/src/VuFind/Db/Table/PluginManager.php +++ b/module/VuFind/src/VuFind/Db/Table/PluginManager.php @@ -46,7 +46,6 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $aliases = [ - //'externalsession' => ExternalSession::class, 'logintoken' => LoginToken::class, 'ratings' => Ratings::class, 'search' => Search::class, @@ -61,7 +60,6 @@ class PluginManager extends \VuFind\ServiceManager\AbstractPluginManager * @var array */ protected $factories = [ - //ExternalSession::class => GatewayFactory::class, LoginToken::class => GatewayFactory::class, Ratings::class => GatewayFactory::class, Search::class => GatewayFactory::class, From 8b6d91319888d5462870e467d338c62f3000b91b Mon Sep 17 00:00:00 2001 From: Padmasree Gade Date: Mon, 9 Dec 2024 14:41:36 -0500 Subject: [PATCH 3/4] changed to eliminate the getArrayResults() problem. --- .../VuFind/src/VuFind/Db/Service/ExternalSessionService.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php index f69ebf7404a..5f61d9c9113 100644 --- a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php +++ b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php @@ -93,8 +93,8 @@ public function getAllByExternalSessionId(string $sid): array . 'WHERE es.externalSessionId = :esid '; $query = $this->entityManager->createQuery($dql); $query->setParameter('esid', $sid); - $result = $query->getArrayResult(); - return $result[0] ?? null; + $result = $query->getResult(); + return $result; } /** From 00d0581d25c7f04ac9f5ab0a2cc4c3225f63b164 Mon Sep 17 00:00:00 2001 From: Padmasree Gade Date: Mon, 9 Dec 2024 15:32:42 -0500 Subject: [PATCH 4/4] Delete basedd on unique "id" rather than external_session_id --- .../src/VuFind/Db/Service/ExternalSessionService.php | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php index 5f61d9c9113..ccd3f958851 100644 --- a/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php +++ b/module/VuFind/src/VuFind/Db/Service/ExternalSessionService.php @@ -46,7 +46,6 @@ class ExternalSessionService extends AbstractDbService implements ExternalSessionServiceInterface, Feature\DeleteExpiredInterface { - /** * Create a new external session entity. * @@ -124,17 +123,17 @@ public function destroySession(string $sid): void public function deleteExpired(DateTime $dateLimit, ?int $limit = null): int { $subQueryBuilder = $this->entityManager->createQueryBuilder(); - $subQueryBuilder->select('es.externalSessionId') + $subQueryBuilder->select('es.id') ->from($this->getEntityClass(ExternalSession::class), 'es') ->where('es.created < :dateLimit') - ->setParameter('dateLimit', $dateLimit->format('Y-m-d H:i:s')); + ->setParameter('dateLimit', $dateLimit); if ($limit) { $subQueryBuilder->setMaxResults($limit); } $queryBuilder = $this->entityManager->createQueryBuilder(); $queryBuilder->delete($this->getEntityClass(ExternalSessionEntityInterface::class), 'es') - ->where('es.externalSessionId IN (:esids)') - ->setParameter('esids', $subQueryBuilder->getQuery()->getResult()); + ->where('es.id IN (:ids)') + ->setParameter('ids', $subQueryBuilder->getQuery()->getResult()); return $queryBuilder->getQuery()->execute(); } }