123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- <?php
- declare(strict_types=1);
- /**
- * @copyright Copyright (c) 2019, Thomas Citharel
- * @copyright Copyright (c) 2019, Georg Ehrke
- *
- * @author Georg Ehrke <oc.list@georgehrke.com>
- * @author Thomas Citharel <nextcloud@tcit.fr>
- *
- * @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\DAV\CalDAV\Reminder;
- /**
- * Class NotificationProviderManager
- *
- * @package OCA\DAV\CalDAV\Reminder
- */
- class NotificationProviderManager {
- /** @var INotificationProvider[] */
- private $providers = [];
- /**
- * Checks whether a provider for a given ACTION exists
- *
- * @param string $type
- * @return bool
- */
- public function hasProvider(string $type):bool {
- return (\in_array($type, ReminderService::REMINDER_TYPES, true)
- && isset($this->providers[$type]));
- }
- /**
- * Get provider for a given ACTION
- *
- * @param string $type
- * @return INotificationProvider
- * @throws NotificationProvider\ProviderNotAvailableException
- * @throws NotificationTypeDoesNotExistException
- */
- public function getProvider(string $type):INotificationProvider {
- if (in_array($type, ReminderService::REMINDER_TYPES, true)) {
- if (isset($this->providers[$type])) {
- return $this->providers[$type];
- }
- throw new NotificationProvider\ProviderNotAvailableException($type);
- }
- throw new NotificationTypeDoesNotExistException($type);
- }
- /**
- * Registers a new provider
- *
- * @param string $providerClassName
- * @throws \OCP\AppFramework\QueryException
- */
- public function registerProvider(string $providerClassName):void {
- $provider = \OC::$server->query($providerClassName);
- if (!$provider instanceof INotificationProvider) {
- throw new \InvalidArgumentException('Invalid notification provider registered');
- }
- $this->providers[$provider::NOTIFICATION_TYPE] = $provider;
- }
- }
|