@@ 199-263 (lines=65) @@ | ||
196 | * |
|
197 | * @throws AuthRequestException on a known request error |
|
198 | */ |
|
199 | public function requestAccessToken($code) |
|
200 | { |
|
201 | $client = $this->getClient(); |
|
202 | ||
203 | try { |
|
204 | $response = $client->request( |
|
205 | 'POST', |
|
206 | '/token', |
|
207 | [ |
|
208 | 'auth' => [ |
|
209 | $this->clientId, |
|
210 | $this->clientSecret |
|
211 | ], |
|
212 | 'form_params' => [ |
|
213 | 'grant_type' => 'authorization_code', |
|
214 | 'code' => $code, |
|
215 | 'client_id' => $this->clientId, |
|
216 | 'client_secret' => $this->clientSecret |
|
217 | ] |
|
218 | ] |
|
219 | ); |
|
220 | } catch (ClientException $ex) { |
|
221 | $result = $this->getDecodedBody($ex->getResponse()->getBody()); |
|
222 | ||
223 | if (is_array($result) && isset($result['error'])) { |
|
224 | // handle a service error message |
|
225 | $message = 'Service responsed with error code "' . $result['error'] . '".'; |
|
226 | ||
227 | if (isset($result['error_description']) && $result['error_description']) { |
|
228 | $message .= ' Description "' . $result['error_description'] . '".'; |
|
229 | } |
|
230 | throw new AuthRequestException($message, 0, $ex); |
|
231 | } |
|
232 | ||
233 | // unknown error. not parsed error |
|
234 | throw $ex; |
|
235 | } |
|
236 | ||
237 | try { |
|
238 | $result = $this->getDecodedBody($response->getBody()); |
|
239 | } catch (\RuntimeException $ex) { |
|
240 | throw new AuthResponseException('Server response can\'t be parsed', 0, $ex); |
|
241 | } |
|
242 | ||
243 | if (!is_array($result)) { |
|
244 | throw new AuthResponseException('Server response has unknown format'); |
|
245 | } |
|
246 | ||
247 | if (!isset($result['access_token'])) { |
|
248 | throw new AuthResponseException('Server response doesn\'t contain access token'); |
|
249 | } |
|
250 | ||
251 | $this->setAccessToken($result['access_token']); |
|
252 | ||
253 | $this->setRefreshToken($result['refresh_token']); |
|
254 | ||
255 | $lifetimeInSeconds = $result['expires_in']; |
|
256 | ||
257 | $expireDateTime = new \DateTime(); |
|
258 | $expireDateTime->add(new \DateInterval('PT' . $lifetimeInSeconds . 'S')); |
|
259 | ||
260 | $this->setExpiresIn($expireDateTime); |
|
261 | ||
262 | return $this; |
|
263 | } |
|
264 | ||
265 | ||
266 | ||
@@ 270-334 (lines=65) @@ | ||
267 | ||
268 | ||
269 | ||
270 | public function refreshAccessToken(string $refreshToken) |
|
271 | { |
|
272 | $client = $this->getClient(); |
|
273 | ||
274 | try { |
|
275 | $response = $client->request( |
|
276 | 'POST', |
|
277 | '/token', |
|
278 | [ |
|
279 | 'auth' => [ |
|
280 | $this->clientId, |
|
281 | $this->clientSecret |
|
282 | ], |
|
283 | 'form_params' => [ |
|
284 | 'refresh_token' => $refreshToken, |
|
285 | 'grant_type' => 'refresh_token', |
|
286 | 'client_id' => $this->clientId, |
|
287 | 'client_secret' => $this->clientSecret |
|
288 | ] |
|
289 | ] |
|
290 | ); |
|
291 | } catch (ClientException $ex) { |
|
292 | $result = $this->getDecodedBody($ex->getResponse()->getBody()); |
|
293 | ||
294 | if (is_array($result) && isset($result['error'])) { |
|
295 | // handle a service error message |
|
296 | $message = 'Service responsed with error code "' . $result['error'] . '".'; |
|
297 | ||
298 | if (isset($result['error_description']) && $result['error_description']) { |
|
299 | $message .= ' Description "' . $result['error_description'] . '".'; |
|
300 | } |
|
301 | throw new AuthRequestException($message, 0, $ex); |
|
302 | } |
|
303 | ||
304 | // unknown error. not parsed error |
|
305 | throw $ex; |
|
306 | } |
|
307 | ||
308 | try { |
|
309 | $result = $this->getDecodedBody($response->getBody()); |
|
310 | } catch (\RuntimeException $ex) { |
|
311 | throw new AuthResponseException('Server response can\'t be parsed', 0, $ex); |
|
312 | } |
|
313 | ||
314 | if (!is_array($result)) { |
|
315 | throw new AuthResponseException('Server response has unknown format'); |
|
316 | } |
|
317 | ||
318 | if (!isset($result['access_token'])) { |
|
319 | throw new AuthResponseException('Server response doesn\'t contain access token'); |
|
320 | } |
|
321 | ||
322 | $this->setAccessToken($result['access_token']); |
|
323 | ||
324 | $this->setRefreshToken($result['refresh_token']); |
|
325 | ||
326 | $lifetimeInSeconds = $result['expires_in']; |
|
327 | ||
328 | $expireDateTime = new \DateTime(); |
|
329 | $expireDateTime->add(new \DateInterval('PT' . $lifetimeInSeconds . 'S')); |
|
330 | ||
331 | $this->setExpiresIn($expireDateTime); |
|
332 | ||
333 | return $this; |
|
334 | } |
|
335 | ||
336 | } |
|
337 |