1
0
mirror of synced 2024-12-01 09:46:07 +03:00
api-client-php/doc/usage/examples/orders_history.md
2021-06-02 17:00:32 +03:00

1.3 KiB

In this example we will fetch all history entries for 1 month from the API.

use RetailCrm\Api\Enum\PaginationLimit;
use RetailCrm\Api\Factory\SimpleClientFactory;
use RetailCrm\Api\Interfaces\ApiExceptionInterface;
use RetailCrm\Api\Interfaces\ClientExceptionInterface;
use RetailCrm\Api\Model\Filter\Orders\OrderHistoryFilterV4Type;
use RetailCrm\Api\Model\Request\Orders\OrdersHistoryRequest;

$history = [];
$client = SimpleClientFactory::createClient('https://test.retailcrm.pro', 'apiKey');
$request = new OrdersHistoryRequest();
$request->filter = new OrderHistoryFilterV4Type();
$request->limit = PaginationLimit::LIMIT_100;
$request->filter->startDate = (new DateTime())->sub(new DateInterval('P1M')); // History for 1 month by default.

do {
    time_nanosleep(0, 100000000); // 10 requests per second

    try {
        $response = $client->orders->history($request);
    } catch (ClientExceptionInterface | ApiExceptionInterface $exception) {
        echo $exception;
        break;
    }

    $history = array_merge($history, $response->history);
    $request->filter->startDate = null;
    $request->filter->sinceId = end($response->history)->id;
} while ($response->pagination->currentPage < $response->pagination->totalPageCount);

// Here you can process all history entries in the `$history` variable.