2011-08-11 09:22:07 +00:00
< ? php
/**
2011-09-23 20:59:24 +00:00
* Copyright ( c ) 2011 Jakob Sack < mail @ jakobsack . de >
* This file is licensed under the Affero General Public License version 3 or
* later .
* See the COPYING - README file .
2011-08-11 09:22:07 +00:00
*/
2012-06-30 15:08:00 +00:00
/**
2011-08-11 09:22:07 +00:00
*
* The following SQL statement is just a help for developers and will not be
* executed !
*
* CREATE TABLE calendar_calendars (
* id INTEGER UNSIGNED NOT NULL PRIMARY KEY AUTO_INCREMENT ,
* userid VARCHAR ( 255 ),
* displayname VARCHAR ( 100 ),
* uri VARCHAR ( 100 ),
2011-08-31 15:29:38 +00:00
* active INTEGER UNSIGNED NOT NULL DEFAULT '0' ,
2011-08-11 09:22:07 +00:00
* ctag INTEGER UNSIGNED NOT NULL DEFAULT '0' ,
* calendarorder INTEGER UNSIGNED NOT NULL DEFAULT '0' ,
* calendarcolor VARCHAR ( 10 ),
* timezone TEXT ,
* components VARCHAR ( 20 )
* );
2012-06-27 19:05:46 +00:00
*
2011-08-11 09:22:07 +00:00
*/
/**
2011-08-22 14:59:16 +00:00
* This class manages our calendars
2011-08-11 09:22:07 +00:00
*/
class OC_Calendar_Calendar {
2011-09-15 20:45:58 +00:00
/**
* @ brief Returns the list of calendars for a specific user .
* @ param string $uid User ID
2012-06-14 23:51:26 +00:00
* @ param boolean $active Only return calendars with this $active state , default ( = false ) is don ' t care
2011-09-15 20:45:58 +00:00
* @ return array
*/
2012-06-14 23:51:26 +00:00
public static function allCalendars ( $uid , $active = false ){
2011-08-31 15:29:38 +00:00
$values = array ( $uid );
2011-08-31 18:20:46 +00:00
$active_where = '' ;
2012-06-14 23:51:26 +00:00
if ( $active ){
2011-08-31 18:20:46 +00:00
$active_where = ' AND active = ?' ;
$values [] = $active ;
}
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'SELECT * FROM *PREFIX*calendar_calendars WHERE userid = ?' . $active_where );
2011-08-31 18:20:46 +00:00
$result = $stmt -> execute ( $values );
2011-09-15 20:45:58 +00:00
2011-08-22 14:59:16 +00:00
$calendars = array ();
2011-08-11 09:22:07 +00:00
while ( $row = $result -> fetchRow ()){
2011-08-22 14:59:16 +00:00
$calendars [] = $row ;
2011-08-11 09:22:07 +00:00
}
2011-08-22 14:59:16 +00:00
return $calendars ;
2011-08-11 09:22:07 +00:00
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Returns the list of calendars for a principal ( DAV term of user )
* @ param string $principaluri
* @ return array
*/
2011-08-22 14:59:16 +00:00
public static function allCalendarsWherePrincipalURIIs ( $principaluri ){
2011-08-11 09:22:07 +00:00
$uid = self :: extractUserID ( $principaluri );
return self :: allCalendars ( $uid );
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Gets the data of one calendar
* @ param integer $id
* @ return associative array
*/
2011-12-18 21:58:20 +00:00
public static function find ( $id ){
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'SELECT * FROM *PREFIX*calendar_calendars WHERE id = ?' );
2011-08-11 09:22:07 +00:00
$result = $stmt -> execute ( array ( $id ));
return $result -> fetchRow ();
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Creates a new calendar
* @ param string $userid
* @ param string $name
* @ param string $components Default : " VEVENT,VTODO,VJOURNAL "
* @ param string $timezone Default : null
* @ param integer $order Default : 1
2012-02-21 19:10:40 +00:00
* @ param string $color Default : null , format : '#RRGGBB(AA)'
2011-09-15 20:45:58 +00:00
* @ return insertid
*/
2011-10-08 11:28:01 +00:00
public static function addCalendar ( $userid , $name , $components = 'VEVENT,VTODO,VJOURNAL' , $timezone = null , $order = 0 , $color = null ){
2011-08-22 14:59:16 +00:00
$all = self :: allCalendars ( $userid );
2011-08-11 09:22:07 +00:00
$uris = array ();
foreach ( $all as $i ){
$uris [] = $i [ 'uri' ];
}
$uri = self :: createURI ( $name , $uris );
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'INSERT INTO *PREFIX*calendar_calendars (userid,displayname,uri,ctag,calendarorder,calendarcolor,timezone,components) VALUES(?,?,?,?,?,?,?,?)' );
2011-10-08 11:28:01 +00:00
$result = $stmt -> execute ( array ( $userid , $name , $uri , 1 , $order , $color , $timezone , $components ));
2011-08-11 09:22:07 +00:00
2012-06-09 10:18:25 +00:00
$insertid = OCP\DB :: insertid ( '*PREFIX*calendar_calendars' );
2012-06-11 13:16:59 +00:00
OCP\Util :: emitHook ( 'OC_Calendar' , 'addCalendar' , $insertid );
2012-06-09 10:18:25 +00:00
return $insertid ;
2011-08-11 09:22:07 +00:00
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Creates a new calendar from the data sabredav provides
* @ param string $principaluri
* @ param string $uri
* @ param string $name
* @ param string $components
* @ param string $timezone
* @ param integer $order
2012-02-21 19:10:40 +00:00
* @ param string $color format : '#RRGGBB(AA)'
2011-09-15 20:45:58 +00:00
* @ return insertid
*/
2011-10-08 11:28:01 +00:00
public static function addCalendarFromDAVData ( $principaluri , $uri , $name , $components , $timezone , $order , $color ){
2011-08-11 09:22:07 +00:00
$userid = self :: extractUserID ( $principaluri );
2011-09-15 20:45:58 +00:00
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'INSERT INTO *PREFIX*calendar_calendars (userid,displayname,uri,ctag,calendarorder,calendarcolor,timezone,components) VALUES(?,?,?,?,?,?,?,?)' );
2011-10-08 11:28:01 +00:00
$result = $stmt -> execute ( array ( $userid , $name , $uri , 1 , $order , $color , $timezone , $components ));
2011-08-11 09:22:07 +00:00
2012-06-09 10:18:25 +00:00
$insertid = OCP\DB :: insertid ( '*PREFIX*calendar_calendars' );
2012-06-11 13:16:59 +00:00
OCP\Util :: emitHook ( 'OC_Calendar' , 'addCalendar' , $insertid );
2012-06-09 10:18:25 +00:00
return $insertid ;
2011-08-11 09:22:07 +00:00
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Edits a calendar
* @ param integer $id
* @ param string $name Default : null
* @ param string $components Default : null
* @ param string $timezone Default : null
* @ param integer $order Default : null
2012-02-21 19:10:40 +00:00
* @ param string $color Default : null , format : '#RRGGBB(AA)'
2011-09-15 20:45:58 +00:00
* @ return boolean
*
* Values not null will be set
*/
2011-10-08 11:28:01 +00:00
public static function editCalendar ( $id , $name = null , $components = null , $timezone = null , $order = null , $color = null ){
2011-08-11 09:22:07 +00:00
// Need these ones for checking uri
2011-12-18 21:58:20 +00:00
$calendar = self :: find ( $id );
2011-08-22 14:59:16 +00:00
// Keep old stuff
2012-01-11 00:53:25 +00:00
if ( is_null ( $name )) $name = $calendar [ 'displayname' ];
2011-08-22 14:59:16 +00:00
if ( is_null ( $components )) $components = $calendar [ 'components' ];
if ( is_null ( $timezone )) $timezone = $calendar [ 'timezone' ];
2011-08-31 18:20:46 +00:00
if ( is_null ( $order )) $order = $calendar [ 'calendarorder' ];
2012-01-11 00:53:25 +00:00
if ( is_null ( $color )) $color = $calendar [ 'calendarcolor' ];
2011-09-15 20:45:58 +00:00
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'UPDATE *PREFIX*calendar_calendars SET displayname=?,calendarorder=?,calendarcolor=?,timezone=?,components=?,ctag=ctag+1 WHERE id=?' );
2011-10-08 11:28:01 +00:00
$result = $stmt -> execute ( array ( $name , $order , $color , $timezone , $components , $id ));
2011-08-11 09:22:07 +00:00
2012-06-11 13:16:59 +00:00
OCP\Util :: emitHook ( 'OC_Calendar' , 'editCalendar' , $id );
2011-08-11 09:22:07 +00:00
return true ;
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Sets a calendar ( in ) active
* @ param integer $id
* @ param boolean $active
* @ return boolean
*/
2011-08-31 15:29:38 +00:00
public static function setCalendarActive ( $id , $active ){
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'UPDATE *PREFIX*calendar_calendars SET active = ? WHERE id = ?' );
2011-08-31 15:29:38 +00:00
$stmt -> execute ( array ( $active , $id ));
2011-08-31 18:20:46 +00:00
2011-08-31 15:29:38 +00:00
return true ;
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Updates ctag for calendar
* @ param integer $id
* @ return boolean
*/
2011-08-11 09:22:07 +00:00
public static function touchCalendar ( $id ){
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'UPDATE *PREFIX*calendar_calendars SET ctag = ctag + 1 WHERE id = ?' );
2011-08-11 09:22:07 +00:00
$stmt -> execute ( array ( $id ));
return true ;
}
2011-09-15 20:45:58 +00:00
/**
* @ brief removes a calendar
* @ param integer $id
* @ return boolean
*/
2011-08-11 09:22:07 +00:00
public static function deleteCalendar ( $id ){
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'DELETE FROM *PREFIX*calendar_calendars WHERE id = ?' );
2011-08-11 09:22:07 +00:00
$stmt -> execute ( array ( $id ));
2011-09-15 20:45:58 +00:00
2012-05-03 11:06:08 +00:00
$stmt = OCP\DB :: prepare ( 'DELETE FROM *PREFIX*calendar_objects WHERE calendarid = ?' );
2011-08-11 09:22:07 +00:00
$stmt -> execute ( array ( $id ));
2012-06-11 13:16:59 +00:00
OCP\Util :: emitHook ( 'OC_Calendar' , 'deleteCalendar' , $id );
2012-06-21 21:21:15 +00:00
if ( count ( self :: allCalendars ( OCP\USER :: getUser ())) == 0 ) {
2012-06-15 00:10:55 +00:00
self :: addCalendar ( OCP\USER :: getUser (), 'Default calendar' );
}
2012-06-09 10:18:25 +00:00
2011-08-11 09:22:07 +00:00
return true ;
}
2012-06-27 18:56:58 +00:00
2012-06-30 15:08:00 +00:00
/**
2012-06-27 18:56:58 +00:00
* @ brief merges two calendars
* @ param integer $id1
* @ param integer $id2
* @ return boolean
*/
public static function mergeCalendar ( $id1 , $id2 ){
$stmt = OCP\DB :: prepare ( 'UPDATE *PREFIX*calendar_objects SET calendarid = ? WHERE calendarid = ?' );
$stmt -> execute ( array ( $id1 , $id2 ));
self :: touchCalendar ( $id1 );
self :: deleteCalendar ( $id2 );
}
2011-09-15 20:45:58 +00:00
/**
* @ brief Creates a URI for Calendar
* @ param string $name name of the calendar
* @ param array $existing existing calendar URIs
* @ return string uri
*/
2011-08-11 09:22:07 +00:00
public static function createURI ( $name , $existing ){
$name = strtolower ( $name );
$newname = $name ;
$i = 1 ;
while ( in_array ( $newname , $existing )){
$newname = $name . $i ;
$i = $i + 1 ;
}
return $newname ;
}
2011-09-15 20:45:58 +00:00
/**
* @ brief gets the userid from a principal path
* @ return string
*/
2011-08-11 09:22:07 +00:00
public static function extractUserID ( $principaluri ){
list ( $prefix , $userid ) = Sabre_DAV_URLUtil :: splitPath ( $principaluri );
return $userid ;
}
2012-06-27 18:56:58 +00:00
2012-06-30 15:08:00 +00:00
/**
2012-06-27 18:56:58 +00:00
* @ brief returns the possible color for calendars
* @ return array
*/
2011-10-14 12:56:18 +00:00
public static function getCalendarColorOptions (){
return array (
2012-02-21 19:10:40 +00:00
'#ff0000' , // "Red"
'#b3dc6c' , // "Green"
'#ffff00' , // "Yellow"
'#808000' , // "Olive"
'#ffa500' , // "Orange"
'#ff7f50' , // "Coral"
'#ee82ee' , // "Violet"
'#9fc6e7' , // "light blue"
2011-10-14 12:56:18 +00:00
);
}
2012-03-01 19:56:51 +00:00
2012-06-30 15:08:00 +00:00
/**
2012-06-27 18:56:58 +00:00
* @ brief generates the Event Source Info for our JS
* @ param array $calendar calendar data
* @ return array
*/
2011-10-19 17:07:56 +00:00
public static function getEventSourceInfo ( $calendar ){
return array (
2012-05-01 21:19:39 +00:00
'url' => OCP\Util :: linkTo ( 'calendar' , 'ajax/events.php' ) . '?calendar_id=' . $calendar [ 'id' ],
2012-02-21 19:10:40 +00:00
'backgroundColor' => $calendar [ 'calendarcolor' ],
2011-10-19 17:07:56 +00:00
'borderColor' => '#888' ,
2012-06-30 22:09:33 +00:00
'textColor' => self :: generateTextColor ( $calendar [ 'calendarcolor' ]),
2012-02-17 20:39:54 +00:00
'cache' => true ,
2011-10-19 17:07:56 +00:00
);
}
2012-06-30 13:17:29 +00:00
/*
* @ brief checks if a calendar name is available for a user
* @ param string $calendarname
* @ param string $userid
* @ return boolean
*/
public static function isCalendarNameavailable ( $calendarname , $userid ){
$calendars = self :: allCalendars ( $userid );
foreach ( $calendars as $calendar ){
if ( $calendar [ 'displayname' ] == $calendarname ){
return false ;
}
}
return true ;
}
2012-06-30 22:09:33 +00:00
/*
* @ brief generates the text color for the calendar
2012-06-30 22:31:05 +00:00
* @ param string $calendarcolor rgb calendar color code in hex format ( with or without the leading #)
* ( this function doesn ' t pay attention on the alpha value of rgba color codes )
2012-06-30 22:09:33 +00:00
* @ return boolean
*/
public static function generateTextColor ( $calendarcolor ){
if ( substr_count ( $calendarcolor , '#' ) == 1 ){
$calendarcolor = substr ( $calendarcolor , 1 );
}
$red = hexdec ( substr ( $calendarcolor , 0 , 2 ));
$green = hexdec ( substr ( $calendarcolor , 2 , 2 ));
$blue = hexdec ( substr ( $calendarcolor , 2 , 2 ));
//recommendation by W3C
$computation = ((( $red * 299 ) + ( $green * 587 ) + ( $blue * 114 )) / 1000 );
2012-06-30 23:02:54 +00:00
return ( $computation > 130 ) ? '#000000' : '#FAFAFA' ;
2012-06-30 22:09:33 +00:00
}
2011-08-11 09:22:07 +00:00
}