我正在编写一个脚本,用于从Google日历中提取事件并将其放在网站上。目的是能够将我的雇主(大学图书馆)的营业时间放在我们的网站上。基本上,我们在Google日历中使用摘要中的营业时间创建活动。我的目标是以编程方式从日历中提取相关信息,并将其放入主页上的div标签中。
从Google修改基本PHP示例以检索必需信息并不困难。不幸的是,控制器代码停止检索新创建的事件。这不是权限问题,因为我是日历的所有者。直到昨天下午,我才能创建新事件,并将脚本打印到我的浏览器中。这是我的代码:
<?php
require __DIR__ . '/vendor/autoload.php';
define('APPLICATION_NAME', 'Library Hours Script');
define('CREDENTIALS_PATH', '~/path-to-credentials');
define('CLIENT_SECRET_PATH', __DIR__ . '/private key file');
// If modifying these scopes, delete your previously saved credentials
// at ~/.credentials/calendar-php-quickstart.json
define('SCOPES', implode(' ', array(
Google_Service_Calendar::CALENDAR_READONLY)
));
/**
* Returns an authorized API client.
* @return Google_Client the authorized client object
*/
$client_email = 'project-name@clean-mason-95113.iam.gserviceaccount.com';
$private_key = file_get_contents('/path-to-private-key');
$credentials = new Google_Auth_AssertionCredentials(
$client_email,
SCOPES,
$private_key
);
// Get the API client and construct the service object.
$client = new Google_Client();
$client->setAssertionCredentials($credentials);
if ($client->getAuth()->isAccessTokenExpired()) {
$client->getAuth()->refreshTokenWithAssertion();
}
$service = new Google_Service_Calendar($client);
// Get the calendar ID. The script currently uses the "Regular Hours" calendar.
$calendarId = 'dsulibraryinfo@gmail.com';
$optParams = array(
'maxResults' => 1,
'singleEvents' => TRUE,
'timeMin' => date('c'),
);
$results = $service->events->listEvents($calendarId, $optParams);
if (count($results->getItems()) == 0) {
print "<a href='http://www.deltastate.edu/academics/libraries/libraries-hours-of-operation/' target='_blank'>Click here for Library hours</a>.\n";
} else {
foreach ($results->getItems() as $event) {
$opHours = $event->getSummary();
$start = $event->start->dateTime;
if (empty($start)) {
$start = $event->start->date;
}
print($opHours . " " . $start . " " . date('c'));
}
}
基本上,上面的代码向Calendar API请求一个事件列表,其中最大结果数为1,按当前日期过滤。然后它将开始日期和摘要打印到屏幕。
API资源管理器返回与在Web服务器上运行脚本时相同的结果。它只显示前一段时间创建的未来事件。我昨天和今天为本周晚些时候创建的活动不会被退回。这个问题似乎并不常见,但没有人报告过它已找到解决方案。任何帮助将不胜感激。
答案 0 :(得分:0)
我认为在设置maxResult
参数时问题与pagination相关。
根据该文件。您可以通过设置maxResults
字段来控制服务器在列表请求响应中返回的最大资源数。此外,对于某些集合(例如事件),服务器永远不会超过的检索条目数存在硬限制。如果事件总数超过此最大值,则服务器返回一页结果。
结果中的非空nextPageToken
字段可以检测到不完整的结果。要检索下一页,请执行与之前完全相同的请求,并在上一页附加pageToken
字段,其值为nextPageToken
。在以下页面中提供了新的nextPageToken
,直到检索到所有结果。
查看SO question如何使用pageToken.
答案 1 :(得分:0)
想出来!这个问题与分页有关,但不是预期的方式。我对Google的示例脚本所做的一项更改是从optParams数组中删除'orderBy',以为只返回一个事件。事实上,剧本就这样做了。但是,结果页面仍按特定顺序给出,可能是创建日期,最高结果是打印出来。因此,最近添加到日历中的事件被隐藏在事件列表的底部,而不是打印到屏幕上。我重新添加了密钥,因此数组如下所示:
$optParams = array(
'maxResults' => 5,
'orderBy' => 'startTime',
'singleEvents' => TRUE,
'timeMin' => date('c'),
);
现在脚本返回我想要的日期。返回多个结果时,它们现在按开始日期排序。感谢您指点我正确的方向。