jojo1981 / polling
Polling library for conditionally retry operations based on a result checker.
Installs: 5 165
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 1
Open Issues: 0
Requires
- php: ^7.4|^8.0
- jojo1981/contracts: ^1.0
- jojo1981/typed-collection: ^5.0
Requires (Dev)
- dg/bypass-finals: ^1.3
- php-coveralls/php-coveralls: ^2.4
- phpunit/phpunit: ^9.0
README
Author: Joost Nijhuis <jnijhuis81@gmail.com>
A simple polling library which retries the poll action as long as the result checker is not returning a success result for a maximum number of times with a given delay in between.
The executor callback can perform any task you want and can return any result you want. The result checker should be able to check whether the result from the executor is successful or not and must return a boolean value. Optionally you can add an exception checker. This can be omitted and be handled in the executor, but for separation of concerns you can split this logic. The delay in microseconds can be given and is by default 10000000 microseconds (10 seconds). The delay will be between the retries. The max poll count can be given and is by default 10. The max poll count is the number of times at maximum the executor will be invoked including the first time. Default arguments for the executor, result checker, exception checker and start polling can be omitted. This can be handy to keep the callback functions pure.
Installation
Library
git clone https://github.com/jojo1981/polling.git
Composer
composer require jojo1981/polling
Usage
<?php use Jojo1981\Polling\Checker\PollResultChecker; use Jojo1981\Polling\Executor\PollExecutor; use Jojo1981\Polling\Poller; use Jojo1981\Polling\Result\PollResult; use Jojo1981\Polling\Value\PollCount; use Jojo1981\Polling\Value\UnsignedInteger; use Jojo1981\TypedCollection\Collection; require 'vendor/autoload.php'; // Example polling with 3 tries and then having a success result. $pollExecutor = new PollExecutor( /** * @param string $text1 * @param string $text2 * @param int $number * @param Collection|PollResult[] $previousResults * @param int $currentPollCount * @return string */ static function (string $text1, string $text2, int $number, Collection $previousResults, int $currentPollCount): string { // order of arguments: start polling arguments (when given), executor arguments (when given), $previousResults and $currentPollCount. return $currentPollCount === 3 ? 'This is a success result :)' : 'We are not yet there :('; }, [1] // optionally the default arguments which will be given to the poll executor callback ); $pollResultChecker = new PollResultChecker( /** * @param string $text1 * @param string $text2 * @param bool $number * @param string $result * @param Collection|PollResult[] $previousResults * @param int $currentPollCount * @return bool */ static function (string $text1, string $text2, bool $number, string $result, Collection $previousResults, int $currentPollCount): bool { // order of arguments: start polling arguments (when given), executor arguments (when given), $previousResults and $currentPollCount. return 'This is a success result :)' === $result; }, [1] // optionally the default arguments which will be given to the poll result checker callback ); // poll delay is expressed in microseconds, so poll max 5 times with in between 5 seconds delay. $poller = new Poller($pollExecutor, $pollResultChecker, null, new UnsignedInteger(5000000), new PollCount(5)); $finalPollResult = $poller->startPolling(['text1', 'text2']); // start polling with optionally some default arguments $finalPollResult->getCount(); // Will return the number of poll retries including the first one. Value: 3 in this case. $finalPollResult->isSuccess(); // Will return true when polling is succeeded. Value true in this case. $finalPollResult->isFailed(); // Will return true when polling has been failed. Value false in this case. $finalPollResult->getResult(); /// Will return the last poll result. Value 'This is a success result :)' in this case.