model_checkout_order->getOrder($order_id); if ($order_info) { // If the order status returns 0, then it becomes greater than 0. Therefore, we send the default html email if (!$order_info['order_status_id'] && $order_status_id) { $this->add($order_info, $order_status_id, $comment, $notify); } // If the order status does not return 0, we send the update as a text email if ($order_info['order_status_id'] && $order_status_id && $notify) { $this->edit($order_info, $order_status_id, $comment, $notify); } } } /** * @param array $order_info * @param int $order_status_id * @param string $comment * @param bool $notify * * @return void * @throws \Exception */ public function add(array $order_info, int $order_status_id, string $comment, bool $notify): void { // Check for any downloadable products $download_status = false; $order_products = $this->model_checkout_order->getProducts($order_info['order_id']); foreach ($order_products as $order_product) { // Check if there are any linked downloads $product_download_query = $this->db->query("SELECT COUNT(*) AS `total` FROM `" . DB_PREFIX . "product_to_download` WHERE `product_id` = '" . (int)$order_product['product_id'] . "'"); if ($product_download_query->row['total']) { $download_status = true; } } $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'); if (!defined('HTTP_CATALOG')) { $store_url = HTTP_SERVER; } else { $store_url = HTTP_CATALOG; } $this->load->model('setting/store'); $store_info = $this->model_setting_store->getStore($order_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']; } $this->load->model('localisation/language'); $language_info = $this->model_localisation_language->getLanguage($order_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/order_add', '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, $order_info['order_id']); $this->load->model('tool/image'); if (is_file(DIR_IMAGE . $store_logo)) { $data['logo'] = $store_url . 'image/' . $store_logo; } else { $data['logo'] = ''; } $data['title'] = sprintf($this->language->get('mail_text_subject'), $store_name, $order_info['order_id']); $data['text_greeting'] = sprintf($this->language->get('mail_text_greeting'), $order_info['store_name']); $data['store'] = $store_name; $data['store_url'] = $order_info['store_url']; $data['customer_id'] = $order_info['customer_id']; $data['link'] = $order_info['store_url'] . 'index.php?route=account/order.info&order_id=' . $order_info['order_id']; if ($download_status) { $data['download'] = $order_info['store_url'] . 'index.php?route=account/download'; } else { $data['download'] = ''; } $data['order_id'] = $order_info['order_id']; $data['date_added'] = date($this->language->get('date_format_short'), strtotime($order_info['date_added'])); $data['payment_method'] = $order_info['payment_method']['name']; $data['shipping_method'] = $order_info['shipping_method']['name']; $data['email'] = $order_info['email']; $data['telephone'] = $order_info['telephone']; $data['ip'] = $order_info['ip']; $order_status_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "order_status` WHERE `order_status_id` = '" . (int)$order_status_id . "' AND `language_id` = '" . (int)$order_info['language_id'] . "'"); if ($order_status_query->num_rows) { $data['order_status'] = $order_status_query->row['name']; } else { $data['order_status'] = ''; } if ($comment) { $data['comment'] = nl2br($comment); } else { $data['comment'] = ''; } // Payment Address if ($order_info['payment_address_format']) { $format = $order_info['payment_address_format']; } else { $format = '{firstname} {lastname}' . "\n" . '{company}' . "\n" . '{address_1}' . "\n" . '{address_2}' . "\n" . '{city} {postcode}' . "\n" . '{zone}' . "\n" . '{country}'; } $find = [ '{firstname}', '{lastname}', '{company}', '{address_1}', '{address_2}', '{city}', '{postcode}', '{zone}', '{zone_code}', '{country}' ]; $replace = [ 'firstname' => $order_info['payment_firstname'], 'lastname' => $order_info['payment_lastname'], 'company' => $order_info['payment_company'], 'address_1' => $order_info['payment_address_1'], 'address_2' => $order_info['payment_address_2'], 'city' => $order_info['payment_city'], 'postcode' => $order_info['payment_postcode'], 'zone' => $order_info['payment_zone'], 'zone_code' => $order_info['payment_zone_code'], 'country' => $order_info['payment_country'] ]; $data['payment_address'] = str_replace(["\r\n", "\r", "\n"], '
', preg_replace(["/\s\s+/", "/\r\r+/", "/\n\n+/"], '
', trim(str_replace($find, $replace, $format)))); // Shipping Address if ($order_info['shipping_address_format']) { $format = $order_info['shipping_address_format']; } else { $format = '{firstname} {lastname}' . "\n" . '{company}' . "\n" . '{address_1}' . "\n" . '{address_2}' . "\n" . '{city} {postcode}' . "\n" . '{zone}' . "\n" . '{country}'; } $find = [ '{firstname}', '{lastname}', '{company}', '{address_1}', '{address_2}', '{city}', '{postcode}', '{zone}', '{zone_code}', '{country}' ]; $replace = [ 'firstname' => $order_info['shipping_firstname'], 'lastname' => $order_info['shipping_lastname'], 'company' => $order_info['shipping_company'], 'address_1' => $order_info['shipping_address_1'], 'address_2' => $order_info['shipping_address_2'], 'city' => $order_info['shipping_city'], 'postcode' => $order_info['shipping_postcode'], 'zone' => $order_info['shipping_zone'], 'zone_code' => $order_info['shipping_zone_code'], 'country' => $order_info['shipping_country'] ]; $data['shipping_address'] = str_replace(["\r\n", "\r", "\n"], '
', preg_replace(["/\s\s+/", "/\r\r+/", "/\n\n+/"], '
', trim(str_replace($find, $replace, $format)))); $this->load->model('tool/upload'); // Products $data['products'] = []; foreach ($order_products as $order_product) { $option_data = []; $order_options = $this->model_checkout_order->getOptions($order_info['order_id'], $order_product['order_product_id']); foreach ($order_options as $order_option) { if ($order_option['type'] != 'file') { $value = $order_option['value']; } else { $upload_info = $this->model_tool_upload->getUploadByCode($order_option['value']); if ($upload_info) { $value = $upload_info['name']; } else { $value = ''; } } $option_data[] = [ 'name' => $order_option['name'], 'value' => (oc_strlen($value) > 20 ? oc_substr($value, 0, 20) . '..' : $value) ]; } $description = ''; $this->load->model('checkout/order'); $subscription_info = $this->model_checkout_order->getSubscription($order_info['order_id'], $order_product['order_product_id']); if ($subscription_info) { if ($subscription_info['trial_status']) { $trial_price = $this->currency->format($subscription_info['trial_price'] + ($this->config->get('config_tax') ? $subscription_info['trial_tax'] : 0), $order_info['currency_code'], $order_info['currency_value']); $trial_cycle = $subscription_info['trial_cycle']; $trial_frequency = $this->language->get('text_' . $subscription_info['trial_frequency']); $trial_duration = $subscription_info['trial_duration']; $description .= sprintf($this->language->get('text_subscription_trial'), $trial_price, $trial_cycle, $trial_frequency, $trial_duration); } $price = $this->currency->format($subscription_info['price'] + ($this->config->get('config_tax') ? $subscription_info['tax'] : 0), $order_info['currency_code'], $order_info['currency_value']); $cycle = $subscription_info['cycle']; $frequency = $this->language->get('text_' . $subscription_info['frequency']); $duration = $subscription_info['duration']; if ($duration) { $description .= sprintf($this->language->get('text_subscription_duration'), $price, $cycle, $frequency, $duration); } else { $description .= sprintf($this->language->get('text_subscription_cancel'), $price, $cycle, $frequency); } } $data['products'][] = [ 'name' => $order_product['name'], 'model' => $order_product['model'], 'option' => $option_data, 'subscription' => $description, 'quantity' => $order_product['quantity'], 'price' => $this->currency->format($order_product['price'] + ($this->config->get('config_tax') ? $order_product['tax'] : 0), $order_info['currency_code'], $order_info['currency_value']), 'total' => $this->currency->format($order_product['total'] + ($this->config->get('config_tax') ? ($order_product['tax'] * $order_product['quantity']) : 0), $order_info['currency_code'], $order_info['currency_value']), 'reward' => $order_product['reward'] ]; } // Vouchers $data['vouchers'] = []; $order_vouchers = $this->model_checkout_order->getVouchers($order_info['order_id']); foreach ($order_vouchers as $order_voucher) { $data['vouchers'][] = [ 'description' => $order_voucher['description'], 'amount' => $this->currency->format($order_voucher['amount'], $order_info['currency_code'], $order_info['currency_value']), ]; } // Order Totals $data['totals'] = []; $order_totals = $this->model_checkout_order->getTotals($order_info['order_id']); foreach ($order_totals as $order_total) { $data['totals'][] = [ 'title' => $order_total['title'], 'text' => $this->currency->format($order_total['value'], $order_info['currency_code'], $order_info['currency_value']), ]; } $this->load->model('setting/setting'); $from = $this->model_setting_setting->getValue('config_email', $order_info['store_id']); if (!$from) { $from = $this->config->get('config_email'); } 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($order_info['email']); $mail->setFrom($from); $mail->setSender($store_name); $mail->setSubject($subject); $mail->setHtml($this->load->view('mail/order_invoice', $data)); $mail->send(); } } /** * @param array $order_info * @param int $order_status_id * @param string $comment * @param bool $notify * * @return void * @throws \Exception */ public function edit(array $order_info, int $order_status_id, string $comment, bool $notify): void { $store_name = html_entity_decode($this->config->get('config_name'), ENT_QUOTES, 'UTF-8'); if (!defined('HTTP_CATALOG')) { $store_url = HTTP_SERVER; } else { $store_url = HTTP_CATALOG; } $this->load->model('setting/store'); $store_info = $this->model_setting_store->getStore($order_info['store_id']); if ($store_info) { $store_name = html_entity_decode($store_info['name'], ENT_QUOTES, 'UTF-8'); $store_url = $store_info['url']; } $this->load->model('localisation/language'); $language_info = $this->model_localisation_language->getLanguage($order_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/order_edit', '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, $order_info['order_id']); $data['order_id'] = $order_info['order_id']; $data['date_added'] = date($this->language->get('date_format_short'), strtotime($order_info['date_added'])); $order_status_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "order_status` WHERE `order_status_id` = '" . (int)$order_status_id . "' AND `language_id` = '" . (int)$order_info['language_id'] . "'"); if ($order_status_query->num_rows) { $data['order_status'] = $order_status_query->row['name']; } else { $data['order_status'] = ''; } if ($order_info['customer_id']) { $data['link'] = $order_info['store_url'] . 'index.php?route=account/order.info&order_id=' . $order_info['order_id']; } else { $data['link'] = ''; } $data['comment'] = strip_tags($comment); $data['store'] = $store_name; $data['store_url'] = $store_url; $this->load->model('setting/setting'); $from = $this->model_setting_setting->getValue('config_email', $order_info['store_id']); if (!$from) { $from = $this->config->get('config_email'); } 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($order_info['email']); $mail->setFrom($from); $mail->setSender($store_name); $mail->setSubject($subject); $mail->setHtml($this->load->view('mail/order_history', $data)); $mail->send(); } } // catalog/model/checkout/order/addHistory/before /** * @param string $route * @param array $args * * @return void * @throws \Exception */ public function alert(string &$route, array &$args): void { if (isset($args[0])) { $order_id = $args[0]; } else { $order_id = 0; } if (isset($args[1])) { $order_status_id = $args[1]; } else { $order_status_id = 0; } if (isset($args[2])) { $comment = $args[2]; } else { $comment = ''; } if (isset($args[3])) { $notify = $args[3]; } else { $notify = ''; } $order_info = $this->model_checkout_order->getOrder($order_id); if ($order_info && !$order_info['order_status_id'] && $order_status_id && in_array('order', (array)$this->config->get('config_mail_alert'))) { $this->load->language('mail/order_alert'); $subject = html_entity_decode(sprintf($this->language->get('text_subject'), $this->config->get('config_name'), $order_info['order_id']), ENT_QUOTES, 'UTF-8'); $data['order_id'] = $order_info['order_id']; $data['date_added'] = date($this->language->get('date_format_short'), strtotime($order_info['date_added'])); $order_status_query = $this->db->query("SELECT * FROM `" . DB_PREFIX . "order_status` WHERE `order_status_id` = '" . (int)$order_status_id . "' AND `language_id` = '" . (int)$this->config->get('config_language_id') . "'"); if ($order_status_query->num_rows) { $data['order_status'] = $order_status_query->row['name']; } else { $data['order_status'] = ''; } $this->load->model('tool/upload'); $data['products'] = []; $order_products = $this->model_checkout_order->getProducts($order_id); foreach ($order_products as $order_product) { $option_data = []; $order_options = $this->model_checkout_order->getOptions($order_info['order_id'], $order_product['order_product_id']); foreach ($order_options as $order_option) { if ($order_option['type'] != 'file') { $value = $order_option['value']; } else { $upload_info = $this->model_tool_upload->getUploadByCode($order_option['value']); if ($upload_info) { $value = $upload_info['name']; } else { $value = ''; } } $option_data[] = [ 'name' => $order_option['name'], 'value' => (oc_strlen($value) > 20 ? oc_substr($value, 0, 20) . '..' : $value) ]; } $description = ''; $this->load->model('checkout/subscription'); $subscription_info = $this->model_checkout_order->getSubscription($order_info['order_id'], $order_product['order_product_id']); if ($subscription_info) { if ($subscription_info['trial_status']) { $trial_price = $this->currency->format($subscription_info['trial_price'] + ($this->config->get('config_tax') ? $subscription_info['trial_tax'] : 0), $this->session->data['currency']); $trial_cycle = $subscription_info['trial_cycle']; $trial_frequency = $this->language->get('text_' . $subscription_info['trial_frequency']); $trial_duration = $subscription_info['trial_duration']; $description .= sprintf($this->language->get('text_subscription_trial'), $trial_price, $trial_cycle, $trial_frequency, $trial_duration); } $price = $this->currency->format($subscription_info['price'] + ($this->config->get('config_tax') ? $subscription_info['tax'] : 0), $this->session->data['currency']); $cycle = $subscription_info['cycle']; $frequency = $this->language->get('text_' . $subscription_info['frequency']); $duration = $subscription_info['duration']; if ($duration) { $description .= sprintf($this->language->get('text_subscription_duration'), $price, $cycle, $frequency, $duration); } else { $description .= sprintf($this->language->get('text_subscription_cancel'), $price, $cycle, $frequency); } } $data['products'][] = [ 'name' => $order_product['name'], 'model' => $order_product['model'], 'quantity' => $order_product['quantity'], 'option' => $option_data, 'subscription' => $description, 'total' => html_entity_decode($this->currency->format($order_product['total'] + ($this->config->get('config_tax') ? $order_product['tax'] * $order_product['quantity'] : 0), $order_info['currency_code'], $order_info['currency_value']), ENT_NOQUOTES, 'UTF-8') ]; } $data['vouchers'] = []; $order_vouchers = $this->model_checkout_order->getVouchers($order_id); foreach ($order_vouchers as $order_voucher) { $data['vouchers'][] = [ 'description' => $order_voucher['description'], 'amount' => html_entity_decode($this->currency->format($order_voucher['amount'], $order_info['currency_code'], $order_info['currency_value']), ENT_NOQUOTES, 'UTF-8') ]; } $data['totals'] = []; $order_totals = $this->model_checkout_order->getTotals($order_id); foreach ($order_totals as $order_total) { $data['totals'][] = [ 'title' => $order_total['title'], 'value' => html_entity_decode($this->currency->format($order_total['value'], $order_info['currency_code'], $order_info['currency_value']), ENT_NOQUOTES, 'UTF-8') ]; } $data['comment'] = nl2br($order_info['comment']); $data['store'] = html_entity_decode($order_info['store_name'], ENT_QUOTES, 'UTF-8'); $data['store_url'] = $order_info['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($this->config->get('config_email')); $mail->setFrom($this->config->get('config_email')); $mail->setSender(html_entity_decode($order_info['store_name'], ENT_QUOTES, 'UTF-8')); $mail->setSubject($subject); $mail->setHtml($this->load->view('mail/order_alert', $data)); $mail->send(); // Send to additional alert emails $emails = explode(',', $this->config->get('config_mail_alert_email')); foreach ($emails as $email) { if ($email && filter_var($email, FILTER_VALIDATE_EMAIL)) { $mail->setTo(trim($email)); $mail->send(); } } } } } }