Back

User Query - Multiple APIs

Code:

<?php
error_reporting(E_ERROR);
ini_set('display_errors', 1);


include_once __DIR__ . '/vendor/autoload.php';
include_once "templates/base.php";

echo pageHeader("User Query - Multiple APIs");

/*************************************************
 * Ensure you've downloaded your oauth credentials
 ************************************************/
if (!$oauth_credentials = getOAuthCredentialsFile()) {
    echo missingOAuth2CredentialsWarning();
    return;
}

/************************************************
 * The redirect URI is to the current page, e.g:
 * http://localhost:8080/multi-api.php
 ************************************************/
$redirect_uri = 'https://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];

$client = new Google\Client();
$client->setAuthConfig($oauth_credentials);
$client->setRedirectUri($redirect_uri);
$client->addScope("https://www.googleapis.com/auth/drive");
$client->addScope("https://www.googleapis.com/auth/contacts");
$client->addScope("https://www.googleapis.com/auth/user.phonenumbers.read");
$client->addScope("https://www.googleapis.com/auth/userinfo.profile");


// add "?logout" to the URL to remove a token from the session
if (isset($_REQUEST['logout'])) {
    unset($_SESSION['multi-api-token']);
}

/************************************************
 * If we have a code back from the OAuth 2.0 flow,
 * we need to exchange that with the
 * Google\Client::fetchAccessTokenWithAuthCode()
 * function. We store the resultant access token
 * bundle in the session, and redirect to ourself.
 ************************************************/
if (isset($_GET['code'])) {
    $token = $client->fetchAccessTokenWithAuthCode($_GET['code'], $_SESSION['code_verifier']);
    $client->setAccessToken($token);

    // store in the session also
    $_SESSION['multi-api-token'] = $token;

    // redirect back to the example
    header('Location: ' . filter_var($redirect_uri, FILTER_SANITIZE_URL));
}

// set the access token as part of the client
if (!empty($_SESSION['multi-api-token'])) {
    $client->setAccessToken($_SESSION['multi-api-token']);
    if ($client->isAccessTokenExpired()) {
        unset($_SESSION['multi-api-token']);
    }
} else {
    $_SESSION['code_verifier'] = $client->getOAuth2Service()->generateCodeVerifier();
    $authUrl = $client->createAuthUrl();
}

/************************************************
  We are going to create both YouTube and Drive
  services, and query both.
 ************************************************/
$yt_service = new Google\Service\YouTube($client);
$dr_service = new Google\Service\Drive($client);
$ctc_service = new Google_Service_PeopleService($client);

/************************************************
  If we're signed in, retrieve channels from YouTube
  and a list of files from Drive.
 ************************************************/
if ($client->getAccessToken()) {
    $_SESSION['multi-api-token'] = $client->getAccessToken();

    echo json_encode($client->getAccessToken() );

    $url = "https://people.googleapis.com/v1/people:searchContacts?pageSize=10&query=60389208330&readMask=phoneNumbers&sources=READ_SOURCE_TYPE_CONTACT&key=[YOUR_API_KEY] HTTP/1.1";


}
?>

<div class="box">
  <div class="request">
<?php if (isset($authUrl)) : ?>
  <a class="login" href="<?= $authUrl ?>">Connect Me!</a>
<?php else : ?>
  <h3>Results Of Drive List:</h3>
    <?php foreach ($dr_results as $item) : ?>
        <?= $item->name ?><br />
    <?php endforeach ?>
<?php endif ?>
  </div>
</div>

<?= pageFooter(__FILE__);