72 lines
2.1 KiB
PHP
72 lines
2.1 KiB
PHP
<?php
|
|
namespace Opencart\Catalog\Model\Account;
|
|
/**
|
|
* Class Gdpr
|
|
*
|
|
* @package Opencart\Catalog\Model\Account
|
|
*/
|
|
class Gdpr extends \Opencart\System\Engine\Model {
|
|
/**
|
|
* @param string $code
|
|
* @param string $email
|
|
* @param string $action
|
|
*
|
|
* @return void
|
|
*/
|
|
public function addGdpr(string $code, string $email, string $action): void {
|
|
$this->db->query("INSERT INTO `" . DB_PREFIX . "gdpr` SET `store_id` = '" . $this->db->escape($this->config->get('config_store_id')) . "', `language_id` = '" . $this->db->escape($this->config->get('config_language_id')) . "', `code` = '" . $this->db->escape($code) . "', `email` = '" . $this->db->escape($email) . "', `action` = '" . $this->db->escape($action) . "', `date_added` = NOW()");
|
|
}
|
|
|
|
/**
|
|
* @param int $gdpr_id
|
|
* @param int $status
|
|
*
|
|
* @return void
|
|
*/
|
|
public function editStatus(int $gdpr_id, int $status): void {
|
|
$this->db->query("UPDATE `" . DB_PREFIX . "gdpr` SET `status` = '" . (int)$status . "' WHERE `gdpr_id` = '" . (int)$gdpr_id . "'");
|
|
}
|
|
|
|
/**
|
|
* @param int $gdpr_id
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getGdpr(int $gdpr_id): array {
|
|
$query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "gdpr` WHERE `gdpr_id` = '" . (int)$gdpr_id . "'");
|
|
|
|
return $query->row;
|
|
}
|
|
|
|
/**
|
|
* @param string $code
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getGdprByCode(string $code): array {
|
|
$query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "gdpr` WHERE `code` = '" . $this->db->escape($code) . "'");
|
|
|
|
return $query->row;
|
|
}
|
|
|
|
/**
|
|
* @param string $email
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getGdprsByEmail(string $email): array {
|
|
$query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "gdpr` WHERE `email` = '" . $this->db->escape($email) . "'");
|
|
|
|
return $query->rows;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getExpires(): array {
|
|
$query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "gdpr` WHERE `status` = '2' AND DATE(`date_added`) <= DATE('" . $this->db->escape(date('Y-m-d', strtotime('+' . (int)$this->config->get('config_gdpr_limit') . ' days'))) . "') ORDER BY `date_added` DESC");
|
|
|
|
return $query->rows;
|
|
}
|
|
}
|