<?php defined('BASEPATH') or exit('No direct script access allowed'); /* ---------------------------------------------------------------------------- * Easy!Appointments - Open Source Web Scheduler * * @package EasyAppointments * @author A.Tselegidis <alextselegidis@gmail.com> * @copyright Copyright (c) 2013 - 2020, Alex Tselegidis * @license http://opensource.org/licenses/GPL-3.0 - GPLv3 * @link http://easyappointments.org * @since v1.3.2 * ---------------------------------------------------------------------------- */ /** * Class Consents_model * * @property CI_DB_query_builder db * @property CI_Loader load * * @package Models */ class Consents_model extends CI_Model { /** * Add a consent record to the database. * * This method adds a consent to the database. * * @param array $consent Associative array with the consent's data. * * @return int Returns the consent ID. */ public function add($consent) { $this->validate($consent); if ( ! isset($consent['id'])) { $consent['id'] = $this->insert($consent); } else { $this->update($consent); } return $consent['id']; } /** * Validate consent data before the insert or update operation is executed. * * @param array $consent Contains the consent data. * * @throws Exception If customer validation fails. */ public function validate($consent) { if ( ! isset($consent['first_name']) || ! isset($consent['last_name']) || ! isset($consent['email']) || ! isset($consent['ip']) || ! isset($consent['type'])) { throw new Exception('Not all required fields are provided: ' . print_r($consent, TRUE)); } } /** * Insert a new consent record to the database. * * @param array $consent Associative array with the consent's data. * * @return int Returns the ID of the new record. * * @throws Exception If consent record could not be inserted. */ protected function insert($consent) { $consent['created'] = time(); $consent['modified'] = time(); if ( ! $this->db->insert('consents', $consent)) { throw new Exception('Could not insert consent to the database.'); } return (int)$this->db->insert_id(); } /** * Update an existing consent record in the database. * * The consent data argument should already include the record ID in order to process the update operation. * * @param array $consent Associative array with the consent's data. * * @return int Returns the updated record ID. * * @throws Exception If consent record could not be updated. */ protected function update($consent) { $consent['modified'] = time(); if ( ! $this->db->update('consents', $consent, ['id' => $consent['id']])) { throw new Exception('Could not update consent to the database.'); } return (int)$consent['id']; } }