2018-01-03 12:17:30 -06:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Transaction.php
|
|
|
|
* Copyright (c) 2018 thegrumpydictator@gmail.com
|
|
|
|
*
|
|
|
|
* This file is part of Firefly III.
|
|
|
|
*
|
|
|
|
* Firefly III 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 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* Firefly III 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 Firefly III. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
namespace FireflyIII\Services\Spectre\Object;
|
|
|
|
|
2018-01-08 12:21:00 -06:00
|
|
|
use Carbon\Carbon;
|
|
|
|
|
2018-01-03 12:17:30 -06:00
|
|
|
/**
|
|
|
|
* Class Transaction
|
2018-08-06 12:14:30 -05:00
|
|
|
*
|
2018-07-27 23:27:30 -05:00
|
|
|
* @codeCoverageIgnore
|
|
|
|
*
|
|
|
|
* @SuppressWarnings(PHPMD.ShortVariable)
|
2018-01-03 12:17:30 -06:00
|
|
|
*/
|
|
|
|
class Transaction extends SpectreObject
|
|
|
|
{
|
2018-01-08 12:21:00 -06:00
|
|
|
/** @var int */
|
|
|
|
private $accountId;
|
|
|
|
/** @var string */
|
|
|
|
private $amount;
|
|
|
|
/** @var string */
|
|
|
|
private $category;
|
|
|
|
/** @var Carbon */
|
|
|
|
private $createdAt;
|
|
|
|
/** @var string */
|
|
|
|
private $currencyCode;
|
|
|
|
/** @var string */
|
|
|
|
private $description;
|
|
|
|
/** @var bool */
|
|
|
|
private $duplicated;
|
|
|
|
/** @var TransactionExtra */
|
|
|
|
private $extra;
|
|
|
|
/** @var int */
|
|
|
|
private $id;
|
|
|
|
/** @var Carbon */
|
|
|
|
private $madeOn;
|
|
|
|
/** @var string */
|
|
|
|
private $mode;
|
|
|
|
/** @var string */
|
|
|
|
private $status;
|
|
|
|
/** @var Carbon */
|
|
|
|
private $updatedAt;
|
|
|
|
|
2018-01-03 12:17:30 -06:00
|
|
|
/**
|
|
|
|
* Transaction constructor.
|
|
|
|
*
|
|
|
|
* @param array $data
|
|
|
|
*/
|
2018-01-08 12:21:00 -06:00
|
|
|
public function __construct(array $data)
|
|
|
|
{
|
2018-04-27 22:25:29 -05:00
|
|
|
$this->id = (int)$data['id'];
|
2018-01-08 12:21:00 -06:00
|
|
|
$this->mode = $data['mode'];
|
|
|
|
$this->status = $data['status'];
|
|
|
|
$this->madeOn = new Carbon($data['made_on']);
|
|
|
|
$this->amount = $data['amount'];
|
|
|
|
$this->currencyCode = $data['currency_code'];
|
|
|
|
$this->description = $data['description'];
|
|
|
|
$this->category = $data['category'];
|
|
|
|
$this->duplicated = $data['duplicated'];
|
|
|
|
$this->extra = new TransactionExtra($data['extra'] ?? []);
|
|
|
|
$this->accountId = $data['account_id'];
|
|
|
|
$this->createdAt = new Carbon($data['created_at']);
|
|
|
|
$this->updatedAt = new Carbon($data['updated_at']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getAmount(): string
|
|
|
|
{
|
2018-04-02 07:50:17 -05:00
|
|
|
return (string)$this->amount;
|
2018-01-08 12:21:00 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getCategory(): string
|
|
|
|
{
|
|
|
|
return $this->category;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getCurrencyCode(): string
|
|
|
|
{
|
|
|
|
return $this->currencyCode;
|
2018-01-03 12:17:30 -06:00
|
|
|
}
|
|
|
|
|
2018-01-08 12:21:00 -06:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getDescription(): string
|
|
|
|
{
|
|
|
|
return $this->description;
|
|
|
|
}
|
|
|
|
|
2018-02-09 12:11:55 -06:00
|
|
|
/**
|
2018-05-19 14:13:00 -05:00
|
|
|
* @return TransactionExtra|null
|
2018-02-09 12:11:55 -06:00
|
|
|
*/
|
2018-05-19 14:13:00 -05:00
|
|
|
public function getExtra(): ?TransactionExtra
|
2018-02-09 12:11:55 -06:00
|
|
|
{
|
|
|
|
return $this->extra;
|
|
|
|
}
|
|
|
|
|
2018-01-08 12:21:00 -06:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getHash(): string
|
|
|
|
{
|
2018-04-02 07:50:17 -05:00
|
|
|
$array = [
|
2018-01-08 12:21:00 -06:00
|
|
|
'id' => $this->id,
|
|
|
|
'mode' => $this->mode,
|
|
|
|
'status' => $this->status,
|
|
|
|
'made_on' => $this->madeOn->toIso8601String(),
|
|
|
|
'amount' => $this->amount,
|
|
|
|
'currency_code' => $this->currencyCode,
|
|
|
|
'description' => $this->description,
|
|
|
|
'category' => $this->category,
|
|
|
|
'duplicated' => $this->duplicated,
|
|
|
|
'extra' => $this->extra->toArray(),
|
|
|
|
'account_id' => $this->accountId,
|
|
|
|
'created_at' => $this->createdAt->toIso8601String(),
|
|
|
|
'updated_at' => $this->updatedAt->toIso8601String(),
|
|
|
|
];
|
|
|
|
|
2018-04-02 07:50:17 -05:00
|
|
|
return hash('sha256', json_encode($array));
|
2018-01-08 12:21:00 -06:00
|
|
|
}
|
|
|
|
|
2018-02-09 12:11:55 -06:00
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getId(): int
|
|
|
|
{
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
2018-01-08 12:21:00 -06:00
|
|
|
/**
|
|
|
|
* @return Carbon
|
|
|
|
*/
|
|
|
|
public function getMadeOn(): Carbon
|
|
|
|
{
|
|
|
|
return $this->madeOn;
|
|
|
|
}
|
|
|
|
|
2018-02-09 12:11:55 -06:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getMode(): string
|
|
|
|
{
|
|
|
|
return $this->mode;
|
|
|
|
}
|
|
|
|
|
2018-05-19 14:13:00 -05:00
|
|
|
/**
|
2018-07-27 23:27:30 -05:00
|
|
|
* Get opposing account data.
|
|
|
|
*
|
2018-05-19 14:13:00 -05:00
|
|
|
* @return array
|
2019-08-17 03:47:29 -05:00
|
|
|
*
|
2018-05-19 14:13:00 -05:00
|
|
|
*/
|
|
|
|
public function getOpposingAccountData(): array
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'name' => null,
|
|
|
|
'iban' => null,
|
|
|
|
'number' => null,
|
|
|
|
'bic' => null,
|
|
|
|
];
|
|
|
|
$extra = $this->getExtra();
|
|
|
|
if (null !== $extra) {
|
|
|
|
$arr = $extra->toArray();
|
|
|
|
foreach ($arr as $key => $value) {
|
|
|
|
switch ($key) {
|
|
|
|
case 'account_number':
|
|
|
|
$data['number'] = $value;
|
2018-07-15 02:38:49 -05:00
|
|
|
$data['name'] = $data['name'] ?? (string)trans('import.spectre_account_with_number', ['number' => $value]);
|
2018-05-19 14:13:00 -05:00
|
|
|
break;
|
|
|
|
case 'payee':
|
|
|
|
$data['name'] = $value;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
2018-02-09 12:11:55 -06:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getStatus(): string
|
|
|
|
{
|
|
|
|
return $this->status;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isDuplicated(): bool
|
|
|
|
{
|
|
|
|
return $this->duplicated;
|
|
|
|
}
|
|
|
|
|
2018-01-08 12:21:00 -06:00
|
|
|
|
2018-03-05 12:35:58 -06:00
|
|
|
}
|