mirror of
				https://bitbucket.org/jsuto/piler.git
				synced 2025-10-26 05:02:28 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			372 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			372 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /*
 | |
|  * Copyright 2010 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.
 | |
|  */
 | |
| 
 | |
| // Check for the required json and curl extensions, the Google API PHP Client won't function without them.
 | |
| if (! function_exists('curl_init')) {
 | |
|   throw new Exception('Google PHP API Client requires the CURL PHP extension');
 | |
| }
 | |
| 
 | |
| if (! function_exists('json_decode')) {
 | |
|   throw new Exception('Google PHP API Client requires the JSON PHP extension');
 | |
| }
 | |
| 
 | |
| if (! function_exists('http_build_query')) {
 | |
|   throw new Exception('Google PHP API Client requires http_build_query()');
 | |
| }
 | |
| 
 | |
| if (! ini_get('date.timezone') && function_exists('date_default_timezone_set')) {
 | |
|   date_default_timezone_set('UTC');
 | |
| }
 | |
| 
 | |
| // hack around with the include paths a bit so the library 'just works'
 | |
| $cwd = dirname(__FILE__);
 | |
| set_include_path("$cwd" . PATH_SEPARATOR . get_include_path());
 | |
| 
 | |
| require_once "config.php";
 | |
| // If a local configuration file is found, merge it's values with the default configuration
 | |
| if (file_exists($cwd . '/local_config.php')) {
 | |
|   $defaultConfig = $apiConfig;
 | |
|   require_once ($cwd . '/local_config.php');
 | |
|   $apiConfig = array_merge($defaultConfig, $apiConfig);
 | |
| }
 | |
| 
 | |
| // Include the top level classes, they each include their own dependencies
 | |
| require_once 'service/apiModel.php';
 | |
| require_once 'service/apiService.php';
 | |
| require_once 'service/apiServiceRequest.php';
 | |
| require_once 'auth/apiAuth.php';
 | |
| require_once 'cache/apiCache.php';
 | |
| require_once 'io/apiIO.php';
 | |
| require_once('service/apiMediaFileUpload.php');
 | |
| 
 | |
| /**
 | |
|  * The Google API Client
 | |
|  * http://code.google.com/p/google-api-php-client/
 | |
|  *
 | |
|  * @author Chris Chabot <chabotc@google.com>
 | |
|  * @author Chirag Shah <chirags@google.com>
 | |
|  */
 | |
| class apiClient {
 | |
|   // the version of the discovery mechanism this class is meant to work with
 | |
|   const discoveryVersion = 'v0.3';
 | |
| 
 | |
|   /**
 | |
|    * @static
 | |
|    * @var apiAuth $auth
 | |
|    */
 | |
|   static $auth;
 | |
| 
 | |
|   /** @var apiIo $io */
 | |
|   static $io;
 | |
| 
 | |
|   /** @var apiCache $cache */
 | |
|   static $cache;
 | |
| 
 | |
|   /** @var array $scopes */
 | |
|   protected $scopes = array();
 | |
| 
 | |
|   /** @var bool $useObjects */
 | |
|   protected $useObjects = false;
 | |
| 
 | |
|   // definitions of services that are discovered.
 | |
|   protected $services = array();
 | |
| 
 | |
|   // Used to track authenticated state, can't discover services after doing authenticate()
 | |
|   private $authenticated = false;
 | |
| 
 | |
|   private $defaultService = array(
 | |
|       'authorization_token_url' => 'https://www.google.com/accounts/OAuthAuthorizeToken',
 | |
|       'request_token_url' => 'https://www.google.com/accounts/OAuthGetRequestToken',
 | |
|       'access_token_url' => 'https://www.google.com/accounts/OAuthGetAccessToken');
 | |
| 
 | |
|   public function __construct($config = array()) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig = array_merge($apiConfig, $config);
 | |
|     self::$cache = new $apiConfig['cacheClass']();
 | |
|     self::$auth = new $apiConfig['authClass']();
 | |
|     self::$io = new $apiConfig['ioClass']();
 | |
|   }
 | |
| 
 | |
|   public function discover($service, $version = 'v1') {
 | |
|     $this->addService($service, $version);
 | |
|     $this->$service = $this->discoverService($service, $this->services[$service]['discoveryURI']);
 | |
|     return $this->$service;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Add a service
 | |
|    */
 | |
|   public function addService($service, $version) {
 | |
|     global $apiConfig;
 | |
|     if ($this->authenticated) {
 | |
|       // Adding services after being authenticated, since the oauth scope is already set (so you wouldn't have access to that data)
 | |
|       throw new apiException('Cant add services after having authenticated');
 | |
|     }
 | |
|     $this->services[$service] = $this->defaultService;
 | |
|     if (isset($apiConfig['services'][$service])) {
 | |
|       // Merge the service descriptor with the default values
 | |
|       $this->services[$service] = array_merge($this->services[$service], $apiConfig['services'][$service]);
 | |
|     }
 | |
|     $this->services[$service]['discoveryURI'] = $apiConfig['basePath'] . '/discovery/' . self::discoveryVersion . '/describe/' . urlencode($service) . '/' . urlencode($version);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the type of Auth class the client should use.
 | |
|    * @param string $authClassName
 | |
|    */
 | |
|   public function setAuthClass($authClassName) {
 | |
|     self::$auth = new $authClassName();
 | |
|   }
 | |
| 
 | |
|   public function authenticate() {
 | |
|     $service = $this->prepareService();
 | |
|     $this->authenticated = true;
 | |
|     return self::$auth->authenticate($service);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Construct the OAuth 2.0 authorization request URI.
 | |
|    * @return string 
 | |
|    */
 | |
|   public function createAuthUrl() {
 | |
|     $service = $this->prepareService();
 | |
|     return self::$auth->createAuthUrl($service['scope']);
 | |
|   }
 | |
| 
 | |
|   private function prepareService() {
 | |
|     $service = $this->defaultService;
 | |
|     $scopes = array();
 | |
|     if ($this->scopes) {
 | |
|       $scopes = $this->scopes;
 | |
|     } else {
 | |
|       foreach ($this->services as $key => $val) {
 | |
|         if (isset($val['scope'])) {
 | |
|           if (is_array($val['scope'])) {
 | |
|             $scopes = array_merge($val['scope'], $scopes);
 | |
|           } else {
 | |
|             $scopes[] = $val['scope'];
 | |
|           }
 | |
|         } else {
 | |
|           $scopes[] = 'https://www.googleapis.com/auth/' . $key;
 | |
|         }
 | |
|         unset($val['discoveryURI']);
 | |
|         unset($val['scope']);
 | |
|         $service = array_merge($service, $val);
 | |
|       }
 | |
|     }
 | |
|     $service['scope'] = implode(' ', $scopes);
 | |
|     return $service;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the OAuth 2.0 access token using the string that resulted from calling authenticate()
 | |
|    * or apiClient#getAccessToken().
 | |
|    * @param string $accessToken JSON encoded string containing in the following format:
 | |
|    * {"access_token":"TOKEN", "refresh_token":"TOKEN", "token_type":"Bearer",
 | |
|    *  "expires_in":3600, "id_token":"TOKEN", "created":1320790426}
 | |
|    */
 | |
|   public function setAccessToken($accessToken) {
 | |
|     if ($accessToken == null || 'null' == $accessToken) {
 | |
|       $accessToken = null;
 | |
|     }
 | |
|     self::$auth->setAccessToken($accessToken);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Get the OAuth 2.0 access token.
 | |
|    * @return string $accessToken JSON encoded string in the following format:
 | |
|    * {"access_token":"TOKEN", "refresh_token":"TOKEN", "token_type":"Bearer",
 | |
|    *  "expires_in":3600,"id_token":"TOKEN", "created":1320790426}
 | |
|    */
 | |
|   public function getAccessToken() {
 | |
|     $token = self::$auth->getAccessToken();
 | |
|     return (null == $token || 'null' == $token) ? null : $token;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the developer key to use, these are obtained through the API Console.
 | |
|    * @see http://code.google.com/apis/console-help/#generatingdevkeys
 | |
|    * @param string $developerKey
 | |
|    */
 | |
|   public function setDeveloperKey($developerKey) {
 | |
|     self::$auth->setDeveloperKey($developerKey);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set OAuth 2.0 "state" parameter to achieve per-request customization.
 | |
|    * @see http://tools.ietf.org/html/draft-ietf-oauth-v2-22#section-3.1.2.2
 | |
|    * @param string $state
 | |
|    */
 | |
|   public function setState($state) {
 | |
|     self::$auth->setState($state);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @param string $accessType Possible values for access_type include:
 | |
|    *  {@code "offline"} to request offline access from the user. (This is the default value)
 | |
|    *  {@code "online"} to request online access from the user.
 | |
|    */
 | |
|   public function setAccessType($accessType) {
 | |
|     self::$auth->setAccessType($accessType);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @param string $approvalPrompt Possible values for approval_prompt include:
 | |
|    *  {@code "force"} to force the approval UI to appear. (This is the default value)
 | |
|    *  {@code "auto"} to request auto-approval when possible.
 | |
|    */
 | |
|   public function setApprovalPrompt($approvalPrompt) {
 | |
|     self::$auth->setApprovalPrompt($approvalPrompt);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the application name, this is included in the User-Agent HTTP header.
 | |
|    * @param string $applicationName
 | |
|    */
 | |
|   public function setApplicationName($applicationName) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig['application_name'] = $applicationName;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the OAuth 2.0 Client ID.
 | |
|    * @param string $clientId
 | |
|    */
 | |
|   public function setClientId($clientId) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig['oauth2_client_id'] = $clientId;
 | |
|     self::$auth->clientId = $clientId;
 | |
|   }
 | |
|   
 | |
|   /**
 | |
|    * Set the OAuth 2.0 Client Secret.
 | |
|    * @param string $clientSecret
 | |
|    */
 | |
|   public function setClientSecret($clientSecret) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig['oauth2_client_secret'] = $clientSecret;
 | |
|     self::$auth->clientSecret = $clientSecret;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Set the OAuth 2.0 Redirect URI.
 | |
|    * @param string $redirectUri
 | |
|    */
 | |
|   public function setRedirectUri($redirectUri) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig['oauth2_redirect_uri'] = $redirectUri;
 | |
|     self::$auth->redirectUri = $redirectUri;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Fetches a fresh OAuth 2.0 access token with the given refresh token.
 | |
|    * @param string $refreshToken
 | |
|    * @return void
 | |
|    */
 | |
|   public function refreshToken($refreshToken) {
 | |
|     self::$auth->refreshToken($refreshToken);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Revoke an OAuth2 access token or refresh token. This method will revoke the current access
 | |
|    * token, if a token isn't provided.
 | |
|    * @throws apiAuthException
 | |
|    * @param string|null $token The token (access token or a refresh token) that should be revoked.
 | |
|    * @return boolean Returns True if the revocation was successful, otherwise False.
 | |
|    */
 | |
|   public function revokeToken($token = null) {
 | |
|     self::$auth->revokeToken($token);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Verify an id_token. This method will verify the current id_token, if one
 | |
|    * isn't provided.
 | |
|    * @throws apiAuthException
 | |
|    * @param string|null $token The token (id_token) that should be verified.
 | |
|    * @return apiLoginTicket Returns an apiLoginTicket if the verification was
 | |
|    * successful.
 | |
|    */
 | |
|   public function verifyIdToken($token = null) {
 | |
|     return self::$auth->verifyIdToken($token);
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * This function allows you to overrule the automatically generated scopes,
 | |
|    * so that you can ask for more or less permission in the auth flow
 | |
|    * Set this before you call authenticate() though!
 | |
|    * @param array $scopes, ie: array('https://www.googleapis.com/auth/plus', 'https://www.googleapis.com/auth/moderator')
 | |
|    */
 | |
|   public function setScopes($scopes) {
 | |
|     $this->scopes = is_string($scopes) ? explode(" ", $scopes) : $scopes;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * Declare if objects should be returned by the api service classes.
 | |
|    *
 | |
|    * @param boolean $useObjects True if objects should be returned by the service classes.
 | |
|    * False if associative arrays should be returned (default behavior).
 | |
|    */
 | |
|   public function setUseObjects($useObjects) {
 | |
|     global $apiConfig;
 | |
|     $apiConfig['use_objects'] = $useObjects;
 | |
|   }
 | |
| 
 | |
|   private function discoverService($serviceName, $serviceURI) {
 | |
|     $request = self::$io->makeRequest(new apiHttpRequest($serviceURI));
 | |
|     if ($request->getResponseHttpCode() != 200) {
 | |
|       throw new apiException("Could not fetch discovery document for $serviceName, code: "
 | |
|             . $request->getResponseHttpCode() . ", response: " . $request->getResponseBody());
 | |
|     }
 | |
|     $discoveryResponse = $request->getResponseBody();
 | |
|     $discoveryDocument = json_decode($discoveryResponse, true);
 | |
|     if ($discoveryDocument == NULL) {
 | |
|       throw new apiException("Invalid json returned for $serviceName");
 | |
|     }
 | |
|     return new apiService($serviceName, $discoveryDocument, apiClient::getIo());
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @static
 | |
|    * @return apiAuth the implementation of apiAuth.
 | |
|    */
 | |
|   public static function getAuth() {
 | |
|     return apiClient::$auth;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @static
 | |
|    * @return apiIo the implementation of apiIo.
 | |
|    */
 | |
|   public static function getIo() {
 | |
|     return apiClient::$io;
 | |
|   }
 | |
| 
 | |
|   /**
 | |
|    * @return apiCache the implementation of apiCache.
 | |
|    */
 | |
|   public function getCache() {
 | |
|     return apiClient::$cache;
 | |
|   }
 | |
| }
 | |
| 
 | |
| // Exceptions that the Google PHP API Library can throw
 | |
| class apiException extends Exception {}
 | |
| class apiAuthException extends apiException {}
 | |
| class apiCacheException extends apiException {}
 | |
| class apiIOException extends apiException {}
 | |
| class apiServiceException extends apiException {}
 |