%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /www/varak.net/nextcloud.varak.net/apps_old/apps/calendar/lib/Notification/
Upload File :
Create Path :
Current File : //www/varak.net/nextcloud.varak.net/apps_old/apps/calendar/lib/Notification/Notifier.php

<?php

declare(strict_types=1);
/**
 * Calendar App
 *
 * @copyright 2023 Anna Larch <anna.larch@gmx.net>
 *
 * @author Anna Larch <anna.larch@gmx.net>
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or any later version.
 *
 * This library 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 library.  If not, see <http://www.gnu.org/licenses/>.
 *
 */

namespace OCA\Calendar\Notification;

use OCA\Calendar\AppInfo\Application;
use OCP\IURLGenerator;
use OCP\L10N\IFactory;
use OCP\Notification\INotification;
use OCP\Notification\INotifier;

class Notifier implements INotifier {
	private IFactory $factory;
	private IURLGenerator $url;

	public function __construct(IFactory $factory,
		IURLGenerator $url) {
		$this->factory = $factory;
		$this->url = $url;
	}

	public function getID(): string {
		return Application::APP_ID;
	}

	/**
	 * Human-readable name describing the notifier
	 * @return string
	 */
	public function getName(): string {
		return $this->factory->get(Application::APP_ID)->t('Calendar');
	}


	public function prepare(INotification $notification, string $languageCode): INotification {
		if ($notification->getApp() !== Application::APP_ID) {
			// Not my app => throw
			throw new \InvalidArgumentException();
		}

		// Read the language from the notification
		$l = $this->factory->get(Application::APP_ID, $languageCode);

		switch ($notification->getSubject()) {
			// Deal with known subjects
			case 'booking_accepted':
				$parameters = $notification->getSubjectParameters();
				$notification->setRichSubject($l->t('New booking {booking}'), [
					'booking' => [
						'id' => $parameters['id'],
						'type' => $parameters['type'],
						'name' => $parameters['name'],
						'link' => $this->url->linkToRouteAbsolute('calendar.view.index')
					]
				]);

				$messageParameters = $notification->getMessageParameters();
				$notification->setRichMessage($l->t('{display_name} ({email}) booked the appointment "{config_display_name}" on {date_time}.'), [
					'display_name' => [
						'type' => 'highlight',
						'id' => $messageParameters['id'],
						'name' => $messageParameters['display_name'],
					],
					'email' => [
						'type' => 'highlight',
						'id' => $messageParameters['id'],
						'name' => $messageParameters['email'],
					],
					'date_time' => [
						'type' => 'highlight',
						'id' => $messageParameters['id'],
						'name' => $messageParameters['date_time'],
					],
					'config_display_name' => [
						'type' => 'highlight',
						'id' => $messageParameters['id'],
						'name' => $messageParameters['config_display_name'],
					]
				]);
				break;
			default:
				throw  new \InvalidArgumentException();
		}

		return $notification;
	}
}

Zerion Mini Shell 1.0