One Hat Cyber Team
Your IP :
216.73.216.182
Server IP :
203.175.9.166
Server :
Linux tanggamus.iixcp.rumahweb.net 5.14.0-427.28.1.el9_4.x86_64 #1 SMP PREEMPT_DYNAMIC Fri Aug 2 03:44:10 EDT 2024 x86_64
Server Software :
LiteSpeed
PHP Version :
7.4.33
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
home
/
cite5577
/
www
/
classes
/
services
/
queryBuilders
/
View File Name :
GalleyQueryBuilder.inc.php
<?php /** * @file classes/services/QueryBuilders/GalleyQueryBuilder.php * * Copyright (c) 2014-2021 Simon Fraser University * Copyright (c) 2000-2021 John Willinsky * Distributed under the GNU GPL v3. For full terms see the file docs/COPYING. * * @class GalleyQueryBuilder * @ingroup query_builders * * @brief Class for building database queries for galleys */ namespace APP\Services\QueryBuilders; use Illuminate\Database\Capsule\Manager as Capsule; use PKP\Services\QueryBuilders\Interfaces\EntityQueryBuilderInterface; class GalleyQueryBuilder implements EntityQueryBuilderInterface { /** @var array List of columns (see getQuery) */ public $columns; /** @var array get authors for one or more publications */ protected $publicationIds = []; /** * Set publicationIds filter * * @param array|int $publicationIds * @return \APP\Services\QueryBuilders\GalleyQueryBuilder */ public function filterByPublicationIds($publicationIds) { $this->publicationIds = is_array($publicationIds) ? $publicationIds : [$publicationIds]; return $this; } /** * @copydoc PKP\Services\QueryBuilders\Interfaces\EntityQueryBuilderInterface::getCount() */ public function getCount() { return $this ->getQuery() ->select('g.galley_id') ->get() ->count(); } /** * @copydoc PKP\Services\QueryBuilders\Interfaces\EntityQueryBuilderInterface::getCount() */ public function getIds() { return $this ->getQuery() ->select('g.galley_id') ->pluck('g.galley_id') ->toArray(); } /** * @copydoc PKP\Services\QueryBuilders\Interfaces\EntityQueryBuilderInterface::getCount() */ public function getQuery() { $this->columns = ['*']; $q = Capsule::table('publication_galleys as g'); if (!empty($this->publicationIds)) { $q->whereIn('g.publication_id', $this->publicationIds); } $q->orderBy('g.seq', 'asc'); // Add app-specific query statements \HookRegistry::call('Galley::getMany::queryObject', array(&$q, $this)); $q->select($this->columns); return $q; } }