AutoRenewJwtToken::handle()   A
last analyzed

Complexity

Conditions 4
Paths 4

Size

Total Lines 17
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 4
eloc 7
nc 4
nop 2
dl 0
loc 17
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace Yeelight\Http\Controllers\Api\Middleware;
4
5
use Closure;
6
use Tymon\JWTAuth\Http\Middleware\BaseMiddleware;
7
8
/**
9
 * Class AutoRenewJwtToken
10
 *
11
 * @category Yeelight
12
 *
13
 * @package Yeelight\Http\Controllers\Api\Middleware
14
 *
15
 * @author Sheldon Lee <[email protected]>
16
 *
17
 * @license https://opensource.org/licenses/MIT MIT
18
 *
19
 * @link https://www.yeelight.com
20
 */
21
class AutoRenewJwtToken extends BaseMiddleware
22
{
23
    /**
24
     * Handle an incoming request.
25
     *
26
     * @param \Illuminate\Http\Request $request Request
27
     * @param \Closure $next Closure
28
     *
29
     * @return mixed
30
     */
31
    public function handle($request, Closure $next)
32
    {
33
        $response = $next($request);
34
35
        // verify only if token present
36
        if ($token = $this->auth->setRequest($request)->getToken()) {
37
            // valid for refresh
38
            if (is_jwt_token_valid_for_refresh($token)) {
39
                $newToken = refresh_jwt_token();
40
                if (!empty($newToken)) {
41
                    // send the refreshed token back to the client
42
                    $response->headers->set('Authorization', $newToken);
43
                }
44
            }
45
        }
46
47
        return $response;
48
    }
49
}
50