$value]); if ($value === 0) { $this->setCertainty(0); return new TransactionCurrency; } /** @var CurrencyRepositoryInterface $repository */ $repository = app(CurrencyRepositoryInterface::class, [$this->user]); if (isset($this->mapping[$value])) { Log::debug('Found currency in mapping. Should exist.', ['value' => $value, 'map' => $this->mapping[$value]]); $currency = $repository->find(intval($this->mapping[$value])); if (!is_null($currency->id)) { Log::debug('Found currency by ID', ['id' => $currency->id]); $this->setCertainty(100); return $currency; } } // not mapped? Still try to find it first: $currency = $repository->find($value); if (!is_null($currency->id)) { Log::debug('Found currency by ID ', ['id' => $currency->id]); $this->setCertainty(100); return $currency; } $this->setCertainty(0); // should not really happen. If the ID does not match FF, what is FF supposed to do? Log::info(sprintf('Could not find category with ID %d. Will return NULL', $value)); return new TransactionCurrency; } }