Closed GoogleCodeExporter closed 9 years ago
I'm having a very similar issue, and I'm trying to use a Service Account to
interact with a Google Apps calendar.
Original comment by j...@boddiford.com
on 5 Sep 2013 at 6:11
Here is my code and the error it produces.
require_once '../assets/google-api-php-client/src/Google_Client.php';
require_once
'../assets/google-api-php-client/src/contrib/Google_CalendarService.php';
define('SERVICE_ACCOUNT_NAME', 'XXXXXXX@developer.gserviceaccount.com');
define('CLIENT_ID','XXXXXXX.apps.googleusercontent.com');
define('KEY_FILE', 'XXXXXXXXX2123e906b6340d2ccba173225c55-privatekey.p12');
define('CALENDAR_ID','USER@GOOGLEAPPSFORBUSINESSDOMAIN.com');
$client = new Google_Client();
$client->setApplicationName("My Application Name");
$client->setClientId(CLIENT_ID);
/* Note: make sure to call $client->setUseObjects(true) if you want to see
* objects returned instead of data (this example code uses objects)
*/
$client->setUseObjects(true);
/*session_start();
if (isset($_SESSION['token'])) {
$client->setAccessToken($_SESSION['token']);
}
*/
/* Load the key in PKCS 12 format - remember: this is the file you had to
* download when you created the Service account on the API console.
*/
$key = file_get_contents(KEY_FILE);
$client->setAssertionCredentials(new Google_AssertionCredentials(
SERVICE_ACCOUNT_NAME,
array('https://www.googleapis.com/auth/calendar'),
$key)
);
if (isset($_SESSION['token'])) {
$client->setAccessToken($_SESSION['token']);
}
/* ------------------------- We are now properly authenticated
------------------- */
$cal = new Google_CalendarService($client);
date_default_timezone_set('America/New_York');
$start = date(DATE_ATOM,strtotime('now'));
$end = date(DATE_ATOM,strtotime('+1 month'));
$params = array(
'singleEvents' => 'true',
'timeMax' => $end,
'timeMin' => $start,
'orderBy' => 'startTime');
$event_list = $cal->events->listEvents(CALENDAR_ID, $params);
$events = $event_list->getItems();
echo '<table border="1"><thead>';
echo '<th>ID</th><th>SAFE</th><th>Start</th><th>End</th></tr></thead>';
foreach ($events as $event) {
echo '<tr>';
echo '<td>'.$event->getId().'</td>';
echo '<td>'.$event->getSummary().'</td>';
echo '<td>'.$event->getStart()->getDateTime().'</td>';
echo '<td>'.$event->getEnd()->getDateTime().'</td>';
echo '</tr>';
}
echo '</table>';
ERROR PRODUCED:
Fatal error: Uncaught exception 'Google_ServiceException' with message 'Error
calling GET
https://www.googleapis.com/calendar/v3/calendars/USER@GOOGLEAPPSFORBUSINESSDOMAI
N.com/events?singleEvents=true&timeMax=2013-10-05T01%3A57%3A49-04%3A00&timeMin=2
013-09-05T01%3A57%3A49-04%3A00&orderBy=startTime&key=AIzaSyC0cnTbebaBQ9e92FcbMr2
YZt0x4Aqzxq4: (404) Not Found' in
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/io/Google_REST.php:66 Stack trace: #0
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/io/Google_REST.php(36):
Google_REST::decodeHttpResponse(Object(Google_HttpRequest)) #1
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/service/Google_ServiceResource.php(186):
Google_REST::execute(Object(Google_HttpRequest)) #2
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/contrib/Google_CalendarService.php(529):
Google_ServiceResource->__call('list', Array) #3
/Users/jboddiford/Production/LeaveRequest/websit in
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/io/Google_REST.php on line 66
Original comment by j...@boddiford.com
on 5 Sep 2013 at 6:14
Have you enable the Calendar API in the API console? And ensured that service
accounthas the proper scopes? It may be easier to ask the Calendar team
directly about this one - as on a PHP level the code looks OK.
Original comment by ianbar...@google.com
on 5 Sep 2013 at 12:20
Hi, Yes... I have verified the Calendar API is enabled in the console and I
have ensured the service account has proper access scope in Google Apps. I
would LOVE to contact the Calendar team directly... can you provide their
contact information?
I've been posting in Google Forums about this and have had no luck with a
response from anyone at Google.
Thanks so much!
Josh
Original comment by j...@boddiford.com
on 5 Sep 2013 at 12:37
Usually stack overflow is the best place to go. Couple of things to try:
Try sharing the calendar (via the UI) with the service account email address,
see if that helps.
Or
Try setting the sub param on the assertion credentials, so you get a token for
that user, e.g.
$cred = new Google_AssertionCredentials(
SERVICE_ACCOUNT_NAME,
array('https://www.googleapis.com/auth/calendar'),
$key);
$cred->sub = "user@appsforbusinessdomain.com"; // whatever this should be.
$client->setAssertionCredentials($cred);
and then try exchanging for a token, and seeing if you have any more joy that
way.
Original comment by ianbar...@google.com
on 5 Sep 2013 at 1:02
I was able to gain access to the calendar, and list the contents, by adding the
service account email address as a MANAGER of the calendar. So that at least
worked... BUT having to do that defeats the whole purpose of having the service
account as that would require each user to edit their calendar security
settings so my app could insert onto them... does that sound right?
I will try out the second suggestion you have here regarding $cred and let you
know.
Is there a specific area on Stack Exchange I should be submitting?
Thanks for the help!
Josh
Original comment by j...@boddiford.com
on 5 Sep 2013 at 1:11
OK,
So I tried the second suggestion you provided and I'm getting a different error
now. It's an "Access Denied" error which sounds like we're getting closer! :-)
Fatal error: Uncaught exception 'Google_AuthException' with message 'Error
refreshing the OAuth2 token, message: '{ "error" : "access_denied" }'' in
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/auth/Google_OAuth2.php:288 Stack trace: #0
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/auth/Google_OAuth2.php(265): Google_OAuth2->refreshTokenRequest(Array) #1
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/auth/Google_OAuth2.php(218): Google_OAuth2->refreshTokenWithAssertion() #2
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/service/Google_ServiceResource.php(167):
Google_OAuth2->sign(Object(Google_HttpRequest)) #3
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/contrib/Google_CalendarService.php(529):
Google_ServiceResource->__call('list', Array) #4
/Users/jboddiford/Production/LeaveRequest/website/test/calendar2.php(110):
Google_EventsServiceRe in
/Users/jboddiford/Production/LeaveRequest/website/assets/google-api-php-client/s
rc/auth/Google_OAuth2.php on line 288
Original comment by j...@boddiford.com
on 5 Sep 2013 at 1:26
Did You found the solutions?
Original comment by tarmo1...@gmail.com
on 9 Oct 2013 at 5:37
This issue tracker is now closing. Development on the Google PHP client library
moved to GitHub with the release of the 1.0.0-alpha, and now the 1.0 branch has
reached beta status there will be no further releases of the 0.6 branch of the
library.
Please take a look at the latest version on
https://github.com/google/google-api-php-client
For information on migrating, please take a look at this guide:
https://developers.google.com/api-client-library/php/guide/migration
For general library support please ask a question on StackOverflow:
http://stackoverflow.com/questions/tagged/google-api-php-client
If you are looking for support with a specific API, please contact the team
working with that API via StackOverflow or their preferred support mechanism.
If your issue still exists with the new version of the library, please raise a
bug in the GitHub issue tracker with a minimal code sample.
Thanks!
Original comment by ianbar...@google.com
on 22 Jan 2014 at 4:53
All that is printed out is an empty Array. I also tried to add an event to the
calendar to see if it was possible but all I end up with is an error that says:
Fatal error: Uncaught exception 'Google_ServiceException' with message 'Error
calling POST https://www.googleapis.com/calendar/v3/calendars/'email address
for google
calendar'/events?key='key'......................................lib/google-api-p
hp-client/src/io/Google_REST.php on line 66
Original comment by develo...@skyzon.com
on 13 Mar 2015 at 4:53
Original issue reported on code.google.com by
kenshine...@gmail.com
on 23 Aug 2013 at 10:45