我有一个可与WordPress一起使用的日历插件,并且希望集成Google Calendar API以创建,读取,更新,删除Google Calendar Events。这是我遵循的过程。
我已经在不同的Calendar插件类中创建了一个函数,该函数是从Google Calendar API文档(https://developers.google.com/calendar/quickstart/php)中获得的:
function getClient() {
try{
$client = new Google_Client();
$client->setApplicationName('Google Calendar API');
$client->setScopes(Google_Service_Calendar::CALENDAR);
$client->setAuthConfig(AEC_PATH .'credentials.json');
$client->setAccessType('offline');
$client->setPrompt('select_account consent');
// Load previously authorized token from a file, if it exists.
// The file token.json stores the user's access and refresh tokens, and is
// created automatically when the authorization flow completes for the first
// time.
$tokenPath = 'token.json';
if (file_exists($tokenPath)) {
$accessToken = json_decode(file_get_contents($tokenPath), true);
$client->setAccessToken($accessToken);
} else {
print 'Access Token not generated!!';
}
// If there is no previous token or it's expired.
if ($client->isAccessTokenExpired()) {
// Refresh the token if possible, else fetch a new one.
if ($client->getRefreshToken()) {
$client->fetchAccessTokenWithRefreshToken($client->getRefreshToken());
} else {
// Request authorization from the user.
$authUrl = $client->createAuthUrl();
printf("Open the following link in your browser:\n%s\n", $authUrl);
print 'Enter verification code: ';
$authCode = trim(fgets(STDIN));
// Exchange authorization code for an access token.
$accessToken = $client->fetchAccessTokenWithAuthCode($authCode);
$client->setAccessToken($accessToken);
// Check to see if there was an error.
if (array_key_exists('error', $accessToken)) {
throw new Exception(join(', ', $accessToken));
}
}
// Save the token to a file.
if (!file_exists(dirname($tokenPath))) {
mkdir(dirname($tokenPath), 0700, true);
}
file_put_contents($tokenPath, json_encode($client->getAccessToken()));
}
return $client;
} catch(Exception $e) {
print_r($e->getMessage());
}
现在,我在构造函数中添加了一个动作挂钩来初始化此功能。
add_action('init', array($this, 'getClient'));
现在,我在另一个函数中调用此函数getClient()以在特定时间间隔进行调用。
try{
// Get the API client and construct the service object.
$client = $this->getClient();
$service = new Google_Service_Calendar($client);
$calendarId = '<Google_Calendar_ID>';
$event = new Google_Service_Calendar_Event(array(
'summary' => $input->title,
'location' => $input->address.''.$input->city.''.$input->state.''.$input->country.''.$input->zip,
'description' => $input->description,
'start' => array(
'dateTime' => '2019-09-22T09:00:00-07:00'
),
'end' => array(
'dateTime' => '2019-09-22T17:00:00-07:00'
),
'reminders' => array(
'useDefault' => FALSE,
'overrides' => array(
array('method' => 'email', 'minutes' => 24 * 60),
array('method' => 'popup', 'minutes' => 10),
),
),
));
$event = $service->events->insert($calendarId, $event);
echo "--Google Event Created-->";
print_r($event);
} catch(Exception $e) {
print_r($e->getMessage());
}
我收到授权错误,而不是我的Google日历创建了新事件。
{
"error": {
"errors": [
{
"domain": "global",
"reason": "insufficientPermissions",
"message": "Insufficient Permission: Request had insufficient authentication scopes."
}
],
"code": 403,
"message": "Insufficient Permission: Request had insufficient authentication scopes."
}
能否请您帮助我理解为什么会出现此错误以及如何解决该错误?
答案 0 :(得分:0)
删除您的token.pickle文件,然后运行脚本
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<div ng-app="myApp" ng-controller="myCtrl">
<div class="form-group entity" ng-repeat="item in list">
<div ng-click="addMapping($index)">{{ item.name }}</div>
<div class="form-group" ng-show="item.mappings.length > 0" ng-repeat="mapping in item.mappings">
<div class="">
<label for="{{$index}}_{{mapping.id}}">{{ mapping.name }}</label>
<input type="checkbox" id="{{$index}}_{{mapping.id}}" ng-model="mapping.selected"/>
</div>
</div>
</div>
<pre>{{list | json}}</pre>
</div>
更改为
SCOPES = ['https://www.googleapis.com/auth/calendar.readonly']
答案 1 :(得分:0)
此错误是由于凭据过期,而不是代码中的错误。为了解决这种情况,您将必须删除名为token.json
的文件并执行代码。系统将提示您使用新范围再次接受您的应用。如果仍然失败,建议您同时删除token.json
和credentials.json
;后者是因为被破坏了。
如果这不起作用,请检查您的范围写成与Authorizing requests with OAuth 2.0上显示的范围完全相同,然后重复该过程。