. */ if (! defined('BASEPATH')) exit('No direct script access allowed'); /** * Controller between the bank related VueJS components and the backend */ class Bank extends FHCAPI_Controller { const BANK_NAME_PARAM = 'name'; const BIC_PARAM = 'bic'; const IBAN_PARAM = 'iban'; /** * Object initialization */ public function __construct() { // Sets permissions parent::__construct(array( 'getBankData' => self::PERM_LOGGED, 'postBankData' => self::PERM_LOGGED )); // Loads model Bankverbindung_model $this->load->model('person/Bankverbindung_model', 'BankverbindungModel'); } //------------------------------------------------------------------------------------------------------------------ // Public methods /** * Reads the bank data using the person id of the logged person and returns them in JSON format */ public function getBankData() { // Person id of the logged user $loggedPersonId = getAuthPersonId(); // If null then not authenticated then terminate if ($loggedPersonId == null) $this->terminateWithError('Not logged user/User without an associated person', self::ERROR_TYPE_AUTH); // Gets the latest added to the database bank data for this logged user $bankDataResult = $this->BankverbindungModel->execReadOnlyQuery( 'SELECT bv.name, bv.bic, bv.iban, COALESCE(bv.updateamum, bv.insertamum) AS update_date, bv.insertamum FROM public.tbl_bankverbindung bv WHERE bv.person_id = ? ORDER BY update_date DESC, bv.insertamum DESC LIMIT 1', array($loggedPersonId) ); // Get the retrieved data or terminate $data = $this->getDataOrTerminateWithError($bankDataResult); // Anyway terminate it! $this->terminateWithSuccess($data); } /** * Writes the bank data using the person id of the logged person and the posted bank data */ public function postBankData() { // Person id of the logged user $loggedPersonId = getAuthPersonId(); // If null then not authenticated then terminate if ($loggedPersonId == null) $this->terminateWithError('Not logged user/User without an associated person', self::ERROR_TYPE_AUTH); // Loads the CI validation library $this->load->library('form_validation'); // Checks if the posted parameters are fine $this->form_validation->set_rules(self::BANK_NAME_PARAM, null, array('required', 'alpha_numeric_spaces')); $this->form_validation->set_rules(self::BIC_PARAM, null, array('required', 'alpha_numeric')); $this->form_validation->set_rules(self::IBAN_PARAM, null, array('required', 'alpha_numeric_spaces')); // Run the validation and checks the result if (!$this->form_validation->run()) $this->terminateWithError('The required data are not valid or missing', self::ERROR_TYPE_VALIDATION); // Check if there is at least a record in the bank data table $bankDataResult = $this->BankverbindungModel->execReadOnlyQuery( 'SELECT bv.bankverbindung_id, COALESCE(bv.updateamum, bv.insertamum) AS update_date, bv.insertamum FROM public.tbl_bankverbindung bv WHERE bv.person_id = ? ORDER BY update_date DESC, bv.insertamum DESC LIMIT 1', array($loggedPersonId) ); // If a db error occurred then terminate if (isError($bankDataResult)) $this->terminateWithError('Database error while retrieving bank data', self::ERROR_TYPE_DB); $writeDataResult = null; // it is considered as an error // If at least a record exists then update if (hasData($bankDataResult)) { // Then update $writeDataResult = $this->BankverbindungModel->update( getData($bankDataResult)[0]->bankverbindung_id, array( 'name' => $this->input->post(self::BANK_NAME_PARAM), 'bic' => $this->input->post(self::BIC_PARAM), 'iban' => $this->input->post(self::IBAN_PARAM), 'updateamum' => 'NOW()', 'verrechnung' => true, 'typ' => 'p' ) ); } else // otherwise insert { // Otherwise insert $writeDataResult = $this->BankverbindungModel->insert( array( 'person_id' => $loggedPersonId, 'name' => $this->input->post(self::BANK_NAME_PARAM), 'bic' => $this->input->post(self::BIC_PARAM), 'iban' => $this->input->post(self::IBAN_PARAM), 'insertamum' => 'NOW()', 'verrechnung' => true, 'typ' => 'p' ) ); } // If a db error occurred then terminate if (isError($writeDataResult)) $this->terminateWithError('Database error while writing bank data', self::ERROR_TYPE_DB); // If everything was fine then return a success $this->terminateWithSuccess('Database updated'); } }