. */ declare(strict_types=1); namespace FireflyIII\Export\Entry; use FireflyIII\Models\Transaction; /** * To extend the exported object, in case of new features in Firefly III for example, * do the following:. * * - Add the field(s) to this class. If you add more than one related field, add a new object. * - Make sure the "fromJournal"-routine fills these fields. * - Add them to the static function that returns its type (key=value. Remember that the only * valid types can be found in config/csv.php (under "roles"). * * These new entries should be should be strings and numbers as much as possible. * * * * Class Entry * * @SuppressWarnings(PHPMD.LongVariable) * @SuppressWarnings(PHPMD.TooManyFields) */ final class Entry { // @formatter:off /** * @var int */ public $journal_id; /** * @var int */ public $transaction_id = 0; /** * @var string */ public $date; /** * @var string */ public $description; /** * @var string */ public $currency_code; /** * @var string */ public $amount; /** * @var string */ public $foreign_currency_code = ''; /** * @var string */ public $foreign_amount = '0'; /** * @var string */ public $transaction_type; /** * @var string */ public $asset_account_id; /** * @var string */ public $asset_account_name; /** * @var string */ public $asset_account_iban; /** * @var string */ public $asset_account_bic; /** * @var string */ public $asset_account_number; /** * @var string */ public $asset_currency_code; /** * @var string */ public $opposing_account_id; /** * @var string */ public $opposing_account_name; /** * @var string */ public $opposing_account_iban; /** * @var string */ public $opposing_account_bic; /** * @var string */ public $opposing_account_number; /** * @var string */ public $opposing_currency_code; /** * @var string */ public $budget_id; /** * @var string */ public $budget_name; /** * @var string */ public $category_id; /** * @var string */ public $category_name; /** * @var string */ public $bill_id; /** * @var string */ public $bill_name; /** * @var string */ public $notes; /** * @var string */ public $tags; // @formatter:on /** * Entry constructor. */ private function __construct() { } /** * Converts a given transaction (as collected by the collector) into an export entry. * * @SuppressWarnings(PHPMD.CyclomaticComplexity) // complex but little choice. * @SuppressWarnings(PHPMD.ExcessiveMethodLength) // cannot be helped * * @param Transaction $transaction * * @return Entry */ public static function fromTransaction(Transaction $transaction): Entry { $entry = new self(); $entry->journal_id = $transaction->journal_id; $entry->transaction_id = $transaction->id; $entry->date = $transaction->date->format('Ymd'); $entry->description = $transaction->description; if (strlen(strval($transaction->transaction_description)) > 0) { $entry->description = $transaction->transaction_description . '(' . $transaction->description . ')'; } $entry->currency_code = $transaction->transactionCurrency->code; $entry->amount = strval(round($transaction->transaction_amount, $transaction->transactionCurrency->decimal_places)); $entry->foreign_currency_code = null === $transaction->foreign_currency_id ? null : $transaction->foreignCurrency->code; $entry->foreign_amount = null === $transaction->foreign_currency_id ? null : strval( round( $transaction->transaction_foreign_amount, $transaction->foreignCurrency->decimal_places ) ); $entry->transaction_type = $transaction->transaction_type_type; $entry->asset_account_id = strval($transaction->account_id); $entry->asset_account_name = app('steam')->tryDecrypt($transaction->account_name); $entry->asset_account_iban = $transaction->account_iban; $entry->asset_account_number = $transaction->account_number; $entry->asset_account_bic = $transaction->account_bic; $entry->asset_currency_code = $transaction->account_currency_code; $entry->opposing_account_id = strval($transaction->opposing_account_id); $entry->opposing_account_name = app('steam')->tryDecrypt($transaction->opposing_account_name); $entry->opposing_account_iban = $transaction->opposing_account_iban; $entry->opposing_account_number = $transaction->opposing_account_number; $entry->opposing_account_bic = $transaction->opposing_account_bic; $entry->opposing_currency_code = $transaction->opposing_currency_code; // budget $entry->budget_id = strval($transaction->transaction_budget_id); $entry->budget_name = app('steam')->tryDecrypt($transaction->transaction_budget_name); if (null === $transaction->transaction_budget_id) { $entry->budget_id = $transaction->transaction_journal_budget_id; $entry->budget_name = app('steam')->tryDecrypt($transaction->transaction_journal_budget_name); } // category $entry->category_id = strval($transaction->transaction_category_id); $entry->category_name = app('steam')->tryDecrypt($transaction->transaction_category_name); if (null === $transaction->transaction_category_id) { $entry->category_id = $transaction->transaction_journal_category_id; $entry->category_name = app('steam')->tryDecrypt($transaction->transaction_journal_category_name); } // budget $entry->bill_id = strval($transaction->bill_id); $entry->bill_name = app('steam')->tryDecrypt($transaction->bill_name); $entry->tags = $transaction->tags; $entry->notes = $transaction->notes; return $entry; } }