cerbero90 /
lazy-json-pages
| 1 | <?php |
||||
| 2 | |||||
| 3 | declare(strict_types=1); |
||||
| 4 | |||||
| 5 | namespace Cerbero\LazyJsonPages\Concerns; |
||||
| 6 | |||||
| 7 | use Cerbero\LazyJsonPages\Exceptions\OutOfAttemptsException; |
||||
| 8 | use Closure; |
||||
| 9 | use Generator; |
||||
| 10 | use GuzzleHttp\Exception\TransferException; |
||||
| 11 | use Illuminate\Support\LazyCollection; |
||||
| 12 | |||||
| 13 | /** |
||||
| 14 | * The trait to retry HTTP requests when they fail. |
||||
| 15 | * |
||||
| 16 | * @property-read \Cerbero\LazyJsonPages\Data\Config $config |
||||
| 17 | * @property-read \Cerbero\LazyJsonPages\Services\Book $book |
||||
| 18 | */ |
||||
| 19 | trait RetriesHttpRequests |
||||
| 20 | { |
||||
| 21 | /** |
||||
| 22 | * Retry to yield HTTP responses from the given callback. |
||||
| 23 | * |
||||
| 24 | * @template TGen of Generator |
||||
| 25 | * @param Closure(): TGen $callback |
||||
| 26 | * @return TGen |
||||
|
0 ignored issues
–
show
|
|||||
| 27 | */ |
||||
| 28 | 41 | protected function retry(Closure $callback): Generator |
|||
| 29 | { |
||||
| 30 | 41 | $attempt = 0; |
|||
| 31 | 41 | $remainingAttempts = $this->config->attempts; |
|||
| 32 | |||||
| 33 | do { |
||||
| 34 | 41 | $failed = false; |
|||
| 35 | 41 | ++$attempt; |
|||
| 36 | 41 | --$remainingAttempts; |
|||
| 37 | |||||
| 38 | try { |
||||
| 39 | 41 | yield from $callback(); |
|||
| 40 | 2 | } catch (TransferException $e) { |
|||
| 41 | 1 | $failed = true; |
|||
| 42 | |||||
| 43 | 1 | if ($remainingAttempts > 0) { |
|||
| 44 | 1 | $this->backoff($attempt); |
|||
| 45 | } else { |
||||
| 46 | 1 | $this->outOfAttempts($e); |
|||
| 47 | } |
||||
| 48 | } |
||||
| 49 | 40 | } while ($failed && $remainingAttempts > 0); |
|||
| 50 | } |
||||
| 51 | |||||
| 52 | /** |
||||
| 53 | * Execute the backoff strategy. |
||||
| 54 | */ |
||||
| 55 | 1 | protected function backoff(int $attempt): void |
|||
| 56 | { |
||||
| 57 | 1 | $backoff = $this->config->backoff ?: fn(int $attempt) => $attempt ** 2 * 100; |
|||
| 58 | |||||
| 59 | 1 | usleep($backoff($attempt) * 1000); |
|||
| 60 | } |
||||
| 61 | |||||
| 62 | /** |
||||
| 63 | * Throw the out of attempts exception. |
||||
| 64 | */ |
||||
| 65 | 1 | protected function outOfAttempts(TransferException $e): never |
|||
| 66 | { |
||||
| 67 | 1 | throw new OutOfAttemptsException($e, $this->book->pullFailedPages(), new LazyCollection(function () { |
|||
|
0 ignored issues
–
show
function(...) { /* ... */ } of type callable is incompatible with the type Illuminate\Contracts\Support\Arrayable expected by parameter $source of Illuminate\Support\LazyCollection::__construct().
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||
| 68 | 1 | foreach ($this->book->pullPages() as $page) { |
|||
| 69 | 1 | yield from $this->yieldItemsFrom($page); |
|||
|
0 ignored issues
–
show
It seems like
yieldItemsFrom() must be provided by classes using this trait. How about adding it as abstract method to this trait?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||
| 70 | } |
||||
| 71 | 1 | })); |
|||
| 72 | } |
||||
| 73 | } |
||||
| 74 |
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths