2018-11-27 16:59:19 +00:00
|
|
|
<?php
|
2022-04-15 11:34:01 +00:00
|
|
|
|
2018-11-27 16:59:19 +00:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Nextcloud - Social Support
|
|
|
|
*
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later. See the COPYING file.
|
|
|
|
*
|
|
|
|
* @author Maxence Lange <maxence@artificial-owl.com>
|
|
|
|
* @copyright 2018, Maxence Lange <maxence@artificial-owl.com>
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Social\Db;
|
|
|
|
|
2022-06-17 14:29:54 +00:00
|
|
|
use OCA\Social\Tools\Traits\TArrayTools;
|
2018-11-27 16:59:19 +00:00
|
|
|
use OCA\Social\Model\RequestQueue;
|
|
|
|
|
|
|
|
class RequestQueueRequestBuilder extends CoreRequestBuilder {
|
|
|
|
use TArrayTools;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Insert request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2018-11-27 16:59:19 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getRequestQueueInsertSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2018-11-27 16:59:19 +00:00
|
|
|
$qb->insert(self::TABLE_REQUEST_QUEUE);
|
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Update request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2018-11-27 16:59:19 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getRequestQueueUpdateSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2018-11-27 16:59:19 +00:00
|
|
|
$qb->update(self::TABLE_REQUEST_QUEUE);
|
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Select request for Shares
|
|
|
|
*
|
2022-11-23 11:07:58 +00:00
|
|
|
* @return SocialQueryBuilder
|
2018-11-27 16:59:19 +00:00
|
|
|
*/
|
2022-11-23 11:07:58 +00:00
|
|
|
protected function getRequestQueueSelectSql(): SocialQueryBuilder {
|
2020-06-25 02:48:36 +00:00
|
|
|
$qb = $this->getQueryBuilder();
|
2018-11-27 16:59:19 +00:00
|
|
|
|
|
|
|
/** @noinspection PhpMethodParametersCountMismatchInspection */
|
|
|
|
$qb->select(
|
|
|
|
'rq.id', 'rq.token', 'rq.author', 'rq.activity', 'rq.instance', 'rq.priority',
|
|
|
|
'rq.status', 'rq.tries', 'rq.last'
|
|
|
|
)
|
|
|
|
->from(self::TABLE_REQUEST_QUEUE, 'rq');
|
|
|
|
|
|
|
|
$this->defaultSelectAlias = 'rq';
|
2020-06-25 02:48:36 +00:00
|
|
|
$qb->setDefaultSelectAlias('rq');
|
2018-11-27 16:59:19 +00:00
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Delete request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2018-11-27 16:59:19 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getRequestQueueDeleteSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2018-11-27 16:59:19 +00:00
|
|
|
$qb->delete(self::TABLE_REQUEST_QUEUE);
|
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $data
|
|
|
|
*
|
|
|
|
* @return RequestQueue
|
|
|
|
*/
|
2020-06-18 19:40:57 +00:00
|
|
|
public function parseRequestQueueSelectSql($data): RequestQueue {
|
2018-11-27 16:59:19 +00:00
|
|
|
$queue = new RequestQueue();
|
|
|
|
$queue->importFromDatabase($data);
|
|
|
|
|
|
|
|
return $queue;
|
|
|
|
}
|
|
|
|
}
|