Вход Регистрация
Файл: upload/catalog/model/openbay/ebay_order.php
Строк: 939
<?php
class ModelOpenbayEbayOrder extends Model{
    public function 
addOrderLine($data$order_id$created) {
        
$order_line $this->getOrderLine($data['txn_id'], $data['item_id']);

        
$created_hours = (int)$this->config->get('ebay_created_hours');
        if (
$created_hours == || $created_hours == '') {
            
$created_hours 24;
        }
        
$from date("Y-m-d H:i:00"mktime(date("H")-$created_hoursdate("i"), date("s"), date("m"), date("d"), date("y")));

        if (
$order_line === false) {
            if (
$created >= $from) {
                
$this->openbay->ebay->log('addOrderLine() - New line');
                
$product_id $this->openbay->ebay->getProductId($data['item_id']);
                
/* add to the transaction table */
                
$this->db->query("
                    INSERT INTO `" 
DB_PREFIX "ebay_transaction`
                    SET
                    `order_id`                  = '" 
. (int)$order_id "',
                    `txn_id`                    = '" 
$this->db->escape($data['txn_id']) . "',
                    `item_id`                   = '" 
$this->db->escape($data['item_id']) . "',
                    `product_id`                = '" 
. (int)$product_id "',
                    `containing_order_id`       = '" 
$data['containing_order_id'] . "',
                    `order_line_id`             = '" 
$this->db->escape($data['order_line_id']) . "',
                    `qty`                       = '" 
. (int)$data['qty'] . "',
                    `smp_id`                    = '" 
. (int)$data['smp_id'] . "',
                    `sku`                       = '" 
$this->db->escape($data['sku']) . "',
                    `created`                   = now(),
                    `modified`                  = now()
                "
);

                if (!empty(
$product_id)) {
                    
$this->openbay->ebay->log('Link found');
                    
$this->modifyStock($product_id$data['qty'], '-'$data['sku']);
                }
            } else {
                
$this->openbay->ebay->log('addOrderLine() - Transaction is older than ' $this->config->get('ebay_created_hours') . ' hours');
            }
        } else {
            
$this->openbay->ebay->log('addOrderLine() - Line existed');

            if (
$order_id != $order_line['order_id']) {
                
$this->openbay->ebay->log('addOrderLine() - Order ID has changed from "' $order_line['order_id'] . '" to "' $order_id '"');
                
$this->db->query("UPDATE `" DB_PREFIX "ebay_transaction` SET `order_id` = '" . (int)$order_id "', `modified` = now() WHERE `txn_id` = '" $this->db->escape((string)$data['txn_id']) . "' AND `item_id` = '" $this->db->escape((string)$data['item_id']) . "' LIMIT 1");

                
//if the order id has changed then remove the old order details
                
$this->delete($order_line['order_id']);
            }

            if (
$order_line['smp_id'] != $data['smp_id']) {
                
$this->openbay->ebay->log('addOrderLine() - SMP ID for orderLine has changed from "' $order_line['smp_id'] . '" to "' $data['smp_id'] . '"');
                
$this->db->query("UPDATE `" DB_PREFIX "ebay_transaction` SET `smp_id` = '" $data['smp_id'] . "', `modified` = now() WHERE `txn_id` = '" $this->db->escape((string)$data['txn_id']) . "' AND `item_id` = '" $this->db->escape((string)$data['item_id']) . "' LIMIT 1");
            }

            if (
$order_line['containing_order_id'] != $data['containing_order_id']) {
                
$this->openbay->ebay->log('addOrderLine() - Containing order ID for orderLine has changed from "' $order_line['containing_order_id'] . '" to "' $data['containing_order_id'] . '"');
                
$this->db->query("UPDATE `" DB_PREFIX "ebay_transaction` SET `containing_order_id` = '" $this->db->escape($data['containing_order_id']) . "', `modified` = now() WHERE `txn_id` = '" $this->db->escape((string)$data['txn_id']) . "' AND `item_id` = '" $this->db->escape((string)$data['item_id']) . "' LIMIT 1");
            }
        }
        
$this->openbay->ebay->log('addOrderLine() - Done');
    }

    public function 
addOrderLines($order$order_id) {
        
$this->openbay->ebay->log('Adding order lines');

        foreach (
$order->txn as $txn) {
            
$this->model_openbay_ebay_order->addOrderLine(array(
                
'txn_id'                => (string)$txn->item->txn,
                
'item_id'               => (string)$txn->item->id,
                
'containing_order_id'   => (string)$order->order->id,
                
'order_line_id'         => (string)$txn->item->line,
                
'qty'                   => (int)$txn->item->qty,
                
'smp_id'                => (string)$order->smp->id,
                
'sku'                   => (string)$txn->item->variantsku
            
), (int)$order_id$order->order->created);
        }
    }

    public function 
getOrderLine($txn_id$item_id) {
        
$this->openbay->ebay->log('getOrderLine() - Testing for order line txn: ' $txn_id ', item: ' $item_id);
        
$res $this->db->query("SELECT * FROM `" DB_PREFIX "ebay_transaction` WHERE `txn_id` = '" $this->db->escape($txn_id) . "' AND `item_id` = '" $this->db->escape($item_id) . "' LIMIT 1");

        if (
$res->num_rows == 0) {
            return 
false;
        } else {
            return 
$res->row;
        }
    }

    public function 
getOrderLines($order_id) {
        
$this->openbay->ebay->log('getOrderLines() - Testing for order lines id: ' $order_id);

        
$result $this->db->query("SELECT * FROM `" DB_PREFIX "ebay_transaction` WHERE `order_id` = '" . (int)$order_id "'");

        
$lines = array();

        foreach (
$result->rows as $line) {
            
$lines[] = $line;
        }

        return 
$lines;
    }

    public function 
removeOrderLines($canceling) {

        foreach (
$canceling as $cancel) {
            
$line $this->getOrderLine($cancel['txn'], $cancel['id']);

            if (
$line === false) {
                
$this->openbay->ebay->log('No line needs cancelling');
            } else {
                
$this->openbay->ebay->log('Found order line to cancel');
                
$this->removeOrderLine($cancel['txn'], $cancel['id'], $line);
            }
        }
    }

    private function 
removeOrderLine($txn_id$item_id$line) {
        
$this->openbay->ebay->log('Removing order line, txn: ' $txn_id ',item id: ' $item_id);

        
$this->db->query("DELETE FROM `" DB_PREFIX "ebay_transaction` WHERE `txn_id` = '" $this->db->escape($txn_id) . "' AND `item_id` = '" $this->db->escape($item_id) . "' LIMIT 1");

        if (
$this->db->countAffected() > 0) {
            
$this->modifyStock($line['product_id'], $line['qty'], '+'$line['sku']);
        }
    }

    public function 
cancel($order_id) {
        
$order_lines $this->getOrderLines($order_id);

        foreach (
$order_lines as $line) {
            
$this->modifyStock($line['product_id'], $line['qty'], '+'$line['sku']);
        }
    }

    public function 
updatePaymentDetails($order_id$order) {
        
$this->db->query("UPDATE `" DB_PREFIX "order` SET `payment_method` = '" $this->db->escape($order->payment->method) . "', `total` = '" . (double)$order->order->total "', `date_modified` = NOW() WHERE `order_id` = '" . (int)$order_id "'");
    }

    public function 
getHistory($order_id) {
        
$this->openbay->ebay->log('Getting order history for ID: ' $order_id);

        
$query $this->db->query("SELECT `order_status_id` FROM `" DB_PREFIX "order_history` WHERE `order_id` = '" . (int)$order_id "'");

        
$status = array();

        if (
$query->num_rows) {
            foreach (
$query->rows as $row) {
                
$status[] = $row['order_status_id'];
            }
        }

        return 
$status;
    }

    public function 
hasAddress($order_id) {
        
// check if the first name, address 1 and country are set
        
$query $this->db->query("SELECT * FROM `" DB_PREFIX "order` WHERE `order_id` = '" . (int)$order_id "' AND `payment_firstname` != '' AND `payment_address_1` != '' AND `payment_country` != ''");

        if (
$query->num_rows == 0) {
            return 
false;
        } else {
            return 
true;
        }
    }

    public function 
update($order_id$order_status_id$comment '') {
        
$order_info $this->model_checkout_order->getOrder($order_id);

        
$notify $this->config->get('ebay_update_notify');

        if (
$order_info) {
            
$this->db->query("UPDATE `" DB_PREFIX "order` SET order_status_id = '" . (int)$order_status_id "', date_modified = NOW() WHERE order_id = '" . (int)$order_id "'");

            
$this->db->query("INSERT INTO " DB_PREFIX "order_history SET order_id = '" . (int)$order_id "', order_status_id = '" . (int)$order_status_id "', notify = '" . (int)$notify "', comment = '" $this->db->escape($comment) . "', date_added = NOW()");

            if (
$notify) {
                
$language = new Language($order_info['language_directory']);
                
$language->load($order_info['language_directory']);
                
$language->load('mail/order');

                
$subject sprintf($language->get('text_update_subject'), html_entity_decode($order_info['store_name'], ENT_QUOTES'UTF-8'), $order_id);

                
$message  $language->get('text_update_order') . ' ' $order_id "n";
                
$message .= $language->get('text_update_date_added') . ' ' date($language->get('date_format_short'), strtotime($order_info['date_added'])) . "nn";

                
$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) {
                    
$message .= $language->get('text_update_order_status') . "nn";
                    
$message .= $order_status_query->row['name'] . "nn";
                }

                if (
$order_info['customer_id']) {
                    
$message .= $language->get('text_update_link') . "n";
                    
$message .= $order_info['store_url'] . 'index.php?route=account/order/info&order_id=' $order_id "nn";
                }

                if (
$comment) {
                    
$message .= $language->get('text_update_comment') . "nn";
                    
$message .= $comment "nn";
                }

                
$message .= $language->get('text_update_footer');

                
$message .= "nn";
                
$message .= 'eBay and Amazon order management - http://www.openbaypro.com/';

                
$mail = new Mail();
                
$mail->protocol $this->config->get('config_mail_protocol');
                
$mail->parameter $this->config->get('config_mail_parameter');
                
$mail->smtp_hostname $this->config->get('config_mail_smtp_hostname');
                
$mail->smtp_username $this->config->get('config_mail_smtp_username');
                
$mail->smtp_password html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES'UTF-8');
                
$mail->smtp_port $this->config->get('config_mail_smtp_port');
                
$mail->smtp_timeout $this->config->get('config_mail_smtp_timeout');

                
$mail->setTo($order_info['email']);
                
$mail->setFrom($this->config->get('config_email'));
                
$mail->setSender(html_entity_decode($order_info['store_name'], ENT_QUOTES'UTF-8'));
                
$mail->setSubject(html_entity_decode($subjectENT_QUOTES'UTF-8'));
                
$mail->setText($message);
                
$mail->send();
            }
        }
    }

    public function 
confirm($order_id$order_status_id$comment '') {
        
$order_info $this->model_checkout_order->getOrder($order_id);
        
$notify $this->config->get('ebay_confirm_notify');

        if (
$order_info && !$order_info['order_status_id']) {
            
$this->db->query("UPDATE `" DB_PREFIX "order` SET order_status_id = '" . (int)$order_status_id "', date_modified = NOW() WHERE order_id = '" . (int)$order_id "'");
            
$this->db->query("INSERT INTO " DB_PREFIX "order_history SET order_id = '" . (int)$order_id "', order_status_id = '" . (int)$order_status_id "', notify = '" . (int)$notify "', comment = '" $this->db->escape($comment) . "', date_added = NOW()");

            if (isset(
$order_info['email']) && !empty($order_info['email']) && $notify == 1){
                
$order_product_query $this->db->query("SELECT * FROM `" DB_PREFIX "order_product` WHERE `order_id` = '" . (int)$order_id "'");

                
$this->cache->delete('product');

                
// Order Totals
                
$order_total_query $this->db->query("SELECT * FROM `" DB_PREFIX "order_total` WHERE `order_id` = '" . (int)$order_id "' ORDER BY `sort_order` ASC");

                foreach (
$order_total_query->rows as $order_total) {
                    
$this->load->model('total/' $order_total['code']);

                    if (
method_exists($this->{'model_total_' $order_total['code']}, 'confirm')) {
                        
$this->{'model_total_' $order_total['code']}->confirm($order_info$order_total);
                    }
                }

                
// Send out order confirmation mail
                
$language = new Language($order_info['language_directory']);
                
$language->load($order_info['language_directory']);
                
$language->load('mail/order');

                
$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) {
                    
$order_status $order_status_query->row['name'];
                } else {
                    
$order_status '';
                }

                
$subject sprintf($language->get('text_new_subject'), html_entity_decode($order_info['store_name'], ENT_QUOTES'UTF-8'), $order_id);

                
// HTML Mail
                
$data = array();

                
$data['title'] = sprintf($language->get('text_new_subject'), $order_info['store_name'], $order_id);
                
$data['text_greeting'] = sprintf($language->get('text_new_greeting'), $order_info['store_name']);
                
$data['text_link'] = $language->get('text_new_link');
                
$data['text_download'] = $language->get('text_new_download');
                
$data['text_order_detail'] = $language->get('text_new_order_detail');
                
$data['text_instruction'] = $language->get('text_new_instruction');
                
$data['text_order_id'] = $language->get('text_new_order_id');
                
$data['text_date_added'] = $language->get('text_new_date_added');
                
$data['text_payment_method'] = $language->get('text_new_payment_method');
                
$data['text_shipping_method'] = $language->get('text_new_shipping_method');
                
$data['text_email'] = $language->get('text_new_email');
                
$data['text_telephone'] = $language->get('text_new_telephone');
                
$data['text_ip'] = $language->get('text_new_ip');
                
$data['text_order_status'] = $language->get('text_new_order_status');
                
$data['text_payment_address'] = $language->get('text_new_payment_address');
                
$data['text_shipping_address'] = $language->get('text_new_shipping_address');
                
$data['text_product'] = $language->get('text_new_product');
                
$data['text_model'] = $language->get('text_new_model');
                
$data['text_quantity'] = $language->get('text_new_quantity');
                
$data['text_price'] = $language->get('text_new_price');
                
$data['text_total'] = $language->get('text_new_total');
                
$data['text_footer'] = $language->get('text_new_footer');

                if (
$this->config->get('ebay_email_brand_disable') == 1) {
                    
$data['text_powered'] = '';
                } else {
                    
$data['text_powered'] = '<a href="http://www.openbaypro.com/">OpenBay Pro - eBay and Amazon order management for OpenCart</a> . ';
                }

                
$data['logo'] = HTTPS_SERVER  'image/' $this->config->get('config_logo');
                
$data['store_name'] = $order_info['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_id;

                
$data['download'] = '';

                
$data['order_id'] = $order_id;
                
$data['date_added'] = date($language->get('date_format_short'), strtotime($order_info['date_added']));
                
$data['payment_method'] = $order_info['payment_method'];
                
$data['shipping_method'] = $order_info['shipping_method'];
                
$data['email'] = $order_info['email'];
                
$data['telephone'] = $order_info['telephone'];
                
$data['ip'] = $order_info['ip'];
                
$data['order_status'] = $order_status;

                
$data['comment'] = '';

                if (
$comment && $notify) {
                    
$data['comment'] = nl2br($comment);
                }

                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 = array(
                    
'{firstname}',
                    
'{lastname}',
                    
'{company}',
                    
'{address_1}',
                    
'{address_2}',
                    
'{city}',
                    
'{postcode}',
                    
'{zone}',
                    
'{zone_code}',
                    
'{country}'
                
);

                
$replace = array(
                    
'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(array("rn""r""n"), '<br />'preg_replace(array("/ss+/""/rr+/""/nn+/"), '<br />'trim(str_replace($find$replace$format))));

                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 = array(
                    
'{firstname}',
                    
'{lastname}',
                    
'{company}',
                    
'{address_1}',
                    
'{address_2}',
                    
'{city}',
                    
'{postcode}',
                    
'{zone}',
                    
'{zone_code}',
                    
'{country}'
                
);

                
$replace = array(
                    
'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(array("rn""r""n"), '<br />'preg_replace(array("/ss+/""/rr+/""/nn+/"), '<br />'trim(str_replace($find$replace$format))));
                
$data['products']         = array();

                foreach (
$order_product_query->rows as $product) {
                    
$option_data = array();

                    
$order_option_query $this->db->query("SELECT * FROM " DB_PREFIX "order_option WHERE order_id = '" . (int)$order_id "' AND order_product_id = '" . (int)$product['order_product_id'] . "'");

                    foreach (
$order_option_query->rows as $option) {
                        if (
$option['type'] != 'file') {
                            
$value $option['value'];
                        } else {
                            
$value utf8_substr($option['value'], 0utf8_strrpos($option['value'], '.'));
                        }

                        
$option_data[] = array(
                            
'name'  => $option['name'],
                            
'value' => (utf8_strlen($value) > 20) ? utf8_substr($value020) . '..' $value
                        
);
                    }

                    
$data['products'][] = array(
                        
'name'     => $product['name'],
                        
'model'    => $product['model'],
                        
'option'   => $option_data,
                        
'quantity' => $product['quantity'],
                        
'price'    => $this->currency->format($product['price'] + ($this->config->get('config_tax') ? $product['tax'] : 0), $order_info['currency_code'], $order_info['currency_value']),
                        
'total'    => $this->currency->format($product['total'] + ($this->config->get('config_tax') ? ($product['tax'] * $product['quantity']) : 0), $order_info['currency_code'], $order_info['currency_value'])
                    );
                }

                
$data['vouchers'] = array();

                foreach (
$order_total_query->rows as $total) {
                    
$data['totals'][] = array(
                        
'title' => $total['title'],
                        
'text'  => $this->currency->format($total['value'], $order_info['currency_code'], $order_info['currency_value']),
                    );
                }

                if (
file_exists(DIR_TEMPLATE $this->config->get('config_template') . '/template/mail/order.tpl')) {
                    
$html $this->load->view($this->config->get('config_template') . '/template/mail/order.tpl'$data);
                } else {
                    
$html $this->load->view('default/template/mail/order.tpl'$data);
                }

                
// Text Mail
                
$text  sprintf($language->get('text_new_greeting'), html_entity_decode($order_info['store_name'], ENT_QUOTES'UTF-8')) . "nn";
                
$text .= $language->get('text_new_order_id') . ' ' $order_id "n";
                
$text .= $language->get('text_new_date_added') . ' ' date($language->get('date_format_short'), strtotime($order_info['date_added'])) . "n";
                
$text .= $language->get('text_new_order_status') . ' ' $order_status "nn";

                if (
$comment && $notify) {
                    
$text .= $language->get('text_new_instruction') . "nn";
                    
$text .= $comment "nn";
                }

                
// Products
                
$text .= $language->get('text_new_products') . "n";

                foreach (
$order_product_query->rows as $product) {
                    
$text .= $product['quantity'] . 'x ' $product['name'] . ' (' $product['model'] . ') ' html_entity_decode($this->currency->format($product['total'] + ($this->config->get('config_tax') ? ($product['tax'] * $product['quantity']) : 0), $order_info['currency_code'], $order_info['currency_value']), ENT_NOQUOTES'UTF-8') . "n";

                    
$order_option_query $this->db->query("SELECT * FROM " DB_PREFIX "order_option WHERE order_id = '" . (int)$order_id "' AND order_product_id = '" . (int)$product['order_product_id'] . "'");

                    foreach (
$order_option_query->rows as $option) {
                        
$text .= chr(9) . '-' $option['name'] . ' ' . (utf8_strlen($option['value']) > 20) ? utf8_substr($option['value'], 020) . '..' $option['value'] . "n";
                    }
                }

                
$text .= "n";

                
$text .= $language->get('text_new_order_total') . "n";

                foreach (
$order_total_query->rows as $total) {
                    
$text .= $total['title'] . ': ' html_entity_decode($this->currency->format($total['value'], $order_info['currency_code'], $order_info['currency_value']), ENT_NOQUOTES'UTF-8') . "n";
                }

                
$text .= "n";

                if (
$order_info['customer_id']) {
                    
$text .= $language->get('text_new_link') . "n";
                    
$text .= $order_info['store_url'] . 'index.php?route=account/order/info&order_id=' $order_id "nn";
                }

                if (
$order_info['comment']) {
                    
$text .= $language->get('text_new_comment') . "nn";
                    
$text .= $order_info['comment'] . "nn";
                }

                
$text .= $language->get('text_new_footer') . "nn";

                if (
$notify == 1) {
                    if (
version_compare(VERSION'2.0.2''<')) {
                        
$mail = new Mail($this->config->get('config_mail'));
                    } else {
                        
$mail = new Mail();
                        
$mail->protocol $this->config->get('config_mail_protocol');
                        
$mail->parameter $this->config->get('config_mail_parameter');
                        
$mail->smtp_hostname $this->config->get('config_mail_smtp_hostname');
                        
$mail->smtp_username $this->config->get('config_mail_smtp_username');
                        
$mail->smtp_password html_entity_decode($this->config->get('config_mail_smtp_password'), ENT_QUOTES'UTF-8');
                        
$mail->smtp_port $this->config->get('config_mail_smtp_port');
                        
$mail->smtp_timeout $this->config->get('config_mail_smtp_timeout');
                    }

                    
$mail->setTo($order_info['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($html);
                    
$mail->setText($text);
                    
$mail->send();
                }
            }
        }
    }

    private function 
modifyStock($product_id$qty$symbol '-'$sku '') {
        
$this->openbay->ebay->log('modifyStock() - Updating stock. Product id: ' $product_id ' qty: ' $qty ', symbol: ' $symbol ' sku: ' $sku);

        
$item_id $this->openbay->ebay->getEbayItemId($product_id);

        if (
$this->openbay->addonLoad('openstock') && !empty($sku)) {
            
$this->db->query("UPDATE `" DB_PREFIX "product_option_variant` SET `stock` = (`stock` " $this->db->escape((string)$symbol) . " " . (int)$qty ") WHERE `sku` = '" . (string)$sku "' AND `product_id` = '" . (int)$product_id "' AND `subtract` = '1'");

            
$stock $this->openbay->ebay->getProductStockLevel($product_id$sku);

            
$this->openbay->ebay->log('modifyStock() /variant  - Stock is now set to: ' $stock['quantity']);

            
$this->openbay->ebay->putStockUpdate($item_id$stock['quantity'], $sku);
        } else {
            
$this->db->query("UPDATE `" DB_PREFIX "product` SET `quantity` = (`quantity` " $this->db->escape((string)$symbol) . " " . (int)$qty ") WHERE `product_id` = '" . (int)$product_id "' AND `subtract` = '1'");

            
$stock $this->openbay->ebay->getProductStockLevel($product_id);

            
$this->openbay->ebay->log('modifyStock() - Stock is now set to: ' $stock['quantity']);

            
//send back stock update to eBay incase of a reserve product level
            
$this->openbay->ebay->putStockUpdate($item_id$stock['quantity']);
        }
    }

    public function 
getCountryAddressFormat($iso2) {
        
$this->openbay->ebay->log('getCountryAddressFormat() - Getting country from ISO2: ' $iso2);

        
$query $this->db->query("SELECT * FROM `" DB_PREFIX "country` WHERE `iso_code_2` = '" $this->db->escape($iso2) . "' LIMIT 1");

        if (!isset(
$query->row['address_format']) || $query->row['address_format'] == '') {
            
$this->openbay->ebay->log('getCountryAddressFormat() - No country found, default');
            return 
false;
        } else {
            
$this->openbay->ebay->log('getCountryAddressFormat() - found country: ' $query->row['address_format']);
            return 
$query->row['address_format'];
        }
    }

    public function 
orderLinkCreate($order_id$smp_id) {
        
$this->openbay->ebay->log('orderLinkCreate() - order_id: ' $order_id ', smp_id: ' $smp_id);

        
$this->db->query("INSERT INTO `" DB_PREFIX "ebay_order` SET `order_id` = '" . (int)$order_id "', `smp_id` = '" . (int)$smp_id "', `parent_ebay_order_id` = 0");

        return 
$this->db->getLastId();
    }

    public function 
delete($order_id) {
        
$this->db->query("DELETE FROM `" DB_PREFIX "order` WHERE `order_id` = '" . (int)$order_id "' LIMIT 1");
        
$this->db->query("DELETE FROM `" DB_PREFIX "order_product` WHERE `order_id` = '" . (int)$order_id "'");
        
$this->db->query("DELETE FROM `" DB_PREFIX "order_option` WHERE `order_id` = '" . (int)$order_id "'");
        
$this->db->query("DELETE FROM `" DB_PREFIX "order_history` WHERE `order_id` = '" . (int)$order_id "'");
        
$this->db->query("DELETE FROM `" DB_PREFIX "order_total` WHERE `order_id` = '" . (int)$order_id "'");
    }

    public function 
lockAdd($smp_id) {
        
$this->openbay->ebay->log('lockAdd() - Added lock, smp_id: ' $smp_id);
        
$this->db->query("INSERT INTO`" DB_PREFIX "ebay_order_lock` SET `smp_id` = '" . (int)$smp_id "'");
    }

    public function 
lockDelete($smp_id) {
        
$this->openbay->ebay->log('lockDelete() - Delete lock, smp_id: ' $smp_id);
        
$this->db->query("DELETE FROM `" DB_PREFIX "ebay_order_lock` WHERE `smp_id` = '" . (int)$smp_id "'");
    }

    public function 
lockExists($smp_id) {
        
$this->openbay->ebay->log('lockExists() - Check lock, smp_id: ' . (int)$smp_id);
        
$query $this->db->query("SELECT * FROM `" DB_PREFIX "ebay_order_lock` WHERE `smp_id` = '" . (int)$smp_id "' LIMIT 1");

        if (
$query->num_rows 0) {
            
$this->openbay->ebay->log('lockExists() - Lock found, stopping order . ');
            return 
true;
        } else {
            
$this->lockAdd($smp_id);
            return 
false;
        }
    }

    public function 
addOrderHistory($order_id) {
        
$this->openbay->ebay->log('addOrderHistory() - Order id:' $order_id ' passed');
        if (!
$this->openbay->ebay->getOrder($order_id)) {
            
$order_products $this->openbay->getOrderProducts($order_id);

            foreach(
$order_products as $order_product) {
                
$product $this->db->query("SELECT * FROM `" DB_PREFIX "product` WHERE `product_id` = '" . (int)$order_product['product_id'] . "' LIMIT 1")->row;

                if (
$this->openbay->addonLoad('openstock') && (isset($product['has_option']) && $product['has_option'] == 1)) {
                    
$order_product_variant $this->openbay->getOrderProductVariant($order_id$order_product['product_id'], $order_product['order_product_id']);

                    if (isset(
$order_product_variant['sku']) && $order_product_variant['sku'] != '') {
                        
$this->openbay->ebay->ebaySaleStockReduce((int)$order_product['product_id'], (string)$order_product_variant['sku']);
                    }
                } else {
                    
$this->openbay->ebay->ebaySaleStockReduce($order_product['product_id']);
                }
            }
        }
    }
}
Онлайн: 1
Реклама