2019-01-24 11:26:44 +00:00
|
|
|
<?php
|
2022-04-15 11:34:01 +00:00
|
|
|
|
2019-01-24 11:26:44 +00:00
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
/**
|
2024-09-08 13:46:22 +00:00
|
|
|
* SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
2019-01-24 11:26:44 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Social\Db;
|
|
|
|
|
|
|
|
use OCA\Social\Model\StreamQueue;
|
2023-05-25 20:45:28 +00:00
|
|
|
use OCA\Social\Tools\Traits\TArrayTools;
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
class StreamQueueRequestBuilder extends CoreRequestBuilder {
|
|
|
|
use TArrayTools;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Insert request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2019-01-24 11:26:44 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getStreamQueueInsertSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2019-05-07 15:11:04 +00:00
|
|
|
$qb->insert(self::TABLE_STREAM_QUEUE);
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Update request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2019-01-24 11:26:44 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getStreamQueueUpdateSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2019-05-07 15:11:04 +00:00
|
|
|
$qb->update(self::TABLE_STREAM_QUEUE);
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Select request for Shares
|
|
|
|
*
|
2020-06-25 02:48:36 +00:00
|
|
|
* @return SocialQueryBuilder
|
2019-01-24 11:26:44 +00:00
|
|
|
*/
|
2020-06-25 02:48:36 +00:00
|
|
|
protected function getStreamQueueSelectSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
/** @noinspection PhpMethodParametersCountMismatchInspection */
|
|
|
|
$qb->select(
|
|
|
|
'qs.id', 'qs.token', 'qs.stream_id', 'qs.type', 'qs.status', 'qs.tries', 'qs.last'
|
|
|
|
)
|
2024-10-28 12:53:06 +00:00
|
|
|
->from(self::TABLE_STREAM_QUEUE, 'qs');
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
$this->defaultSelectAlias = 'qs';
|
2020-06-25 02:48:36 +00:00
|
|
|
$qb->setDefaultSelectAlias('qs');
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base of the Sql Delete request
|
|
|
|
*
|
2022-12-03 16:55:34 +00:00
|
|
|
* @return SocialQueryBuilder
|
2019-01-24 11:26:44 +00:00
|
|
|
*/
|
2022-11-22 23:16:36 +00:00
|
|
|
protected function getStreamQueueDeleteSql(): SocialQueryBuilder {
|
|
|
|
$qb = $this->getQueryBuilder();
|
2019-05-07 15:11:04 +00:00
|
|
|
$qb->delete(self::TABLE_STREAM_QUEUE);
|
2019-01-24 11:26:44 +00:00
|
|
|
|
|
|
|
return $qb;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $data
|
|
|
|
*
|
|
|
|
* @return StreamQueue
|
|
|
|
*/
|
2020-06-18 19:40:57 +00:00
|
|
|
public function parseStreamQueueSelectSql($data): StreamQueue {
|
2019-01-24 11:26:44 +00:00
|
|
|
$queue = new StreamQueue();
|
|
|
|
$queue->importFromDatabase($data);
|
|
|
|
|
|
|
|
return $queue;
|
|
|
|
}
|
|
|
|
}
|