* * @author 2020 Christoph Wurst * * @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 . */ namespace OCA\Mail\Db; use OCP\AppFramework\Db\QBMapper; use OCP\IDBConnection; class TrustedSenderMapper extends QBMapper { public function __construct(IDBConnection $db) { parent::__construct($db, 'mail_trusted_senders'); } public function exists(string $uid, string $email): bool { $emailObject = new \Horde_Mail_Rfc822_Address($email); $host = $emailObject->host; $qb = $this->db->getQueryBuilder(); $select = $qb->select('*') ->from($this->getTableName()) ->where( $qb->expr()->orX( $qb->expr()->andX( $qb->expr()->eq('email', $qb->createNamedParameter($email)), $qb->expr()->eq('type', $qb->createNamedParameter('individual')) ), $qb->expr()->andX( $qb->expr()->eq('email', $qb->createNamedParameter($host)), $qb->expr()->eq('type', $qb->createNamedParameter('domain')) ) ), $qb->expr()->eq('user_id', $qb->createNamedParameter($uid)) ); /** @var TrustedSender[] $rows */ $rows = $this->findEntities($select); return !empty($rows); } public function create(string $uid, string $email, string $type): void { $qb = $this->db->getQueryBuilder(); $insert = $qb->insert($this->getTableName()) ->values([ 'user_id' => $qb->createNamedParameter($uid), 'email' => $qb->createNamedParameter($email), 'type' => $qb->createNamedParameter($type), ]); $insert->execute(); } public function remove(string $uid, string $email, string $type): void { $qb = $this->db->getQueryBuilder(); $delete = $qb->delete($this->getTableName()) ->where( $qb->expr()->eq('user_id', $qb->createNamedParameter($uid)), $qb->expr()->eq('email', $qb->createNamedParameter($email)), $qb->expr()->eq('type', $qb->createNamedParameter($type)) ); $delete->execute(); } /** * @param string $uid * @return TrustedSender[] */ public function findAll(string $uid): array { $qb = $this->db->getQueryBuilder(); $select = $qb->select('*') ->from($this->getTableName()) ->where($qb->expr()->eq('user_id', $qb->createNamedParameter($uid))); return $this->findEntities($select); } }