Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
],
"require": {
"php": ">=7.1",
"laravel/framework": "^5.5|^6|^7",
"laravel/framework": "^5.5|^6|^7|^8",
"guzzlehttp/guzzle": "*",
"ext-json": "*",
"spatie/guzzle-rate-limiter-middleware": "^1.0"
Expand Down
103 changes: 82 additions & 21 deletions src/Builders/Builder.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
use Rackbeat\Traits\ApiFiltering;
use Rackbeat\Utils\Model;
use Rackbeat\Utils\Request;
use Illuminate\Support\Str;


class Builder
Expand Down Expand Up @@ -80,46 +81,106 @@ protected function populateModelsFromResponse( $response ) {
*
* @return mixed
*/
public function all( $filters = [] ) {
$page = 1;
$this->limit( 1000 );

$items = collect();
public function all( $filters = [], $chunkSize = 100 ) {
$entity = Str::plural($this->entity);
$offset = 0;

$response = function ( $filters, $page ) {
$this->page( $page );
$response = function ( $filters, $offset, $entity ) use ($chunkSize){
$filters['limit'] = $chunkSize;
$filters['offset'] = $offset;

$urlFilters = $this->parseFilters( $filters );

return $this->request->handleWithExceptions( function () use ( $urlFilters ) {

return $this->request->handleWithExceptions( function () use ( $urlFilters, $entity ) {
$response = $this->request->client->get( "{$this->entity}{$urlFilters}" );

$responseData = json_decode( (string) $response->getBody() );
$fetchedItems = $this->getResponse( $response );
$pages = $responseData->pages;
$items = $this->populateModelsFromResponse( $fetchedItems->first() );

$fetchedItems = collect($responseData->{$entity});
$items = collect([]);
$count = (isset($responseData->paging)) ? $responseData->paging->count : 0;

foreach ($fetchedItems as $index => $item) {
/** @var Model $model */
$model = new $this->model($this->request, $item);
$items->push($model);
}
return (object) [

'items' => $items,
'pages' => $pages,
'count' => $count,
];
} );
};

do {

$resp = $response( $filters, $page );
$resp = $response( $filters, $offset, $entity );

$items = $items->merge( $resp->items );
$page++;
$countResults = count($resp->items);
if ( $countResults === 0 ) {
break;
}
foreach ($resp->items as $result ) {
yield $result;
}

} while ( $page <= $resp->pages );
unset( $resp );

$offset += $chunkSize;

return $items;
} while ( $countResults === $chunkSize );
}

/**
* It will iterate over all pages until it does not receive empty response, you can also set query parameters,
* Return a Generator that you' handle first before quering the next offset
*
* @param int $chunkSize
*
* @return Generator
*/
public function allWithGenerator(int $chunkSize = 50)
{
$page = 1;
$this->limit($chunkSize);

$items = collect();

$response = function ($page) {
$this->page($page);
$urlFilters = $this->parseFilters();

return $this->request->handleWithExceptions(function () use ($urlFilters) {
$response = $this->request->client->get("{$this->entity}{$urlFilters}");

$responseData = json_decode((string) $response->getBody());
$fetchedItems = $this->getResponse($response);
$pages = $responseData->pages;
$items = $this->populateModelsFromResponse($fetchedItems->first());

return (object) [
'items' => $items,
'pages' => $pages,
];
});
};

do {
$resp = $response($page);

$countResults = count($resp->items);
if ($countResults === 0) {
break;
}
// make a generator of the results and return them
// so the logic will handle them before the next iteration
// in order to avoid memory leaks
foreach ($resp->items as $result) {
yield $result;
}

unset($resp);

$page++;
} while ($countResults === $chunkSize);
}

/**
Expand Down
20 changes: 19 additions & 1 deletion src/Builders/CustomerInvoiceBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,22 @@ class CustomerInvoiceBuilder extends Builder
{
protected $entity = 'customer-invoices';
protected $model = CustomerInvoice::class;
}

/**
* Mark invoice as booked
*
* @param $number
*
* @return mixed
* @throws \Rackbeat\Exceptions\RackbeatClientException
* @throws \Rackbeat\Exceptions\RackbeatRequestException
*/
public function markBook( $number )
{
return $this->request->handleWithExceptions( function () use ( $number ) {

$response = $this->request->client->post( $this->entity . '/' . $number . '/book' );
$responseData = $this->getResponse( $response );
} );
}
}