/var/www/hkosl.com/b2b2c/webadmin/libraies/google/auth/src/Middleware/AuthTokenMiddleware.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
<?php
/*
 * Copyright 2015 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.
 */

namespace Google\Auth\Middleware;

use 
Google\Auth\FetchAuthTokenInterface;
use 
Psr\Http\Message\RequestInterface;

/**
 * AuthTokenMiddleware is a Guzzle Middleware that adds an Authorization header
 * provided by an object implementing FetchAuthTokenInterface.
 *
 * The FetchAuthTokenInterface#fetchAuthToken is used to obtain a hash; one of
 * the values value in that hash is added as the authorization header.
 *
 * Requests will be accessed with the authorization header:
 *
 * 'authorization' 'Bearer <value of auth_token>'
 */
class AuthTokenMiddleware
{
    
/**
     * @var callback
     */
    
private $httpHandler;

    
/**
     * @var FetchAuthTokenInterface
     */
    
private $fetcher;

    
/**
     * @var callable
     */
    
private $tokenCallback;

    
/**
     * Creates a new AuthTokenMiddleware.
     *
     * @param FetchAuthTokenInterface $fetcher is used to fetch the auth token
     * @param callable $httpHandler (optional) callback which delivers psr7 request
     * @param callable $tokenCallback (optional) function to be called when a new token is fetched.
     */
    
public function __construct(
        
FetchAuthTokenInterface $fetcher,
        
callable $httpHandler null,
        
callable $tokenCallback null
    
) {
        
$this->fetcher $fetcher;
        
$this->httpHandler $httpHandler;
        
$this->tokenCallback $tokenCallback;
    }

    
/**
     * Updates the request with an Authorization header when auth is 'google_auth'.
     *
     *   use Google\Auth\Middleware\AuthTokenMiddleware;
     *   use Google\Auth\OAuth2;
     *   use GuzzleHttp\Client;
     *   use GuzzleHttp\HandlerStack;
     *
     *   $config = [..<oauth config param>.];
     *   $oauth2 = new OAuth2($config)
     *   $middleware = new AuthTokenMiddleware($oauth2);
     *   $stack = HandlerStack::create();
     *   $stack->push($middleware);
     *
     *   $client = new Client([
     *       'handler' => $stack,
     *       'base_uri' => 'https://www.googleapis.com/taskqueue/v1beta2/projects/',
     *       'auth' => 'google_auth' // authorize all requests
     *   ]);
     *
     *   $res = $client->get('myproject/taskqueues/myqueue');
     *
     * @param callable $handler
     *
     * @return \Closure
     */
    
public function __invoke(callable $handler)
    {
        return function (
RequestInterface $request, array $options) use ($handler) {
            
// Requests using "auth"="google_auth" will be authorized.
            
if (!isset($options['auth']) || $options['auth'] !== 'google_auth') {
                return 
$handler($request$options);
            }

            
$request $request->withHeader('authorization''Bearer ' $this->fetchToken());

            return 
$handler($request$options);
        };
    }

    
/**
     * Call fetcher to fetch the token.
     *
     * @return string
     */
    
private function fetchToken()
    {
        
$auth_tokens $this->fetcher->fetchAuthToken($this->httpHandler);

        if (
array_key_exists('access_token'$auth_tokens)) {
            
// notify the callback if applicable
            
if ($this->tokenCallback) {
                
call_user_func($this->tokenCallback$this->fetcher->getCacheKey(), $auth_tokens['access_token']);
            }

            return 
$auth_tokens['access_token'];
        }
    }
}