aboutsummaryrefslogtreecommitdiffstats
path: root/apps/dav/lib/BackgroundJob/OutOfOfficeEventDispatcherJob.php
blob: 8293b37099635507e45e162f8cac52ab6fb983f1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php

declare(strict_types=1);

/**
 * SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */

namespace OCA\DAV\BackgroundJob;

use OCA\DAV\CalDAV\TimezoneService;
use OCA\DAV\Db\AbsenceMapper;
use OCP\AppFramework\Db\DoesNotExistException;
use OCP\AppFramework\Utility\ITimeFactory;
use OCP\BackgroundJob\QueuedJob;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\IUserManager;
use OCP\User\Events\OutOfOfficeEndedEvent;
use OCP\User\Events\OutOfOfficeStartedEvent;
use Psr\Log\LoggerInterface;

class OutOfOfficeEventDispatcherJob extends QueuedJob {
	public const EVENT_START = 'start';
	public const EVENT_END = 'end';

	public function __construct(
		ITimeFactory $time,
		private AbsenceMapper $absenceMapper,
		private LoggerInterface $logger,
		private IEventDispatcher $eventDispatcher,
		private IUserManager $userManager,
		private TimezoneService $timezoneService,
	) {
		parent::__construct($time);
	}

	public function run($argument): void {
		$id = $argument['id'];
		$event = $argument['event'];

		try {
			$absence = $this->absenceMapper->findById($id);
		} catch (DoesNotExistException | \OCP\DB\Exception $e) {
			$this->logger->error('Failed to dispatch out-of-office event: ' . $e->getMessage(), [
				'exception' => $e,
				'argument' => $argument,
			]);
			return;
		}

		$userId = $absence->getUserId();
		$user = $this->userManager->get($userId);
		if ($user === null) {
			$this->logger->error("Failed to dispatch out-of-office event: User $userId does not exist", [
				'argument' => $argument,
			]);
			return;
		}

		$data = $absence->toOutOufOfficeData(
			$user,
			$this->timezoneService->getUserTimezone($userId) ?? $this->timezoneService->getDefaultTimezone(),
		);
		if ($event === self::EVENT_START) {
			$this->eventDispatcher->dispatchTyped(new OutOfOfficeStartedEvent($data));
		} elseif ($event === self::EVENT_END) {
			$this->eventDispatcher->dispatchTyped(new OutOfOfficeEndedEvent($data));
		} else {
			$this->logger->error("Invalid out-of-office event: $event", [
				'argument' => $argument,
			]);
		}
	}
}