1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-07 05:11:05 +01:00

Store "start", "end", and "until" event dates as CalendarDateTime objects

Summary:
Ref T10747. This does double-writes and starts generating/writing CalendarDateTimes.

This greater flexibility is necessary to support the full range of ICS-specifiable events, including "floating" events.

This doesn't do anything yet.

Test Plan: Created and edited events, verified sensible representations of corresponding datetimes appeared in the database.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T10747

Differential Revision: https://secure.phabricator.com/D16661
This commit is contained in:
epriestley 2016-10-03 10:14:14 -07:00
parent 0ce7eacaf1
commit e042533375
6 changed files with 110 additions and 6 deletions

View file

@ -0,0 +1,5 @@
ALTER TABLE {$NAMESPACE}_calendar.calendar_event
ADD parameters LONGTEXT NOT NULL COLLATE {$COLLATE_TEXT};
UPDATE {$NAMESPACE}_calendar.calendar_event
SET parameters = '{}' WHERE parameters = '';

View file

@ -44,6 +44,7 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
protected $utcInitialEpoch; protected $utcInitialEpoch;
protected $utcUntilEpoch; protected $utcUntilEpoch;
protected $utcInstanceEpoch; protected $utcInstanceEpoch;
protected $parameters = array();
private $parentEvent = self::ATTACHABLE; private $parentEvent = self::ATTACHABLE;
private $invitees = self::ATTACHABLE; private $invitees = self::ATTACHABLE;
@ -87,6 +88,11 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
$default_icon = 'fa-calendar'; $default_icon = 'fa-calendar';
$datetime_start = PhutilCalendarAbsoluteDateTime::newFromEpoch(
$now,
$actor->getTimezoneIdentifier());
$datetime_end = $datetime_start->newRelativeDateTime('PT1H');
return id(new PhabricatorCalendarEvent()) return id(new PhabricatorCalendarEvent())
->setHostPHID($actor->getPHID()) ->setHostPHID($actor->getPHID())
->setIsCancelled(0) ->setIsCancelled(0)
@ -106,6 +112,8 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
->setDateTo($epoch_max) ->setDateTo($epoch_max)
->setAllDayDateFrom($now_min) ->setAllDayDateFrom($now_min)
->setAllDayDateTo($now_max) ->setAllDayDateTo($now_max)
->setStartDateTime($datetime_start)
->setEndDateTime($datetime_end)
->applyViewerTimezone($actor); ->applyViewerTimezone($actor);
} }
@ -443,6 +451,7 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
), ),
self::CONFIG_SERIALIZATION => array( self::CONFIG_SERIALIZATION => array(
'recurrenceFrequency' => self::SERIALIZATION_JSON, 'recurrenceFrequency' => self::SERIALIZATION_JSON,
'parameters' => self::SERIALIZATION_JSON,
), ),
) + parent::getConfiguration(); ) + parent::getConfiguration();
} }
@ -785,16 +794,31 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
} }
public function newStartDateTime() { public function newStartDateTime() {
$datetime = $this->getParameter('startDateTime');
if ($datetime) {
return $this->newDateTimeFromDictionary($datetime);
}
$epoch = $this->getDateFrom(); $epoch = $this->getDateFrom();
return $this->newDateTimeFromEpoch($epoch); return $this->newDateTimeFromEpoch($epoch);
} }
public function newEndDateTime() { public function newEndDateTime() {
$datetime = $this->getParameter('endDateTime');
if ($datetime) {
return $this->newDateTimeFromDictionary($datetime);
}
$epoch = $this->getDateTo(); $epoch = $this->getDateTo();
return $this->newDateTimeFromEpoch($epoch); return $this->newDateTimeFromEpoch($epoch);
} }
public function newUntilDateTime() { public function newUntilDateTime() {
$datetime = $this->getParameter('untilDateTime');
if ($datetime) {
return $this->newDateTimeFromDictionary($datetime);
}
$epoch = $this->getRecurrenceEndDate(); $epoch = $this->getRecurrenceEndDate();
if (!$epoch) { if (!$epoch) {
return null; return null;
@ -824,18 +848,53 @@ final class PhabricatorCalendarEvent extends PhabricatorCalendarDAO
private function newDateTimeFromEpoch($epoch) { private function newDateTimeFromEpoch($epoch) {
$datetime = PhutilCalendarAbsoluteDateTime::newFromEpoch($epoch); $datetime = PhutilCalendarAbsoluteDateTime::newFromEpoch($epoch);
if ($this->getIsAllDay()) {
$datetime->setIsAllDay(true);
}
return $this->newDateTimeFromDateTime($datetime);
}
private function newDateTimeFromDictionary(array $dict) {
$datetime = PhutilCalendarAbsoluteDateTime::newFromDictionary($dict);
return $this->newDateTimeFromDateTime($datetime);
}
private function newDateTimeFromDateTime(PhutilCalendarDateTime $datetime) {
$viewer_timezone = $this->viewerTimezone; $viewer_timezone = $this->viewerTimezone;
if ($viewer_timezone) { if ($viewer_timezone) {
$datetime->setViewerTimezone($viewer_timezone); $datetime->setViewerTimezone($viewer_timezone);
} }
if ($this->getIsAllDay()) {
$datetime->setIsAllDay(true);
}
return $datetime; return $datetime;
} }
public function getParameter($key, $default = null) {
return idx($this->parameters, $key, $default);
}
public function setParameter($key, $value) {
$this->parameters[$key] = $value;
return $this;
}
public function setStartDateTime(PhutilCalendarDateTime $datetime) {
return $this->setParameter(
'startDateTime',
$datetime->newAbsoluteDateTime()->toDictionary());
}
public function setEndDateTime(PhutilCalendarDateTime $datetime) {
return $this->setParameter(
'endDateTime',
$datetime->newAbsoluteDateTime()->toDictionary());
}
public function setUntilDateTime(PhutilCalendarDateTime $datetime) {
return $this->setParameter(
'untilDateTime',
$datetime->newAbsoluteDateTime()->toDictionary());
}
/* -( Markup Interface )--------------------------------------------------- */ /* -( Markup Interface )--------------------------------------------------- */

View file

@ -15,6 +15,25 @@ final class PhabricatorCalendarEventAllDayTransaction
public function applyInternalEffects($object, $value) { public function applyInternalEffects($object, $value) {
$object->setIsAllDay($value); $object->setIsAllDay($value);
// Adjust the flags on any other dates the event has.
$keys = array(
'startDateTime',
'endDateTime',
'untilDateTime',
);
foreach ($keys as $key) {
$dict = $object->getParameter($key);
if (!$dict) {
continue;
}
$datetime = PhutilCalendarAbsoluteDateTime::newFromDictionary($dict);
$datetime->setIsAllDay($value);
$object->setParameter($key, $datetime->toDictionary());
}
} }
public function getTitle() { public function getTitle() {

View file

@ -12,8 +12,8 @@ final class PhabricatorCalendarEventEndDateTransaction
public function applyInternalEffects($object, $value) { public function applyInternalEffects($object, $value) {
$actor = $this->getActor(); $actor = $this->getActor();
// TODO: DEPRECATED.
$object->setDateTo($value); $object->setDateTo($value);
$object->setAllDayDateTo( $object->setAllDayDateTo(
$object->getDateEpochForTimezone( $object->getDateEpochForTimezone(
$value, $value,
@ -21,6 +21,12 @@ final class PhabricatorCalendarEventEndDateTransaction
'Y-m-d 23:59:00', 'Y-m-d 23:59:00',
null, null,
new DateTimeZone('UTC'))); new DateTimeZone('UTC')));
$datetime = PhutilCalendarAbsoluteDateTime::newFromEpoch(
$value,
$actor->getTimezoneIdentifier());
$datetime->setIsAllDay($object->getIsAllDay());
$object->setEndDateTime($datetime);
} }
public function getTitle() { public function getTitle() {

View file

@ -12,8 +12,8 @@ final class PhabricatorCalendarEventStartDateTransaction
public function applyInternalEffects($object, $value) { public function applyInternalEffects($object, $value) {
$actor = $this->getActor(); $actor = $this->getActor();
// TODO: DEPRECATED.
$object->setDateFrom($value); $object->setDateFrom($value);
$object->setAllDayDateFrom( $object->setAllDayDateFrom(
$object->getDateEpochForTimezone( $object->getDateEpochForTimezone(
$value, $value,
@ -21,6 +21,12 @@ final class PhabricatorCalendarEventStartDateTransaction
'Y-m-d', 'Y-m-d',
null, null,
new DateTimeZone('UTC'))); new DateTimeZone('UTC')));
$datetime = PhutilCalendarAbsoluteDateTime::newFromEpoch(
$value,
$actor->getTimezoneIdentifier());
$datetime->setIsAllDay($object->getIsAllDay());
$object->setStartDateTime($datetime);
} }
public function getTitle() { public function getTitle() {

View file

@ -10,7 +10,16 @@ final class PhabricatorCalendarEventUntilDateTransaction
} }
public function applyInternalEffects($object, $value) { public function applyInternalEffects($object, $value) {
$actor = $this->getActor();
// TODO: DEPRECATED.
$object->setRecurrenceEndDate($value); $object->setRecurrenceEndDate($value);
$datetime = PhutilCalendarAbsoluteDateTime::newFromEpoch(
$value,
$actor->getTimezoneIdentifier());
$datetime->setIsAllDay($object->getIsAllDay());
$object->setUntilDateTime($datetime);
} }
public function getTitle() { public function getTitle() {