diff options
Diffstat (limited to 'apps/calendar/lib/import.php')
-rw-r--r-- | apps/calendar/lib/import.php | 103 |
1 files changed, 90 insertions, 13 deletions
diff --git a/apps/calendar/lib/import.php b/apps/calendar/lib/import.php index e64a9e91eb3..864fc02fdf5 100644 --- a/apps/calendar/lib/import.php +++ b/apps/calendar/lib/import.php @@ -10,9 +10,9 @@ */ class OC_Calendar_Import{ /* - * @brief var to check if errors happend while initialization + * @brief var saves if the percentage should be saved with OC_Cache */ - private $error; + private $cacheprogress; /* * @brief Sabre_VObject_Component_VCalendar object - for documentation see http://code.google.com/p/sabredav/wiki/Sabre_VObject_Component_VCalendar @@ -20,19 +20,24 @@ class OC_Calendar_Import{ private $calobject; /* - * @brief var saves the ical string that was submitted with the __construct function + * @brief var to check if errors happend while initialization */ - private $ical; + private $error; /* * @brief var saves the ical string that was submitted with the __construct function */ - private $tz; + private $ical; /* * @brief var saves the percentage of the import's progress */ private $progress; + + /* + * @brief var saves the timezone the events shell converted to + */ + private $tz; /* * public methods @@ -40,10 +45,11 @@ class OC_Calendar_Import{ /* * @brief does general initialization for import object - * @param string $calendar + * @param string $calendar content of ical file + * @param string $tz timezone of the user * @return boolean */ - public function __construct($ical, $tz){ + public function __construct($ical){ $this->error = null; $this->ical = $ical; try{ @@ -53,7 +59,7 @@ class OC_Calendar_Import{ $this->error = true; return false; } - $this->tz = $tz; + return true; } /* @@ -65,7 +71,21 @@ class OC_Calendar_Import{ if(!$this->isValid() && !$force){ return false; } - + foreach($this->calobject->getComponents() as $object){ + if(!($object instanceof Sabre_VObject_Component_VEvent) && !($object instanceof Sabre_VObject_Component_VJournal) && !($object instanceof Sabre_VObject_Component_VTodo)){ + continue; + } + + } + } + + /* + * @brief sets the timezone + * @return boolean + */ + public function setTimeZone($tz){ + $this->tz = $tz; + return true; } /* @@ -86,12 +106,62 @@ class OC_Calendar_Import{ public function getProgress(){ return $this->progress; } + + /* + * @brief enables the cache for the percentage of progress + * @return boolean + */ + public function enableProgressCache(){ + $this->cacheprogress = true; + return true; + } + + /* + * @brief disables the cache for the percentage of progress + * @return boolean + */ + public function disableProgressCache(){ + $this->cacheprogress = false; + return false; + } /* * private methods */ /* + * @brief generates an unique ID + * @return string + */ + private function createUID(){ + return substr(md5(rand().time()),0,10); + } + + /* + * @brief checks is the UID is already in use for another event + * @param string $uid uid to check + * @return boolean + */ + private function isUIDAvailable($uid){ + + } + + /* + * @brief generates a proper VCalendar string + * @param string $vobject + * @return string + */ + private function createVCalendar($vobject){ + if(is_object($vobject)){ + $vobject = @$vobject->serialize(); + } + $vcalendar = "BEGIN:VCALENDAR\nVERSION:2.0\nPRODID:ownCloud Calendar " . OCP\App::getAppVersion('calendar') . "\n"; + $vcalendar .= $vobject; + $vcalendar .= "END:VCALENDAR"; + return $vcalendar; + } + + /* * @brief * @return */ @@ -99,16 +169,23 @@ class OC_Calendar_Import{ } + /* + * @brief + * @return + */ + private function (){ + + } /* - * methods for X-... + * public methods for prerendering of X-... Attributes */ /* * @brief guesses the calendar color * @return mixed - string or boolean */ - private function guessCalendarColor(){ + public function guessCalendarColor(){ if(!is_null($this->calobject->__get('X-APPLE-CALENDAR-COLOR'))){ return $this->calobject->__get('X-APPLE-CALENDAR-COLOR'); } @@ -119,7 +196,7 @@ class OC_Calendar_Import{ * @brief guesses the calendar description * @return mixed - string or boolean */ - private function guessCalendarDescription(){ + public function guessCalendarDescription(){ if(!is_null($this->calobject->__get('X-WR-CALDESC'))){ return $this->calobject->__get('X-WR-CALDESC'); } @@ -130,7 +207,7 @@ class OC_Calendar_Import{ * @brief guesses the calendar name * @return mixed - string or boolean */ - private function guessCalendarName(){ + public function guessCalendarName(){ if(!is_null($this->calobject->__get('X-WR-CALNAME'))){ return $this->calobject->__get('X-WR-CALNAME'); } |