<?php namespace SGalinski\SgMail\Domain\Repository; /*************************************************************** * Copyright notice * * (c) sgalinski Internet Services (https://www.sgalinski.de) * * All rights reserved * * This script is part of the TYPO3 project. The TYPO3 project is * free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * The GNU General Public License can be found at * http://www.gnu.org/copyleft/gpl.html. * * This script 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 General Public License for more details. * * This copyright notice MUST APPEAR in all copies of the script! ***************************************************************/ use TYPO3\CMS\Extbase\Persistence\Generic\Query; use TYPO3\CMS\Extbase\Persistence\QueryResultInterface; /** * Repository for the Mail object */ class MailRepository extends AbstractRepository { /** * Returns all mails that are still not sent ordered by priority. * * @param int $limit * @return array|QueryResultInterface */ public function findMailsToSend($limit = NULL) { $query = $this->createQuery(); if ($limit) { $query->setLimit($limit); } $query->setOrderings(['priority' => Query::ORDER_DESCENDING]); return $query->matching($query->equals('sent', FALSE))->execute(); } /** * Find all mails (sent & unsent) for extension key and template name * * @param string $extensionKey * @param string $templateName * @param int $siteroot * @param int $limit * @return array|QueryResultInterface */ public function findAllEntries($extensionKey, $templateName, $siteroot = 0, $limit = NULL) { $query = $this->createQuery(); if ($limit) { $query->setLimit($limit); } $constraintsAnd[] = $query->equals('extension_key', $extensionKey); $constraintsAnd[] = $query->equals('template_name', $templateName); $constraintsAnd[] = $query->equals('site_root_id', (int) $siteroot); $query->setOrderings(['tstamp' => Query::ORDER_DESCENDING]); return $query->matching($query->logicalAnd($constraintsAnd))->execute(TRUE); } }