2011-12-18 21:58:20 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Copyright (c) 2011 Bart Visscher <bartv@thisnet.nl>
|
2012-03-31 20:13:04 +00:00
|
|
|
* Copyright (c) 2012 Georg Ehrke <georg@owncloud.com>
|
2011-12-18 21:58:20 +00:00
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
2012-03-31 20:13:04 +00:00
|
|
|
*
|
2011-12-18 21:58:20 +00:00
|
|
|
* This class manages our app actions
|
|
|
|
*/
|
|
|
|
OC_Calendar_App::$l10n = new OC_L10N('calendar');
|
|
|
|
class OC_Calendar_App{
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* @brief: language object for calendar app
|
|
|
|
*/
|
2011-12-18 21:58:20 +00:00
|
|
|
public static $l10n;
|
|
|
|
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* @brief: returns informations about a calendar
|
|
|
|
* @param: int $id - id of the calendar
|
|
|
|
* @param: bool $security - check access rights or not
|
|
|
|
* @param: bool $shared - check if the user got access via sharing
|
|
|
|
* @return: mixed - bool / array
|
|
|
|
*/
|
|
|
|
public static function getCalendar($id, $security = true, $shared = false){
|
|
|
|
$calendar = OC_Calendar_Object::find($id);
|
|
|
|
if($shared === true){
|
|
|
|
if(OC_Calendar_Share::check_access(OC_User::getUser(), $id, OC_Calendar_Share::CALENDAR)){
|
|
|
|
return $calendar;
|
|
|
|
}
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
if($security === true){
|
|
|
|
if($calendar['userid'] != OC_User::getUser()){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if($calendar === false){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return OC_Calendar_Calendar::find($id);
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns informations about an event
|
|
|
|
* @param: int $id - id of the event
|
|
|
|
* @param: bool $security - check access rights or not
|
|
|
|
* @param: bool $shared - check if the user got access via sharing
|
|
|
|
* @return: mixed - bool / array
|
|
|
|
*/
|
|
|
|
public static function getEventObject($id, $security = true, $shared = false){
|
|
|
|
$event = OC_Calendar_Object::find($id);
|
|
|
|
if($shared === true){
|
|
|
|
if(OC_Calendar_Share::check_access(OC_User::getUser(), $id, OC_Calendar_Share::EVENT)){
|
|
|
|
return $calendar;
|
|
|
|
}
|
2012-03-26 13:24:43 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
if($security === true){
|
|
|
|
$calendar = self::getCalendar($event['calendarid'], false);
|
|
|
|
if($calendar['userid'] != OC_User::getUser()){
|
|
|
|
return false;
|
2012-03-26 13:24:43 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
if($event === false){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return $event;
|
2012-03-26 13:24:43 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the parsed calendar data
|
|
|
|
* @param: int $id - id of the event
|
|
|
|
* @param: bool $security - check access rights or not
|
|
|
|
* @return: mixed - bool / object
|
|
|
|
*/
|
|
|
|
public static function getVCalendar($id, $security = true){
|
|
|
|
$event_object = self::getEventObject($id, $security);
|
|
|
|
if($event_object === false){
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$vobject = OC_VObject::parse($event_object['calendardata']);
|
|
|
|
if(is_null($vobject)){
|
|
|
|
return false;
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
return $vobject;
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function isNotModified($vevent, $lastmodified){
|
2011-12-18 21:58:20 +00:00
|
|
|
$last_modified = $vevent->__get('LAST-MODIFIED');
|
|
|
|
if($last_modified && $lastmodified != $last_modified->getDateTime()->format('U')){
|
|
|
|
OC_JSON::error(array('modified'=>true));
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* THIS FUNCTION IS DEPRECATED AND WILL BE REMOVED SOON
|
|
|
|
* @brief: returns the valid categories
|
|
|
|
* @return: array - categories
|
|
|
|
*/
|
|
|
|
public static function getCategoryOptions(){
|
|
|
|
return OC_Calendar_Object::getCategoryOptions(self::$l10n);
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an repeating event
|
|
|
|
* @return: array - valid inputs for repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getRepeatOptions(){
|
|
|
|
return OC_Calendar_Object::getRepeatOptions(self::$l10n);
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for the end of an repeating event
|
|
|
|
* @return: array - valid inputs for the end of an repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getEndOptions(){
|
|
|
|
return OC_Calendar_Object::getEndOptions(self::$l10n);
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an monthly repeating event
|
|
|
|
* @return: array - valid inputs for monthly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getMonthOptions(){
|
|
|
|
return OC_Calendar_Object::getMonthOptions(self::$l10n);
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an weekly repeating event
|
|
|
|
* @return: array - valid inputs for weekly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getWeeklyOptions(){
|
|
|
|
return OC_Calendar_Object::getWeeklyOptions(self::$l10n);
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an yearly repeating event
|
|
|
|
* @return: array - valid inputs for yearly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getYearOptions(){
|
|
|
|
return OC_Calendar_Object::getYearOptions(self::$l10n);
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an yearly repeating event which occurs on specific days of the year
|
|
|
|
* @return: array - valid inputs for yearly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getByYearDayOptions(){
|
|
|
|
return OC_Calendar_Object::getByYearDayOptions();
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an yearly repeating event which occurs on specific month of the year
|
|
|
|
* @return: array - valid inputs for yearly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getByMonthOptions(){
|
|
|
|
return OC_Calendar_Object::getByMonthOptions(self::$l10n);
|
|
|
|
}
|
|
|
|
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* @brief: returns the options for an yearly repeating event which occurs on specific week numbers of the year
|
|
|
|
* @return: array - valid inputs for yearly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getByWeekNoOptions(){
|
|
|
|
return OC_Calendar_Object::getByWeekNoOptions();
|
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @brief: returns the options for an yearly or monthly repeating event which occurs on specific days of the month
|
|
|
|
* @return: array - valid inputs for yearly or monthly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getByMonthDayOptions(){
|
|
|
|
return OC_Calendar_Object::getByMonthDayOptions();
|
|
|
|
}
|
|
|
|
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* @brief: returns the options for an monthly repeating event which occurs on specific weeks of the month
|
|
|
|
* @return: array - valid inputs for monthly repeating events
|
|
|
|
*/
|
2011-12-25 22:19:49 +00:00
|
|
|
public static function getWeekofMonth(){
|
|
|
|
return OC_Calendar_Object::getWeekofMonth(self::$l10n);
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|
2012-02-11 13:02:51 +00:00
|
|
|
|
2012-03-31 20:13:04 +00:00
|
|
|
/*
|
|
|
|
* @brief: returns the prepared output for the json calendar data
|
|
|
|
* @param: array $event - array with event informations (self::getEventObject)
|
|
|
|
* @return: array - prepared output
|
|
|
|
*/
|
|
|
|
public static function prepareForOutput($event){
|
|
|
|
if(isset($event['calendardata'])){
|
|
|
|
$object = self::getVCalendar($event['calendardata'], false);
|
|
|
|
$vevent = $object->VEVENT;
|
|
|
|
}else{
|
|
|
|
$vevent = $event['vevent'];
|
2012-02-11 13:02:51 +00:00
|
|
|
}
|
2012-03-31 20:13:04 +00:00
|
|
|
$last_modified = ($vevent->__get('LAST-MODIFIED'))?$last_modified->getDateTime()->format('U'):0;
|
|
|
|
$return = array('id'=>(int)$event['id'],
|
|
|
|
'title' => htmlspecialchars(($event['summary']!=NULL || $event['summary'] != '')?$event['summary']: self::$l10n->t('unnamed')),
|
|
|
|
'description' => isset($vevent->DESCRIPTION)?htmlspecialchars($vevent->DESCRIPTION->value):'',
|
|
|
|
'lastmodified'=>(int)$lastmodified);
|
|
|
|
return $return;
|
2012-02-11 13:02:51 +00:00
|
|
|
}
|
2011-12-18 21:58:20 +00:00
|
|
|
}
|