annotate vendor/sabre/vobject/lib/Component/VAlarm.php @ 43:771f6803cc4b default tip

somehow lost the correctly updated metadata so e.g. 'mail' package wasn't being imported
author Charlie Root
date Sun, 26 Jan 2025 13:13:49 -0500
parents 430dbd5346f7
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
7
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
1 <?php
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
2
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
3 namespace Sabre\VObject\Component;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
4 use Sabre\VObject;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
5
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
6 /**
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
7 * VAlarm component
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
8 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
9 * This component contains some additional functionality specific for VALARMs.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
10 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
11 * @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/).
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
12 * @author Evert Pot (http://evertpot.com/)
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
13 * @license http://sabre.io/license/ Modified BSD License
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
14 */
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
15 class VAlarm extends VObject\Component {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
16
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
17 /**
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
18 * Returns a DateTime object when this alarm is going to trigger.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
19 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
20 * This ignores repeated alarm, only the first trigger is returned.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
21 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
22 * @return DateTime
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
23 */
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
24 public function getEffectiveTriggerTime() {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
25
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
26 $trigger = $this->TRIGGER;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
27 if(!isset($trigger['VALUE']) || strtoupper($trigger['VALUE']) === 'DURATION') {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
28 $triggerDuration = VObject\DateTimeParser::parseDuration($this->TRIGGER);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
29 $related = (isset($trigger['RELATED']) && strtoupper($trigger['RELATED']) == 'END') ? 'END' : 'START';
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
30
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
31 $parentComponent = $this->parent;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
32 if ($related === 'START') {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
33
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
34 if ($parentComponent->name === 'VTODO') {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
35 $propName = 'DUE';
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
36 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
37 $propName = 'DTSTART';
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
38 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
39
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
40 $effectiveTrigger = clone $parentComponent->$propName->getDateTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
41 $effectiveTrigger->add($triggerDuration);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
42 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
43 if ($parentComponent->name === 'VTODO') {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
44 $endProp = 'DUE';
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
45 } elseif ($parentComponent->name === 'VEVENT') {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
46 $endProp = 'DTEND';
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
47 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
48 throw new \LogicException('time-range filters on VALARM components are only supported when they are a child of VTODO or VEVENT');
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
49 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
50
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
51 if (isset($parentComponent->$endProp)) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
52 $effectiveTrigger = clone $parentComponent->$endProp->getDateTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
53 $effectiveTrigger->add($triggerDuration);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
54 } elseif (isset($parentComponent->DURATION)) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
55 $effectiveTrigger = clone $parentComponent->DTSTART->getDateTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
56 $duration = VObject\DateTimeParser::parseDuration($parentComponent->DURATION);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
57 $effectiveTrigger->add($duration);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
58 $effectiveTrigger->add($triggerDuration);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
59 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
60 $effectiveTrigger = clone $parentComponent->DTSTART->getDateTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
61 $effectiveTrigger->add($triggerDuration);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
62 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
63 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
64 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
65 $effectiveTrigger = $trigger->getDateTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
66 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
67 return $effectiveTrigger;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
68
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
69 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
70
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
71 /**
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
72 * Returns true or false depending on if the event falls in the specified
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
73 * time-range. This is used for filtering purposes.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
74 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
75 * The rules used to determine if an event falls within the specified
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
76 * time-range is based on the CalDAV specification.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
77 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
78 * @param \DateTime $start
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
79 * @param \DateTime $end
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
80 * @return bool
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
81 */
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
82 public function isInTimeRange(\DateTime $start, \DateTime $end) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
83
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
84 $effectiveTrigger = $this->getEffectiveTriggerTime();
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
85
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
86 if (isset($this->DURATION)) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
87 $duration = VObject\DateTimeParser::parseDuration($this->DURATION);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
88 $repeat = (string)$this->repeat;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
89 if (!$repeat) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
90 $repeat = 1;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
91 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
92
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
93 $period = new \DatePeriod($effectiveTrigger, $duration, (int)$repeat);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
94
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
95 foreach($period as $occurrence) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
96
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
97 if ($start <= $occurrence && $end > $occurrence) {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
98 return true;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
99 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
100 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
101 return false;
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
102 } else {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
103 return ($start <= $effectiveTrigger && $end > $effectiveTrigger);
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
104 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
105
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
106 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
107
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
108 /**
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
109 * A simple list of validation rules.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
110 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
111 * This is simply a list of properties, and how many times they either
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
112 * must or must not appear.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
113 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
114 * Possible values per property:
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
115 * * 0 - Must not appear.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
116 * * 1 - Must appear exactly once.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
117 * * + - Must appear at least once.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
118 * * * - Can appear any number of times.
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
119 *
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
120 * @var array
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
121 */
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
122 public function getValidationRules() {
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
123
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
124 return array(
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
125 'ACTION' => 1,
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
126 'TRIGGER' => 1,
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
127
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
128 'DURATION' => '?',
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
129 'REPEAT' => '?',
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
130
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
131 'ATTACH' => '?',
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
132 );
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
133
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
134 }
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
135
430dbd5346f7 vendor sabre as distributed
Charlie Root
parents:
diff changeset
136 }