Google Calendar API不会返回新创建的事件

时间:2016-03-30 19:07:45

标签: php google-calendar-api gdata-api

我正在编写一个脚本,用于从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服务器上运行脚本时相同的结果。它只显示前一段时间创建的未来事件。我昨天和今天为本周晚些时候创建的活动不会被退回。这个问题似乎并不常见,但没有人报告过它已找到解决方案。任何帮助将不胜感激。

2 个答案:

答案 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'),
);

现在脚本返回我想要的日期。返回多个结果时,它们现在按开始日期排序。感谢您指点我正确的方向。