. */ /** @noinspection MultipleReturnStatementsInspection */ declare(strict_types=1); namespace FireflyIII\Factory; use FireflyIII\Exceptions\FireflyException; use FireflyIII\Models\TransactionCurrency; use Illuminate\Database\QueryException; use Log; /** * Class TransactionCurrencyFactory */ class TransactionCurrencyFactory { /** * @param array $data * * @return TransactionCurrency * @throws FireflyException */ public function create(array $data): TransactionCurrency { // if the code already exists (deleted) // force delete it and then create the transaction: $count = TransactionCurrency::withTrashed()->whereCode($data['code'])->count(); if (1 === $count) { $old = TransactionCurrency::withTrashed()->whereCode($data['code'])->first(); $old->forceDelete(); Log::warning(sprintf('Force deleted old currency with ID #%d and code "%s".', $old->id, $data['code'])); } try { /** @var TransactionCurrency $result */ $result = TransactionCurrency::create( [ 'name' => $data['name'], 'code' => $data['code'], 'symbol' => $data['symbol'], 'decimal_places' => $data['decimal_places'], 'enabled' => $data['enabled'], ] ); } catch (QueryException $e) { $result = null; Log::error(sprintf('Could not create new currency: %s', $e->getMessage())); throw new FireflyException('400004: Could not store new currency.', 0, $e); } return $result; } /** * @param int|null $currencyId * @param null|string $currencyCode * * @return TransactionCurrency|null */ public function find(?int $currencyId, ?string $currencyCode): ?TransactionCurrency { $currencyCode = (string) $currencyCode; $currencyId = (int) $currencyId; if ('' === $currencyCode && 0 === $currencyId) { Log::debug('Cannot find anything on empty currency code and empty currency ID!'); return null; } // first by ID: if ($currencyId > 0) { $currency = TransactionCurrency::find($currencyId); if (null !== $currency) { return $currency; } Log::warning(sprintf('Currency ID is %d but found nothing!', $currencyId)); } // then by code: if ('' !== $currencyCode) { $currency = TransactionCurrency::whereCode($currencyCode)->first(); if (null !== $currency) { return $currency; } Log::warning(sprintf('Currency code is %d but found nothing!', $currencyCode)); } Log::warning('Found nothing for currency.'); return null; } }