Я использую 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));
}
?>