fixing IDE warnings

This commit is contained in:
Ralf Becker 2015-01-14 13:52:34 +00:00
parent 31fe89849e
commit 83ca579700

View File

@ -7,7 +7,7 @@
* @author Ralf Becker <RalfBecker-AT-outdoor-training.de> * @author Ralf Becker <RalfBecker-AT-outdoor-training.de>
* @author Christian Binder <christian-AT-jaytraxx.de> * @author Christian Binder <christian-AT-jaytraxx.de>
* @author Joerg Lehrke <jlehrke@noc.de> * @author Joerg Lehrke <jlehrke@noc.de>
* @copyright (c) 2005-14 by RalfBecker-At-outdoor-training.de * @copyright (c) 2005-15 by RalfBecker-At-outdoor-training.de
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License * @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
* @version $Id$ * @version $Id$
*/ */
@ -137,12 +137,12 @@ class calendar_so
* All times (start, end and modified) are returned as timesstamps in servertime! * All times (start, end and modified) are returned as timesstamps in servertime!
* *
* @param int|array|string $ids id or array of id's of the entries to read, or string with a single uid * @param int|array|string $ids id or array of id's of the entries to read, or string with a single uid
* @param int $recur_date=0 if set read the next recurrence at or after the timestamp, default 0 = read the initital one * @param int $recur_date =0 if set read the next recurrence at or after the timestamp, default 0 = read the initital one
* @return array|boolean array with cal_id => event array pairs or false if entry not found * @return array|boolean array with cal_id => event array pairs or false if entry not found
*/ */
function read($ids,$recur_date=0) function read($ids,$recur_date=0)
{ {
//_debug_array(__METHOD__.__LINE__.'#'.$recur_date.'#'.function_backtrace()); //error_log(__METHOD__.'('.array2string($ids).",$recur_date) ".function_backtrace());
if (isset($GLOBALS['egw_info']['user']['preferences']['syncml']['minimum_uid_length'])) if (isset($GLOBALS['egw_info']['user']['preferences']['syncml']['minimum_uid_length']))
{ {
$minimum_uid_length = $GLOBALS['egw_info']['user']['preferences']['syncml']['minimum_uid_length']; $minimum_uid_length = $GLOBALS['egw_info']['user']['preferences']['syncml']['minimum_uid_length'];
@ -152,8 +152,6 @@ class calendar_so
$minimum_uid_length = 8; $minimum_uid_length = 8;
} }
//echo "<p>socal::read(".print_r($ids,true).",$recur_date)<br />\n".function_backtrace()."<p>\n";
$cols = self::get_columns('calendar', $this->cal_table); $cols = self::get_columns('calendar', $this->cal_table);
$cols[0] = $this->db->to_varchar($this->cal_table.'.cal_id'); $cols[0] = $this->db->to_varchar($this->cal_table.'.cal_id');
$cols = "$this->repeats_table.recur_type,$this->repeats_table.recur_interval,$this->repeats_table.recur_data,".implode(',',$cols); $cols = "$this->repeats_table.recur_type,$this->repeats_table.recur_interval,$this->repeats_table.recur_data,".implode(',',$cols);
@ -331,8 +329,8 @@ class calendar_so
* This includes ALL recurences of an event series * This includes ALL recurences of an event series
* *
* @param int|string|array $users one or mulitple calendar users * @param int|string|array $users one or mulitple calendar users
* @param booelan $owner_too=false if true return also events owned by given users * @param booelan $owner_too =false if true return also events owned by given users
* @param boolean $master_only=false only check recurance master (egw_cal_user.recur_date=0) * @param boolean $master_only =false only check recurance master (egw_cal_user.recur_date=0)
* @return int maximum modification timestamp * @return int maximum modification timestamp
*/ */
function get_ctag($users, $owner_too=false,$master_only=false) function get_ctag($users, $owner_too=false,$master_only=false)
@ -350,6 +348,7 @@ class calendar_so
$types = array(); $types = array();
foreach((array)$users as $uid) foreach((array)$users as $uid)
{ {
$type = $id = null;
self::split_user($uid, $type, $id); self::split_user($uid, $type, $id);
$types[$type][] = $id; $types[$type][] = $id;
} }
@ -394,10 +393,10 @@ class calendar_so
* Use as: foreach(get_cal_data() as $data) { $data = egw_db::strip_array_keys($data, 'cal_'); // do something with $data * Use as: foreach(get_cal_data() as $data) { $data = egw_db::strip_array_keys($data, 'cal_'); // do something with $data
* *
* @param array $query filter, keys have to use 'cal_' prefix * @param array $query filter, keys have to use 'cal_' prefix
* @param string|array $cols='cal_id,cal_reference,cal_etag,cal_modified,cal_user_modified' cols to query * @param string|array $cols ='cal_id,cal_reference,cal_etag,cal_modified,cal_user_modified' cols to query
* @return Iterator as egw_db::select * @return Iterator as egw_db::select
*/ */
function get_cal_data(array $query, $cols='cal_id,cal_reference,cal_etag,cal_modified,cal_user_modified', $include_user_modified=false) function get_cal_data(array $query, $cols='cal_id,cal_reference,cal_etag,cal_modified,cal_user_modified')
{ {
if (!is_array($cols)) $cols = explode(',', $cols); if (!is_array($cols)) $cols = explode(',', $cols);
@ -441,23 +440,23 @@ class calendar_so
* @param int $start startdate of the search/list (servertime) * @param int $start startdate of the search/list (servertime)
* @param int $end enddate of the search/list (servertime) * @param int $end enddate of the search/list (servertime)
* @param int|array $users user-id or array of user-id's, !$users means all entries regardless of users * @param int|array $users user-id or array of user-id's, !$users means all entries regardless of users
* @param int|array $cat_id=0 mixed category-id or array of cat-id's (incl. all sub-categories), default 0 = all * @param int|array $cat_id =0 mixed category-id or array of cat-id's (incl. all sub-categories), default 0 = all
* @param string $filter='all' string filter-name: all (not rejected), accepted, unknown, tentative, rejected or everything (incl. rejected, deleted) * @param string $filter ='all' string filter-name: all (not rejected), accepted, unknown, tentative, rejected or everything (incl. rejected, deleted)
* @param int|boolean $offset=False offset for a limited query or False (default) * @param int|boolean $offset =False offset for a limited query or False (default)
* @param int $num_rows=0 number of rows to return if offset set, default 0 = use default in user prefs * @param int $num_rows =0 number of rows to return if offset set, default 0 = use default in user prefs
* @param array $params=array() * @param array $params =array()
* @param string|array $params['query'] string: pattern so search for, if unset or empty all matching entries are returned (no search) * @param string|array $params['query'] string: pattern so search for, if unset or empty all matching entries are returned (no search)
* Please Note: a search never returns repeating events more then once AND does not honor start+end date !!! * Please Note: a search never returns repeating events more then once AND does not honor start+end date !!!
* array: everything is directly used as $where * array: everything is directly used as $where
* @param string $params['order']='cal_start' column-names plus optional DESC|ASC separted by comma * @param string $params['order'] ='cal_start' column-names plus optional DESC|ASC separted by comma
* @param string $params['sql_filter'] sql to be and'ed into query (fully quoted) * @param string $params['sql_filter'] sql to be and'ed into query (fully quoted)
* @param string|array $params['cols'] what to select, default "$this->repeats_table.*,$this->cal_table.*,cal_start,cal_end,cal_recur_date", * @param string|array $params['cols'] what to select, default "$this->repeats_table.*,$this->cal_table.*,cal_start,cal_end,cal_recur_date",
* if specified and not false an iterator for the rows is returned * if specified and not false an iterator for the rows is returned
* @param string $params['append'] SQL to append to the query before $order, eg. for a GROUP BY clause * @param string $params['append'] SQL to append to the query before $order, eg. for a GROUP BY clause
* @param array $params['cfs'] custom fields to query, null = none, array() = all, or array with cfs names * @param array $params['cfs'] custom fields to query, null = none, array() = all, or array with cfs names
* @param array $params['users'] raw parameter as passed to calendar_bo::search() no memberships resolved! * @param array $params['users'] raw parameter as passed to calendar_bo::search() no memberships resolved!
* @param boolean $params['master_only']=false, true only take into account participants/status from master (for AS) * @param boolean $params['master_only'] =false, true only take into account participants/status from master (for AS)
* @param int $remove_rejected_by_user=null add join to remove entry, if given user has rejected it * @param int $remove_rejected_by_user =null add join to remove entry, if given user has rejected it
* @return array of cal_ids, or false if error in the parameters * @return array of cal_ids, or false if error in the parameters
* *
* ToDo: search custom-fields too * ToDo: search custom-fields too
@ -535,7 +534,10 @@ class calendar_so
$cal_table_def = $this->db->get_table_definitions('calendar',$this->cal_table); $cal_table_def = $this->db->get_table_definitions('calendar',$this->cal_table);
// only users can be owners, no need to add groups // only users can be owners, no need to add groups
$user_ids = array(); $user_ids = array();
foreach($ids as $user_id) if ($GLOBALS['egw']->accounts->get_type($user_id) === 'u') $user_ids[] = $user_id; foreach($ids as $user_id)
{
if ($GLOBALS['egw']->accounts->get_type($user_id) === 'u') $user_ids[] = $user_id;
}
$owner_or = $this->db->expression($cal_table_def,array('cal_owner' => $user_ids)); $owner_or = $this->db->expression($cal_table_def,array('cal_owner' => $user_ids));
} }
} }
@ -662,7 +664,7 @@ class calendar_so
'cols' => $cols, 'cols' => $cols,
'where' => $where, 'where' => $where,
'app' => 'calendar', 'app' => 'calendar',
'append'=> $params['append'].' '.$group_by, 'append'=> $params['append'],
); );
if ($params['enum_recuring']) // dates table join only needed to enum recuring events if ($params['enum_recuring']) // dates table join only needed to enum recuring events
{ {
@ -910,7 +912,7 @@ class calendar_so
'filter'=> $filter, 'filter'=> $filter,
'query' => $query, 'query' => $query,
)); ));
foreach(self::$integration_data as $app => $data) foreach(self::$integration_data as $data)
{ {
if (is_array($data['selects'])) if (is_array($data['selects']))
{ {
@ -937,7 +939,7 @@ class calendar_so
* *
* @param array $app_cols required name => own name pairs * @param array $app_cols required name => own name pairs
* @param string|array $required array or comma separated column names or table.* * @param string|array $required array or comma separated column names or table.*
* @param string $required_app='calendar' * @param string $required_app ='calendar'
* @return string cols for union query to match ones supplied in $required * @return string cols for union query to match ones supplied in $required
*/ */
public static function union_cols(array $app_cols,$required,$required_app='calendar') public static function union_cols(array $app_cols,$required,$required_app='calendar')
@ -950,6 +952,7 @@ class calendar_so
$return_cols = array(); $return_cols = array();
foreach(is_array($required) ? $required : explode(',',$required) as $cols) foreach(is_array($required) ? $required : explode(',',$required) as $cols)
{ {
$matches = null;
if (substr($cols,-2) == '.*') if (substr($cols,-2) == '.*')
{ {
$cols = self::get_columns($required_app,substr($cols,0,-2)); $cols = self::get_columns($required_app,substr($cols,0,-2));
@ -1053,7 +1056,7 @@ ORDER BY cal_user_type, cal_usre_id
* @param array $event * @param array $event
* @param boolean &$set_recurrences on return: true if the recurrences need to be written, false otherwise * @param boolean &$set_recurrences on return: true if the recurrences need to be written, false otherwise
* @param int &$set_recurrences_start=0 on return: time from which on the recurrences should be rebuilt, default 0=all * @param int &$set_recurrences_start=0 on return: time from which on the recurrences should be rebuilt, default 0=all
* @param int $change_since=0 time from which on the repetitions should be changed, default 0=all * @param int $change_since =0 time from which on the repetitions should be changed, default 0=all
* @param int &$etag etag=null etag to check or null, on return new etag * @param int &$etag etag=null etag to check or null, on return new etag
* @return boolean|int false on error, 0 if etag does not match, cal_id otherwise * @return boolean|int false on error, 0 if etag does not match, cal_id otherwise
*/ */
@ -1413,18 +1416,18 @@ ORDER BY cal_user_type, cal_usre_id
/** /**
* Shift alarm on recurring events to next future recurrence * Shift alarm on recurring events to next future recurrence
* *
* @param array $event event with optional 'cal_' prefix in keys * @param array $_event event with optional 'cal_' prefix in keys
* @param array &$alarm * @param array &$alarm
* @return boolean true if alarm could be shifted, false if not * @return boolean true if alarm could be shifted, false if not
*/ */
public static function shift_alarm(array $event, array &$alarm) public static function shift_alarm(array $_event, array &$alarm)
{ {
if ($event['recur_type'] == MCAL_RECUR_NONE) if ($_event['recur_type'] == MCAL_RECUR_NONE)
{ {
return false; return false;
} }
$start = (int)time() + $alarm['offset']; $start = (int)time() + $alarm['offset'];
$event = egw_db::strip_array_keys($event, 'cal_'); $event = egw_db::strip_array_keys($_event, 'cal_');
$rrule = calendar_rrule::event2rrule($event, false); $rrule = calendar_rrule::event2rrule($event, false);
foreach ($rrule as $time) foreach ($rrule as $time)
{ {
@ -1443,9 +1446,9 @@ ORDER BY cal_user_type, cal_usre_id
* @param int $cal_id * @param int $cal_id
* @param int $start new starttime * @param int $start new starttime
* @param int $end new endtime * @param int $end new endtime
* @param int|boolean $change_since=0 false=new entry, > 0 time from which on the repetitions should be changed, default 0=all * @param int|boolean $change_since =0 false=new entry, > 0 time from which on the repetitions should be changed, default 0=all
* @param int $old_start=0 old starttime or (default) 0, to query it from the db * @param int $old_start =0 old starttime or (default) 0, to query it from the db
* @param int $old_end=0 old starttime or (default) 0 * @param int $old_end =0 old starttime or (default) 0
* @todo Recalculate recurrences, if timezone changes * @todo Recalculate recurrences, if timezone changes
* @return int|boolean number of moved recurrences or false on error * @return int|boolean number of moved recurrences or false on error
*/ */
@ -1536,8 +1539,8 @@ ORDER BY cal_user_type, cal_usre_id
* Combine status, quantity and role into one value * Combine status, quantity and role into one value
* *
* @param string $status * @param string $status
* @param int $quantity=1 * @param int $quantity =1
* @param string $role='REQ-PARTICIPANT' * @param string $role ='REQ-PARTICIPANT'
* @return string * @return string
*/ */
static function combine_status($status,$quantity=1,$role='REQ-PARTICIPANT') static function combine_status($status,$quantity=1,$role='REQ-PARTICIPANT')
@ -1561,6 +1564,7 @@ ORDER BY cal_user_type, cal_usre_id
$quantity = 1; $quantity = 1;
$role = 'REQ-PARTICIPANT'; $role = 'REQ-PARTICIPANT';
//error_log(__METHOD__.__LINE__.array2string($status)); //error_log(__METHOD__.__LINE__.array2string($status));
$matches = null;
if (is_string($status) && strlen($status) > 1 && preg_match('/^.([0-9]*)(.*)$/',$status,$matches)) if (is_string($status) && strlen($status) > 1 && preg_match('/^.([0-9]*)(.*)$/',$status,$matches))
{ {
if ((int)$matches[1] > 0) $quantity = (int)$matches[1]; if ((int)$matches[1] > 0) $quantity = (int)$matches[1];
@ -1581,9 +1585,9 @@ ORDER BY cal_user_type, cal_usre_id
* *
* @param int $cal_id * @param int $cal_id
* @param array $participants uid => status pairs * @param array $participants uid => status pairs
* @param int|boolean $change_since=0, false=new event, * @param int|boolean $change_since =0, false=new event,
* 0=all, > 0 time from which on the repetitions should be changed * 0=all, > 0 time from which on the repetitions should be changed
* @param boolean $add_only=false * @param boolean $add_only =false
* false = add AND delete participants if needed (full list of participants required in $participants) * false = add AND delete participants if needed (full list of participants required in $participants)
* true = only add participants if needed, no participant will be deleted (participants to check/add required in $participants) * true = only add participants if needed, no participant will be deleted (participants to check/add required in $participants)
* @return int|boolean number of updated recurrences or false on error * @return int|boolean number of updated recurrences or false on error
@ -1729,8 +1733,8 @@ ORDER BY cal_user_type, cal_usre_id
* @param char $user_type 'u' regular user, 'r' resource, 'c' contact * @param char $user_type 'u' regular user, 'r' resource, 'c' contact
* @param int $user_id * @param int $user_id
* @param int|char $status numeric status (defines) or 1-char code: 'R', 'U', 'T' or 'A' * @param int|char $status numeric status (defines) or 1-char code: 'R', 'U', 'T' or 'A'
* @param int $recur_date=0 date to change, or 0 = all since now * @param int $recur_date =0 date to change, or 0 = all since now
* @param string $role=null role to set if !is_null($role) * @param string $role =null role to set if !is_null($role)
* @return int number of changed recurrences * @return int number of changed recurrences
*/ */
function set_status($cal_id,$user_type,$user_id,$status,$recur_date=0,$role=null) function set_status($cal_id,$user_type,$user_id,$status,$recur_date=0,$role=null)
@ -1799,8 +1803,8 @@ ORDER BY cal_user_type, cal_usre_id
* @param int $cal_id * @param int $cal_id
* @param int $start * @param int $start
* @param int $end * @param int $end
* @param boolean $exception=null true or false to set recure_exception flag, null leave it unchanged (new are by default no exception)
* @param array $participants uid => status pairs * @param array $participants uid => status pairs
* @param boolean $exception =null true or false to set recure_exception flag, null leave it unchanged (new are by default no exception)
*/ */
function recurrence($cal_id,$start,$end,$participants,$exception=null) function recurrence($cal_id,$start,$end,$participants,$exception=null)
{ {
@ -1826,6 +1830,7 @@ ORDER BY cal_user_type, cal_usre_id
$type = ''; $type = '';
$id = null; $id = null;
self::split_user($uid,$type,$id); self::split_user($uid,$type,$id);
$quantity = $role = null;
self::split_status($status,$quantity,$role); self::split_status($status,$quantity,$role);
$this->db->insert($this->user_table,array( $this->db->insert($this->user_table,array(
'cal_status' => $status, 'cal_status' => $status,
@ -1926,7 +1931,7 @@ ORDER BY cal_user_type, cal_usre_id
* alarm-id is a string of 'cal:'.$cal_id.':'.$alarm_nr, it is used as the job-id too * alarm-id is a string of 'cal:'.$cal_id.':'.$alarm_nr, it is used as the job-id too
* *
* @param int|array $cal_id * @param int|array $cal_id
* @param boolean $update_cache=null true: re-read given $cal_id, false: delete given $cal_id * @param boolean $update_cache =null true: re-read given $cal_id, false: delete given $cal_id
* @return array of (cal_id => array of) alarms with alarm-id as key * @return array of (cal_id => array of) alarms with alarm-id as key
*/ */
function read_alarms($cal_id, $update_cache=null) function read_alarms($cal_id, $update_cache=null)
@ -1934,7 +1939,7 @@ ORDER BY cal_user_type, cal_usre_id
if (!isset(self::$alarm_cache) && is_array($cal_id)) if (!isset(self::$alarm_cache) && is_array($cal_id))
{ {
self::$alarm_cache = array(); self::$alarm_cache = array();
if ($jobs = $this->async->read('cal:%')) if (($jobs = $this->async->read('cal:%')))
{ {
foreach($jobs as $id => $job) foreach($jobs as $id => $job)
{ {
@ -1984,7 +1989,7 @@ ORDER BY cal_user_type, cal_usre_id
private function read_alarms_nocache($cal_id) private function read_alarms_nocache($cal_id)
{ {
if ($jobs = $this->async->read('cal:'.(int)$cal_id.':%')) if (($jobs = $this->async->read('cal:'.(int)$cal_id.':%')))
{ {
foreach($jobs as $id => $job) foreach($jobs as $id => $job)
{ {
@ -2011,9 +2016,9 @@ ORDER BY cal_user_type, cal_usre_id
{ {
return False; return False;
} }
list($id,$job) = each($jobs); list($alarm_id,$job) = each($jobs);
$alarm = $job['data']; // text, enabled $alarm = $job['data']; // text, enabled
$alarm['id'] = $id; $alarm['id'] = $alarm_id;
$alarm['time'] = $job['next']; $alarm['time'] = $job['next'];
//echo "<p>read_alarm('$id')="; print_r($alarm); echo "</p>\n"; //echo "<p>read_alarm('$id')="; print_r($alarm); echo "</p>\n";
@ -2025,7 +2030,7 @@ ORDER BY cal_user_type, cal_usre_id
* *
* @param int $cal_id Id of the calendar-entry * @param int $cal_id Id of the calendar-entry
* @param array $alarm array with fields: text, owner, enabled, .. * @param array $alarm array with fields: text, owner, enabled, ..
* @param boolean $update_modified=true call update modified, default true * @param boolean $update_modified =true call update modified, default true
* @return string id of the alarm * @return string id of the alarm
*/ */
function save_alarm($cal_id, $alarm, $update_modified=true) function save_alarm($cal_id, $alarm, $update_modified=true)
@ -2076,7 +2081,7 @@ ORDER BY cal_user_type, cal_usre_id
//error_log(__METHOD__."($cal_id) ".function_backtrace()); //error_log(__METHOD__."($cal_id) ".function_backtrace());
if (($alarms = $this->read_alarms($cal_id))) if (($alarms = $this->read_alarms($cal_id)))
{ {
foreach($alarms as $id => $alarm) foreach(array_keys($alarms) as $id)
{ {
$this->async->cancel_timer($id); $this->async->cancel_timer($id);
} }
@ -2113,9 +2118,9 @@ ORDER BY cal_user_type, cal_usre_id
* Delete account hook * Delete account hook
* *
* @param array|int $old_user integer old user or array with keys 'account_id' and 'new_owner' as the deleteaccount hook uses it * @param array|int $old_user integer old user or array with keys 'account_id' and 'new_owner' as the deleteaccount hook uses it
* @param int $new_user=null * @param int $new_user =null
*/ */
function deleteaccount($old_user, $newuser=null) function deleteaccount($old_user, $new_user=null)
{ {
if (is_array($old_user)) if (is_array($old_user))
{ {
@ -2179,9 +2184,9 @@ ORDER BY cal_user_type, cal_usre_id
* get stati of all recurrences of an event for a specific participant * get stati of all recurrences of an event for a specific participant
* *
* @param int $cal_id * @param int $cal_id
* @param int $uid=null participant uid; if == null return only the recur dates * @param int $uid =null participant uid; if == null return only the recur dates
* @param int $start=0 if != 0: startdate of the search/list (servertime) * @param int $start =0 if != 0: startdate of the search/list (servertime)
* @param int $end=0 if != 0: enddate of the search/list (servertime) * @param int $end =0 if != 0: enddate of the search/list (servertime)
* *
* @return array recur_date => status pairs (index 0 => main status) * @return array recur_date => status pairs (index 0 => main status)
*/ */
@ -2204,19 +2209,20 @@ ORDER BY cal_user_type, cal_usre_id
if (is_null($uid)) return $participant_status; if (is_null($uid)) return $participant_status;
$user_type = $user_id = null; $user_type = $user_id = null;
self::split_user($uid, $user_type, $user_id); self::split_user($uid, $user_type, $user_id);
$where = array(
$where2 = array(
'cal_id' => $cal_id, 'cal_id' => $cal_id,
'cal_user_type' => $user_type ? $user_type : 'u', 'cal_user_type' => $user_type ? $user_type : 'u',
'cal_user_id' => $user_id, 'cal_user_id' => $user_id,
); );
if ($start != 0 && $end == 0) $where[] = '(cal_recur_date = 0 OR cal_recur_date >= ' . (int)$start . ')'; if ($start != 0 && $end == 0) $where2[] = '(cal_recur_date = 0 OR cal_recur_date >= ' . (int)$start . ')';
if ($start == 0 && $end != 0) $where[] = '(cal_recur_date = 0 OR cal_recur_date <= ' . (int)$end . ')'; if ($start == 0 && $end != 0) $where2[] = '(cal_recur_date = 0 OR cal_recur_date <= ' . (int)$end . ')';
if ($start != 0 && $end != 0) if ($start != 0 && $end != 0)
{ {
$where[] = '(cal_recur_date = 0 OR (cal_recur_date >= ' . (int)$start . $where2[] = '(cal_recur_date = 0 OR (cal_recur_date >= ' . (int)$start .
' AND cal_recur_date <= ' . (int)$end . '))'; ' AND cal_recur_date <= ' . (int)$end . '))';
} }
foreach ($this->db->select($this->user_table,'cal_recur_date,cal_status,cal_quantity,cal_role',$where, foreach ($this->db->select($this->user_table,'cal_recur_date,cal_status,cal_quantity,cal_role',$where2,
__LINE__,__FILE__,false,'','calendar') as $row) __LINE__,__FILE__,false,'','calendar') as $row)
{ {
$status = self::combine_status($row['cal_status'],$row['cal_quantity'],$row['cal_role']); $status = self::combine_status($row['cal_status'],$row['cal_quantity'],$row['cal_role']);
@ -2229,7 +2235,7 @@ ORDER BY cal_user_type, cal_usre_id
* get all participants of an event * get all participants of an event
* *
* @param int $cal_id * @param int $cal_id
* @param int $recur_date=0 gives participants of this recurrence, default 0=all * @param int $recur_date =0 gives participants of this recurrence, default 0=all
* *
* @return array participants * @return array participants
*/ */
@ -2285,9 +2291,9 @@ ORDER BY cal_user_type, cal_usre_id
* *
* @param array $event Recurring Event. * @param array $event Recurring Event.
* @param string tz_id=null timezone for exports (null for event's timezone) * @param string tz_id=null timezone for exports (null for event's timezone)
* @param int $start=0 if != 0: startdate of the search/list (servertime) * @param int $start =0 if != 0: startdate of the search/list (servertime)
* @param int $end=0 if != 0: enddate of the search/list (servertime) * @param int $end =0 if != 0: enddate of the search/list (servertime)
* @param string $filter='all' string filter-name: all (not rejected), * @param string $filter ='all' string filter-name: all (not rejected),
* accepted, unknown, tentative, rejected, delegated * accepted, unknown, tentative, rejected, delegated
* rrule return array of remote exceptions in servertime * rrule return array of remote exceptions in servertime
* tz_rrule/tz_only, return (only by) timezone transition affected entries * tz_rrule/tz_only, return (only by) timezone transition affected entries
@ -2456,9 +2462,9 @@ ORDER BY cal_user_type, cal_usre_id
*/ */
function status_pseudo_exception($cal_id, $recur_date, $filter) function status_pseudo_exception($cal_id, $recur_date, $filter)
{ {
static $recurrence_zero; static $recurrence_zero=null;
static $cached_id; static $cached_id=null;
static $user; static $user=null;
if (!isset($cached_id) || $cached_id != $cal_id) if (!isset($cached_id) || $cached_id != $cal_id)
{ {
@ -2587,14 +2593,14 @@ ORDER BY cal_user_type, cal_usre_id
} }
$timezone = self::$tz_cache[$event['tzid']]; $timezone = self::$tz_cache[$event['tzid']];
} }
$start = new egw_time($event['start'],egw_time::$server_timezone); $start_time = new egw_time($event['start'],egw_time::$server_timezone);
$start->setTimezone($timezone); $start_time->setTimezone($timezone);
$end = new egw_time($event['end'],egw_time::$server_timezone); $end_time = new egw_time($event['end'],egw_time::$server_timezone);
$end->setTimezone($timezone); $end_time->setTimezone($timezone);
//error_log(__FILE__.'['.__LINE__.'] '.__METHOD__. //error_log(__FILE__.'['.__LINE__.'] '.__METHOD__.
// '(): ' . $start . '-' . $end); // '(): ' . $start . '-' . $end);
$start = egw_time::to($start,'array'); $start = egw_time::to($start_time,'array');
$end = egw_time::to($end,'array'); $end = egw_time::to($end_time,'array');
return !$start['hour'] && !$start['minute'] && $end['hour'] == 23 && $end['minute'] == 59; return !$start['hour'] && !$start['minute'] && $end['hour'] == 23 && $end['minute'] == 59;
@ -2629,9 +2635,9 @@ ORDER BY cal_user_type, cal_usre_id
* Updates the modification timestamp to force an etag, ctag and sync-token change * Updates the modification timestamp to force an etag, ctag and sync-token change
* *
* @param int $id event id * @param int $id event id
* @param int|boolean $update_master=false id of series master or true, to update series master too * @param int|boolean $update_master =false id of series master or true, to update series master too
* @param int $time=null new timestamp, default current (server-)time * @param int $time =null new timestamp, default current (server-)time
* @param int $modifier=null uid of the modifier, default current user * @param int $modifier =null uid of the modifier, default current user
*/ */
function updateModified($id, $update_master=false, $time=null, $modifier=null) function updateModified($id, $update_master=false, $time=null, $modifier=null)
{ {