AbstractProvider.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @copyright Copyright (c) 2019, Thomas Citharel
  5. * @copyright Copyright (c) 2019, Georg Ehrke
  6. *
  7. * @author Thomas Citharel <tcit@tcit.fr>
  8. * @author Georg Ehrke <oc.list@georgehrke.com>
  9. *
  10. * @license GNU AGPL version 3 or any later version
  11. *
  12. * This program is free software: you can redistribute it and/or modify
  13. * it under the terms of the GNU Affero General Public License as
  14. * published by the Free Software Foundation, either version 3 of the
  15. * License, or (at your option) any later version.
  16. *
  17. * This program is distributed in the hope that it will be useful,
  18. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  20. * GNU Affero General Public License for more details.
  21. *
  22. * You should have received a copy of the GNU Affero General Public License
  23. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  24. *
  25. */
  26. namespace OCA\DAV\CalDAV\Reminder\NotificationProvider;
  27. use OCA\DAV\CalDAV\Reminder\INotificationProvider;
  28. use OCP\IConfig;
  29. use OCP\IL10N;
  30. use OCP\ILogger;
  31. use OCP\IURLGenerator;
  32. use OCP\L10N\IFactory as L10NFactory;
  33. use OCP\IUser;
  34. use Sabre\VObject\Component\VEvent;
  35. use Sabre\VObject\DateTimeParser;
  36. use Sabre\VObject\Property;
  37. /**
  38. * Class AbstractProvider
  39. *
  40. * @package OCA\DAV\CalDAV\Reminder\NotificationProvider
  41. */
  42. abstract class AbstractProvider implements INotificationProvider {
  43. /** @var string */
  44. public const NOTIFICATION_TYPE = '';
  45. /** @var ILogger */
  46. protected $logger;
  47. /** @var L10NFactory */
  48. private $l10nFactory;
  49. /** @var IL10N[] */
  50. private $l10ns;
  51. /** @var string */
  52. private $fallbackLanguage;
  53. /** @var IURLGenerator */
  54. protected $urlGenerator;
  55. /** @var IConfig */
  56. protected $config;
  57. /**
  58. * @param ILogger $logger
  59. * @param L10NFactory $l10nFactory
  60. * @param IConfig $config
  61. * @param IUrlGenerator $urlGenerator
  62. */
  63. public function __construct(ILogger $logger,
  64. L10NFactory $l10nFactory,
  65. IURLGenerator $urlGenerator,
  66. IConfig $config) {
  67. $this->logger = $logger;
  68. $this->l10nFactory = $l10nFactory;
  69. $this->urlGenerator = $urlGenerator;
  70. $this->config = $config;
  71. }
  72. /**
  73. * Send notification
  74. *
  75. * @param VEvent $vevent
  76. * @param string $calendarDisplayName
  77. * @param IUser[] $users
  78. * @return void
  79. */
  80. abstract public function send(VEvent $vevent,
  81. string $calendarDisplayName,
  82. array $users=[]): void;
  83. /**
  84. * @return string
  85. */
  86. protected function getFallbackLanguage():string {
  87. if ($this->fallbackLanguage) {
  88. return $this->fallbackLanguage;
  89. }
  90. $fallbackLanguage = $this->l10nFactory->findLanguage();
  91. $this->fallbackLanguage = $fallbackLanguage;
  92. return $fallbackLanguage;
  93. }
  94. /**
  95. * @param string $lang
  96. * @return bool
  97. */
  98. protected function hasL10NForLang(string $lang):bool {
  99. return $this->l10nFactory->languageExists('dav', $lang);
  100. }
  101. /**
  102. * @param string $lang
  103. * @return IL10N
  104. */
  105. protected function getL10NForLang(string $lang):IL10N {
  106. if (isset($this->l10ns[$lang])) {
  107. return $this->l10ns[$lang];
  108. }
  109. $l10n = $this->l10nFactory->get('dav', $lang);
  110. $this->l10ns[$lang] = $l10n;
  111. return $l10n;
  112. }
  113. /**
  114. * @param VEvent $vevent
  115. * @return string
  116. */
  117. private function getStatusOfEvent(VEvent $vevent):string {
  118. if ($vevent->STATUS) {
  119. return (string) $vevent->STATUS;
  120. }
  121. // Doesn't say so in the standard,
  122. // but we consider events without a status
  123. // to be confirmed
  124. return 'CONFIRMED';
  125. }
  126. /**
  127. * @param VEvent $vevent
  128. * @return bool
  129. */
  130. protected function isEventTentative(VEvent $vevent):bool {
  131. return $this->getStatusOfEvent($vevent) === 'TENTATIVE';
  132. }
  133. /**
  134. * @param VEvent $vevent
  135. * @return Property\ICalendar\DateTime
  136. */
  137. protected function getDTEndFromEvent(VEvent $vevent):Property\ICalendar\DateTime {
  138. if (isset($vevent->DTEND)) {
  139. return $vevent->DTEND;
  140. }
  141. if (isset($vevent->DURATION)) {
  142. $isFloating = $vevent->DTSTART->isFloating();
  143. /** @var Property\ICalendar\DateTime $end */
  144. $end = clone $vevent->DTSTART;
  145. $endDateTime = $end->getDateTime();
  146. $endDateTime = $endDateTime->add(DateTimeParser::parse($vevent->DURATION->getValue()));
  147. $end->setDateTime($endDateTime, $isFloating);
  148. return $end;
  149. }
  150. if (!$vevent->DTSTART->hasTime()) {
  151. $isFloating = $vevent->DTSTART->isFloating();
  152. /** @var Property\ICalendar\DateTime $end */
  153. $end = clone $vevent->DTSTART;
  154. $endDateTime = $end->getDateTime();
  155. $endDateTime = $endDateTime->modify('+1 day');
  156. $end->setDateTime($endDateTime, $isFloating);
  157. return $end;
  158. }
  159. return clone $vevent->DTSTART;
  160. }
  161. }