2014-08-19 07:56:17 +04:00
|
|
|
<?php
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
require_once 'base_history.php';
|
|
|
|
|
|
|
|
class ModelRetailcrmHistory extends ModelRetailcrmBaseHistory
|
2015-07-23 00:27:20 +03:00
|
|
|
{
|
2016-02-09 16:21:45 +03:00
|
|
|
protected $createResult;
|
|
|
|
|
2016-04-14 13:55:11 +03:00
|
|
|
private $opencartApiClient;
|
|
|
|
|
2015-07-23 00:27:20 +03:00
|
|
|
public function request()
|
2016-04-15 12:02:42 +03:00
|
|
|
{
|
2015-07-23 00:27:20 +03:00
|
|
|
$this->load->model('setting/setting');
|
|
|
|
$this->load->model('setting/store');
|
2016-07-13 17:42:44 +03:00
|
|
|
$this->load->model('user/api');
|
2015-07-23 00:27:20 +03:00
|
|
|
$this->load->model('sale/order');
|
2016-04-07 13:03:09 +03:00
|
|
|
if (version_compare(VERSION, '2.1.0.0', '>=')) {
|
|
|
|
$this->load->model('customer/customer');
|
|
|
|
} else {
|
|
|
|
$this->load->model('sale/customer');
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
$this->load->model('retailcrm/references');
|
2015-07-23 00:27:20 +03:00
|
|
|
$this->load->model('catalog/product');
|
2016-07-25 17:21:15 +03:00
|
|
|
$this->load->model('catalog/option');
|
2015-07-23 00:27:20 +03:00
|
|
|
$this->load->model('localisation/zone');
|
|
|
|
|
|
|
|
$this->load->language('module/retailcrm');
|
|
|
|
|
|
|
|
$settings = $this->model_setting_setting->getSetting('retailcrm');
|
2016-02-09 16:21:45 +03:00
|
|
|
$history = $this->model_setting_setting->getSetting('retailcrm_history');
|
2015-07-23 00:27:20 +03:00
|
|
|
$settings['domain'] = parse_url(HTTP_SERVER, PHP_URL_HOST);
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$url = isset($settings['retailcrm_url']) ? $settings['retailcrm_url'] : null;
|
|
|
|
$key = isset($settings['retailcrm_apikey']) ? $settings['retailcrm_apikey'] : null;
|
2016-01-29 17:59:53 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (empty($url) || empty($key)) {
|
|
|
|
$this->log->addNotice('You need to configure retailcrm module first.');
|
|
|
|
return false;
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-07-13 17:42:44 +03:00
|
|
|
$this->opencartApiClient = new OpencartApiClient($this->registry);
|
2016-04-14 13:55:11 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$crm = new RetailcrmProxy(
|
|
|
|
$settings['retailcrm_url'],
|
|
|
|
$settings['retailcrm_apikey'],
|
2017-07-03 12:12:20 +03:00
|
|
|
$this->setLogs()
|
2016-02-09 16:21:45 +03:00
|
|
|
);
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$lastRun = !empty($history['retailcrm_history'])
|
|
|
|
? new DateTime($history['retailcrm_history'])
|
|
|
|
: new DateTime(date('Y-m-d H:i:s', strtotime('-1 days', strtotime(date('Y-m-d H:i:s')))));
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-08-31 17:28:11 +03:00
|
|
|
$packs = $crm->ordersHistory(array(
|
|
|
|
'startDate' => $lastRun->format('Y-m-d H:i:s'),
|
|
|
|
), 1, 100);
|
2018-02-26 13:23:36 +03:00
|
|
|
if (!$packs->isSuccessful() && count($packs->history) <= 0) {
|
|
|
|
|
2016-08-31 17:28:11 +03:00
|
|
|
return false;
|
2018-02-26 13:23:36 +03:00
|
|
|
}
|
|
|
|
|
2016-08-31 17:28:11 +03:00
|
|
|
$orders = RetailcrmHistoryHelper::assemblyOrder($packs->history);
|
|
|
|
|
2016-12-28 19:24:27 +03:00
|
|
|
$generatedAt = $packs['generatedAt'];
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->subtotalSettings = $this->model_setting_setting->getSetting('sub_total');
|
|
|
|
$this->totalSettings = $this->model_setting_setting->getSetting('total');
|
|
|
|
$this->shippingSettings = $this->model_setting_setting->getSetting('shipping');
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->delivery = array_flip($settings['retailcrm_delivery']);
|
|
|
|
$this->payment = array_flip($settings['retailcrm_payment']);
|
|
|
|
$this->status = array_flip($settings['retailcrm_status']);
|
2018-02-26 13:23:36 +03:00
|
|
|
$this->settings = $settings;
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->ocPayment = $this->model_retailcrm_references
|
|
|
|
->getOpercartPaymentTypes();
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->ocDelivery = $this->model_retailcrm_references
|
|
|
|
->getOpercartDeliveryTypes();
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->zones = $this->model_localisation_zone->getZones();
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$updatedOrders = array();
|
|
|
|
$newOrders = array();
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-08-31 17:28:11 +03:00
|
|
|
foreach ($orders as $order) {
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['deleted'])) {
|
|
|
|
continue;
|
|
|
|
}
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (isset($order['externalId'])) {
|
|
|
|
$updatedOrders[] = $order['id'];
|
|
|
|
} else {
|
|
|
|
$newOrders[] = $order['id'];
|
|
|
|
}
|
|
|
|
}
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
unset($orders);
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (!empty($newOrders)) {
|
|
|
|
$orders = $crm->ordersList($filter = array('ids' => $newOrders));
|
|
|
|
if ($orders) {
|
|
|
|
$this->createResult = $this->createOrders($orders['orders']);
|
|
|
|
}
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (!empty($updatedOrders)) {
|
|
|
|
$orders = $crm->ordersList($filter = array('ids' => $updatedOrders));
|
|
|
|
if ($orders) {
|
|
|
|
$this->updateOrders($orders['orders']);
|
|
|
|
}
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$this->model_setting_setting->editSetting('retailcrm_history', array('retailcrm_history' => $generatedAt));
|
|
|
|
|
|
|
|
if (!empty($this->createResult['customers'])) {
|
|
|
|
$crm->customersFixExternalIds($this->createResult['customers']);
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-03-03 17:16:43 +03:00
|
|
|
if (!empty($this->createResult['orders'])) {
|
2016-02-09 16:21:45 +03:00
|
|
|
$crm->ordersFixExternalIds($this->createResult['orders']);
|
|
|
|
}
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
protected function updateOrders($orders)
|
|
|
|
{
|
|
|
|
foreach ($orders as $order) {
|
2018-02-26 13:23:36 +03:00
|
|
|
$ocOrder = $this->model_sale_order->getOrder($order['externalId']);
|
|
|
|
|
|
|
|
if (isset($order['paymentType'])) {
|
|
|
|
$payment['type'] = $order['paymentType'];
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
$data = array();
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$mail = isset($order['email']) ? $order['email'] : $order['customer']['email'];
|
|
|
|
$phone = isset($order['phone']) ? $order['phone'] : '';
|
|
|
|
|
|
|
|
if (!$phone) {
|
|
|
|
$data['telephone'] = $order['customer']['phones'] ? $order['customer']['phones'][0]['number'] : '80000000000';
|
|
|
|
} else {
|
|
|
|
$data['telephone'] = $phone;
|
|
|
|
}
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['customer'] = $order['firstName'];
|
|
|
|
$data['customer_id'] = (!empty($order['customer']['externalId'])) ? $order['customer']['externalId'] : 0;
|
|
|
|
$data['customer_group_id'] = 1;
|
|
|
|
$data['firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['lastname'] = isset($order['lastName']) ? $order['lastName'] : $order['firstName'];
|
|
|
|
$data['email'] = $mail ? $mail : uniqid() . '@retailrcm.ru';
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['comment'] = !empty($order['customerComment']) ? $order['customerComment'] : '';
|
|
|
|
$data['payment_address'] = '0';
|
|
|
|
$data['payment_firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['payment_lastname'] = isset($order['lastName']) ? $order['lastName'] : $order['firstName'];
|
2016-04-08 16:39:51 +03:00
|
|
|
$data['payment_address_1'] = isset($order['customer']['address']) ? $order['customer']['address']['text'] : '';
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['payment_address_2'] = '';
|
|
|
|
$data['payment_city'] = !empty($order['customer']['address']['city']) ? $order['customer']['address']['city'] : $order['delivery']['address']['city'];
|
|
|
|
$data['payment_postcode'] = !empty( $order['customer']['address']['index'] ) ? $order['customer']['address']['index'] : $order['delivery']['address']['index'];
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = '';
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
if (is_int($order['delivery']['address']['region'])) {
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = $order['delivery']['address']['region'];
|
2016-02-09 16:21:45 +03:00
|
|
|
} else {
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = $this->getZoneByName($order['delivery']['address']['region']);
|
|
|
|
|
|
|
|
if ($shippingZone) {
|
|
|
|
$shipping_zone_id = $shippingZone['zone_id'];
|
|
|
|
} else {
|
|
|
|
$shipping_zone_id = 0;
|
2016-02-09 04:22:06 +03:00
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
}
|
2015-07-23 00:27:20 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['customer']['address']['region'])) {
|
|
|
|
$paymentZone = $this->getZoneByName($order['customer']['address']['region']);
|
|
|
|
|
|
|
|
if ($paymentZone) {
|
|
|
|
$payment_zone_id = $paymentZone['zone_id'];
|
|
|
|
} else {
|
|
|
|
$payment_zone_id = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($order['countryIso']) && !empty($order['countryIso'])) {
|
|
|
|
$shippingCountry = $this->getCountryByIsoCode($order['countryIso']);
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['customer']['address']['countryIso']) && !empty($order['customer']['address']['countryIso'])) {
|
|
|
|
$paymentCountry = $this->getCountryByIsoCode($order['customer']['address']['countryIso']);
|
|
|
|
} else {
|
|
|
|
$paymentCountry = $this->getCountryByIsoCode($order['countryIso']);
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$delivery = isset($order['delivery']['code']) ? $order['delivery']['code'] : null;
|
|
|
|
$data['payment_country_id'] = $paymentCountry ? $paymentCountry['country_id'] : $ocOrder['payment_country_id'];
|
|
|
|
$data['payment_country'] = isset($paymentCountry) ? $paymentCountry['name'] : $ocOrder['payment_country'];
|
|
|
|
$data['payment_zone_id'] = $payment_zone_id ? $payment_zone_id : $ocOrder['payment_zone_id'];
|
|
|
|
$data['payment_zone'] = isset($order['customer']['address']['region']) ? $order['customer']['address']['region'] : $ocOrder['payment_zone'];
|
|
|
|
$data['shipping_country_id'] = $shippingCountry ? $shippingCountry['country_id'] : $ocOrder['shipping_country_id'];
|
|
|
|
$data['shipping_country'] = $shippingCountry ? $shippingCountry['name'] : $ocOrder['shipping_country'];
|
|
|
|
$data['shipping_zone_id'] = $shipping_zone_id ? $shipping_zone_id : $ocOrder['shipping_zone_id'];
|
|
|
|
$data['shipping_zone'] = $shippingZone ? $shippingZone['name'] : $ocOrder['shipping_zone'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['shipping_address'] = '0';
|
|
|
|
$data['shipping_firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['shipping_lastname'] = isset($order['lastName']) ? $order['lastName'] : $order['firstName'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['shipping_address_1'] = $order['delivery']['address']['text'];
|
|
|
|
$data['shipping_address_2'] = '';
|
|
|
|
$data['shipping_company'] = '';
|
|
|
|
$data['shipping_company_id'] = '';
|
|
|
|
$data['shipping_city'] = $order['delivery']['address']['city'];
|
|
|
|
$data['shipping_postcode'] = $order['delivery']['address']['index'];
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if ($delivery !== null) {
|
|
|
|
if (isset($this->settings['retailcrm_delivery'][$ocOrder['shipping_code']])
|
|
|
|
&& isset($this->delivery[$delivery])
|
|
|
|
) {
|
|
|
|
$data['shipping'] = $this->delivery[$delivery];
|
2016-04-08 16:39:51 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$shipping = explode('.', $data['shipping']);
|
|
|
|
$shippingModule = $shipping[0];
|
|
|
|
|
|
|
|
if (isset($this->ocDelivery[$shippingModule][$data['shipping']]['title'])) {
|
|
|
|
$data['shipping_method'] = $this->ocDelivery[$shippingModule][$data['shipping']]['title'];
|
|
|
|
} else {
|
|
|
|
$data['shipping_method'] =$this->ocDelivery[$shippingModule]['title'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['shipping_code'] = $data['shipping'];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (!isset($this->settings[$ocOrder['shipping_code']])
|
|
|
|
|| !isset($this->delivery[$delivery])
|
|
|
|
) {
|
|
|
|
$data['shipping_method'] = $ocOrder['shipping_method'];
|
|
|
|
$data['shipping_code'] = $ocOrder['shipping_code'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($payment)) {
|
|
|
|
$data['payment'] = $this->payment[$payment['type']];
|
|
|
|
$data['payment_method'] = isset($this->ocPayment[$data['payment']]) ? $this->ocPayment[$data['payment']] : $ocOrder['payment_method'];
|
|
|
|
$data['payment_code'] = isset($this->payment[$payment['type']]) ? $this->payment[$payment['type']] : $ocOrder['payment_code'];
|
|
|
|
} else {
|
|
|
|
$data['payment_method'] = $ocOrder['payment_method'];
|
|
|
|
$data['payment_code'] = $ocOrder['payment_code'];
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
// this data will not retrive from crm for now
|
|
|
|
$data['tax'] = '';
|
|
|
|
$data['tax_id'] = '';
|
|
|
|
$data['product'] = '';
|
|
|
|
$data['product_id'] = '';
|
|
|
|
$data['reward'] = '';
|
|
|
|
$data['affiliate'] = '';
|
|
|
|
$data['affiliate_id'] = '';
|
|
|
|
$data['payment_tax_id'] = '';
|
|
|
|
$data['order_product_id'] = '';
|
|
|
|
$data['payment_company'] = '';
|
|
|
|
$data['payment_company_id'] = '';
|
|
|
|
$data['company'] = '';
|
|
|
|
$data['company_id'] = '';
|
|
|
|
|
|
|
|
$data['order_product'] = array();
|
|
|
|
|
|
|
|
foreach ($order['items'] as $item) {
|
2016-07-25 17:21:15 +03:00
|
|
|
$productId = $item['offer']['externalId'];
|
|
|
|
$options = array();
|
2018-02-26 13:23:36 +03:00
|
|
|
|
|
|
|
if (mb_strpos($item['offer']['externalId'], '#') > 1) {
|
2016-07-25 17:21:15 +03:00
|
|
|
$offer = explode('#', $item['offer']['externalId']);
|
|
|
|
$productId = $offer[0];
|
|
|
|
$optionsFromCRM = explode('_', $offer[1]);
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
foreach ($optionsFromCRM as $optionFromCRM) {
|
2016-07-25 17:21:15 +03:00
|
|
|
$optionData = explode('-', $optionFromCRM);
|
|
|
|
$productOptionId = $optionData[0];
|
|
|
|
$optionValueId = $optionData[1];
|
|
|
|
|
|
|
|
$productOptions = $this->model_catalog_product->getProductOptions($productId);
|
|
|
|
|
|
|
|
foreach($productOptions as $productOption) {
|
|
|
|
if($productOptionId == $productOption['product_option_id']) {
|
|
|
|
foreach($productOption['product_option_value'] as $productOptionValue) {
|
|
|
|
if($productOptionValue['option_value_id'] == $optionValueId) {
|
2018-02-26 13:23:36 +03:00
|
|
|
$options[] = array(
|
|
|
|
'product_option_id' => $productOptionId,
|
|
|
|
'product_option_value_id' => $productOptionValue['product_option_value_id'],
|
|
|
|
'value' => $this->getOptionValue($productOptionValue['option_value_id'], 'name'),
|
|
|
|
'type' => $productOption['type'],
|
|
|
|
'name' => $productOption['name'],
|
|
|
|
);
|
2016-07-25 17:21:15 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-02-26 13:23:36 +03:00
|
|
|
|
|
|
|
$product = $this->model_catalog_product->getProduct($productId);
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['order_product'][] = array(
|
2018-02-26 13:23:36 +03:00
|
|
|
'name' => $product['name'],
|
|
|
|
'model' => $product['model'],
|
|
|
|
'price' => $item['initialPrice'],
|
|
|
|
'total' => (float)($item['initialPrice'] * $item['quantity']),
|
2016-07-25 17:21:15 +03:00
|
|
|
'product_id' => $productId,
|
2016-02-09 16:21:45 +03:00
|
|
|
'quantity' => $item['quantity'],
|
2016-07-25 17:21:15 +03:00
|
|
|
'option' => $options
|
2016-02-09 16:21:45 +03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$deliveryCost = !empty($order['delivery']['cost']) ? $order['delivery']['cost'] : 0;
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['discount']) && $order['discount'] > 0) {
|
2017-10-30 13:33:57 +03:00
|
|
|
$orderTotals = $this->model_sale_order->getOrderTotals($order['externalId']);
|
|
|
|
foreach($orderTotals as $orderTotal) {
|
|
|
|
if($orderTotal['code'] == 'coupon') {
|
|
|
|
$data['order_total'][] = $orderTotal;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['total'] = $order['totalSumm'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['order_total'] = array(
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'sub_total',
|
|
|
|
'title' => $this->language->get('product_summ'),
|
|
|
|
'value' => $order['summ'],
|
|
|
|
'text' => $order['summ'],
|
|
|
|
'sort_order' => $this->subtotalSettings['sub_total_sort_order']
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'shipping',
|
2018-02-26 13:23:36 +03:00
|
|
|
'title' => $data['shipping_method'],
|
2016-02-09 16:21:45 +03:00
|
|
|
'value' => $deliveryCost,
|
|
|
|
'text' => $deliveryCost,
|
2018-02-26 13:23:36 +03:00
|
|
|
'sort_order' => $this->shippingSettings[$this->totalTitle . 'shipping_sort_order']
|
2016-02-09 16:21:45 +03:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'total',
|
|
|
|
'title' => $this->language->get('column_total'),
|
|
|
|
'value' => isset($order['totalSumm']) ? $order['totalSumm'] : $order['summ'] + $deliveryCost,
|
|
|
|
'text' => isset($order['totalSumm']) ? $order['totalSumm'] : $order['summ'] + $deliveryCost,
|
2018-02-26 13:23:36 +03:00
|
|
|
'sort_order' => $this->totalSettings[$this->totalTitle . 'total_sort_order']
|
2016-02-09 04:22:06 +03:00
|
|
|
)
|
2016-02-09 16:21:45 +03:00
|
|
|
);
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['fromApi'] = true;
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (array_key_exists($order['status'], $this->status)) {
|
|
|
|
$data['order_status_id'] = $this->status[$order['status']];
|
|
|
|
} else {
|
|
|
|
$tmpOrder = $this->model_sale_order->getOrder($order['externalId']);
|
|
|
|
$data['order_status_id'] = $tmpOrder['order_status_id'];
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$this->editOrder($order['externalId'], $data);
|
|
|
|
$this->opencartApiClient->addHistory($order['externalId'], $data['order_status_id']);
|
2016-02-09 16:21:45 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function createOrders($orders)
|
|
|
|
{
|
|
|
|
$customersIdsFix = array();
|
|
|
|
$ordersIdsFix = array();
|
|
|
|
|
|
|
|
foreach ($orders as $order) {
|
|
|
|
$store = $this->config->get('config_store_id');
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['paymentType'])) {
|
|
|
|
$payment['type'] = $order['paymentType'];
|
|
|
|
}
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$customer_id = (!empty($order['customer']['externalId']))
|
|
|
|
? $order['customer']['externalId']
|
|
|
|
: 0;
|
|
|
|
|
|
|
|
$data = array();
|
|
|
|
|
|
|
|
if ($customer_id == 0) {
|
|
|
|
$cData = array(
|
|
|
|
'store_id' => 0,
|
|
|
|
'customer_group_id' => '1',
|
|
|
|
'firstname' => $order['firstName'],
|
|
|
|
'lastname' => (!empty($order['lastName'])) ? $order['lastName'] : ' ',
|
|
|
|
'email' => $order['email'],
|
|
|
|
'telephone' => (!empty($order['customer']['phones'][0]['number']) ) ? $order['customer']['phones'][0]['number'] : ' ',
|
|
|
|
'fax' => '',
|
|
|
|
'newsletter' => 0,
|
|
|
|
'password' => 'tmppass',
|
|
|
|
'status' => 1,
|
2018-02-26 13:23:36 +03:00
|
|
|
'approved' => 1,
|
|
|
|
'safe' => 0,
|
2016-02-09 16:21:45 +03:00
|
|
|
'address' => array(
|
|
|
|
array(
|
|
|
|
'firstname' => $order['firstName'],
|
|
|
|
'lastname' => (!empty($order['lastName'])) ? $order['lastName'] : ' ',
|
|
|
|
'address_1' => $order['customer']['address']['text'],
|
|
|
|
'address_2' => ' ',
|
|
|
|
'city' => !empty($order['customer']['address']['city']) ? $order['customer']['address']['city'] : $order['delivery']['address']['city'],
|
|
|
|
'postcode' => isset($order['customer']['address']['index']) ? $order['customer']['address']['index'] : $order['delivery']['address']['index'],
|
|
|
|
'tax_id' => '1',
|
|
|
|
'company' => '',
|
|
|
|
'company_id' => '',
|
|
|
|
'zone_id' => '0',
|
|
|
|
'country_id' => 0
|
|
|
|
)
|
2016-02-09 04:22:06 +03:00
|
|
|
),
|
|
|
|
);
|
|
|
|
|
2016-04-07 13:03:09 +03:00
|
|
|
if (version_compare(VERSION, '2.1.0.0', '>=')) {
|
|
|
|
$this->model_customer_customer->addCustomer($cData);
|
|
|
|
} else {
|
|
|
|
$this->model_sale_customer->addCustomer($cData);
|
|
|
|
}
|
2016-02-09 04:22:06 +03:00
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
if (!empty($order['email'])) {
|
2016-04-07 13:03:09 +03:00
|
|
|
if (version_compare(VERSION, '2.1.0.0', '>=')) {
|
|
|
|
$tryToFind = $this->model_customer_customer->getCustomerByEmail($order['email']);
|
|
|
|
} else {
|
|
|
|
$tryToFind = $this->model_sale_customer->getCustomerByEmail($order['email']);
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
$customer_id = $tryToFind['customer_id'];
|
2016-02-09 04:22:06 +03:00
|
|
|
} else {
|
2016-04-07 13:03:09 +03:00
|
|
|
if (version_compare(VERSION, '2.1.0.0', '>=')) {
|
|
|
|
$last = $this->model_customer_customer->getCustomers($data = array('order' => 'DESC', 'limit' => 1));
|
|
|
|
} else {
|
|
|
|
$last = $this->model_sale_customer->getCustomers($data = array('order' => 'DESC', 'limit' => 1));
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
$customer_id = $last[0]['customer_id'];
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
$customersIdsFix[] = array('id' => $order['customer']['id'], 'externalId' => (int)$customer_id);
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$mail = isset($order['email']) ? $order['email'] : $order['customer']['email'];
|
|
|
|
$phone = isset($order['phone']) ? $order['phone'] : '';
|
|
|
|
|
|
|
|
if (!$phone) {
|
|
|
|
$data['telephone'] = $order['customer']['phones'] ? $order['customer']['phones'][0]['number'] : '80000000000';
|
|
|
|
} else {
|
|
|
|
$data['telephone'] = $phone;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['store_url'] = $this->config->get('config_url');
|
|
|
|
$data['currency_code'] = $this->config->get('config_currency');
|
|
|
|
$data['currency_value'] = $this->getCurrencyByCode($data['currency_code'], 'value');
|
|
|
|
$data['currency_id'] = $this->getCurrencyByCode($data['currency_code'], 'currency_id');
|
|
|
|
$data['language_id'] = $this->getLanguageByCode($this->config->get('config_language'), 'language_id');
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['store_id'] = $store == null ? 0 : $store;
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['store_name'] = $this->config->get('config_name');
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['customer'] = $order['firstName'];
|
|
|
|
$data['customer_id'] = $customer_id;
|
|
|
|
$data['customer_group_id'] = 1;
|
|
|
|
$data['firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['lastname'] = (isset($order['lastName'])) ? $order['lastName'] : $order['firstName'];
|
|
|
|
$data['email'] = $mail ? $mail : uniqid() . '@retailrcm.ru';
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['comment'] = !empty($order['customerComment']) ? $order['customerComment'] : '';
|
|
|
|
$data['fax'] = '';
|
|
|
|
$data['payment_address'] = '0';
|
|
|
|
$data['payment_firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['payment_lastname'] = (isset($order['lastName'])) ? $order['lastName'] : $order['firstName'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['payment_address_1'] = $order['customer']['address']['text'];
|
|
|
|
$data['payment_address_2'] = '';
|
|
|
|
$data['payment_company'] = '';
|
|
|
|
$data['payment_company_id'] = '';
|
|
|
|
$data['payment_city'] = !empty($order['customer']['address']['city']) ? $order['customer']['address']['city'] : $order['delivery']['address']['city'];
|
|
|
|
$data['payment_postcode'] = !empty($order['customer']['address']['index']) ? $order['customer']['address']['index'] : $order['delivery']['address']['index'];
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = '';
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
if (!empty($order['delivery']['address']['region']) && is_int($order['delivery']['address']['region'])) {
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = $order['delivery']['address']['region'];
|
2016-02-09 16:21:45 +03:00
|
|
|
} else {
|
2018-02-26 13:23:36 +03:00
|
|
|
$shippingZone = $this->getZoneByName($order['delivery']['address']['region']);
|
|
|
|
|
|
|
|
if ($shippingZone) {
|
|
|
|
$shipping_zone_id = $shippingZone['zone_id'];
|
|
|
|
} else {
|
|
|
|
$shipping_zone_id = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($order['customer']['address']['region'])) {
|
|
|
|
$paymentZone = $this->getZoneByName($order['customer']['address']['region']);
|
|
|
|
|
|
|
|
if ($paymentZone) {
|
|
|
|
$payment_zone_id = $paymentZone['zone_id'];
|
|
|
|
} else {
|
|
|
|
$payment_zone_id = 0;
|
2016-02-09 16:21:45 +03:00
|
|
|
}
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($order['delivery']['address']['countryIso'])) {
|
|
|
|
$shippingCountry = $this->getCountryByIsoCode($order['delivery']['address']['countryIso']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($order['customer']['address']['countryIso'])) {
|
|
|
|
$paymentCountry = $this->getCountryByIsoCode($order['customer']['address']['countryIso']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$delivery = isset($order['delivery']['code']) ? $order['delivery']['code'] : null;
|
|
|
|
$data['payment_country_id'] = $paymentCountry ? $paymentCountry['country_id'] : 0;
|
|
|
|
$data['payment_country'] = isset($paymentCountry) ? $paymentCountry['name'] : '';
|
|
|
|
$data['payment_zone_id'] = $payment_zone_id;
|
|
|
|
$data['payment_zone'] = isset($order['customer']['address']['region']) ? $order['customer']['address']['region'] : '';
|
|
|
|
$data['shipping_country_id'] = $shippingCountry ? $shippingCountry['country_id'] : 0;
|
|
|
|
$data['shipping_country'] = $shippingCountry ? $shippingCountry['name'] : '';
|
|
|
|
$data['shipping_zone_id'] = $shipping_zone_id;
|
|
|
|
$data['shipping_zone'] = $shippingZone ? $shippingZone['name'] : $data['payment_zone'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['shipping_address'] = '0';
|
|
|
|
$data['shipping_firstname'] = $order['firstName'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['shipping_lastname'] = (isset($order['lastName'])) ? $order['lastName'] : $order['firstName'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['shipping_address_1'] = $order['delivery']['address']['text'];
|
|
|
|
$data['shipping_address_2'] = '';
|
|
|
|
$data['shipping_company'] = '';
|
|
|
|
$data['shipping_company_id'] = '';
|
|
|
|
$data['shipping_city'] = $order['delivery']['address']['city'];
|
|
|
|
$data['shipping_postcode'] = $order['delivery']['address']['index'];
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['shipping'] = $delivery != null ? $this->delivery[$delivery] : '';
|
|
|
|
$data['shipping_code'] = $delivery != null ? $this->delivery[$delivery] : '';
|
|
|
|
|
|
|
|
$shipping = explode('.', $data['shipping']);
|
|
|
|
$shippingModule = $shipping[0];
|
|
|
|
|
|
|
|
if (isset($this->ocDelivery[$shippingModule][$data['shipping']]['title'])) {
|
|
|
|
$data['shipping_method'] = $this->ocDelivery[$shippingModule][$data['shipping']]['title'];
|
|
|
|
} else {
|
|
|
|
$data['shipping_method'] =$this->ocDelivery[$shippingModule]['title'];
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
if (isset($payment)) {
|
|
|
|
$data['payment'] = $this->payment[$payment['type']];
|
|
|
|
$data['payment_method'] = $this->ocPayment[$data['payment']];
|
|
|
|
$data['payment_code'] = $this->payment[$payment['type']];
|
|
|
|
} else {
|
|
|
|
$data['payment'] = 'free_checkout';
|
|
|
|
$data['payment_method'] = $this->ocPayment[$data['payment']];
|
|
|
|
$data['payment_code'] = 'free_checkout';
|
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
// this data will not retrive from crm for now
|
|
|
|
$data['tax'] = '';
|
|
|
|
$data['tax_id'] = '';
|
|
|
|
$data['product'] = '';
|
|
|
|
$data['product_id'] = '';
|
|
|
|
$data['reward'] = '';
|
|
|
|
$data['affiliate'] = '';
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['affiliate_id'] = 0;
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['payment_tax_id'] = '';
|
|
|
|
$data['order_product_id'] = '';
|
|
|
|
$data['payment_company'] = '';
|
|
|
|
$data['payment_company_id'] = '';
|
|
|
|
$data['company'] = '';
|
|
|
|
$data['company_id'] = '';
|
|
|
|
|
|
|
|
$data['order_product'] = array();
|
|
|
|
|
|
|
|
foreach ($order['items'] as $item) {
|
2018-02-26 13:23:36 +03:00
|
|
|
$productId = $item['offer']['externalId'];
|
|
|
|
$options = array();
|
|
|
|
|
|
|
|
if(mb_strpos($item['offer']['externalId'], '#') > 1) {
|
|
|
|
$offer = explode('#', $item['offer']['externalId']);
|
|
|
|
$productId = $offer[0];
|
|
|
|
$optionsFromCRM = explode('_', $offer[1]);
|
|
|
|
|
|
|
|
foreach ($optionsFromCRM as $optionFromCRM) {
|
|
|
|
$optionData = explode('-', $optionFromCRM);
|
|
|
|
$productOptionId = $optionData[0];
|
|
|
|
$optionValueId = $optionData[1];
|
|
|
|
|
|
|
|
$productOptions = $this->model_catalog_product->getProductOptions($productId);
|
|
|
|
|
|
|
|
foreach($productOptions as $productOption) {
|
|
|
|
if($productOptionId == $productOption['product_option_id']) {
|
|
|
|
foreach($productOption['product_option_value'] as $productOptionValue) {
|
|
|
|
if($productOptionValue['option_value_id'] == $optionValueId) {
|
|
|
|
$options[] = array(
|
|
|
|
'product_option_id' => $productOptionId,
|
|
|
|
'product_option_value_id' => $productOptionValue['product_option_value_id'],
|
|
|
|
'value' => $this->getOptionValue($productOptionValue['option_value_id'], 'name'),
|
|
|
|
'type' => $productOption['type'],
|
|
|
|
'name' => $productOption['name'],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$product = $this->model_catalog_product->getProduct($productId);
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['order_product'][] = array(
|
2018-02-26 13:23:36 +03:00
|
|
|
'name' => $product['name'],
|
2016-02-09 16:21:45 +03:00
|
|
|
'model' => $product['model'],
|
2018-02-26 13:23:36 +03:00
|
|
|
'price' => $item['initialPrice'],
|
|
|
|
'total' => (float)($item['initialPrice'] * $item['quantity']),
|
|
|
|
'product_id' => $productId,
|
|
|
|
'quantity' => $item['quantity'],
|
|
|
|
'option' => $options
|
2016-02-09 16:21:45 +03:00
|
|
|
);
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
|
|
|
|
2016-02-09 16:21:45 +03:00
|
|
|
$deliveryCost = !empty($order['delivery']['cost']) ? $order['delivery']['cost'] : 0;
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$data['total'] = $order['totalSumm'];
|
2016-02-09 16:21:45 +03:00
|
|
|
$data['order_total'] = array(
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'sub_total',
|
|
|
|
'title' => $this->language->get('product_summ'),
|
|
|
|
'value' => $order['summ'],
|
|
|
|
'text' => $order['summ'],
|
|
|
|
'sort_order' => $this->subtotalSettings['sub_total_sort_order']
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'shipping',
|
2018-02-26 13:23:36 +03:00
|
|
|
'title' => $data['shipping_method'],
|
2016-02-09 16:21:45 +03:00
|
|
|
'value' => $deliveryCost,
|
|
|
|
'text' => $deliveryCost,
|
2018-02-26 13:23:36 +03:00
|
|
|
'sort_order' => $this->shippingSettings[$this->totalTitle . 'shipping_sort_order']
|
2016-02-09 16:21:45 +03:00
|
|
|
),
|
|
|
|
array(
|
|
|
|
'order_total_id' => '',
|
|
|
|
'code' => 'total',
|
|
|
|
'title' => $this->language->get('column_total'),
|
|
|
|
'value' => !empty($order['totalSumm']) ? $order['totalSumm'] : $order['summ'] + $deliveryCost,
|
|
|
|
'text' => isset($order['totalSumm']) ? $order['totalSumm'] : $order['summ'] + $deliveryCost,
|
2018-02-26 13:23:36 +03:00
|
|
|
'sort_order' => $this->totalSettings[$this->totalTitle . 'total_sort_order']
|
2016-02-09 16:21:45 +03:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$data['fromApi'] = true;
|
|
|
|
$data['order_status_id'] = 1;
|
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$order_id = $this->addOrder($data);
|
2016-02-09 16:21:45 +03:00
|
|
|
|
2018-02-26 13:23:36 +03:00
|
|
|
$ordersIdsFix[] = array('id' => $order['id'], 'externalId' => (int) $order_id);
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
2016-02-09 16:21:45 +03:00
|
|
|
|
|
|
|
return array('customers' => $customersIdsFix, 'orders' => $ordersIdsFix);
|
2015-07-23 00:27:20 +03:00
|
|
|
}
|
2017-06-07 15:28:27 +03:00
|
|
|
|
|
|
|
private function setLogs()
|
|
|
|
{
|
2018-02-26 13:23:36 +03:00
|
|
|
if (version_compare(VERSION, '2.1', '>')) {
|
2017-09-22 11:24:35 +03:00
|
|
|
$logs = DIR_SYSTEM . 'storage/logs/retailcrm.log';
|
2017-06-07 15:28:27 +03:00
|
|
|
} else {
|
2017-09-22 11:24:35 +03:00
|
|
|
$logs = DIR_SYSTEM . 'logs/retailcrm.log';
|
2017-06-07 15:28:27 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
return $logs;
|
|
|
|
}
|
2015-07-23 13:14:23 +03:00
|
|
|
}
|