2024-08-06 18:06:00 +05:45

494 lines
17 KiB
PHP

<?php
namespace Opencart\Admin\Controller\Mail;
/**
* Class Gdpr
*
* @package Opencart\Admin\Controller\Mail
*/
class Gdpr extends \Opencart\System\Engine\Controller {
// admin/model/customer/gdpr/editStatus
/**
* @param string $route
* @param array $args
* @param mixed $output
*
* @return void
*/
public function index(string &$route, array &$args, mixed &$output): void {
$this->load->model('customer/gdpr');
$gdpr_info = $this->model_customer_gdpr->getGdpr($args[0]);
if ($gdpr_info) {
// Choose which mail to send
// Export plus complete
if ($gdpr_info['action'] == 'export' && (int)$args[1] == 3) {
$this->export($gdpr_info);
}
// Approve plus processing
if ($gdpr_info['action'] == 'approve' && (int)$args[1] == 2) {
$this->approve($gdpr_info);
}
// Remove plus complete
if ($gdpr_info['action'] == 'remove' && (int)$args[1] == 3) {
$this->remove($gdpr_info);
}
// Deny
if ($args[1] == -1) {
$this->deny($gdpr_info);
}
}
}
/**
* @param array $gdpr_info
*
* @return void
* @throws \Exception
*/
public function export(array $gdpr_info): void {
$this->load->model('setting/store');
$store_info = $this->model_setting_store->getStore($gdpr_info['store_id']);
if ($store_info) {
$this->load->model('setting/setting');
$store_logo = html_entity_decode($this->model_setting_setting->getValue('config_logo', $store_info['store_id']), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($store_info['name'], ENT_QUOTES, 'UTF-8');
$store_url = $store_info['url'];
} else {
$store_logo = html_entity_decode($this->config->get('config_logo'), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($this->config->get('config_name'), ENT_QUOTES, 'UTF-8');
$store_url = HTTP_CATALOG;
}
// Send the email in the correct language
$this->load->model('localisation/language');
$language_info = $this->model_localisation_language->getLanguage($gdpr_info['language_id']);
if ($language_info) {
$language_code = $language_info['code'];
} else {
$language_code = $this->config->get('config_language');
}
// Load the language for any mails using a different country code and prefixing it so it does not pollute the main data pool.
$this->load->language('default', 'mail', $language_code);
$this->load->language('mail/gdpr_export', 'mail', $language_code);
// Add language vars to the template folder
$results = $this->language->all('mail');
foreach ($results as $key => $value) {
$data[$key] = $value;
}
$subject = sprintf($this->language->get('mail_text_subject'), $store_name);
if (is_file(DIR_IMAGE . $store_logo)) {
$data['logo'] = $store_url . 'image/' . $store_logo;
} else {
$data['logo'] = '';
}
$this->load->model('customer/customer');
$customer_info = $this->model_customer_customer->getCustomerByEmail($gdpr_info['email']);
if ($customer_info) {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), html_entity_decode($customer_info['firstname'], ENT_QUOTES, 'UTF-8'));
} else {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), $this->language->get('mail_text_user'));
}
// Personal info
if ($customer_info) {
$data['customer_id'] = $customer_info['customer_id'];
$data['firstname'] = $customer_info['firstname'];
$data['lastname'] = $customer_info['lastname'];
$data['email'] = $customer_info['email'];
$data['telephone'] = $customer_info['telephone'];
}
// Addresses
$data['addresses'] = [];
if ($customer_info) {
$results = $this->model_customer_customer->getAddresses($customer_info['customer_id']);
foreach ($results as $result) {
$address = [
'firstname' => $result['firstname'],
'lastname' => $result['lastname'],
'address_1' => $result['address_1'],
'address_2' => $result['address_2'],
'city' => $result['city'],
'postcode' => $result['postcode'],
'country' => $result['country'],
'zone' => $result['zone']
];
if (!in_array($address, $data['addresses'])) {
$data['addresses'][] = $address;
}
}
}
// Order Addresses
$this->load->model('sale/order');
$results = $this->model_sale_order->getOrders(['filter_email' => $gdpr_info['email']]);
foreach ($results as $result) {
$order_info = $this->model_sale_order->getOrder($result['order_id']);
if ($order_info['payment_country_id']) {
$address = [
'firstname' => $order_info['payment_firstname'],
'lastname' => $order_info['payment_lastname'],
'address_1' => $order_info['payment_address_1'],
'address_2' => $order_info['payment_address_2'],
'city' => $order_info['payment_city'],
'postcode' => $order_info['payment_postcode'],
'country' => $order_info['payment_country'],
'zone' => $order_info['payment_zone']
];
if (!in_array($address, $data['addresses'])) {
$data['addresses'][] = $address;
}
}
if ($order_info['shipping_country_id']) {
$address = [
'firstname' => $order_info['shipping_firstname'],
'lastname' => $order_info['shipping_lastname'],
'address_1' => $order_info['shipping_address_1'],
'address_2' => $order_info['shipping_address_2'],
'city' => $order_info['shipping_city'],
'postcode' => $order_info['shipping_postcode'],
'country' => $order_info['shipping_country'],
'zone' => $order_info['shipping_zone']
];
if (!in_array($address, $data['addresses'])) {
$data['addresses'][] = $address;
}
}
}
// Ip's
$data['ips'] = [];
if ($customer_info) {
$results = $this->model_customer_customer->getIps($customer_info['customer_id']);
foreach ($results as $result) {
$data['ips'][] = [
'ip' => $result['ip'],
'date_added' => date($this->language->get('mail_datetime_format'), strtotime($result['date_added']))
];
}
}
$data['store_name'] = $store_name;
$data['store_url'] = $store_url;
if ($this->config->get('config_mail_engine')) {
$mail_option = [
'parameter' => $this->config->get('config_mail_parameter'),
'smtp_hostname' => $this->config->get('config_mail_smtp_hostname'),
'smtp_username' => $this->config->get('config_mail_smtp_username'),
'smtp_password' => html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES, 'UTF-8'),
'smtp_port' => $this->config->get('config_mail_smtp_port'),
'smtp_timeout' => $this->config->get('config_mail_smtp_timeout')
];
$mail = new \Opencart\System\Library\Mail($this->config->get('config_mail_engine'), $mail_option);
$mail->setTo($gdpr_info['email']);
$mail->setFrom($this->config->get('config_email'));
$mail->setSender($store_name);
$mail->setSubject($subject);
$mail->setHtml($this->load->view('mail/gdpr_export', $data));
$mail->send();
}
}
/**
* @param array $gdpr_info
*
* @return void
* @throws \Exception
*/
public function approve(array $gdpr_info): void {
$this->load->model('setting/store');
$store_info = $this->model_setting_store->getStore($gdpr_info['store_id']);
if ($store_info) {
$this->load->model('setting/setting');
$store_logo = html_entity_decode($this->model_setting_setting->getValue('config_logo', $store_info['store_id']), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($store_info['name'], ENT_QUOTES, 'UTF-8');
$store_url = $store_info['url'];
} else {
$store_logo = html_entity_decode($this->config->get('config_logo'), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($this->config->get('config_name'), ENT_QUOTES, 'UTF-8');
$store_url = HTTP_CATALOG;
}
// Send the email in the correct language
$this->load->model('localisation/language');
$language_info = $this->model_localisation_language->getLanguage($gdpr_info['language_id']);
if ($language_info) {
$language_code = $language_info['code'];
} else {
$language_code = $this->config->get('config_language');
}
// Load the language for any mails using a different country code and prefixing it so it does not pollute the main data pool.
$this->load->language('default', 'mail', $language_code);
$this->load->language('mail/gdpr_approve', 'mail', $language_code);
// Add language vars to the template folder
$results = $this->language->all('mail');
foreach ($results as $key => $value) {
$data[$key] = $value;
}
$subject = sprintf($this->language->get('mail_text_subject'), $store_name);
$this->load->model('tool/image');
if (is_file(DIR_IMAGE . $store_logo)) {
$data['logo'] = $store_url . 'image/' . $store_logo;
} else {
$data['logo'] = '';
}
$this->load->model('customer/customer');
$customer_info = $this->model_customer_customer->getCustomerByEmail($gdpr_info['email']);
if ($customer_info) {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), html_entity_decode($customer_info['firstname'], ENT_QUOTES, 'UTF-8'));
} else {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), $this->language->get('mail_text_user'));
}
$data['text_gdpr'] = sprintf($this->language->get('mail_text_gdpr'), $this->config->get('config_gdpr_limit'));
$data['text_a'] = sprintf($this->language->get('mail_text_a'), $this->config->get('config_gdpr_limit'));
$data['store_name'] = $store_name;
$data['store_url'] = $store_url;
if ($this->config->get('config_mail_engine')) {
$mail_option = [
'parameter' => $this->config->get('config_mail_parameter'),
'smtp_hostname' => $this->config->get('config_mail_smtp_hostname'),
'smtp_username' => $this->config->get('config_mail_smtp_username'),
'smtp_password' => html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES, 'UTF-8'),
'smtp_port' => $this->config->get('config_mail_smtp_port'),
'smtp_timeout' => $this->config->get('config_mail_smtp_timeout')
];
$mail = new \Opencart\System\Library\Mail($this->config->get('config_mail_engine'), $mail_option);
$mail->setTo($gdpr_info['email']);
$mail->setFrom($this->config->get('config_email'));
$mail->setSender($store_name);
$mail->setSubject($subject);
$mail->setHtml($this->load->view('mail/gdpr_approve', $data));
$mail->send();
}
}
/**
* @param array $gdpr_info
*
* @return void
* @throws \Exception
*/
public function deny(array $gdpr_info): void {
$this->load->model('setting/store');
$store_info = $this->model_setting_store->getStore($gdpr_info['store_id']);
if ($store_info) {
$this->load->model('setting/setting');
$store_logo = html_entity_decode($this->model_setting_setting->getValue('config_logo', $store_info['store_id']), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($store_info['name'], ENT_QUOTES, 'UTF-8');
$store_url = $store_info['url'];
} else {
$store_logo = html_entity_decode($this->config->get('config_logo'), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($this->config->get('config_name'), ENT_QUOTES, 'UTF-8');
$store_url = HTTP_CATALOG;
}
// Send the email in the correct language
$this->load->model('localisation/language');
$language_info = $this->model_localisation_language->getLanguage($gdpr_info['language_id']);
if ($language_info) {
$language_code = $language_info['code'];
} else {
$language_code = $this->config->get('config_language');
}
// Load the language for any mails using a different country code and prefixing it so it does not pollute the main data pool.
$this->load->language('default', 'mail', $language_code);
$this->load->language('mail/gdpr_deny', 'mail', $language_code);
// Add language vars to the template folder
$results = $this->language->all('mail');
foreach ($results as $key => $value) {
$data[$key] = $value;
}
$subject = sprintf($this->language->get('mail_text_subject'), $store_name);
$this->load->model('tool/image');
if (is_file(DIR_IMAGE . $store_logo)) {
$data['logo'] = $store_url . 'image/' . $store_logo;
} else {
$data['logo'] = '';
}
$data['text_request'] = $this->language->get('mail_text_' . $gdpr_info['action']);
$this->load->model('customer/customer');
$customer_info = $this->model_customer_customer->getCustomerByEmail($gdpr_info['email']);
if ($customer_info) {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), html_entity_decode($customer_info['firstname'], ENT_QUOTES, 'UTF-8'));
} else {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), $this->language->get('mail_text_user'));
}
$data['store_name'] = $store_name;
$data['store_url'] = $store_url;
$data['contact'] = $store_url . 'index.php?route=information/contact';
if ($this->config->get('config_mail_engine')) {
$mail_option = [
'parameter' => $this->config->get('config_mail_parameter'),
'smtp_hostname' => $this->config->get('config_mail_smtp_hostname'),
'smtp_username' => $this->config->get('config_mail_smtp_username'),
'smtp_password' => html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES, 'UTF-8'),
'smtp_port' => $this->config->get('config_mail_smtp_port'),
'smtp_timeout' => $this->config->get('config_mail_smtp_timeout')
];
$mail = new \Opencart\System\Library\Mail($this->config->get('config_mail_engine'), $mail_option);
$mail->setTo($gdpr_info['email']);
$mail->setFrom($this->config->get('config_email'));
$mail->setSender($store_name);
$mail->setSubject($subject);
$mail->setHtml($this->load->view('mail/gdpr_deny', $data));
$mail->send();
}
}
/**
* @param array $gdpr_info
*
* @return void
* @throws \Exception
*/
public function remove(array $gdpr_info): void {
$this->load->model('setting/store');
$store_info = $this->model_setting_store->getStore($gdpr_info['store_id']);
if ($store_info) {
$this->load->model('setting/setting');
$store_logo = html_entity_decode($this->model_setting_setting->getValue('config_logo', $store_info['store_id']), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($store_info['name'], ENT_QUOTES, 'UTF-8');
$store_url = $store_info['url'];
} else {
$store_logo = html_entity_decode($this->config->get('config_logo'), ENT_QUOTES, 'UTF-8');
$store_name = html_entity_decode($this->config->get('config_name'), ENT_QUOTES, 'UTF-8');
$store_url = HTTP_CATALOG;
}
// Send the email in the correct language
$this->load->model('localisation/language');
$language_info = $this->model_localisation_language->getLanguage($gdpr_info['language_id']);
if ($language_info) {
$language_code = $language_info['code'];
} else {
$language_code = $this->config->get('config_language');
}
// Load the language for any mails using a different country code and prefixing it so it does not pollute the main data pool.
$this->load->language('default', 'mail', $language_code);
$this->load->language('mail/gdpr_delete', 'mail', $language_code);
// Add language vars to the template folder
$results = $this->language->all('mail');
foreach ($results as $key => $value) {
$data[$key] = $value;
}
$subject = sprintf($this->language->get('mail_text_subject'), $store_name);
$this->load->model('tool/image');
if (is_file(DIR_IMAGE . $store_logo)) {
$data['logo'] = $store_url . 'image/' . $store_logo;
} else {
$data['logo'] = '';
}
$this->load->model('customer/customer');
$customer_info = $this->model_customer_customer->getCustomerByEmail($gdpr_info['email']);
if ($customer_info) {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), html_entity_decode($customer_info['firstname'], ENT_QUOTES, 'UTF-8'));
} else {
$data['text_hello'] = sprintf($this->language->get('mail_text_hello'), $this->language->get('mail_text_user'));
}
$data['store_name'] = $store_name;
$data['store_url'] = $store_url;
$data['contact'] = $store_url . 'index.php?route=information/contact';
if ($this->config->get('config_mail_engine')) {
$mail_option = [
'parameter' => $this->config->get('config_mail_parameter'),
'smtp_hostname' => $this->config->get('config_mail_smtp_hostname'),
'smtp_username' => $this->config->get('config_mail_smtp_username'),
'smtp_password' => html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES, 'UTF-8'),
'smtp_port' => $this->config->get('config_mail_smtp_port'),
'smtp_timeout' => $this->config->get('config_mail_smtp_timeout')
];
$mail = new \Opencart\System\Library\Mail($this->config->get('config_mail_engine'), $mail_option);
$mail->setTo($gdpr_info['email']);
$mail->setFrom($this->config->get('config_email'));
$mail->setSender($store_name);
$mail->setSubject($subject);
$mail->setHtml($this->load->view('mail/gdpr_delete', $data));
$mail->send();
}
}
}