test_mode = config('ninja.nordigen.test_mode'); if (!(config('ninja.nordigen.secret_id') && config('ninja.nordigen.secret_key'))) throw new \Exception('missing nordigen credentials'); $this->client = new \Nordigen\NordigenPHP\API\NordigenClient(config('ninja.nordigen.secret_id'), config('ninja.nordigen.secret_key')); $this->client->createAccessToken(); // access_token is valid 24h -> so we dont have to implement a refresh-cycle } // metadata-section for frontend public function getInstitutions() { if ($this->test_mode) return (array) $this->client->institution->getInstitution($this->sandbox_institutionId); return $this->client->institution->getInstitutions(); } // requisition-section public function createRequisition(string $redirect, string $initutionId, string $reference) { if ($this->test_mode && $initutionId != $this->sandbox_institutionId) throw new \Exception('invalid institutionId while in test-mode'); return $this->client->requisition->createRequisition($redirect, $initutionId, null, $reference); } public function getRequisition(string $requisitionId) { return $this->client->requisition->getRequisition($requisitionId); } // TODO: return null on not found public function getAccount(string $account_id) { try { $out = new \stdClass(); $out->data = $this->client->account($account_id)->getAccountDetails()["account"]; $out->metadata = $this->client->account($account_id)->getAccountMetaData(); $out->balances = $this->client->account($account_id)->getAccountBalances()["balances"]; $out->institution = $this->client->institution->getInstitution($out->metadata["institution_id"]); $it = new AccountTransformer(); return $it->transform($out); } catch (\Exception $e) { if (strpos($e->getMessage(), "Invalid Account ID") !== false) return null; throw $e; } } public function isAccountActive(string $account_id) { try { $account = $this->client->account($account_id)->getAccountMetaData(); if ($account["status"] != "READY") return false; return true; } catch (\Exception $e) { if (strpos($e->getMessage(), "Invalid Account ID") !== false) return false; throw $e; } } /** * this method returns booked transactions from the bank_account, pending transactions are not part of the result * @todo @turbo124 should we include pending transactions within the integration-process and mark them with a specific category?! */ public function getTransactions(string $accountId, string $dateFrom = null) { $transactionResponse = $this->client->account($accountId)->getAccountTransactions($dateFrom); Log::info($transactionResponse); $it = new TransactionTransformer(); return $it->transform($transactionResponse); } }