我正在调试一个会议室预订日历,该日历是由不再与我合作的人整理的。这是一场噩梦,因为它有很多问题,但我无法弄清楚究竟是什么导致了最后一个错误。日历会检查房间是否已经在特定时间被预订,并且他们没有显示在正确的时间预订的问题,但是如果有人在房间空出后一小时或更短的时间内尝试预订同一个房间移入或移出 DST,它显示房间仍被预订。例子:
- 用户看到房间已为 11 月 29 日上午 9 点至 10 点预订。
- 然后,用户尝试在 11 月 29 日上午 10:30 至下午 12:00 预订房间。
- 日历取消第二个请求并通知用户房间已被预订。
应该注意的是,在转换为 DST(11 月 4 日)之前的任何时候都不会发生这种情况。这是确定房间是否可用的函数:
function calCheck($starttime, $endtime, $cal_name, $cat_id, $myDB, $myHost, $myUser, $myPass) {
$timezone = 'America/Denver';
date_default_timezone_set ($timezone);
$dset = new DateTime($odate, new DateTimeZone($timezone));
$dset2 = $dset->getOffset();
//$starttime = $starttime + 1;
//$endtime = $endtime - 1;
$starttime = $starttime - $dset2 + 1;
$endtime = $endtime - $dset2 - 1;
$starttime = $starttime;
$endtime = $endtime;
//echo $starttime .'</br>'. $endtime . '</br>';
$db = new myDB($myDB, $myHost, $myUser, $myPass);
$db->myDB_Connect();
//echo 'calcheck</br>';
$ck_query = 'SELECT * FROM vw_cal_chk
WHERE (stime < '. $starttime . ' AND etime > ' . $starttime . ' ) and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"
OR (stime < ' . $endtime . ' AND etime > ' . $endtime . ') and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"
OR (stime >= '. $starttime . ' AND etime < ' . $endtime .') and Calendar = "' . $cal_name . '" and cat_id = "' .$cat_id . '"';
$ck_result = $db->myQuery($ck_query);
$num = mysql_num_rows($ck_result);
//echo $ck_query . '</br>' . $num;
if ($num >> 0){
$avail = 1;
} else {
$avail = 0;
}
return $avail;
}
到目前为止,我所有的时间戳都是 UTC 格式,我注意到该$odate
变量实际上从未在任何地方实例化,但我无法确定要传递什么值才能使偏移正常工作。如果我能找出它想要什么样的约会,我应该能够解决剩下的问题。