Created
September 29, 2022 15:30
-
-
Save MyFRA/c272cdb5cb0b5133523c5cad0f3a8aed to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* Copyright 2018 Google Inc. | |
* | |
* Licensed under the Apache License, Version 2.0 (the "License"); | |
* you may not use this file except in compliance with the License. | |
* You may obtain a copy of the License at | |
* | |
* http://www.apache.org/licenses/LICENSE-2.0 | |
* | |
* Unless required by applicable law or agreed to in writing, software | |
* distributed under the License is distributed on an "AS IS" BASIS, | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
* See the License for the specific language governing permissions and | |
* limitations under the License. | |
*/ | |
// [START drive_quickstart] | |
require __DIR__ . '/vendor/autoload.php'; | |
if (php_sapi_name() != 'cli') { | |
throw new Exception('This application must be run on the command line.'); | |
} | |
use Google\Client; | |
use Google\Service\Drive; | |
/** | |
* Returns an authorized API client. | |
* @return Client the authorized client object | |
*/ | |
function getClient() | |
{ | |
$client = new Client(); | |
$client->setApplicationName('Google Drive API PHP Quickstart'); | |
$client->setScopes('https://www.googleapis.com/auth/drive.metadata.readonly'); | |
$client->setAuthConfig('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); | |
} | |
// If there is no previous token or it's expired. | |
try{ | |
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())); | |
} | |
} | |
catch(Exception $e) { | |
// TODO(developer) - handle error appropriately | |
echo 'Some error occured: '.$e->getMessage(); | |
} | |
return $client; | |
} | |
// Get the API client and construct the service object. | |
$client = getClient(); | |
$service = new Drive($client); | |
// Print the names and IDs for up to 10 files. | |
$optParams = array( | |
'pageSize' => 10, | |
'fields' => 'nextPageToken, files(id, name)' | |
); | |
$results = $service->files->listFiles($optParams); | |
if (count($results->getFiles()) == 0) { | |
print "No files found.\n"; | |
} else { | |
print "Files:\n"; | |
foreach ($results->getFiles() as $file) { | |
printf("%s (%s)\n", $file->getName(), $file->getId()); | |
} | |
} | |
// [END drive_quickstart] |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Note: disitu ndak bisa diisi localhost atau subdomain, jadi langsung TLD nya, (bukan subdomain). App name diisi dengan id dari project yang dibuat tadi, untuk nyari ID nya, bisa lah dicari. Hehe
composer require google/apiclient