src/Jobs/Wallet/Character/Transactions.php
<?php
/*
* This file is part of SeAT
*
* Copyright (C) 2015 to present Leon Jacobs
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
namespace Seat\Eveapi\Jobs\Wallet\Character;
use Seat\Eveapi\Jobs\AbstractAuthCharacterJob;
use Seat\Eveapi\Mapping\Financial\WalletTransactionMapping;
use Seat\Eveapi\Models\Wallet\CharacterWalletTransaction;
/**
* Class Transactions.
*
* @package Seat\Eveapi\Jobs\Wallet\Character
*/
class Transactions extends AbstractAuthCharacterJob
{
/**
* @var string
*/
protected $method = 'get';
/**
* @var string
*/
protected $endpoint = '/characters/{character_id}/wallet/transactions/';
/**
* @var string
*/
protected $version = 'v1';
/**
* @var string
*/
protected $scope = 'esi-wallet.read_character_wallet.v1';
/**
* @var array
*/
protected $tags = ['character', 'wallet'];
/**
* A counter used to walk the transactions backwards.
*
* @var int
*/
protected $from_id = 0;
/**
* Execute the job.
*
* @throws \Throwable
*/
public function handle()
{
parent::handle();
// Perform a journal walk backwards to get all of the
// entries as far back as possible. When the response from
// ESI is empty, we can assume we have everything.
while (true) {
$this->query_string = ['from_id' => $this->from_id];
$response = $this->retrieve([
'character_id' => $this->getCharacterId(),
]);
$entries = collect($response->getBody());
// If we have no more entries, break the loop.
if ($entries->count() === 0)
break;
$entries->each(function ($transaction) {
$transaction_entry = CharacterWalletTransaction::firstOrNew([
'character_id' => $this->getCharacterId(),
'transaction_id' => $transaction->transaction_id,
]);
// If this transaction entry has already been recorded,
// move on to the next.
if ($transaction_entry->exists)
return;
WalletTransactionMapping::make($transaction_entry, $transaction, [
'character_id' => function () {
return $this->getCharacterId();
},
'is_personal' => function () use ($transaction) {
return $transaction->is_personal;
},
])->save();
});
// Update the from_id to be the new lowest (ref_id - 1) that we
// know of. The next all will use this.
$this->from_id = $entries->min('transaction_id') - 1;
}
}
}