HummingBirdAnimeClient/src/API/ParallelAPIRequest.php

111 lines
2.2 KiB
PHP
Raw Normal View History

2017-02-17 08:25:19 -05:00
<?php declare(strict_types=1);
/**
* Hummingbird Anime List Client
*
2018-08-22 13:48:27 -04:00
* An API client for Kitsu to manage anime and manga watch lists
2017-02-17 08:25:19 -05:00
*
2019-12-03 15:17:25 -05:00
* PHP version 7.2
2017-02-17 08:25:19 -05:00
*
* @package HummingbirdAnimeClient
* @author Timothy J. Warren <tim@timshomepage.net>
2018-01-15 14:43:15 -05:00
* @copyright 2015 - 2018 Timothy J. Warren
2017-02-17 08:25:19 -05:00
* @license http://www.opensource.org/licenses/mit-license.html MIT License
2018-10-01 11:35:51 -04:00
* @version 4.1
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
2017-02-17 08:25:19 -05:00
*/
namespace Aviat\AnimeClient\API;
2019-12-06 09:15:49 -05:00
use Amp\Artax\Request;
use function Amp\call;
use function Amp\Promise\{all, wait};
use function Aviat\AnimeClient\getApiClient;
2018-11-29 11:00:50 -05:00
2017-02-17 08:25:19 -05:00
/**
* Class to simplify making and validating simultaneous requests
*/
final class ParallelAPIRequest {
2017-02-17 08:25:19 -05:00
/**
* Set of requests to make in parallel
*
* @var array
*/
private $requests = [];
2017-02-17 08:25:19 -05:00
/**
* Add a request
*
2019-12-06 09:15:49 -05:00
* @param string|Request $request
2017-02-17 08:25:19 -05:00
* @param string|number $key
* @return self
*/
2017-02-17 10:55:17 -05:00
public function addRequest($request, $key = NULL): self
2017-02-17 08:25:19 -05:00
{
2018-02-02 09:50:58 -05:00
if ($key !== NULL)
2017-02-17 08:25:19 -05:00
{
$this->requests[$key] = $request;
return $this;
}
2017-02-17 08:25:19 -05:00
$this->requests[] = $request;
return $this;
}
2017-02-17 08:25:19 -05:00
/**
* Add multiple requests
*
2019-12-06 09:15:49 -05:00
* @param string[]|Request[] $requests
2017-02-17 08:25:19 -05:00
* @return self
*/
public function addRequests(array $requests): self
{
array_walk($requests, [$this, 'addRequest']);
return $this;
}
2017-02-17 08:25:19 -05:00
/**
2018-10-01 10:50:22 -04:00
* Make the requests, and return the body for each
2017-02-17 08:25:19 -05:00
*
* @return array
2018-09-26 22:31:04 -04:00
* @throws \Throwable
2017-02-17 08:25:19 -05:00
*/
public function makeRequests(): array
2017-02-17 08:25:19 -05:00
{
$client = getApiClient();
$promises = [];
foreach ($this->requests as $key => $url)
{
2019-12-06 09:15:49 -05:00
$promises[$key] = call(static function () use ($client, $url) {
$response = yield $client->request($url);
return yield $response->getBody();
});
}
return wait(all($promises));
2017-02-17 08:25:19 -05:00
}
2018-10-01 10:50:22 -04:00
/**
* Make the requests and return the response objects
*
* @return array
* @throws \Throwable
*/
public function getResponses(): array
{
$client = getApiClient();
2018-10-01 10:50:22 -04:00
$promises = [];
foreach ($this->requests as $key => $url)
{
2019-12-06 09:15:49 -05:00
$promises[$key] = call(static function () use ($client, $url) {
2018-10-01 10:50:22 -04:00
return yield $client->request($url);
});
}
return wait(all($promises));
}
2017-02-17 08:25:19 -05:00
}