| Conditions | 6 |
| Paths | 8 |
| Total Lines | 31 |
| Code Lines | 14 |
| Lines | 0 |
| Ratio | 0 % |
| Changes | 0 | ||
| 1 | <?php |
||
| 25 | public function oauthAuthenticate(HTTPRequest $request, $scopes = []) |
||
| 26 | { |
||
| 27 | $headers = $request->getHeaders(); |
||
| 28 | |||
| 29 | // must have a client |
||
| 30 | if (empty($headers['oauth_client_id'])) { |
||
| 31 | return false; |
||
| 32 | } |
||
| 33 | |||
| 34 | // if scopes passed, check request contains all the scopes |
||
| 35 | if (!empty($scopes)) { |
||
| 36 | $matchedScopes = []; |
||
| 37 | |||
| 38 | $requestScopes = !empty($headers['oauth_scopes']) ? |
||
| 39 | explode(',', $headers['oauth_scopes']) : |
||
| 40 | []; |
||
| 41 | |||
| 42 | // if request has no scopes then authentication failed |
||
| 43 | if (empty($requestScopes)) { |
||
| 44 | return false; |
||
| 45 | } |
||
| 46 | |||
| 47 | foreach ($scopes as $scope) { |
||
| 48 | $matchedScopes[] = in_array($scope, $requestScopes); |
||
| 49 | } |
||
| 50 | |||
| 51 | return (bool)min($matchedScopes); |
||
| 52 | } |
||
| 53 | |||
| 54 | return true; |
||
| 55 | } |
||
| 56 | } |