API Календаря Google - получать события - PullRequest
0 голосов
/ 13 мая 2018

Я использую PHP и MySQL, но, думаю, этот вопрос может быть задан практически всем.У меня есть веб-сайт, где люди могут зарегистрироваться / создать учетную запись и войти.У меня на сайте есть календарь для каждого пользователя.Я хочу реализовать API Календаря Google (oauth), чтобы они могли входить в свои учетные записи Google и синхронизировать свои события Календаря Google с календарем на моем сайте.

Но благодаря их документации я нигде не вижутам написано, как я могу сохранить учетную запись google для каждого человека на моем сайте, чтобы к ним подключался только их учетная запись google и чтобы в их календаре на моем сайте отображались только их события google calendar.

Например, если пользователь 2на моем сайте связывает свою учетную запись google (user2@gmail.com) через oauth, как мой сайт узнает в следующий раз, когда он хочет получать события из учетной записи google, чтобы получить его от user2@gmail.com, а не от учетной записи google другого пользователя, которая имеетВошел?Вот что я пытаюсь сказать:

user 2 = user2@gmail.com
user 5 = user5@gmail.com
user 8 = user8@gmail.com

, поэтому в следующий раз, когда пользователь выбирает события из API календаря Google, он получит его из своего аккаунта Google, а не аккаунта другого пользователя.

как мне это сделать?Должен ли я что-то сохранить в своей базе данных MySQL?

Вот полный рабочий код Google Calendar API v3:

link-google-account.php:

<?php
require_once __DIR__.'/vendor/autoload.php';

session_start();

$client = new Google_Client();
$client->setAuthConfig('client_secrets.json');
$client->addScope(Google_Service_Calendar::CALENDAR_READONLY);

if (isset($_SESSION['access_token']) && $_SESSION['access_token']) {
  $client->setAccessToken($_SESSION['access_token']);

  // Print the next 10 events on the user's calendar.
  $calendarId = 'primary';
  $optParams = array(
    'maxResults' => 10,
    'orderBy' => 'startTime',
    'singleEvents' => TRUE,
    'timeMin' => date('c'),
  );

  $service = new Google_Service_Calendar($client);
  $results = $service->events->listEvents($calendarId, $optParams);

  if (count($results->getItems()) == 0) {
    print "No upcoming events found.\n";
  } else {
    print "Upcoming events:\n";
    foreach ($results->getItems() as $event) {
      $start = $event->start->dateTime;
      if (empty($start)) {
        $start = $event->start->date;
      }
      printf("%s (%s)\n", $event->getSummary(), $start);
    }
  }

} else {
  $redirect_uri = 'http://' . $_SERVER['HTTP_HOST'] . '/oauth.php';
  header('Location: ' . filter_var($redirect_uri, FILTER_SANITIZE_URL));
}
?>

oauth.php:

<?php
require_once __DIR__.'/vendor/autoload.php';

session_start();

$client = new Google_Client();
$client->setAuthConfigFile('client_secrets.json');
$client->setRedirectUri('http://' . $_SERVER['HTTP_HOST'] . '/oauth.php');
$client->addScope(Google_Service_Calendar::CALENDAR_READONLY);

if (! isset($_GET['code'])) {
  $auth_url = $client->createAuthUrl();
  header('Location: ' . filter_var($auth_url, FILTER_SANITIZE_URL));
} else {
  $client->authenticate($_GET['code']);
  $_SESSION['access_token'] = $client->getAccessToken();
  $redirect_uri = 'http://' . $_SERVER['HTTP_HOST'] . '/';
  header('Location: ' . filter_var($redirect_uri, FILTER_SANITIZE_URL));
}
?>
...