Version Notes
Production version
Download this release
Release Info
| Developer | David Potts |
| Extension | Saleswarp_Oms |
| Version | 0.1.3 |
| Comparing to | |
| See all releases | |
Code changes from version 0.1.2 to 0.1.3
- app/code/local/Saleswarp/Oms/Block/Adminhtml/System/Config/Form/Button.php +79 -79
- app/code/local/Saleswarp/Oms/Block/Adminhtml/System/Config/Form/Key.php +27 -27
- app/code/local/Saleswarp/Oms/Block/Form/Saleswarp.php +21 -21
- app/code/local/Saleswarp/Oms/Block/Info/Saleswarp.php +29 -29
- app/code/local/Saleswarp/Oms/Helper/Data.php +3 -3
- app/code/local/Saleswarp/Oms/Model/Category/Api.php +16 -16
- app/code/local/Saleswarp/Oms/Model/Config/Api.php +53 -53
- app/code/local/Saleswarp/Oms/Model/Customer/Api.php +34 -34
- app/code/local/Saleswarp/Oms/Model/Order/Api.php +580 -563
- app/code/local/Saleswarp/Oms/Model/Product/Api.php +362 -355
- app/code/local/Saleswarp/Oms/Model/Product/Attribute/Api.php +5 -5
- app/code/local/Saleswarp/Oms/Model/Product/Attribute/Media/Api.php +4 -4
- app/code/local/Saleswarp/Oms/Model/Saleswarp.php +53 -53
- app/code/local/Saleswarp/Oms/controllers/Adminhtml/GetkeyController.php +63 -63
- app/code/local/Saleswarp/Oms/controllers/FastapiController.php +136 -136
- app/code/local/Saleswarp/Oms/etc/adminhtml.xml +22 -22
- app/code/local/Saleswarp/Oms/etc/config.xml +92 -92
- app/code/local/Saleswarp/Oms/etc/system.xml +96 -96
- app/code/local/Saleswarp/Oms/sql/oms_setup/mysql4-install-0.1.1.php +265 -265
- app/code/local/Saleswarp/Oms/sql/oms_setup/mysql4-upgrade-0.1.2.php +28 -28
- app/code/local/Saleswarp/Publish/Helper/Data.php +5 -0
- app/code/local/Saleswarp/Publish/Model/Category/Api.php +326 -0
- app/code/local/Saleswarp/Publish/Model/Config/Api.php +83 -0
- app/code/local/Saleswarp/Publish/Model/Customer/Api.php +26 -0
- app/code/local/Saleswarp/Publish/Model/Product/Api.php +2191 -0
- app/code/local/Saleswarp/Publish/Model/Product/Attribute/Api.php +38 -0
- app/code/local/Saleswarp/Publish/Model/Product/Attribute/Media/Api.php +153 -0
- app/code/local/Saleswarp/Publish/etc/config.xml +30 -0
- app/code/local/Saleswarp/WhitelistIP/Helper/Data.php +5 -0
- app/code/local/Saleswarp/WhitelistIP/controllers/FastapiController.php +36 -0
- app/code/local/Saleswarp/WhitelistIP/etc/config.xml +19 -0
- app/code/local/Saleswarp/WhitelistIP/etc/system.xml +37 -0
- app/design/adminhtml/default/default/template/oms/form/saleswarp.phtml +16 -16
- app/design/adminhtml/default/default/template/oms/system/config/button.phtml +35 -35
- app/etc/modules/Saleswarp_Oms.xml +9 -9
- package.xml +5 -5
app/code/local/Saleswarp/Oms/Block/Adminhtml/System/Config/Form/Button.php
CHANGED
|
@@ -1,80 +1,80 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
class Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Button extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 16 |
-
{
|
| 17 |
-
/*
|
| 18 |
-
* Set template
|
| 19 |
-
*/
|
| 20 |
-
protected function _construct()
|
| 21 |
-
{
|
| 22 |
-
parent::_construct();
|
| 23 |
-
$this->setTemplate('oms/system/config/button.phtml');
|
| 24 |
-
}
|
| 25 |
-
|
| 26 |
-
/**
|
| 27 |
-
* Return element html
|
| 28 |
-
*
|
| 29 |
-
* @param Varien_Data_Form_Element_Abstract $element
|
| 30 |
-
* @return string
|
| 31 |
-
*/
|
| 32 |
-
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 33 |
-
{
|
| 34 |
-
return $this->_toHtml();
|
| 35 |
-
}
|
| 36 |
-
|
| 37 |
-
/**
|
| 38 |
-
* Return ajax url for button
|
| 39 |
-
*
|
| 40 |
-
* @return string
|
| 41 |
-
*/
|
| 42 |
-
public function getAjaxCheckUrl()
|
| 43 |
-
{
|
| 44 |
-
return Mage::helper('adminhtml')->getUrl('admin_oms/adminhtml_getkey');
|
| 45 |
-
}
|
| 46 |
-
|
| 47 |
-
/**
|
| 48 |
-
* Generate button html
|
| 49 |
-
*
|
| 50 |
-
* @return string
|
| 51 |
-
*/
|
| 52 |
-
public function getButtonHtml()
|
| 53 |
-
{
|
| 54 |
-
$button = $this->getLayout()->createBlock('adminhtml/widget_button')
|
| 55 |
-
->setData(array(
|
| 56 |
-
'id' => 'saleswarp_oms_button',
|
| 57 |
-
'label' => $this->helper('adminhtml')->__('Get Key'),
|
| 58 |
-
'onclick' => 'javascript:getKey(); return false;'
|
| 59 |
-
));
|
| 60 |
-
return $button->toHtml();
|
| 61 |
-
}
|
| 62 |
-
|
| 63 |
-
public function isKeyAvailable() {
|
| 64 |
-
$key = Mage::getStoreConfig('oms/registration/key');
|
| 65 |
-
if($key && trim($key)) {
|
| 66 |
-
return true;
|
| 67 |
-
} else {
|
| 68 |
-
return false;
|
| 69 |
-
}
|
| 70 |
-
}
|
| 71 |
-
|
| 72 |
-
public function getKeyData() {
|
| 73 |
-
$data = array();
|
| 74 |
-
$data['key'] = Mage::getStoreConfig('oms/registration/key');
|
| 75 |
-
$coreVariable = Mage::getModel('core/variable');
|
| 76 |
-
$data['create_url'] = $coreVariable->loadByCode('saleswarp_create_url')->getValue('plain');
|
| 77 |
-
$data['login_url'] = $coreVariable->loadByCode('saleswarp_login_url')->getValue('plain');
|
| 78 |
-
return $data;
|
| 79 |
-
}
|
| 80 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
class Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Button extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 16 |
+
{
|
| 17 |
+
/*
|
| 18 |
+
* Set template
|
| 19 |
+
*/
|
| 20 |
+
protected function _construct()
|
| 21 |
+
{
|
| 22 |
+
parent::_construct();
|
| 23 |
+
$this->setTemplate('oms/system/config/button.phtml');
|
| 24 |
+
}
|
| 25 |
+
|
| 26 |
+
/**
|
| 27 |
+
* Return element html
|
| 28 |
+
*
|
| 29 |
+
* @param Varien_Data_Form_Element_Abstract $element
|
| 30 |
+
* @return string
|
| 31 |
+
*/
|
| 32 |
+
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 33 |
+
{
|
| 34 |
+
return $this->_toHtml();
|
| 35 |
+
}
|
| 36 |
+
|
| 37 |
+
/**
|
| 38 |
+
* Return ajax url for button
|
| 39 |
+
*
|
| 40 |
+
* @return string
|
| 41 |
+
*/
|
| 42 |
+
public function getAjaxCheckUrl()
|
| 43 |
+
{
|
| 44 |
+
return Mage::helper('adminhtml')->getUrl('admin_oms/adminhtml_getkey');
|
| 45 |
+
}
|
| 46 |
+
|
| 47 |
+
/**
|
| 48 |
+
* Generate button html
|
| 49 |
+
*
|
| 50 |
+
* @return string
|
| 51 |
+
*/
|
| 52 |
+
public function getButtonHtml()
|
| 53 |
+
{
|
| 54 |
+
$button = $this->getLayout()->createBlock('adminhtml/widget_button')
|
| 55 |
+
->setData(array(
|
| 56 |
+
'id' => 'saleswarp_oms_button',
|
| 57 |
+
'label' => $this->helper('adminhtml')->__('Get Key'),
|
| 58 |
+
'onclick' => 'javascript:getKey(); return false;'
|
| 59 |
+
));
|
| 60 |
+
return $button->toHtml();
|
| 61 |
+
}
|
| 62 |
+
|
| 63 |
+
public function isKeyAvailable() {
|
| 64 |
+
$key = Mage::getStoreConfig('oms/registration/key');
|
| 65 |
+
if($key && trim($key)) {
|
| 66 |
+
return true;
|
| 67 |
+
} else {
|
| 68 |
+
return false;
|
| 69 |
+
}
|
| 70 |
+
}
|
| 71 |
+
|
| 72 |
+
public function getKeyData() {
|
| 73 |
+
$data = array();
|
| 74 |
+
$data['key'] = Mage::getStoreConfig('oms/registration/key');
|
| 75 |
+
$coreVariable = Mage::getModel('core/variable');
|
| 76 |
+
$data['create_url'] = $coreVariable->loadByCode('saleswarp_create_url')->getValue('plain');
|
| 77 |
+
$data['login_url'] = $coreVariable->loadByCode('saleswarp_login_url')->getValue('plain');
|
| 78 |
+
return $data;
|
| 79 |
+
}
|
| 80 |
}
|
app/code/local/Saleswarp/Oms/Block/Adminhtml/System/Config/Form/Key.php
CHANGED
|
@@ -1,28 +1,28 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
class Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Key extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 16 |
-
{
|
| 17 |
-
/**
|
| 18 |
-
* Return element html
|
| 19 |
-
*
|
| 20 |
-
* @param Varien_Data_Form_Element_Abstract $element
|
| 21 |
-
* @return string
|
| 22 |
-
*/
|
| 23 |
-
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 24 |
-
{
|
| 25 |
-
$element->setDisabled('disabled');
|
| 26 |
-
return parent::_getElementHtml($element);
|
| 27 |
-
}
|
| 28 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
class Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Key extends Mage_Adminhtml_Block_System_Config_Form_Field
|
| 16 |
+
{
|
| 17 |
+
/**
|
| 18 |
+
* Return element html
|
| 19 |
+
*
|
| 20 |
+
* @param Varien_Data_Form_Element_Abstract $element
|
| 21 |
+
* @return string
|
| 22 |
+
*/
|
| 23 |
+
protected function _getElementHtml(Varien_Data_Form_Element_Abstract $element)
|
| 24 |
+
{
|
| 25 |
+
$element->setDisabled('disabled');
|
| 26 |
+
return parent::_getElementHtml($element);
|
| 27 |
+
}
|
| 28 |
}
|
app/code/local/Saleswarp/Oms/Block/Form/Saleswarp.php
CHANGED
|
@@ -1,22 +1,22 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
class Saleswarp_Oms_Block_Form_Saleswarp extends Mage_Payment_Block_Form
|
| 16 |
-
{
|
| 17 |
-
protected function _construct()
|
| 18 |
-
{
|
| 19 |
-
parent::_construct();
|
| 20 |
-
$this->setTemplate('oms/form/saleswarp.phtml');
|
| 21 |
-
}
|
| 22 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
class Saleswarp_Oms_Block_Form_Saleswarp extends Mage_Payment_Block_Form
|
| 16 |
+
{
|
| 17 |
+
protected function _construct()
|
| 18 |
+
{
|
| 19 |
+
parent::_construct();
|
| 20 |
+
$this->setTemplate('oms/form/saleswarp.phtml');
|
| 21 |
+
}
|
| 22 |
}
|
app/code/local/Saleswarp/Oms/Block/Info/Saleswarp.php
CHANGED
|
@@ -1,30 +1,30 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Block_Info_Saleswarp extends Mage_Payment_Block_Info
|
| 15 |
-
{
|
| 16 |
-
protected function _prepareSpecificInformation($transport = null)
|
| 17 |
-
{
|
| 18 |
-
if (null !== $this->_paymentSpecificInformation) {
|
| 19 |
-
return $this->_paymentSpecificInformation;
|
| 20 |
-
}
|
| 21 |
-
$info = $this->getInfo();
|
| 22 |
-
$transport = new Varien_Object();
|
| 23 |
-
$transport = parent::_prepareSpecificInformation($transport);
|
| 24 |
-
$transport->addData(array(
|
| 25 |
-
Mage::helper('payment')->__('Transaction No#') => $info->getTransctionNo(),
|
| 26 |
-
Mage::helper('payment')->__('Payment Method') => $info->getPaymentMethod()
|
| 27 |
-
));
|
| 28 |
-
return $transport;
|
| 29 |
-
}
|
| 30 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Block_Info_Saleswarp extends Mage_Payment_Block_Info
|
| 15 |
+
{
|
| 16 |
+
protected function _prepareSpecificInformation($transport = null)
|
| 17 |
+
{
|
| 18 |
+
if (null !== $this->_paymentSpecificInformation) {
|
| 19 |
+
return $this->_paymentSpecificInformation;
|
| 20 |
+
}
|
| 21 |
+
$info = $this->getInfo();
|
| 22 |
+
$transport = new Varien_Object();
|
| 23 |
+
$transport = parent::_prepareSpecificInformation($transport);
|
| 24 |
+
$transport->addData(array(
|
| 25 |
+
Mage::helper('payment')->__('Transaction No#') => $info->getTransctionNo(),
|
| 26 |
+
Mage::helper('payment')->__('Payment Method') => $info->getPaymentMethod()
|
| 27 |
+
));
|
| 28 |
+
return $transport;
|
| 29 |
+
}
|
| 30 |
}
|
app/code/local/Saleswarp/Oms/Helper/Data.php
CHANGED
|
@@ -1,4 +1,4 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
class Saleswarp_Oms_Helper_Data extends Mage_Core_Helper_Abstract
|
| 3 |
-
{
|
| 4 |
}
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Oms_Helper_Data extends Mage_Core_Helper_Abstract
|
| 3 |
+
{
|
| 4 |
}
|
app/code/local/Saleswarp/Oms/Model/Category/Api.php
CHANGED
|
@@ -1,17 +1,17 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Model_Category_Api extends Mage_Catalog_Model_Category_Api {
|
| 15 |
-
|
| 16 |
-
}
|
| 17 |
?>
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Model_Category_Api extends Mage_Catalog_Model_Category_Api {
|
| 15 |
+
|
| 16 |
+
}
|
| 17 |
?>
|
app/code/local/Saleswarp/Oms/Model/Config/Api.php
CHANGED
|
@@ -1,53 +1,53 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
/**
|
| 15 |
-
* Use this API to get/set key config data for the storefronts
|
| 16 |
-
*/
|
| 17 |
-
class Saleswarp_Oms_Model_Config_Api
|
| 18 |
-
{
|
| 19 |
-
/**
|
| 20 |
-
* get Attribute id by attribute name
|
| 21 |
-
* @params attribute name
|
| 22 |
-
* @return attribute id
|
| 23 |
-
*/
|
| 24 |
-
public function getProductAttributesId($attribute_code)
|
| 25 |
-
{
|
| 26 |
-
$resource = Mage::getSingleton('core/resource');
|
| 27 |
-
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 28 |
-
|
| 29 |
-
$sql = "SELECT attribute_id from " . $resource->getTableName('eav_attribute') . "
|
| 30 |
-
WHERE entity_type_id = :entityTypeId
|
| 31 |
-
AND attribute_code = :attributeCode ";
|
| 32 |
-
|
| 33 |
-
$binds = array(
|
| 34 |
-
'entityTypeId' => $entity_type_id,
|
| 35 |
-
'attributeCode' => $attribute_code
|
| 36 |
-
);
|
| 37 |
-
$att = $resource->getConnection('core_read')->fetchAll($sql, $binds);
|
| 38 |
-
return $att;
|
| 39 |
-
}
|
| 40 |
-
|
| 41 |
-
/**
|
| 42 |
-
* get website and store Id
|
| 43 |
-
*/
|
| 44 |
-
public function getStoreIds()
|
| 45 |
-
{
|
| 46 |
-
$resource = Mage::getSingleton('core/resource');
|
| 47 |
-
$sql = "SELECT str.*, web.* from " . $resource->getTableName('core_store') . " as str
|
| 48 |
-
JOIN " . $resource->getTableName('core_website') . " as web ON str.website_id = web.website_id ";
|
| 49 |
-
$stores = $resource->getConnection('core_read')->fetchAll($sql);
|
| 50 |
-
return $stores;
|
| 51 |
-
}
|
| 52 |
-
}
|
| 53 |
-
?>
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
/**
|
| 15 |
+
* Use this API to get/set key config data for the storefronts
|
| 16 |
+
*/
|
| 17 |
+
class Saleswarp_Oms_Model_Config_Api
|
| 18 |
+
{
|
| 19 |
+
/**
|
| 20 |
+
* get Attribute id by attribute name
|
| 21 |
+
* @params attribute name
|
| 22 |
+
* @return attribute id
|
| 23 |
+
*/
|
| 24 |
+
public function getProductAttributesId($attribute_code)
|
| 25 |
+
{
|
| 26 |
+
$resource = Mage::getSingleton('core/resource');
|
| 27 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 28 |
+
|
| 29 |
+
$sql = "SELECT attribute_id from " . $resource->getTableName('eav_attribute') . "
|
| 30 |
+
WHERE entity_type_id = :entityTypeId
|
| 31 |
+
AND attribute_code = :attributeCode ";
|
| 32 |
+
|
| 33 |
+
$binds = array(
|
| 34 |
+
'entityTypeId' => $entity_type_id,
|
| 35 |
+
'attributeCode' => $attribute_code
|
| 36 |
+
);
|
| 37 |
+
$att = $resource->getConnection('core_read')->fetchAll($sql, $binds);
|
| 38 |
+
return $att;
|
| 39 |
+
}
|
| 40 |
+
|
| 41 |
+
/**
|
| 42 |
+
* get website and store Id
|
| 43 |
+
*/
|
| 44 |
+
public function getStoreIds()
|
| 45 |
+
{
|
| 46 |
+
$resource = Mage::getSingleton('core/resource');
|
| 47 |
+
$sql = "SELECT str.*, web.* from " . $resource->getTableName('core_store') . " as str
|
| 48 |
+
JOIN " . $resource->getTableName('core_website') . " as web ON str.website_id = web.website_id ";
|
| 49 |
+
$stores = $resource->getConnection('core_read')->fetchAll($sql);
|
| 50 |
+
return $stores;
|
| 51 |
+
}
|
| 52 |
+
}
|
| 53 |
+
?>
|
app/code/local/Saleswarp/Oms/Model/Customer/Api.php
CHANGED
|
@@ -1,35 +1,35 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
/**
|
| 16 |
-
* Use this API to get/set key config data for the storefronts
|
| 17 |
-
*/
|
| 18 |
-
class Saleswarp_Oms_Model_Customer_Api extends Mage_Customer_Model_Customer_Api
|
| 19 |
-
{
|
| 20 |
-
/**
|
| 21 |
-
* Get Customer Group name
|
| 22 |
-
* @params group id
|
| 23 |
-
* @return Group name
|
| 24 |
-
*/
|
| 25 |
-
function get_customer_group_name_by_id($groupId)
|
| 26 |
-
{
|
| 27 |
-
$group = Mage::getModel('customer/group')->load($groupId);
|
| 28 |
-
if ($group->getId()) {
|
| 29 |
-
return $group->getCode();
|
| 30 |
-
} else {
|
| 31 |
-
return "Guest";
|
| 32 |
-
}
|
| 33 |
-
}
|
| 34 |
-
}
|
| 35 |
?>
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
/**
|
| 16 |
+
* Use this API to get/set key config data for the storefronts
|
| 17 |
+
*/
|
| 18 |
+
class Saleswarp_Oms_Model_Customer_Api extends Mage_Customer_Model_Customer_Api
|
| 19 |
+
{
|
| 20 |
+
/**
|
| 21 |
+
* Get Customer Group name
|
| 22 |
+
* @params group id
|
| 23 |
+
* @return Group name
|
| 24 |
+
*/
|
| 25 |
+
function get_customer_group_name_by_id($groupId)
|
| 26 |
+
{
|
| 27 |
+
$group = Mage::getModel('customer/group')->load($groupId);
|
| 28 |
+
if ($group->getId()) {
|
| 29 |
+
return $group->getCode();
|
| 30 |
+
} else {
|
| 31 |
+
return "Guest";
|
| 32 |
+
}
|
| 33 |
+
}
|
| 34 |
+
}
|
| 35 |
?>
|
app/code/local/Saleswarp/Oms/Model/Order/Api.php
CHANGED
|
@@ -1,563 +1,580 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Model_Order_Api extends Mage_Sales_Model_Order_Api
|
| 15 |
-
{
|
| 16 |
-
const STATE_RETURN_REQUESTED = 'return_requested';
|
| 17 |
-
const STATE_EXCHANGE = 'exchange';
|
| 18 |
-
const STATE_ADVANCED_EXCHANGE = 'advanced_exchange';
|
| 19 |
-
const STATE_RETURN_RECEIVED = 'return_received';
|
| 20 |
-
|
| 21 |
-
/**
|
| 22 |
-
* return a recent order list
|
| 23 |
-
* if any parameter is set to zero then that will not be considered for order pull.
|
| 24 |
-
*/
|
| 25 |
-
|
| 26 |
-
|
| 27 |
-
|
| 28 |
-
$
|
| 29 |
-
|
| 30 |
-
// return a list of orders in the last X days
|
| 31 |
-
if ($lastdays != 0) {
|
| 32 |
-
$
|
| 33 |
-
}
|
| 34 |
-
|
| 35 |
-
|
| 36 |
-
|
| 37 |
-
|
| 38 |
-
|
| 39 |
-
|
| 40 |
-
|
| 41 |
-
|
| 42 |
-
|
| 43 |
-
$
|
| 44 |
-
|
| 45 |
-
|
| 46 |
-
|
| 47 |
-
|
| 48 |
-
|
| 49 |
-
|
| 50 |
-
|
| 51 |
-
|
| 52 |
-
|
| 53 |
-
|
| 54 |
-
$methods
|
| 55 |
-
|
| 56 |
-
|
| 57 |
-
|
| 58 |
-
|
| 59 |
-
|
| 60 |
-
|
| 61 |
-
|
| 62 |
-
|
| 63 |
-
|
| 64 |
-
|
| 65 |
-
|
| 66 |
-
|
| 67 |
-
|
| 68 |
-
|
| 69 |
-
|
| 70 |
-
|
| 71 |
-
|
| 72 |
-
|
| 73 |
-
|
| 74 |
-
|
| 75 |
-
|
| 76 |
-
|
| 77 |
-
|
| 78 |
-
|
| 79 |
-
|
| 80 |
-
|
| 81 |
-
|
| 82 |
-
|
| 83 |
-
|
| 84 |
-
|
| 85 |
-
|
| 86 |
-
*
|
| 87 |
-
*/
|
| 88 |
-
function
|
| 89 |
-
{
|
| 90 |
-
|
| 91 |
-
$
|
| 92 |
-
$
|
| 93 |
-
|
| 94 |
-
|
| 95 |
-
|
| 96 |
-
|
| 97 |
-
|
| 98 |
-
|
| 99 |
-
|
| 100 |
-
|
| 101 |
-
|
| 102 |
-
|
| 103 |
-
|
| 104 |
-
|
| 105 |
-
|
| 106 |
-
|
| 107 |
-
|
| 108 |
-
|
| 109 |
-
|
| 110 |
-
|
| 111 |
-
|
| 112 |
-
|
| 113 |
-
|
| 114 |
-
|
| 115 |
-
|
| 116 |
-
|
| 117 |
-
|
| 118 |
-
if (!empty($data['
|
| 119 |
-
$
|
| 120 |
-
} else {
|
| 121 |
-
$
|
| 122 |
-
}
|
| 123 |
-
|
| 124 |
-
if (!empty($data['ShippingAddress']['
|
| 125 |
-
$
|
| 126 |
-
} else {
|
| 127 |
-
$
|
| 128 |
-
}
|
| 129 |
-
|
| 130 |
-
if (!empty($data['BillingAddress']['
|
| 131 |
-
$
|
| 132 |
-
} else {
|
| 133 |
-
$
|
| 134 |
-
}
|
| 135 |
-
|
| 136 |
-
|
| 137 |
-
|
| 138 |
-
$
|
| 139 |
-
}
|
| 140 |
-
|
| 141 |
-
|
| 142 |
-
|
| 143 |
-
|
| 144 |
-
|
| 145 |
-
|
| 146 |
-
|
| 147 |
-
|
| 148 |
-
|
| 149 |
-
|
| 150 |
-
|
| 151 |
-
|
| 152 |
-
|
| 153 |
-
|
| 154 |
-
$
|
| 155 |
-
|
| 156 |
-
|
| 157 |
-
'
|
| 158 |
-
|
| 159 |
-
|
| 160 |
-
|
| 161 |
-
|
| 162 |
-
|
| 163 |
-
|
| 164 |
-
|
| 165 |
-
|
| 166 |
-
|
| 167 |
-
|
| 168 |
-
|
| 169 |
-
|
| 170 |
-
|
| 171 |
-
|
| 172 |
-
'
|
| 173 |
-
|
| 174 |
-
|
| 175 |
-
|
| 176 |
-
|
| 177 |
-
|
| 178 |
-
'
|
| 179 |
-
'
|
| 180 |
-
'
|
| 181 |
-
'
|
| 182 |
-
|
| 183 |
-
|
| 184 |
-
|
| 185 |
-
|
| 186 |
-
|
| 187 |
-
'
|
| 188 |
-
|
| 189 |
-
|
| 190 |
-
|
| 191 |
-
|
| 192 |
-
|
| 193 |
-
'
|
| 194 |
-
'
|
| 195 |
-
'
|
| 196 |
-
'
|
| 197 |
-
|
| 198 |
-
|
| 199 |
-
|
| 200 |
-
|
| 201 |
-
$
|
| 202 |
-
|
| 203 |
-
|
| 204 |
-
|
| 205 |
-
|
| 206 |
-
|
| 207 |
-
|
| 208 |
-
|
| 209 |
-
|
| 210 |
-
|
| 211 |
-
|
| 212 |
-
|
| 213 |
-
|
| 214 |
-
|
| 215 |
-
|
| 216 |
-
|
| 217 |
-
|
| 218 |
-
|
| 219 |
-
|
| 220 |
-
|
| 221 |
-
|
| 222 |
-
|
| 223 |
-
|
| 224 |
-
|
| 225 |
-
|
| 226 |
-
|
| 227 |
-
|
| 228 |
-
|
| 229 |
-
|
| 230 |
-
|
| 231 |
-
|
| 232 |
-
|
| 233 |
-
|
| 234 |
-
|
| 235 |
-
|
| 236 |
-
|
| 237 |
-
|
| 238 |
-
|
| 239 |
-
|
| 240 |
-
|
| 241 |
-
|
| 242 |
-
|
| 243 |
-
|
| 244 |
-
|
| 245 |
-
|
| 246 |
-
|
| 247 |
-
|
| 248 |
-
|
| 249 |
-
|
| 250 |
-
|
| 251 |
-
|
| 252 |
-
|
| 253 |
-
|
| 254 |
-
|
| 255 |
-
|
| 256 |
-
|
| 257 |
-
|
| 258 |
-
|
| 259 |
-
|
| 260 |
-
|
| 261 |
-
$
|
| 262 |
-
|
| 263 |
-
|
| 264 |
-
|
| 265 |
-
|
| 266 |
-
|
| 267 |
-
|
| 268 |
-
|
| 269 |
-
|
| 270 |
-
|
| 271 |
-
|
| 272 |
-
|
| 273 |
-
|
| 274 |
-
|
| 275 |
-
|
| 276 |
-
|
| 277 |
-
|
| 278 |
-
|
| 279 |
-
|
| 280 |
-
|
| 281 |
-
|
| 282 |
-
|
| 283 |
-
|
| 284 |
-
$
|
| 285 |
-
|
| 286 |
-
|
| 287 |
-
|
| 288 |
-
|
| 289 |
-
|
| 290 |
-
|
| 291 |
-
|
| 292 |
-
|
| 293 |
-
|
| 294 |
-
|
| 295 |
-
|
| 296 |
-
|
| 297 |
-
|
| 298 |
-
|
| 299 |
-
|
| 300 |
-
|
| 301 |
-
|
| 302 |
-
|
| 303 |
-
|
| 304 |
-
|
| 305 |
-
}
|
| 306 |
-
|
| 307 |
-
|
| 308 |
-
|
| 309 |
-
|
| 310 |
-
|
| 311 |
-
|
| 312 |
-
|
| 313 |
-
|
| 314 |
-
|
| 315 |
-
|
| 316 |
-
|
| 317 |
-
|
| 318 |
-
|
| 319 |
-
|
| 320 |
-
|
| 321 |
-
|
| 322 |
-
|
| 323 |
-
|
| 324 |
-
|
| 325 |
-
|
| 326 |
-
|
| 327 |
-
|
| 328 |
-
|
| 329 |
-
|
| 330 |
-
|
| 331 |
-
|
| 332 |
-
|
| 333 |
-
|
| 334 |
-
|
| 335 |
-
|
| 336 |
-
|
| 337 |
-
|
| 338 |
-
|
| 339 |
-
return
|
| 340 |
-
}
|
| 341 |
-
|
| 342 |
-
|
| 343 |
-
|
| 344 |
-
|
| 345 |
-
|
| 346 |
-
|
| 347 |
-
|
| 348 |
-
|
| 349 |
-
|
| 350 |
-
|
| 351 |
-
|
| 352 |
-
|
| 353 |
-
|
| 354 |
-
|
| 355 |
-
|
| 356 |
-
|
| 357 |
-
|
| 358 |
-
|
| 359 |
-
|
| 360 |
-
|
| 361 |
-
|
| 362 |
-
|
| 363 |
-
|
| 364 |
-
|
| 365 |
-
|
| 366 |
-
|
| 367 |
-
|
| 368 |
-
|
| 369 |
-
|
| 370 |
-
|
| 371 |
-
|
| 372 |
-
|
| 373 |
-
|
| 374 |
-
|
| 375 |
-
|
| 376 |
-
|
| 377 |
-
|
| 378 |
-
|
| 379 |
-
|
| 380 |
-
|
| 381 |
-
|
| 382 |
-
|
| 383 |
-
|
| 384 |
-
|
| 385 |
-
|
| 386 |
-
|
| 387 |
-
|
| 388 |
-
|
| 389 |
-
|
| 390 |
-
|
| 391 |
-
|
| 392 |
-
|
| 393 |
-
|
| 394 |
-
|
| 395 |
-
|
| 396 |
-
|
| 397 |
-
|
| 398 |
-
|
| 399 |
-
|
| 400 |
-
|
| 401 |
-
|
| 402 |
-
|
| 403 |
-
|
| 404 |
-
|
| 405 |
-
|
| 406 |
-
|
| 407 |
-
|
| 408 |
-
|
| 409 |
-
$this->order_shipment
|
| 410 |
-
|
| 411 |
-
|
| 412 |
-
|
| 413 |
-
|
| 414 |
-
|
| 415 |
-
|
| 416 |
-
|
| 417 |
-
|
| 418 |
-
|
| 419 |
-
|
| 420 |
-
|
| 421 |
-
|
| 422 |
-
|
| 423 |
-
|
| 424 |
-
|
| 425 |
-
|
| 426 |
-
|
| 427 |
-
|
| 428 |
-
|
| 429 |
-
|
| 430 |
-
|
| 431 |
-
|
| 432 |
-
|
| 433 |
-
|
| 434 |
-
|
| 435 |
-
|
| 436 |
-
|
| 437 |
-
|
| 438 |
-
|
| 439 |
-
|
| 440 |
-
|
| 441 |
-
|
| 442 |
-
|
| 443 |
-
|
| 444 |
-
|
| 445 |
-
|
| 446 |
-
|
| 447 |
-
|
| 448 |
-
|
| 449 |
-
|
| 450 |
-
|
| 451 |
-
|
| 452 |
-
|
| 453 |
-
|
| 454 |
-
|
| 455 |
-
|
| 456 |
-
|
| 457 |
-
|
| 458 |
-
|
| 459 |
-
|
| 460 |
-
|
| 461 |
-
|
| 462 |
-
|
| 463 |
-
|
| 464 |
-
|
| 465 |
-
|
| 466 |
-
|
| 467 |
-
$
|
| 468 |
-
|
| 469 |
-
|
| 470 |
-
|
| 471 |
-
|
| 472 |
-
|
| 473 |
-
|
| 474 |
-
|
| 475 |
-
|
| 476 |
-
|
| 477 |
-
|
| 478 |
-
|
| 479 |
-
|
| 480 |
-
|
| 481 |
-
|
| 482 |
-
|
| 483 |
-
|
| 484 |
-
$
|
| 485 |
-
|
| 486 |
-
|
| 487 |
-
|
| 488 |
-
|
| 489 |
-
|
| 490 |
-
|
| 491 |
-
|
| 492 |
-
|
| 493 |
-
|
| 494 |
-
|
| 495 |
-
|
| 496 |
-
|
| 497 |
-
|
| 498 |
-
|
| 499 |
-
|
| 500 |
-
|
| 501 |
-
|
| 502 |
-
|
| 503 |
-
|
| 504 |
-
|
| 505 |
-
|
| 506 |
-
|
| 507 |
-
|
| 508 |
-
|
| 509 |
-
|
| 510 |
-
|
| 511 |
-
|
| 512 |
-
|
| 513 |
-
|
| 514 |
-
|
| 515 |
-
|
| 516 |
-
|
| 517 |
-
|
| 518 |
-
|
| 519 |
-
|
| 520 |
-
|
| 521 |
-
|
| 522 |
-
|
| 523 |
-
|
| 524 |
-
|
| 525 |
-
|
| 526 |
-
|
| 527 |
-
|
| 528 |
-
|
| 529 |
-
|
| 530 |
-
|
| 531 |
-
|
| 532 |
-
|
| 533 |
-
|
| 534 |
-
|
| 535 |
-
|
| 536 |
-
|
| 537 |
-
|
| 538 |
-
|
| 539 |
-
|
| 540 |
-
|
| 541 |
-
|
| 542 |
-
|
| 543 |
-
|
| 544 |
-
|
| 545 |
-
|
| 546 |
-
|
| 547 |
-
$
|
| 548 |
-
|
| 549 |
-
|
| 550 |
-
|
| 551 |
-
|
| 552 |
-
|
| 553 |
-
|
| 554 |
-
|
| 555 |
-
|
| 556 |
-
|
| 557 |
-
|
| 558 |
-
|
| 559 |
-
|
| 560 |
-
|
| 561 |
-
|
| 562 |
-
|
| 563 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Model_Order_Api extends Mage_Sales_Model_Order_Api
|
| 15 |
+
{
|
| 16 |
+
const STATE_RETURN_REQUESTED = 'return_requested';
|
| 17 |
+
const STATE_EXCHANGE = 'exchange';
|
| 18 |
+
const STATE_ADVANCED_EXCHANGE = 'advanced_exchange';
|
| 19 |
+
const STATE_RETURN_RECEIVED = 'return_received';
|
| 20 |
+
|
| 21 |
+
/**
|
| 22 |
+
* return a recent order list
|
| 23 |
+
* if any parameter is set to zero then that will not be considered for order pull.
|
| 24 |
+
*/
|
| 25 |
+
public function get_recent_order_list($limit = 0, $lastdays = 5, $offset = 0)
|
| 26 |
+
{
|
| 27 |
+
$storeId = Mage::app()->getStore()->getStoreId();
|
| 28 |
+
$conditions = ' WHERE store_id = ' . $storeId . ' AND ';
|
| 29 |
+
|
| 30 |
+
// return a list of orders in the last X days
|
| 31 |
+
if ($lastdays != 0) {
|
| 32 |
+
$conditions .= " created_at > '" . strftime('%Y-%m-%d %H:%M:%S', (time() - (24 * 60 * 60 * $lastdays))) . "'";
|
| 33 |
+
}
|
| 34 |
+
|
| 35 |
+
// set limit for orders
|
| 36 |
+
if ($limit != 0) {
|
| 37 |
+
$conditions .= " LIMIT $offset, $limit";
|
| 38 |
+
}
|
| 39 |
+
|
| 40 |
+
$salesFlatTable = Mage::getSingleton('core/resource')->getTableName('sales_flat_order');
|
| 41 |
+
$sql = "select * from " . $salesFlatTable . $conditions;
|
| 42 |
+
|
| 43 |
+
$orders = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 44 |
+
return $orders;
|
| 45 |
+
}
|
| 46 |
+
|
| 47 |
+
/**
|
| 48 |
+
* get active shipping methods
|
| 49 |
+
*/
|
| 50 |
+
public function getActShipMethods()
|
| 51 |
+
{
|
| 52 |
+
$methods = Mage::getSingleton('shipping/config')->getActiveCarriers();
|
| 53 |
+
$shipping = array();
|
| 54 |
+
foreach ($methods as $_ccode => $_carrier) {
|
| 55 |
+
if ($_methods = $_carrier->getAllowedMethods()) {
|
| 56 |
+
if (!$_title = Mage::getStoreConfig("carriers/$_ccode/title")) {
|
| 57 |
+
$_title = $_ccode;
|
| 58 |
+
}
|
| 59 |
+
foreach ($_methods as $_mcode => $_method) {
|
| 60 |
+
$_code = $_ccode . '_' . $_mcode;
|
| 61 |
+
$shipping[$_code] = array(
|
| 62 |
+
'title' => $_method,
|
| 63 |
+
'carrier' => $_title
|
| 64 |
+
);
|
| 65 |
+
}
|
| 66 |
+
}
|
| 67 |
+
}
|
| 68 |
+
return $shipping;
|
| 69 |
+
}
|
| 70 |
+
|
| 71 |
+
/**
|
| 72 |
+
* get active Payment methods
|
| 73 |
+
* */
|
| 74 |
+
function getActPayment()
|
| 75 |
+
{
|
| 76 |
+
$payments = Mage::getSingleton('payment/config')->getActiveMethods();
|
| 77 |
+
foreach ($payments as $paymentCode => $paymentModel) {
|
| 78 |
+
$paymentTitle[] = $paymentCode;
|
| 79 |
+
}
|
| 80 |
+
return $paymentTitle;
|
| 81 |
+
}
|
| 82 |
+
|
| 83 |
+
/**
|
| 84 |
+
* function to get lineitem id
|
| 85 |
+
* @param magento order id
|
| 86 |
+
* @return lineitems id
|
| 87 |
+
*/
|
| 88 |
+
function getLineItem($mageOrderId)
|
| 89 |
+
{
|
| 90 |
+
// get the order id
|
| 91 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 92 |
+
$salesFlatTable = Mage::getSingleton( 'core/resource' )->getTableName( 'sales_flat_order' );
|
| 93 |
+
$orderItemTable = Mage::getSingleton( 'core/resource' )->getTableName( 'sales_flat_order_item' );
|
| 94 |
+
|
| 95 |
+
//check for existig group
|
| 96 |
+
$chk = $write->query("SELECT l.item_id, l.product_id FROM ". $salesFlatTable ." ord INNER JOIN
|
| 97 |
+
". $orderItemTable ." l ON ord.entity_id = l.order_id WHERE ord.increment_id = '".(int)$mageOrderId."'");
|
| 98 |
+
$row = $chk->fetchAll(PDO::FETCH_ASSOC);
|
| 99 |
+
return $row;
|
| 100 |
+
}
|
| 101 |
+
|
| 102 |
+
/**
|
| 103 |
+
* Create order in magento
|
| 104 |
+
*/
|
| 105 |
+
function create_order($data)
|
| 106 |
+
{
|
| 107 |
+
$logFileName = 'create_order.log';
|
| 108 |
+
$customer = Mage::getModel('customer/customer');
|
| 109 |
+
$quote = Mage::getModel('sales/quote')->setStoreId(Mage::app()->getStore('default')->getId());
|
| 110 |
+
|
| 111 |
+
$password = Mage::getModel('customer/customer')->generatePassword();
|
| 112 |
+
if (!empty($data['BaseCustomer']['email'])) {
|
| 113 |
+
$email = $data['BaseCustomer']['email'];
|
| 114 |
+
} else {
|
| 115 |
+
$email = 'customer_' . $data['BaseCustomer']['id'] . '@saleswarp.com';
|
| 116 |
+
}
|
| 117 |
+
|
| 118 |
+
if (!empty($data['ShippingAddress']['street'])) {
|
| 119 |
+
$sStreet = $data['ShippingAddress']['street'];
|
| 120 |
+
} else {
|
| 121 |
+
$sStreet = '';
|
| 122 |
+
}
|
| 123 |
+
|
| 124 |
+
if (!empty($data['ShippingAddress']['street1'])) {
|
| 125 |
+
$sStreet1 = $data['ShippingAddress']['street1'];
|
| 126 |
+
} else {
|
| 127 |
+
$sStreet1 = '';
|
| 128 |
+
}
|
| 129 |
+
|
| 130 |
+
if (!empty($data['BillingAddress']['street'])) {
|
| 131 |
+
$bStreet = $data['BillingAddress']['street'];
|
| 132 |
+
} else {
|
| 133 |
+
$bStreet = '';
|
| 134 |
+
}
|
| 135 |
+
if (!empty($data['BillingAddress']['street1'])) {
|
| 136 |
+
$bStreet1 = $data['BillingAddress']['street1'];
|
| 137 |
+
} else {
|
| 138 |
+
$bStreet1 = '';
|
| 139 |
+
}
|
| 140 |
+
|
| 141 |
+
if (!empty($data['ShippingAddress']['region_code']) && $data['ShippingAddress']['region_code'] != 'na') {
|
| 142 |
+
$sregion_id = $data['ShippingAddress']['region_code'];
|
| 143 |
+
} else {
|
| 144 |
+
$sregion_id = '';
|
| 145 |
+
}
|
| 146 |
+
|
| 147 |
+
if (!empty($data['BillingAddress']['region_code']) && $data['BillingAddress']['region_code'] != 'na') {
|
| 148 |
+
$bregion_id = $data['BillingAddress']['region_code'];
|
| 149 |
+
} else {
|
| 150 |
+
$bregion_id = '';
|
| 151 |
+
}
|
| 152 |
+
|
| 153 |
+
// customer address//
|
| 154 |
+
if (!empty($data['BaseCustomer']['street'])) {
|
| 155 |
+
$cStreet = $data['BaseCustomer']['street'];
|
| 156 |
+
} else {
|
| 157 |
+
$cStreet = '';
|
| 158 |
+
}
|
| 159 |
+
if (!empty($data['BaseCustomer']['street1'])) {
|
| 160 |
+
$cStreet1 = $data['BaseCustomer']['street1'];
|
| 161 |
+
} else {
|
| 162 |
+
$cStreet1 = '';
|
| 163 |
+
}
|
| 164 |
+
|
| 165 |
+
if (!empty($data['BaseCustomer']['region_code']) && $data['BaseCustomer']['region_code'] != 'na') {
|
| 166 |
+
$cregion_id = $data['BaseCustomer']['region_code'];
|
| 167 |
+
} else {
|
| 168 |
+
$cregion_id = '';
|
| 169 |
+
}
|
| 170 |
+
|
| 171 |
+
$shipAddressData = array(
|
| 172 |
+
'firstname' => (!empty($data['ShippingAddress']['first_name'])) ? $data['ShippingAddress']['first_name'] : '',
|
| 173 |
+
'lastname' => (!empty($data['ShippingAddress']['last_name'])) ? $data['ShippingAddress']['last_name'] : '',
|
| 174 |
+
'street' => array(
|
| 175 |
+
'0' => $sStreet,
|
| 176 |
+
'1' => $sStreet1
|
| 177 |
+
),
|
| 178 |
+
'city' => (!empty($data['ShippingAddress']['city'])) ? $data['ShippingAddress']['city'] : '',
|
| 179 |
+
'postcode' => (!empty($data['ShippingAddress']['post_code'])) ? $data['ShippingAddress']['post_code'] : '',
|
| 180 |
+
'telephone' => ($data['ShippingAddress']['phone']) ? $data['ShippingAddress']['phone'] : '111-111-1111',
|
| 181 |
+
'country_id' => (!empty($data['ShippingAddress']['country_code'])) ? $data['ShippingAddress']['country_code'] : 'US',
|
| 182 |
+
'region_id' => $sregion_id,
|
| 183 |
+
'region' => (!empty($data['ShippingAddress']['state'])) ? $data['ShippingAddress']['state'] : ''
|
| 184 |
+
);
|
| 185 |
+
|
| 186 |
+
$billAddressData = array(
|
| 187 |
+
'firstname' => (!empty($data['BillingAddress']['first_name'])) ? $data['BillingAddress']['first_name'] : '',
|
| 188 |
+
'lastname' => (!empty($data['BillingAddress']['last_name'])) ? $data['BillingAddress']['last_name'] : '',
|
| 189 |
+
'street' => array(
|
| 190 |
+
'0' => $bStreet,
|
| 191 |
+
'1' => $bStreet1
|
| 192 |
+
),
|
| 193 |
+
'city' => (!empty($data['BillingAddress']['city'])) ? $data['BillingAddress']['city'] : '',
|
| 194 |
+
'postcode' => (!empty($data['BillingAddress']['post_code'])) ? $data['BillingAddress']['post_code'] : '',
|
| 195 |
+
'telephone' => ($data['BillingAddress']['phone']) ? $data['BillingAddress']['phone'] : '111-111-1111',
|
| 196 |
+
'country_id' => (!empty($data['BillingAddress']['country_code'])) ? $data['BillingAddress']['country_code'] : 'US',
|
| 197 |
+
'region_id' => $bregion_id,
|
| 198 |
+
'region' => (!empty($data['BillingAddress']['state'])) ? $data['BillingAddress']['state'] : ''
|
| 199 |
+
);
|
| 200 |
+
|
| 201 |
+
$customerAddressData = array(
|
| 202 |
+
'firstname' => (!empty($data['BaseCustomer']['first_name'])) ? $data['BaseCustomer']['first_name'] : '',
|
| 203 |
+
'lastname' => (!empty($data['BaseCustomer']['last_name'])) ? $data['BaseCustomer']['last_name'] : '',
|
| 204 |
+
'street' => array(
|
| 205 |
+
'0' => $cStreet,
|
| 206 |
+
'1' => $cStreet1
|
| 207 |
+
),
|
| 208 |
+
'city' => (!empty($data['BaseCustomer']['city'])) ? $data['BaseCustomer']['city'] : '',
|
| 209 |
+
'postcode' => (!empty($data['BaseCustomer']['post_code'])) ? $data['BaseCustomer']['post_code'] : '',
|
| 210 |
+
'telephone' => ($data['BaseCustomer']['phone']) ? $data['BaseCustomer']['phone'] : '111-111-1111',
|
| 211 |
+
'country_id' => (!empty($data['BaseCustomer']['country_code'])) ? $data['BaseCustomer']['country_code'] : 'US',
|
| 212 |
+
'region_id' => $bregion_id,
|
| 213 |
+
'region' => (!empty($data['BaseCustomer']['state'])) ? $data['BaseCustomer']['state'] : ''
|
| 214 |
+
);
|
| 215 |
+
|
| 216 |
+
$customer_group_id = $this->get_customer_group_id_by_name($data['BaseCustomer']['group']);
|
| 217 |
+
$customer->setWebsiteId(1);
|
| 218 |
+
$customer->loadByEmail($email);
|
| 219 |
+
|
| 220 |
+
if (!$customer->getId()) {
|
| 221 |
+
$customer->setEmail($email);
|
| 222 |
+
$customer->setWebsiteId(1);
|
| 223 |
+
$customer->setFirstname($data['BaseCustomer']['first_name']);
|
| 224 |
+
$customer->setLastname($data['BaseCustomer']['last_name']);
|
| 225 |
+
$customer->setPassword($password);
|
| 226 |
+
$customer->setGroupId($customer_group_id);
|
| 227 |
+
try {
|
| 228 |
+
$customer->save();
|
| 229 |
+
$customer->setConfirmation(null);
|
| 230 |
+
$customer->save();
|
| 231 |
+
// save billing address//
|
| 232 |
+
$address = Mage::getModel("customer/address");
|
| 233 |
+
$address->setData($billAddressData)->setCustomerId($customer->getId())->setIsDefaultBilling('1')->setIsDefaultShipping('1')->setSaveInAddressBook('1');
|
| 234 |
+
|
| 235 |
+
try {
|
| 236 |
+
$address->save();
|
| 237 |
+
}catch (Exception $ex) {
|
| 238 |
+
Mage::log($ex->getMessage(), null, $logFileName);
|
| 239 |
+
return false;
|
| 240 |
+
}
|
| 241 |
+
|
| 242 |
+
//Make a "login" of new customer
|
| 243 |
+
Mage::getSingleton('customer/session')->loginById($customer->getId());
|
| 244 |
+
$quote->assignCustomer($customer);
|
| 245 |
+
}
|
| 246 |
+
catch (Exception $ex) {
|
| 247 |
+
Mage::log($ex->getMessage(), null, $logFileName);
|
| 248 |
+
return false;
|
| 249 |
+
}
|
| 250 |
+
} else {
|
| 251 |
+
$quote->assignCustomer($customer);
|
| 252 |
+
}
|
| 253 |
+
|
| 254 |
+
$store_id = $data['BaseOrder']['base_store_id'];
|
| 255 |
+
$lineitem = $data['Lineitem'];
|
| 256 |
+
foreach ($lineitem as $item) {
|
| 257 |
+
// check whether item/product published or not
|
| 258 |
+
$prod_id = $item['base_product_id'];
|
| 259 |
+
$mage_prod_id = $item['mageProdId'];
|
| 260 |
+
$prodId[$prod_id] = $item['mageProdId'];
|
| 261 |
+
$qty_ordered = (int) $item['qty_ordered'];
|
| 262 |
+
$buyInfo = array('qty' => $qty_ordered);
|
| 263 |
+
$prod = Mage::getModel('catalog/product')->load($mage_prod_id);
|
| 264 |
+
$prod->setPrice($item['price_after_discount']);
|
| 265 |
+
$prod->setSpecialPrice($item['price_after_discount']);
|
| 266 |
+
try {
|
| 267 |
+
$quote->addProduct($prod, new Varien_Object($buyInfo));
|
| 268 |
+
}
|
| 269 |
+
catch (Exception $e) {
|
| 270 |
+
Mage::log($e->getMessage(), null, $logFileName);
|
| 271 |
+
continue;
|
| 272 |
+
}
|
| 273 |
+
}
|
| 274 |
+
|
| 275 |
+
$shipMethod = !empty($data['Saleswarp']['freightID']) ? $data['Saleswarp']['freightID'] : 'flatrate_flatrate';
|
| 276 |
+
|
| 277 |
+
try {
|
| 278 |
+
$billingAddress = $quote->getBillingAddress()->addData($billAddressData);
|
| 279 |
+
}
|
| 280 |
+
catch (Exception $e) {
|
| 281 |
+
Mage::log($e->getMessage(), null, $logFileName);
|
| 282 |
+
}
|
| 283 |
+
$shippingAddress = $quote->getShippingAddress()->addData($shipAddressData);
|
| 284 |
+
$shippingAddress->setCollectShippingRates(true)->collectShippingRates()->setShippingMethod($shipMethod);
|
| 285 |
+
|
| 286 |
+
$paymentMethod = array(
|
| 287 |
+
'method' => 'saleswarp',
|
| 288 |
+
'transction_no' => $data['Saleswarp']['transactionId'],
|
| 289 |
+
'payment_method' => $data['Saleswarp']['payMethodName']
|
| 290 |
+
);
|
| 291 |
+
|
| 292 |
+
try {
|
| 293 |
+
$quote->getPayment()->importData($paymentMethod);
|
| 294 |
+
}
|
| 295 |
+
catch (Exception $e) {
|
| 296 |
+
Mage::log($e->getMessage(), null, $logFileName);
|
| 297 |
+
return false;
|
| 298 |
+
}
|
| 299 |
+
$quote->collectTotals()->save();
|
| 300 |
+
|
| 301 |
+
$service = Mage::getModel('sales/service_quote', $quote);
|
| 302 |
+
|
| 303 |
+
try {
|
| 304 |
+
$service->submitAll();
|
| 305 |
+
}
|
| 306 |
+
catch (Exception $e) {
|
| 307 |
+
Mage::log($e->getMessage(), null, $logFileName);
|
| 308 |
+
return false;
|
| 309 |
+
}
|
| 310 |
+
|
| 311 |
+
try {
|
| 312 |
+
$order = $service->getOrder();
|
| 313 |
+
if ($order) {
|
| 314 |
+
$morder_id = $order->getIncrementId();
|
| 315 |
+
Mage::log("Created order: " . $morder_id, null, $logFileName);
|
| 316 |
+
return $morder_id;
|
| 317 |
+
}
|
| 318 |
+
}
|
| 319 |
+
catch (Exception $e) {
|
| 320 |
+
Mage::log($e->getMessage(), null, $logFileName);
|
| 321 |
+
return false;
|
| 322 |
+
}
|
| 323 |
+
}
|
| 324 |
+
|
| 325 |
+
/**
|
| 326 |
+
* Get Customer Group id by group name
|
| 327 |
+
*/
|
| 328 |
+
function get_customer_group_id_by_name($name)
|
| 329 |
+
{
|
| 330 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 331 |
+
$type = addslashes($name);
|
| 332 |
+
|
| 333 |
+
//check for existig group
|
| 334 |
+
$customerGrpTable = Mage::getSingleton('core/resource')->getTableName('customer_group');
|
| 335 |
+
|
| 336 |
+
$chk = $write->query("SELECT customer_group_id FROM " . $customerGrpTable . " WHERE customer_group_code = '" . $type . "'");
|
| 337 |
+
$row = $chk->fetch(PDO::FETCH_ASSOC);
|
| 338 |
+
if ($row) {
|
| 339 |
+
return $row['customer_group_id'];
|
| 340 |
+
}
|
| 341 |
+
return false;
|
| 342 |
+
}
|
| 343 |
+
|
| 344 |
+
/**
|
| 345 |
+
* * Cancel Order
|
| 346 |
+
*/
|
| 347 |
+
function cancel_order($magento_orderId)
|
| 348 |
+
{
|
| 349 |
+
$orderModel = Mage::getModel('sales/order')->loadByIncrementId($magento_orderId);
|
| 350 |
+
if ($orderModel->canCancel()) {
|
| 351 |
+
$orderModel->setState(Mage_Sales_Model_Order::STATE_CANCELED, true)->save();
|
| 352 |
+
return true;
|
| 353 |
+
} else if($this->creditmemo_order($magento_orderId)) {
|
| 354 |
+
return true;
|
| 355 |
+
} else {
|
| 356 |
+
return false;
|
| 357 |
+
}
|
| 358 |
+
}
|
| 359 |
+
|
| 360 |
+
/**
|
| 361 |
+
* Hold order
|
| 362 |
+
*/
|
| 363 |
+
function hold_order($magento_orderId)
|
| 364 |
+
{
|
| 365 |
+
$orderModel = Mage::getModel('sales/order')->loadByIncrementId($magento_orderId);
|
| 366 |
+
if ($orderModel->canHold()) {
|
| 367 |
+
$orderModel->setState(Mage_Sales_Model_Order::STATE_HOLDED, true)->save();
|
| 368 |
+
return true;
|
| 369 |
+
} else {
|
| 370 |
+
return false;
|
| 371 |
+
}
|
| 372 |
+
}
|
| 373 |
+
|
| 374 |
+
/**
|
| 375 |
+
* Create Credit memo
|
| 376 |
+
*/
|
| 377 |
+
function creditmemo_order($magento_orderId)
|
| 378 |
+
{
|
| 379 |
+
Mage::getModel('sales/order_creditmemo_api')->create($magento_orderId);
|
| 380 |
+
Mage::getModel('sales/order')->loadByIncrementId($magento_orderId)->setState(Mage_Sales_Model_Order::STATE_CLOSED, true)->save();
|
| 381 |
+
return true;
|
| 382 |
+
}
|
| 383 |
+
|
| 384 |
+
/**
|
| 385 |
+
* Add tracking information to a order
|
| 386 |
+
*/
|
| 387 |
+
function create_ship_track($shipment_id, $carrier, $msg, $track_id)
|
| 388 |
+
{
|
| 389 |
+
$this->order_shipment = Mage::getSingleton('sales/order_shipment_api');
|
| 390 |
+
return $this->order_shipment->addTrack($shipment_id, $carrier, $msg, $track_id);
|
| 391 |
+
}
|
| 392 |
+
|
| 393 |
+
/**
|
| 394 |
+
* Send Shipment email to customer
|
| 395 |
+
*/
|
| 396 |
+
function send_ship_email($newShipmentId, $comment)
|
| 397 |
+
{
|
| 398 |
+
$this->order_shipment = Mage::getSingleton('sales/order_shipment_api');
|
| 399 |
+
return $this->order_shipment->sendInfo($newShipmentId, $comment);
|
| 400 |
+
}
|
| 401 |
+
|
| 402 |
+
/**
|
| 403 |
+
* Add comment to a shipment
|
| 404 |
+
*/
|
| 405 |
+
|
| 406 |
+
function create_ship_comment($shipment_id, $comment, $send_email, $include_comment)
|
| 407 |
+
{
|
| 408 |
+
$this->order_shipment = Mage::getSingleton('sales/order_shipment_api');
|
| 409 |
+
return $this->order_shipment->addComment($shipment_id, $comment, $send_email, $include_comment);
|
| 410 |
+
}
|
| 411 |
+
|
| 412 |
+
/**
|
| 413 |
+
* Add comment to Order
|
| 414 |
+
*/
|
| 415 |
+
function create_order_comment($order_id, $comment, $status = "complete", $notify = true)
|
| 416 |
+
{
|
| 417 |
+
$this->order = Mage::getSingleton('sales/order_api');
|
| 418 |
+
return $this->order->addComment($order_id, $comment, $status, $notify);
|
| 419 |
+
}
|
| 420 |
+
|
| 421 |
+
/**
|
| 422 |
+
* Create order shipment
|
| 423 |
+
*/
|
| 424 |
+
function create_order_shipment($order_id, $info, $message = "Shipped", $send_email = true, $include_comment = true)
|
| 425 |
+
{
|
| 426 |
+
$this->order_shipment = Mage::getSingleton('sales/order_shipment_api');
|
| 427 |
+
return $this->order_shipment->create($order_id, $info, $message, $send_email, $include_comment);
|
| 428 |
+
}
|
| 429 |
+
|
| 430 |
+
/**
|
| 431 |
+
* Retrieve full order information
|
| 432 |
+
*
|
| 433 |
+
* @param string $orderIncrementId
|
| 434 |
+
* @return array
|
| 435 |
+
*/
|
| 436 |
+
public function info($orderIncrementId)
|
| 437 |
+
{
|
| 438 |
+
$order = $this->_initOrder($orderIncrementId);
|
| 439 |
+
|
| 440 |
+
if ($order->getGiftMessageId() > 0) {
|
| 441 |
+
$order->setGiftMessage(Mage::getSingleton('giftmessage/message')->load($order->getGiftMessageId())->getMessage());
|
| 442 |
+
}
|
| 443 |
+
|
| 444 |
+
$result = $this->_getAttributes($order, 'order');
|
| 445 |
+
|
| 446 |
+
$result['shipping_address'] = $this->_getAttributes($order->getShippingAddress(), 'order_address');
|
| 447 |
+
$result['billing_address'] = $this->_getAttributes($order->getBillingAddress(), 'order_address');
|
| 448 |
+
$result['items'] = array();
|
| 449 |
+
|
| 450 |
+
foreach ($order->getAllItems() as $item) {
|
| 451 |
+
if ($item->getGiftMessageId() > 0) {
|
| 452 |
+
$item->setGiftMessage(Mage::getSingleton('giftmessage/message')->load($item->getGiftMessageId())->getMessage());
|
| 453 |
+
}
|
| 454 |
+
|
| 455 |
+
// We need to grab some saleswarp data from the related product
|
| 456 |
+
$product = Mage::getModel('catalog/product')->load((int) $item['product_id']);
|
| 457 |
+
|
| 458 |
+
foreach ($product->getData() as $k => $v) {
|
| 459 |
+
if (strpos($k, 'saleswarp') !== false)
|
| 460 |
+
$item[$k] = $v;
|
| 461 |
+
}
|
| 462 |
+
$item['prod_url'] = $product->getProductUrl();
|
| 463 |
+
|
| 464 |
+
$result['items'][] = $this->_getAttributes($item, 'order_item');
|
| 465 |
+
}
|
| 466 |
+
|
| 467 |
+
$result['payment'] = $this->_getAttributes($order->getPayment(), 'order_payment');
|
| 468 |
+
$result['status_history'] = array();
|
| 469 |
+
|
| 470 |
+
foreach ($order->getAllStatusHistory() as $history) {
|
| 471 |
+
$result['status_history'][] = $this->_getAttributes($history, 'order_status_history');
|
| 472 |
+
}
|
| 473 |
+
|
| 474 |
+
return $result;
|
| 475 |
+
}
|
| 476 |
+
|
| 477 |
+
/**
|
| 478 |
+
* Genearate Refund for a order
|
| 479 |
+
*/
|
| 480 |
+
function refund_invoice($magento_orderId, $data)
|
| 481 |
+
{
|
| 482 |
+
$order = Mage::getModel('sales/order')->loadByIncrementId($magento_orderId);
|
| 483 |
+
|
| 484 |
+
$inv = true;
|
| 485 |
+
if (isset($data['inv'])) {
|
| 486 |
+
$inv = false;
|
| 487 |
+
unset($data['inv']);
|
| 488 |
+
}
|
| 489 |
+
$creditmemo = $this->_initCreditmemo($data, $magento_orderId, $inv);
|
| 490 |
+
|
| 491 |
+
if (isset($data['do_refund'])) {
|
| 492 |
+
$creditmemo->setRefundRequested(true);
|
| 493 |
+
}
|
| 494 |
+
if (isset($data['do_offline'])) {
|
| 495 |
+
$creditmemo->setOfflineRequested((bool) (int) $data['do_offline']);
|
| 496 |
+
}
|
| 497 |
+
$creditmemo->register();
|
| 498 |
+
if (!empty($data['send_email'])) {
|
| 499 |
+
$creditmemo->setEmailSent(true);
|
| 500 |
+
}
|
| 501 |
+
$creditmemo->getOrder()->setCustomerNoteNotify(!empty($data['send_email']));
|
| 502 |
+
$this->_saveCreditmemo($creditmemo);
|
| 503 |
+
return true;
|
| 504 |
+
}
|
| 505 |
+
|
| 506 |
+
protected function _saveCreditmemo($creditmemo)
|
| 507 |
+
{
|
| 508 |
+
$transactionSave = Mage::getModel('core/resource_transaction')->addObject($creditmemo)->addObject($creditmemo->getOrder());
|
| 509 |
+
if ($creditmemo->getInvoice()) {
|
| 510 |
+
$transactionSave->addObject($creditmemo->getInvoice());
|
| 511 |
+
}
|
| 512 |
+
$transactionSave->save();
|
| 513 |
+
return $this;
|
| 514 |
+
}
|
| 515 |
+
|
| 516 |
+
protected function _initInvoice($order, $invoiceId)
|
| 517 |
+
{
|
| 518 |
+
if ($invoiceId) {
|
| 519 |
+
$invoice = Mage::getModel('sales/order_invoice')->load($invoiceId)->setOrder($order);
|
| 520 |
+
if ($invoice->getId()) {
|
| 521 |
+
return $invoice;
|
| 522 |
+
}
|
| 523 |
+
}
|
| 524 |
+
return false;
|
| 525 |
+
}
|
| 526 |
+
|
| 527 |
+
protected function _getItemData($data)
|
| 528 |
+
{
|
| 529 |
+
if (isset($data['items'])) {
|
| 530 |
+
$qtys = $data['items'];
|
| 531 |
+
} else {
|
| 532 |
+
$qtys = array();
|
| 533 |
+
}
|
| 534 |
+
return $qtys;
|
| 535 |
+
}
|
| 536 |
+
|
| 537 |
+
protected function _initCreditmemo($data, $orderId, $inv = true)
|
| 538 |
+
{
|
| 539 |
+
$creditmemo = false;
|
| 540 |
+
$creditmemoId = null;
|
| 541 |
+
if ($creditmemoId) {
|
| 542 |
+
$creditmemo = Mage::getModel('sales/order_creditmemo')->load($creditmemoId);
|
| 543 |
+
} elseif ($orderId) {
|
| 544 |
+
$order = Mage::getModel('sales/order')->loadByIncrementId($orderId);
|
| 545 |
+
if ($inv === true) {
|
| 546 |
+
foreach ($order->getInvoiceCollection() as $invoice) {
|
| 547 |
+
if ($invoice->canRefund()) {
|
| 548 |
+
$invoiceId = $invoice->getId();
|
| 549 |
+
break;
|
| 550 |
+
}
|
| 551 |
+
}
|
| 552 |
+
$invoice = $this->_initInvoice($order, $invoiceId);
|
| 553 |
+
} else {
|
| 554 |
+
$invoice = false;
|
| 555 |
+
}
|
| 556 |
+
$savedData = $this->_getItemData($data);
|
| 557 |
+
$qtys = array();
|
| 558 |
+
$backToStock = array();
|
| 559 |
+
foreach ($savedData as $orderItemId => $itemData) {
|
| 560 |
+
if (isset($itemData['qty'])) {
|
| 561 |
+
$qtys[$orderItemId] = $itemData['qty'];
|
| 562 |
+
}
|
| 563 |
+
if (isset($itemData['back_to_stock'])) {
|
| 564 |
+
$backToStock[$orderItemId] = true;
|
| 565 |
+
}
|
| 566 |
+
}
|
| 567 |
+
$data['qtys'] = $qtys;
|
| 568 |
+
|
| 569 |
+
|
| 570 |
+
$service = Mage::getModel('sales/service_order', $order);
|
| 571 |
+
if ($invoice) {
|
| 572 |
+
$creditmemo = $service->prepareInvoiceCreditmemo($invoice, $data);
|
| 573 |
+
} else {
|
| 574 |
+
$creditmemo = $service->prepareCreditmemo($data);
|
| 575 |
+
}
|
| 576 |
+
}
|
| 577 |
+
Mage::register('current_creditmemo', $creditmemo);
|
| 578 |
+
return $creditmemo;
|
| 579 |
+
}
|
| 580 |
+
} // Class end
|
app/code/local/Saleswarp/Oms/Model/Product/Api.php
CHANGED
|
@@ -1,355 +1,362 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Model_Product_Api extends Mage_Catalog_Model_Product_Api
|
| 15 |
-
{
|
| 16 |
-
/**
|
| 17 |
-
* function to update configurable swatches
|
| 18 |
-
*/
|
| 19 |
-
function enableConfigurableSwatches()
|
| 20 |
-
{
|
| 21 |
-
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 22 |
-
$catalogAttrTable = Mage::getSingleton('core/resource')->getTableName('catalog_eav_attribute');
|
| 23 |
-
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 24 |
-
|
| 25 |
-
$sql = "SELECT `e`.`attribute_id` FROM `" . $eavAttrTable . "` as `e`
|
| 26 |
-
JOIN `" . $catalogAttrTable . "` as `c` ON `e`.`attribute_id` = `c`.`attribute_id`
|
| 27 |
-
WHERE `e`.`entity_type_id` = '4'
|
| 28 |
-
AND `e`.`frontend_input` = 'select'
|
| 29 |
-
AND `e`.`is_user_defined` = '1'
|
| 30 |
-
AND `c`.`is_configurable` = 1 ";
|
| 31 |
-
$result = $read->fetchAll($sql);
|
| 32 |
-
if ($result) {
|
| 33 |
-
$arr = array();
|
| 34 |
-
foreach ($result as $id) {
|
| 35 |
-
array_push($arr, $id['attribute_id']);
|
| 36 |
-
}
|
| 37 |
-
$ids = implode(',', $arr);
|
| 38 |
-
if ($ids) {
|
| 39 |
-
$configModel = new Mage_Core_Model_Config();
|
| 40 |
-
$configModel->saveConfig('configswatches/general/enabled', "1", 'default', 0);
|
| 41 |
-
$configModel->saveConfig('configswatches/general/swatch_attributes', $ids, 'default', 0);
|
| 42 |
-
}
|
| 43 |
-
}
|
| 44 |
-
return $ids;
|
| 45 |
-
}
|
| 46 |
-
|
| 47 |
-
/**
|
| 48 |
-
* function to disble configurable swatches
|
| 49 |
-
*/
|
| 50 |
-
function disableConfigurableSwatches()
|
| 51 |
-
{
|
| 52 |
-
$configModel = new Mage_Core_Model_Config();
|
| 53 |
-
$configModel->saveConfig('configswatches/general/enabled', "0", 'default', 0);
|
| 54 |
-
$configModel->saveConfig('configswatches/general/swatch_attributes', "", 'default', 0);
|
| 55 |
-
}
|
| 56 |
-
|
| 57 |
-
/**
|
| 58 |
-
* * Capture Offline payment
|
| 59 |
-
* */
|
| 60 |
-
public function capture_offline($orderId, $invoiceId)
|
| 61 |
-
{
|
| 62 |
-
$order = Mage::getModel('sales/order')->loadByIncrementId($orderId);
|
| 63 |
-
if (!$order->canCreditmemo()) {
|
| 64 |
-
if ($invoiceId) {
|
| 65 |
-
$invoice = Mage::getModel('sales/order_invoice')->loadByIncrementId($invoiceId)->setOrder($order);
|
| 66 |
-
|
| 67 |
-
$capture_case = 'offline';
|
| 68 |
-
$invoice->setRequestedCaptureCase($capture_case)->setCanVoidFlag(false)->pay();
|
| 69 |
-
|
| 70 |
-
$transactionSave = Mage::getModel('core/resource_transaction')->addObject($invoice)->addObject($invoice->getOrder());
|
| 71 |
-
$transactionSave->save();
|
| 72 |
-
$this->order = Mage::getSingleton('sales/order_api');
|
| 73 |
-
$this->order->addComment($
|
| 74 |
-
return true;
|
| 75 |
-
}
|
| 76 |
-
} else {
|
| 77 |
-
return false;
|
| 78 |
-
}
|
| 79 |
-
}
|
| 80 |
-
|
| 81 |
-
/**
|
| 82 |
-
* * Check invoice exists or not
|
| 83 |
-
* * @param = order id
|
| 84 |
-
* * return true or false
|
| 85 |
-
* */
|
| 86 |
-
public function check_invoice_exists($orderId)
|
| 87 |
-
{
|
| 88 |
-
$invoiceTable = Mage::getSingleton('core/resource')->getTableName('sales_flat_invoice');
|
| 89 |
-
$order = Mage::getModel('sales/order')->loadByIncrementId($orderId);
|
| 90 |
-
$Id = $order->getId();
|
| 91 |
-
$sql = "select entity_id from " . $invoiceTable . "
|
| 92 |
-
where order_id = '" . (int) $Id . "'";
|
| 93 |
-
|
| 94 |
-
$invoice = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 95 |
-
|
| 96 |
-
if (!empty($invoice)) {
|
| 97 |
-
return true;
|
| 98 |
-
} else {
|
| 99 |
-
return false;
|
| 100 |
-
}
|
| 101 |
-
}
|
| 102 |
-
|
| 103 |
-
/**
|
| 104 |
-
* * Create Order invoice *
|
| 105 |
-
* **/
|
| 106 |
-
public function create_invoice($order_id, $info, $message, $send_email, $include_comment)
|
| 107 |
-
{
|
| 108 |
-
$this->invoice = Mage::getSingleton('sales/order_invoice_api');
|
| 109 |
-
$invoice = $this->invoice->create($order_id, $info, $message, $send_email, $include_comment);
|
| 110 |
-
if ($invoice) {
|
| 111 |
-
$this->order = Mage::getSingleton('sales/order_api');
|
| 112 |
-
$this->order->addComment($order_id, 'processing', 'Invoice Created Successfully', false);
|
| 113 |
-
}
|
| 114 |
-
return $invoice;
|
| 115 |
-
}
|
| 116 |
-
|
| 117 |
-
/**
|
| 118 |
-
* * function to get total product count ( type wise eg: simple, configured )
|
| 119 |
-
*
|
| 120 |
-
* * @params $type string Magento Product type eg: simple, configured
|
| 121 |
-
* @params $modifiedAfter date product last modified date filter
|
| 122 |
-
* * @return int number of products
|
| 123 |
-
* */
|
| 124 |
-
function get_total_prod_count($type, $modifiedAfter = null)
|
| 125 |
-
{
|
| 126 |
-
$collection = Mage::getModel('catalog/product')
|
| 127 |
-
->getCollection()
|
| 128 |
-
->addFieldToFilter('type_id', $type);
|
| 129 |
-
|
| 130 |
-
if (!empty($modifiedAfter)) {
|
| 131 |
-
$collection->addAttributeToFilter('updated_at', array('gteq' => $modifiedAfter));
|
| 132 |
-
}
|
| 133 |
-
return $collection->getSize();
|
| 134 |
-
}
|
| 135 |
-
|
| 136 |
-
/**
|
| 137 |
-
* * function to get product collection with limit
|
| 138 |
-
*
|
| 139 |
-
* * @params $type int Magento Product type Id
|
| 140 |
-
* * @params $offset int set current page
|
| 141 |
-
* * @params $limit int products per page
|
| 142 |
-
* * @params $modifiedAfter date product last modified date filter
|
| 143 |
-
* * @return array products or bool(false)
|
| 144 |
-
* */
|
| 145 |
-
function get_product_collection($type, $offset = 1, $limit = 10, $modifiedAfter = null, $createdAfter = null)
|
| 146 |
-
{
|
| 147 |
-
$data = array();
|
| 148 |
-
|
| 149 |
-
|
| 150 |
-
$collection = Mage::getModel('catalog/product')
|
| 151 |
-
->getCollection()
|
| 152 |
-
->addAttributeToSelect('*') // select all attributes
|
| 153 |
-
->addFieldToFilter('type_id', $type);
|
| 154 |
-
|
| 155 |
-
|
| 156 |
-
|
| 157 |
-
|
| 158 |
-
|
| 159 |
-
|
| 160 |
-
|
| 161 |
-
|
| 162 |
-
|
| 163 |
-
$collection->
|
| 164 |
-
|
| 165 |
-
|
| 166 |
-
|
| 167 |
-
|
| 168 |
-
|
| 169 |
-
|
| 170 |
-
|
| 171 |
-
|
| 172 |
-
|
| 173 |
-
|
| 174 |
-
|
| 175 |
-
)
|
| 176 |
-
|
| 177 |
-
|
| 178 |
-
|
| 179 |
-
|
| 180 |
-
|
| 181 |
-
|
| 182 |
-
|
| 183 |
-
|
| 184 |
-
|
| 185 |
-
|
| 186 |
-
|
| 187 |
-
|
| 188 |
-
|
| 189 |
-
|
| 190 |
-
|
| 191 |
-
|
| 192 |
-
|
| 193 |
-
|
| 194 |
-
|
| 195 |
-
|
| 196 |
-
|
| 197 |
-
|
| 198 |
-
|
| 199 |
-
|
| 200 |
-
|
| 201 |
-
|
| 202 |
-
|
| 203 |
-
|
| 204 |
-
|
| 205 |
-
|
| 206 |
-
|
| 207 |
-
|
| 208 |
-
|
| 209 |
-
|
| 210 |
-
|
| 211 |
-
|
| 212 |
-
|
| 213 |
-
|
| 214 |
-
|
| 215 |
-
|
| 216 |
-
|
| 217 |
-
|
| 218 |
-
|
| 219 |
-
|
| 220 |
-
|
| 221 |
-
|
| 222 |
-
|
| 223 |
-
|
| 224 |
-
|
| 225 |
-
|
| 226 |
-
*
|
| 227 |
-
*
|
| 228 |
-
|
| 229 |
-
|
| 230 |
-
|
| 231 |
-
|
| 232 |
-
|
| 233 |
-
|
| 234 |
-
|
| 235 |
-
|
| 236 |
-
|
| 237 |
-
|
| 238 |
-
|
| 239 |
-
|
| 240 |
-
|
| 241 |
-
|
| 242 |
-
|
| 243 |
-
|
| 244 |
-
|
| 245 |
-
|
| 246 |
-
|
| 247 |
-
|
| 248 |
-
|
| 249 |
-
|
| 250 |
-
|
| 251 |
-
|
| 252 |
-
|
| 253 |
-
*
|
| 254 |
-
*
|
| 255 |
-
|
| 256 |
-
|
| 257 |
-
|
| 258 |
-
|
| 259 |
-
|
| 260 |
-
|
| 261 |
-
|
| 262 |
-
|
| 263 |
-
|
| 264 |
-
|
| 265 |
-
|
| 266 |
-
|
| 267 |
-
|
| 268 |
-
|
| 269 |
-
|
| 270 |
-
|
| 271 |
-
|
| 272 |
-
|
| 273 |
-
$status
|
| 274 |
-
}
|
| 275 |
-
|
| 276 |
-
|
| 277 |
-
|
| 278 |
-
|
| 279 |
-
|
| 280 |
-
|
| 281 |
-
|
| 282 |
-
|
| 283 |
-
|
| 284 |
-
|
| 285 |
-
|
| 286 |
-
|
| 287 |
-
$
|
| 288 |
-
|
| 289 |
-
|
| 290 |
-
|
| 291 |
-
|
| 292 |
-
|
| 293 |
-
|
| 294 |
-
|
| 295 |
-
|
| 296 |
-
|
| 297 |
-
|
| 298 |
-
|
| 299 |
-
|
| 300 |
-
|
| 301 |
-
|
| 302 |
-
|
| 303 |
-
|
| 304 |
-
|
| 305 |
-
$
|
| 306 |
-
|
| 307 |
-
|
| 308 |
-
|
| 309 |
-
|
| 310 |
-
|
| 311 |
-
|
| 312 |
-
$
|
| 313 |
-
|
| 314 |
-
|
| 315 |
-
|
| 316 |
-
|
| 317 |
-
|
| 318 |
-
|
| 319 |
-
|
| 320 |
-
|
| 321 |
-
|
| 322 |
-
|
| 323 |
-
|
| 324 |
-
|
| 325 |
-
|
| 326 |
-
|
| 327 |
-
|
| 328 |
-
|
| 329 |
-
|
| 330 |
-
|
| 331 |
-
|
| 332 |
-
|
| 333 |
-
|
| 334 |
-
|
| 335 |
-
|
| 336 |
-
|
| 337 |
-
|
| 338 |
-
|
| 339 |
-
|
| 340 |
-
|
| 341 |
-
|
| 342 |
-
|
| 343 |
-
|
| 344 |
-
|
| 345 |
-
|
| 346 |
-
$
|
| 347 |
-
}
|
| 348 |
-
|
| 349 |
-
|
| 350 |
-
|
| 351 |
-
|
| 352 |
-
|
| 353 |
-
|
| 354 |
-
|
| 355 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Model_Product_Api extends Mage_Catalog_Model_Product_Api
|
| 15 |
+
{
|
| 16 |
+
/**
|
| 17 |
+
* function to update configurable swatches
|
| 18 |
+
*/
|
| 19 |
+
function enableConfigurableSwatches()
|
| 20 |
+
{
|
| 21 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 22 |
+
$catalogAttrTable = Mage::getSingleton('core/resource')->getTableName('catalog_eav_attribute');
|
| 23 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 24 |
+
|
| 25 |
+
$sql = "SELECT `e`.`attribute_id` FROM `" . $eavAttrTable . "` as `e`
|
| 26 |
+
JOIN `" . $catalogAttrTable . "` as `c` ON `e`.`attribute_id` = `c`.`attribute_id`
|
| 27 |
+
WHERE `e`.`entity_type_id` = '4'
|
| 28 |
+
AND `e`.`frontend_input` = 'select'
|
| 29 |
+
AND `e`.`is_user_defined` = '1'
|
| 30 |
+
AND `c`.`is_configurable` = 1 ";
|
| 31 |
+
$result = $read->fetchAll($sql);
|
| 32 |
+
if ($result) {
|
| 33 |
+
$arr = array();
|
| 34 |
+
foreach ($result as $id) {
|
| 35 |
+
array_push($arr, $id['attribute_id']);
|
| 36 |
+
}
|
| 37 |
+
$ids = implode(',', $arr);
|
| 38 |
+
if ($ids) {
|
| 39 |
+
$configModel = new Mage_Core_Model_Config();
|
| 40 |
+
$configModel->saveConfig('configswatches/general/enabled', "1", 'default', 0);
|
| 41 |
+
$configModel->saveConfig('configswatches/general/swatch_attributes', $ids, 'default', 0);
|
| 42 |
+
}
|
| 43 |
+
}
|
| 44 |
+
return $ids;
|
| 45 |
+
}
|
| 46 |
+
|
| 47 |
+
/**
|
| 48 |
+
* function to disble configurable swatches
|
| 49 |
+
*/
|
| 50 |
+
function disableConfigurableSwatches()
|
| 51 |
+
{
|
| 52 |
+
$configModel = new Mage_Core_Model_Config();
|
| 53 |
+
$configModel->saveConfig('configswatches/general/enabled', "0", 'default', 0);
|
| 54 |
+
$configModel->saveConfig('configswatches/general/swatch_attributes', "", 'default', 0);
|
| 55 |
+
}
|
| 56 |
+
|
| 57 |
+
/**
|
| 58 |
+
* * Capture Offline payment
|
| 59 |
+
* */
|
| 60 |
+
public function capture_offline($orderId, $invoiceId)
|
| 61 |
+
{
|
| 62 |
+
$order = Mage::getModel('sales/order')->loadByIncrementId($orderId);
|
| 63 |
+
if (!$order->canCreditmemo()) {
|
| 64 |
+
if ($invoiceId) {
|
| 65 |
+
$invoice = Mage::getModel('sales/order_invoice')->loadByIncrementId($invoiceId)->setOrder($order);
|
| 66 |
+
|
| 67 |
+
$capture_case = 'offline';
|
| 68 |
+
$invoice->setRequestedCaptureCase($capture_case)->setCanVoidFlag(false)->pay();
|
| 69 |
+
|
| 70 |
+
$transactionSave = Mage::getModel('core/resource_transaction')->addObject($invoice)->addObject($invoice->getOrder());
|
| 71 |
+
$transactionSave->save();
|
| 72 |
+
$this->order = Mage::getSingleton('sales/order_api');
|
| 73 |
+
$this->order->addComment($orderId, 'processing', 'Captured Offlined successfully', false);
|
| 74 |
+
return true;
|
| 75 |
+
}
|
| 76 |
+
} else {
|
| 77 |
+
return false;
|
| 78 |
+
}
|
| 79 |
+
}
|
| 80 |
+
|
| 81 |
+
/**
|
| 82 |
+
* * Check invoice exists or not
|
| 83 |
+
* * @param = order id
|
| 84 |
+
* * return true or false
|
| 85 |
+
* */
|
| 86 |
+
public function check_invoice_exists($orderId)
|
| 87 |
+
{
|
| 88 |
+
$invoiceTable = Mage::getSingleton('core/resource')->getTableName('sales_flat_invoice');
|
| 89 |
+
$order = Mage::getModel('sales/order')->loadByIncrementId($orderId);
|
| 90 |
+
$Id = $order->getId();
|
| 91 |
+
$sql = "select entity_id from " . $invoiceTable . "
|
| 92 |
+
where order_id = '" . (int) $Id . "'";
|
| 93 |
+
|
| 94 |
+
$invoice = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 95 |
+
|
| 96 |
+
if (!empty($invoice)) {
|
| 97 |
+
return true;
|
| 98 |
+
} else {
|
| 99 |
+
return false;
|
| 100 |
+
}
|
| 101 |
+
}
|
| 102 |
+
|
| 103 |
+
/**
|
| 104 |
+
* * Create Order invoice *
|
| 105 |
+
* **/
|
| 106 |
+
public function create_invoice($order_id, $info, $message, $send_email, $include_comment)
|
| 107 |
+
{
|
| 108 |
+
$this->invoice = Mage::getSingleton('sales/order_invoice_api');
|
| 109 |
+
$invoice = $this->invoice->create($order_id, $info, $message, $send_email, $include_comment);
|
| 110 |
+
if ($invoice) {
|
| 111 |
+
$this->order = Mage::getSingleton('sales/order_api');
|
| 112 |
+
$this->order->addComment($order_id, 'processing', 'Invoice Created Successfully', false);
|
| 113 |
+
}
|
| 114 |
+
return $invoice;
|
| 115 |
+
}
|
| 116 |
+
|
| 117 |
+
/**
|
| 118 |
+
* * function to get total product count ( type wise eg: simple, configured )
|
| 119 |
+
*
|
| 120 |
+
* * @params $type string Magento Product type eg: simple, configured
|
| 121 |
+
* @params $modifiedAfter date product last modified date filter
|
| 122 |
+
* * @return int number of products
|
| 123 |
+
* */
|
| 124 |
+
function get_total_prod_count($type, $modifiedAfter = null)
|
| 125 |
+
{
|
| 126 |
+
$collection = Mage::getModel('catalog/product')
|
| 127 |
+
->getCollection()
|
| 128 |
+
->addFieldToFilter('type_id', $type);
|
| 129 |
+
|
| 130 |
+
if (!empty($modifiedAfter)) {
|
| 131 |
+
$collection->addAttributeToFilter('updated_at', array('gteq' => $modifiedAfter));
|
| 132 |
+
}
|
| 133 |
+
return $collection->getSize();
|
| 134 |
+
}
|
| 135 |
+
|
| 136 |
+
/**
|
| 137 |
+
* * function to get product collection with limit
|
| 138 |
+
*
|
| 139 |
+
* * @params $type int Magento Product type Id
|
| 140 |
+
* * @params $offset int set current page
|
| 141 |
+
* * @params $limit int products per page
|
| 142 |
+
* * @params $modifiedAfter date product last modified date filter
|
| 143 |
+
* * @return array products or bool(false)
|
| 144 |
+
* */
|
| 145 |
+
function get_product_collection($type, $offset = 1, $limit = 10, $modifiedAfter = null, $createdAfter = null)
|
| 146 |
+
{
|
| 147 |
+
$data = array();
|
| 148 |
+
/* Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
|
| 149 |
+
|
| 150 |
+
$collection = Mage::getModel('catalog/product')
|
| 151 |
+
->getCollection()
|
| 152 |
+
->addAttributeToSelect('*') // select all attributes
|
| 153 |
+
->addFieldToFilter('type_id', $type);
|
| 154 |
+
*/
|
| 155 |
+
$storeId = Mage::app()->getStore()->getStoreId();
|
| 156 |
+
|
| 157 |
+
$collection = Mage::getResourceModel('catalog/product_collection')
|
| 158 |
+
->addStoreFilter($storeId)
|
| 159 |
+
->addAttributeToSelect('*')
|
| 160 |
+
->addFieldToFilter('type_id', $type);
|
| 161 |
+
|
| 162 |
+
if (!empty($modifiedAfter)) {
|
| 163 |
+
$collection->addAttributeToFilter('updated_at', array('gteq' => $modifiedAfter));
|
| 164 |
+
}
|
| 165 |
+
|
| 166 |
+
if (!empty($createdAfter)) {
|
| 167 |
+
$collection->addAttributeToFilter('updated_at', array('gteq' => $createdAfter));
|
| 168 |
+
}
|
| 169 |
+
|
| 170 |
+
$collection->setPageSize($limit) // limit number of results returned //
|
| 171 |
+
->setOrder('entity_id', 'DESC')
|
| 172 |
+
->setCurPage($offset);
|
| 173 |
+
|
| 174 |
+
foreach ($collection as $product) {
|
| 175 |
+
$stocklevel = Mage::getSingleton('cataloginventory/stock_item')
|
| 176 |
+
->loadByProduct($product)->getData();
|
| 177 |
+
|
| 178 |
+
$data[] = array_merge(
|
| 179 |
+
$product->getData(),
|
| 180 |
+
array('prod_url' => $product->getProductUrl()),
|
| 181 |
+
array('stock' => $stocklevel)
|
| 182 |
+
);
|
| 183 |
+
}
|
| 184 |
+
return $data;
|
| 185 |
+
}
|
| 186 |
+
|
| 187 |
+
/**
|
| 188 |
+
* * Get attribute name By ID
|
| 189 |
+
* * @param attribute id
|
| 190 |
+
* * @return attribute name
|
| 191 |
+
* */
|
| 192 |
+
function get_attr_name_by_id($id)
|
| 193 |
+
{
|
| 194 |
+
$entityTypeId = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 195 |
+
$attributeSetId = Mage::getModel('eav/entity_attribute_set')->getCollection()
|
| 196 |
+
->setEntityTypeFilter($entityTypeId)
|
| 197 |
+
->addFieldToFilter('attribute_set_id', $id)
|
| 198 |
+
->getFirstItem()
|
| 199 |
+
->getAttributeSetName();
|
| 200 |
+
if ($attributeSetId) {
|
| 201 |
+
return $attributeSetId;
|
| 202 |
+
} else {
|
| 203 |
+
return false;
|
| 204 |
+
}
|
| 205 |
+
}
|
| 206 |
+
|
| 207 |
+
/**
|
| 208 |
+
* * return allchildren product of magento product id
|
| 209 |
+
* * @params Magento Product Id
|
| 210 |
+
* * @return product data or bool(false)
|
| 211 |
+
* */
|
| 212 |
+
function get_child_product($entity_id)
|
| 213 |
+
{
|
| 214 |
+
$relTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_relation');
|
| 215 |
+
$sql = "SELECT child_id FROM `" . $relTable . "`
|
| 216 |
+
WHERE parent_id = '" . (int) $entity_id . "'";
|
| 217 |
+
$prods = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 218 |
+
if ($prods) {
|
| 219 |
+
return $prods;
|
| 220 |
+
} else {
|
| 221 |
+
return false;
|
| 222 |
+
}
|
| 223 |
+
}
|
| 224 |
+
|
| 225 |
+
/**
|
| 226 |
+
* check product exists in target store using saleswarp_product_id in magento catalog_product_entity_in
|
| 227 |
+
*
|
| 228 |
+
* use this check_product_exists to query store by warehouse fields that are
|
| 229 |
+
* known to not change (sku changes)
|
| 230 |
+
*
|
| 231 |
+
* @param mixed $attr_id - attribute id, get this after config lookup
|
| 232 |
+
* @param mixed $base_product_id
|
| 233 |
+
*
|
| 234 |
+
* @todo seperate these functions into extension API once we debug issue with override extensions in Magento
|
| 235 |
+
*/
|
| 236 |
+
public function check_product_exists($attr_id, $base_product_id)
|
| 237 |
+
{
|
| 238 |
+
$productIntTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity_int');
|
| 239 |
+
$sql = "select entity_id from " . $productIntTable . "
|
| 240 |
+
where attribute_id = '" . (int) $attr_id . "'
|
| 241 |
+
and value = '" . (int) $base_product_id . "'";
|
| 242 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 243 |
+
if (!empty($prod)) {
|
| 244 |
+
$pid = $prod['entity_id'];
|
| 245 |
+
unset($prod);
|
| 246 |
+
return $pid;
|
| 247 |
+
} else {
|
| 248 |
+
return false;
|
| 249 |
+
}
|
| 250 |
+
}
|
| 251 |
+
|
| 252 |
+
/**
|
| 253 |
+
* light weight inventory update when product is detected out of stock or discontinued and full
|
| 254 |
+
* update info (cogs, weight, price) not longer apply
|
| 255 |
+
*
|
| 256 |
+
* @param mixed $store_prod_id
|
| 257 |
+
* @param mixed $store_qty
|
| 258 |
+
* @param mixed $discontinued
|
| 259 |
+
* @param mixed $status
|
| 260 |
+
* @return mixed
|
| 261 |
+
* */
|
| 262 |
+
function update_inventory($store_prod_id, $store_qty, $discontinued, $attribute_id, $status = 1, $website_id = 1, $stock_id = 1)
|
| 263 |
+
{
|
| 264 |
+
$resource = Mage::getSingleton('core/resource');
|
| 265 |
+
$invStockItemTable = $resource->getTableName('cataloginventory_stock_item');
|
| 266 |
+
$invStockStatusTable = $resource->getTableName('cataloginventory_stock_status');
|
| 267 |
+
$prodDateTimeTable = $resource->getTableName('catalog_product_entity_datetime');
|
| 268 |
+
|
| 269 |
+
$write = $resource->getConnection('core_write');
|
| 270 |
+
$read = $resource->getConnection('core_read');
|
| 271 |
+
|
| 272 |
+
if ($store_qty <= 0 || $discontinued == 1) {
|
| 273 |
+
$status = 0;
|
| 274 |
+
} else {
|
| 275 |
+
$status = 1;
|
| 276 |
+
}
|
| 277 |
+
|
| 278 |
+
if (is_null($store_qty)) {
|
| 279 |
+
$store_qty = 0;
|
| 280 |
+
$status = 0;
|
| 281 |
+
}
|
| 282 |
+
|
| 283 |
+
$sql = "UPDATE " . $invStockItemTable . "
|
| 284 |
+
SET qty = :qty,
|
| 285 |
+
is_in_stock = :is_in_stock
|
| 286 |
+
WHERE product_id = :product_id ";
|
| 287 |
+
$binds = array(
|
| 288 |
+
'qty' => $store_qty,
|
| 289 |
+
'is_in_stock' => $status,
|
| 290 |
+
'product_id' => $store_prod_id,
|
| 291 |
+
);
|
| 292 |
+
$result = $write->query($sql, $binds);
|
| 293 |
+
|
| 294 |
+
$sql = "SELECT * FROM " . $invStockStatusTable . "
|
| 295 |
+
WHERE product_id = :product_id
|
| 296 |
+
AND website_id = :website_id
|
| 297 |
+
AND stock_id = :stock_id ";
|
| 298 |
+
$binds = array(
|
| 299 |
+
'product_id' => $store_prod_id,
|
| 300 |
+
'website_id' => $website_id,
|
| 301 |
+
'stock_id' => $stock_id,
|
| 302 |
+
);
|
| 303 |
+
$chk = $read->fetchRow($sql, $binds);
|
| 304 |
+
if (empty($chk)) {
|
| 305 |
+
$sql = "INSERT INTO " . $invStockStatusTable . "
|
| 306 |
+
SET qty = :qty,
|
| 307 |
+
stock_status = :stock_status,
|
| 308 |
+
stock_id = :stock_id,
|
| 309 |
+
website_id = :website_id,
|
| 310 |
+
product_id = :product_id ";
|
| 311 |
+
|
| 312 |
+
$binds = array(
|
| 313 |
+
'qty' => $store_qty,
|
| 314 |
+
'stock_status' => $status,
|
| 315 |
+
'stock_id' => $stock_id,
|
| 316 |
+
'website_id' => $website_id,
|
| 317 |
+
'product_id' => $store_prod_id,
|
| 318 |
+
);
|
| 319 |
+
$result2 = $write->query($sql, $binds);
|
| 320 |
+
} else { // do update
|
| 321 |
+
$sql = "UPDATE " . $invStockStatusTable . "
|
| 322 |
+
SET qty = :qty, stock_status = :stock_status
|
| 323 |
+
WHERE product_id = :product_id ";
|
| 324 |
+
$binds = array(
|
| 325 |
+
'qty' => $store_qty,
|
| 326 |
+
'stock_status' => $status,
|
| 327 |
+
'product_id' => $store_prod_id,
|
| 328 |
+
);
|
| 329 |
+
$result2 = $write->query($sql, $binds);
|
| 330 |
+
}
|
| 331 |
+
|
| 332 |
+
// Update saleswarp_last_inventory_update fields
|
| 333 |
+
$sql = "SELECT * FROM " . $prodDateTimeTable . "
|
| 334 |
+
WHERE entity_type_id = 4
|
| 335 |
+
AND entity_id = $store_prod_id
|
| 336 |
+
AND attribute_id = $attribute_id";
|
| 337 |
+
$chk = $read->fetchAll($sql);
|
| 338 |
+
|
| 339 |
+
if (empty($chk)) { // insert it
|
| 340 |
+
$sql = "INSERT INTO " . $prodDateTimeTable . "
|
| 341 |
+
SET value = NOW(),
|
| 342 |
+
entity_type_id = 4,
|
| 343 |
+
store_id = 0,
|
| 344 |
+
entity_id = $store_prod_id,
|
| 345 |
+
attribute_id = $attribute_id";
|
| 346 |
+
$insert_result = $write->query($sql);
|
| 347 |
+
} else { // update it
|
| 348 |
+
$sql = "UPDATE " . $prodDateTimeTable . "
|
| 349 |
+
SET value = NOW()
|
| 350 |
+
WHERE entity_type_id = 4
|
| 351 |
+
AND entity_id = $store_prod_id
|
| 352 |
+
AND attribute_id = $attribute_id";
|
| 353 |
+
$update_result = $write->query($sql);
|
| 354 |
+
}
|
| 355 |
+
|
| 356 |
+
if ($result && $result2) {
|
| 357 |
+
return "Saved inventory record";
|
| 358 |
+
} else {
|
| 359 |
+
return "FAILED save() inventory update";
|
| 360 |
+
}
|
| 361 |
+
}
|
| 362 |
+
}
|
app/code/local/Saleswarp/Oms/Model/Product/Attribute/Api.php
CHANGED
|
@@ -1,5 +1,5 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
class Saleswarp_Oms_Model_Product_Attribute_Api extends Mage_Catalog_Model_Product_Attribute_Api
|
| 3 |
-
{
|
| 4 |
-
|
| 5 |
-
}
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Oms_Model_Product_Attribute_Api extends Mage_Catalog_Model_Product_Attribute_Api
|
| 3 |
+
{
|
| 4 |
+
|
| 5 |
+
}
|
app/code/local/Saleswarp/Oms/Model/Product/Attribute/Media/Api.php
CHANGED
|
@@ -1,5 +1,5 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
class Saleswarp_Oms_Model_Product_Attribute_Media_Api extends Mage_Catalog_Model_Product_Attribute_Media_Api
|
| 3 |
-
{
|
| 4 |
-
|
| 5 |
}
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Oms_Model_Product_Attribute_Media_Api extends Mage_Catalog_Model_Product_Attribute_Media_Api
|
| 3 |
+
{
|
| 4 |
+
|
| 5 |
}
|
app/code/local/Saleswarp/Oms/Model/Saleswarp.php
CHANGED
|
@@ -1,53 +1,53 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Model_Saleswarp extends Mage_Payment_Model_Method_Abstract
|
| 15 |
-
{
|
| 16 |
-
protected $_code = 'saleswarp';
|
| 17 |
-
protected $_formBlockType = 'oms/form_saleswarp';
|
| 18 |
-
protected $_infoBlockType = 'oms/info_saleswarp';
|
| 19 |
-
protected $_canUseInternal = true;
|
| 20 |
-
protected $_canUseCheckout = false;
|
| 21 |
-
|
| 22 |
-
public function assignData($data)
|
| 23 |
-
{
|
| 24 |
-
if (!($data instanceof Varien_Object)) {
|
| 25 |
-
$data = new Varien_Object($data);
|
| 26 |
-
}
|
| 27 |
-
$info = $this->getInfoInstance();
|
| 28 |
-
$info->setTransctionNo($data->getTransctionNo())
|
| 29 |
-
->setPaymentMethod($data->getPaymentMethod());
|
| 30 |
-
return $this;
|
| 31 |
-
}
|
| 32 |
-
|
| 33 |
-
public function validate()
|
| 34 |
-
{
|
| 35 |
-
parent::validate();
|
| 36 |
-
|
| 37 |
-
$info = $this->getInfoInstance();
|
| 38 |
-
|
| 39 |
-
$no = $info->getTransctionNo();
|
| 40 |
-
$method = $info->getPaymentMethod();
|
| 41 |
-
if(empty($no) || empty($method)){
|
| 42 |
-
$errorCode = 'invalid_data';
|
| 43 |
-
$errorMsg = $this->_getHelper()->__('Transaction No and Payment Method are required fields');
|
| 44 |
-
}
|
| 45 |
-
|
| 46 |
-
if($errorMsg){
|
| 47 |
-
Mage::throwException($errorMsg);
|
| 48 |
-
}
|
| 49 |
-
|
| 50 |
-
return $this;
|
| 51 |
-
}
|
| 52 |
-
}
|
| 53 |
-
?>
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Model_Saleswarp extends Mage_Payment_Model_Method_Abstract
|
| 15 |
+
{
|
| 16 |
+
protected $_code = 'saleswarp';
|
| 17 |
+
protected $_formBlockType = 'oms/form_saleswarp';
|
| 18 |
+
protected $_infoBlockType = 'oms/info_saleswarp';
|
| 19 |
+
protected $_canUseInternal = true;
|
| 20 |
+
protected $_canUseCheckout = false;
|
| 21 |
+
|
| 22 |
+
public function assignData($data)
|
| 23 |
+
{
|
| 24 |
+
if (!($data instanceof Varien_Object)) {
|
| 25 |
+
$data = new Varien_Object($data);
|
| 26 |
+
}
|
| 27 |
+
$info = $this->getInfoInstance();
|
| 28 |
+
$info->setTransctionNo($data->getTransctionNo())
|
| 29 |
+
->setPaymentMethod($data->getPaymentMethod());
|
| 30 |
+
return $this;
|
| 31 |
+
}
|
| 32 |
+
|
| 33 |
+
public function validate()
|
| 34 |
+
{
|
| 35 |
+
parent::validate();
|
| 36 |
+
|
| 37 |
+
$info = $this->getInfoInstance();
|
| 38 |
+
|
| 39 |
+
$no = $info->getTransctionNo();
|
| 40 |
+
$method = $info->getPaymentMethod();
|
| 41 |
+
if(empty($no) || empty($method)){
|
| 42 |
+
$errorCode = 'invalid_data';
|
| 43 |
+
$errorMsg = $this->_getHelper()->__('Transaction No and Payment Method are required fields');
|
| 44 |
+
}
|
| 45 |
+
|
| 46 |
+
if($errorMsg){
|
| 47 |
+
Mage::throwException($errorMsg);
|
| 48 |
+
}
|
| 49 |
+
|
| 50 |
+
return $this;
|
| 51 |
+
}
|
| 52 |
+
}
|
| 53 |
+
?>
|
app/code/local/Saleswarp/Oms/controllers/Adminhtml/GetkeyController.php
CHANGED
|
@@ -1,64 +1,64 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_Adminhtml_GetkeyController extends Mage_Adminhtml_Controller_Action
|
| 15 |
-
{
|
| 16 |
-
public function indexAction()
|
| 17 |
-
{
|
| 18 |
-
$return = array();
|
| 19 |
-
$value = $this->makeKeyRequest();
|
| 20 |
-
if($value) {
|
| 21 |
-
$key = new Mage_Core_Model_Config();
|
| 22 |
-
$key->saveConfig('oms/registration/key', $value);
|
| 23 |
-
|
| 24 |
-
$return['success'] = 1;
|
| 25 |
-
$return['key'] = $value;
|
| 26 |
-
} else {
|
| 27 |
-
$return['success'] = 0;
|
| 28 |
-
}
|
| 29 |
-
$return = Mage::helper('core')->jsonEncode($return);
|
| 30 |
-
$this->getResponse()->setHeader('Content-type', 'application/json');
|
| 31 |
-
$this->getResponse()->setBody($return);
|
| 32 |
-
}
|
| 33 |
-
|
| 34 |
-
public function makeKeyRequest() {
|
| 35 |
-
|
| 36 |
-
$data = array();
|
| 37 |
-
$data['BaseUrl'] = Mage::getBaseUrl();
|
| 38 |
-
|
| 39 |
-
$admin = Mage::getSingleton('admin/session')->getUser()->getData();
|
| 40 |
-
$data['admin']['username'] = $admin['username'];
|
| 41 |
-
$data['admin']['email'] = $admin['email'];
|
| 42 |
-
|
| 43 |
-
$url = Mage::getModel('core/variable')->loadByCode('saleswarp_api_url')->getValue('plain');
|
| 44 |
-
|
| 45 |
-
$dataString = http_build_query($data);
|
| 46 |
-
$ch = curl_init($url);
|
| 47 |
-
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
|
| 48 |
-
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
|
| 49 |
-
curl_setopt($ch, CURLOPT_TIMEOUT, 6000);
|
| 50 |
-
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
| 51 |
-
curl_setopt($ch, CURLOPT_POST, true);
|
| 52 |
-
curl_setopt($ch, CURLOPT_POSTFIELDS, $dataString);
|
| 53 |
-
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
|
| 54 |
-
|
| 55 |
-
$return = curl_exec($ch);
|
| 56 |
-
|
| 57 |
-
$info = curl_getinfo($ch);
|
| 58 |
-
if($info['http_code'] == '200') {
|
| 59 |
-
return $return;
|
| 60 |
-
} else {
|
| 61 |
-
return false;
|
| 62 |
-
}
|
| 63 |
-
}
|
| 64 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_Adminhtml_GetkeyController extends Mage_Adminhtml_Controller_Action
|
| 15 |
+
{
|
| 16 |
+
public function indexAction()
|
| 17 |
+
{
|
| 18 |
+
$return = array();
|
| 19 |
+
$value = $this->makeKeyRequest();
|
| 20 |
+
if($value) {
|
| 21 |
+
$key = new Mage_Core_Model_Config();
|
| 22 |
+
$key->saveConfig('oms/registration/key', $value);
|
| 23 |
+
|
| 24 |
+
$return['success'] = 1;
|
| 25 |
+
$return['key'] = $value;
|
| 26 |
+
} else {
|
| 27 |
+
$return['success'] = 0;
|
| 28 |
+
}
|
| 29 |
+
$return = Mage::helper('core')->jsonEncode($return);
|
| 30 |
+
$this->getResponse()->setHeader('Content-type', 'application/json');
|
| 31 |
+
$this->getResponse()->setBody($return);
|
| 32 |
+
}
|
| 33 |
+
|
| 34 |
+
public function makeKeyRequest() {
|
| 35 |
+
|
| 36 |
+
$data = array();
|
| 37 |
+
$data['BaseUrl'] = Mage::getBaseUrl();
|
| 38 |
+
|
| 39 |
+
$admin = Mage::getSingleton('admin/session')->getUser()->getData();
|
| 40 |
+
$data['admin']['username'] = $admin['username'];
|
| 41 |
+
$data['admin']['email'] = $admin['email'];
|
| 42 |
+
|
| 43 |
+
$url = Mage::getModel('core/variable')->loadByCode('saleswarp_api_url')->getValue('plain');
|
| 44 |
+
|
| 45 |
+
$dataString = http_build_query($data);
|
| 46 |
+
$ch = curl_init($url);
|
| 47 |
+
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
|
| 48 |
+
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
|
| 49 |
+
curl_setopt($ch, CURLOPT_TIMEOUT, 6000);
|
| 50 |
+
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
|
| 51 |
+
curl_setopt($ch, CURLOPT_POST, true);
|
| 52 |
+
curl_setopt($ch, CURLOPT_POSTFIELDS, $dataString);
|
| 53 |
+
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
|
| 54 |
+
|
| 55 |
+
$return = curl_exec($ch);
|
| 56 |
+
|
| 57 |
+
$info = curl_getinfo($ch);
|
| 58 |
+
if($info['http_code'] == '200') {
|
| 59 |
+
return $return;
|
| 60 |
+
} else {
|
| 61 |
+
return false;
|
| 62 |
+
}
|
| 63 |
+
}
|
| 64 |
}
|
app/code/local/Saleswarp/Oms/controllers/FastapiController.php
CHANGED
|
@@ -1,137 +1,137 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
class Saleswarp_Oms_FastapiController extends Mage_Core_Controller_Front_Action {
|
| 15 |
-
|
| 16 |
-
public $authError = '';
|
| 17 |
-
|
| 18 |
-
/**
|
| 19 |
-
* * Receive API call and process API
|
| 20 |
-
* *
|
| 21 |
-
* * @param json encoded data
|
| 22 |
-
* * @return json encode data
|
| 23 |
-
* */
|
| 24 |
-
public function IndexAction()
|
| 25 |
-
{
|
| 26 |
-
$response = array();
|
| 27 |
-
$data = json_decode(@file_get_contents('php://input'), true);
|
| 28 |
-
|
| 29 |
-
if (empty($data)) {
|
| 30 |
-
$this->_redirect('/');
|
| 31 |
-
return;
|
| 32 |
-
}
|
| 33 |
-
|
| 34 |
-
if (isset($data['hash']['key'])) {
|
| 35 |
-
// authenticate
|
| 36 |
-
if(!$this->ApiAuthentication($data['hash']['key'])) {
|
| 37 |
-
$response['error_msg'] = $this->authError;
|
| 38 |
-
$response['error_code'] = '2';
|
| 39 |
-
echo json_encode($response);
|
| 40 |
-
exit;
|
| 41 |
-
}
|
| 42 |
-
// call method api
|
| 43 |
-
$response['data'] = $this->callFastApi($data);
|
| 44 |
-
if(!$response['data']) {
|
| 45 |
-
$response['error_msg'] = 'Invalid data';
|
| 46 |
-
$response['error_code'] = '3';
|
| 47 |
-
} else {
|
| 48 |
-
$response['error_msg'] = '';
|
| 49 |
-
$response['error_code'] = '0';
|
| 50 |
-
}
|
| 51 |
-
} else {
|
| 52 |
-
$response['error_msg'] = 'Invalid data';
|
| 53 |
-
$response['error_code'] = '1';
|
| 54 |
-
}
|
| 55 |
-
echo json_encode($response);
|
| 56 |
-
exit;
|
| 57 |
-
}
|
| 58 |
-
|
| 59 |
-
/**
|
| 60 |
-
* * Load fast api and call methods
|
| 61 |
-
* *
|
| 62 |
-
* * @param array of data
|
| 63 |
-
* * @return array of data
|
| 64 |
-
* */
|
| 65 |
-
public function callFastApi($data = array())
|
| 66 |
-
{
|
| 67 |
-
if (empty($data)) {
|
| 68 |
-
return false;
|
| 69 |
-
} else {
|
| 70 |
-
if (isset($data['api']) && strstr($data['api'], 'saleswarp_fastapi') !== false) {
|
| 71 |
-
// load api
|
| 72 |
-
$className = $data['api'];
|
| 73 |
-
|
| 74 |
-
switch ($className) {
|
| 75 |
-
case 'saleswarp_fastapi_model_order_api':
|
| 76 |
-
$className = 'oms/order_api';
|
| 77 |
-
break;
|
| 78 |
-
case 'saleswarp_fastapi_model_product_api':
|
| 79 |
-
$className = 'oms/product_api';
|
| 80 |
-
break;
|
| 81 |
-
case 'saleswarp_fastapi_model_category_api':
|
| 82 |
-
$className = 'oms/category_api';
|
| 83 |
-
break;
|
| 84 |
-
case 'saleswarp_fastapi_model_config_api':
|
| 85 |
-
$className = 'oms/config_api';
|
| 86 |
-
break;
|
| 87 |
-
case 'saleswarp_fastapi_model_product_attribute_media_api':
|
| 88 |
-
$className = 'oms/product_attribute_media_api';
|
| 89 |
-
break;
|
| 90 |
-
case 'saleswarp_fastapi_model_customer_api':
|
| 91 |
-
$className = 'oms/customer_api';
|
| 92 |
-
break;
|
| 93 |
-
}
|
| 94 |
-
|
| 95 |
-
try {
|
| 96 |
-
$mage = Mage::getModel($className);
|
| 97 |
-
if(!method_exists($mage, $data['methodName'])) {
|
| 98 |
-
throw new Exception('Class or Function does not exists');
|
| 99 |
-
} else {
|
| 100 |
-
$fastData = call_user_func_array(array($mage, $data['methodName']), $data['methodParams']);
|
| 101 |
-
}
|
| 102 |
-
} catch(Exception $e) {
|
| 103 |
-
return [$e->getMessage()];
|
| 104 |
-
}
|
| 105 |
-
|
| 106 |
-
return $fastData;
|
| 107 |
-
} else {
|
| 108 |
-
return false;
|
| 109 |
-
}
|
| 110 |
-
}
|
| 111 |
-
}
|
| 112 |
-
|
| 113 |
-
/**
|
| 114 |
-
* * Authentication API request
|
| 115 |
-
* *
|
| 116 |
-
* * @params string hash key
|
| 117 |
-
* * @return bool(trur or false)
|
| 118 |
-
* */
|
| 119 |
-
public function ApiAuthentication($hash = null)
|
| 120 |
-
{
|
| 121 |
-
if(empty($hash)) {
|
| 122 |
-
$this->authError = 'No hash key supplied';
|
| 123 |
-
return false;
|
| 124 |
-
} else {
|
| 125 |
-
$mageHash = Mage::getStoreConfig('oms/registration/key');
|
| 126 |
-
|
| 127 |
-
// get user ip address
|
| 128 |
-
$remoteIP = Mage::helper('core/http')->getRemoteAddr(false);
|
| 129 |
-
if (!empty($mageHash) && $hash == $mageHash) {
|
| 130 |
-
return true;
|
| 131 |
-
} else {
|
| 132 |
-
$this->authError = 'Incorrect Hash key';
|
| 133 |
-
return false;
|
| 134 |
-
}
|
| 135 |
-
}
|
| 136 |
-
}
|
| 137 |
}
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
class Saleswarp_Oms_FastapiController extends Mage_Core_Controller_Front_Action {
|
| 15 |
+
|
| 16 |
+
public $authError = '';
|
| 17 |
+
|
| 18 |
+
/**
|
| 19 |
+
* * Receive API call and process API
|
| 20 |
+
* *
|
| 21 |
+
* * @param json encoded data
|
| 22 |
+
* * @return json encode data
|
| 23 |
+
* */
|
| 24 |
+
public function IndexAction()
|
| 25 |
+
{
|
| 26 |
+
$response = array();
|
| 27 |
+
$data = json_decode(@file_get_contents('php://input'), true);
|
| 28 |
+
|
| 29 |
+
if (empty($data)) {
|
| 30 |
+
$this->_redirect('/');
|
| 31 |
+
return;
|
| 32 |
+
}
|
| 33 |
+
|
| 34 |
+
if (isset($data['hash']['key'])) {
|
| 35 |
+
// authenticate
|
| 36 |
+
if(!$this->ApiAuthentication($data['hash']['key'])) {
|
| 37 |
+
$response['error_msg'] = $this->authError;
|
| 38 |
+
$response['error_code'] = '2';
|
| 39 |
+
echo json_encode($response);
|
| 40 |
+
exit;
|
| 41 |
+
}
|
| 42 |
+
// call method api
|
| 43 |
+
$response['data'] = $this->callFastApi($data);
|
| 44 |
+
if(!$response['data']) {
|
| 45 |
+
$response['error_msg'] = 'Invalid data';
|
| 46 |
+
$response['error_code'] = '3';
|
| 47 |
+
} else {
|
| 48 |
+
$response['error_msg'] = '';
|
| 49 |
+
$response['error_code'] = '0';
|
| 50 |
+
}
|
| 51 |
+
} else {
|
| 52 |
+
$response['error_msg'] = 'Invalid data';
|
| 53 |
+
$response['error_code'] = '1';
|
| 54 |
+
}
|
| 55 |
+
echo json_encode($response);
|
| 56 |
+
exit;
|
| 57 |
+
}
|
| 58 |
+
|
| 59 |
+
/**
|
| 60 |
+
* * Load fast api and call methods
|
| 61 |
+
* *
|
| 62 |
+
* * @param array of data
|
| 63 |
+
* * @return array of data
|
| 64 |
+
* */
|
| 65 |
+
public function callFastApi($data = array())
|
| 66 |
+
{
|
| 67 |
+
if (empty($data)) {
|
| 68 |
+
return false;
|
| 69 |
+
} else {
|
| 70 |
+
if (isset($data['api']) && strstr($data['api'], 'saleswarp_fastapi') !== false) {
|
| 71 |
+
// load api
|
| 72 |
+
$className = $data['api'];
|
| 73 |
+
|
| 74 |
+
switch ($className) {
|
| 75 |
+
case 'saleswarp_fastapi_model_order_api':
|
| 76 |
+
$className = 'oms/order_api';
|
| 77 |
+
break;
|
| 78 |
+
case 'saleswarp_fastapi_model_product_api':
|
| 79 |
+
$className = 'oms/product_api';
|
| 80 |
+
break;
|
| 81 |
+
case 'saleswarp_fastapi_model_category_api':
|
| 82 |
+
$className = 'oms/category_api';
|
| 83 |
+
break;
|
| 84 |
+
case 'saleswarp_fastapi_model_config_api':
|
| 85 |
+
$className = 'oms/config_api';
|
| 86 |
+
break;
|
| 87 |
+
case 'saleswarp_fastapi_model_product_attribute_media_api':
|
| 88 |
+
$className = 'oms/product_attribute_media_api';
|
| 89 |
+
break;
|
| 90 |
+
case 'saleswarp_fastapi_model_customer_api':
|
| 91 |
+
$className = 'oms/customer_api';
|
| 92 |
+
break;
|
| 93 |
+
}
|
| 94 |
+
|
| 95 |
+
try {
|
| 96 |
+
$mage = Mage::getModel($className);
|
| 97 |
+
if(!method_exists($mage, $data['methodName'])) {
|
| 98 |
+
throw new Exception('Class or Function does not exists');
|
| 99 |
+
} else {
|
| 100 |
+
$fastData = call_user_func_array(array($mage, $data['methodName']), $data['methodParams']);
|
| 101 |
+
}
|
| 102 |
+
} catch(Exception $e) {
|
| 103 |
+
return [$e->getMessage()];
|
| 104 |
+
}
|
| 105 |
+
|
| 106 |
+
return $fastData;
|
| 107 |
+
} else {
|
| 108 |
+
return false;
|
| 109 |
+
}
|
| 110 |
+
}
|
| 111 |
+
}
|
| 112 |
+
|
| 113 |
+
/**
|
| 114 |
+
* * Authentication API request
|
| 115 |
+
* *
|
| 116 |
+
* * @params string hash key
|
| 117 |
+
* * @return bool(trur or false)
|
| 118 |
+
* */
|
| 119 |
+
public function ApiAuthentication($hash = null)
|
| 120 |
+
{
|
| 121 |
+
if(empty($hash)) {
|
| 122 |
+
$this->authError = 'No hash key supplied';
|
| 123 |
+
return false;
|
| 124 |
+
} else {
|
| 125 |
+
$mageHash = Mage::getStoreConfig('oms/registration/key');
|
| 126 |
+
|
| 127 |
+
// get user ip address
|
| 128 |
+
$remoteIP = Mage::helper('core/http')->getRemoteAddr(false);
|
| 129 |
+
if (!empty($mageHash) && $hash == $mageHash) {
|
| 130 |
+
return true;
|
| 131 |
+
} else {
|
| 132 |
+
$this->authError = 'Incorrect Hash key';
|
| 133 |
+
return false;
|
| 134 |
+
}
|
| 135 |
+
}
|
| 136 |
+
}
|
| 137 |
}
|
app/code/local/Saleswarp/Oms/etc/adminhtml.xml
CHANGED
|
@@ -1,23 +1,23 @@
|
|
| 1 |
-
<?xml version="1.0"?>
|
| 2 |
-
<config>
|
| 3 |
-
<acl>
|
| 4 |
-
<resources>
|
| 5 |
-
<admin>
|
| 6 |
-
<children>
|
| 7 |
-
<system>
|
| 8 |
-
<children>
|
| 9 |
-
<config>
|
| 10 |
-
<children>
|
| 11 |
-
<oms translate="title" module="oms">
|
| 12 |
-
<title>Saleswarp Oms Section</title>
|
| 13 |
-
<sort_order>0</sort_order>
|
| 14 |
-
</oms>
|
| 15 |
-
</children>
|
| 16 |
-
</config>
|
| 17 |
-
</children>
|
| 18 |
-
</system>
|
| 19 |
-
</children>
|
| 20 |
-
</admin>
|
| 21 |
-
</resources>
|
| 22 |
-
</acl>
|
| 23 |
</config>
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<acl>
|
| 4 |
+
<resources>
|
| 5 |
+
<admin>
|
| 6 |
+
<children>
|
| 7 |
+
<system>
|
| 8 |
+
<children>
|
| 9 |
+
<config>
|
| 10 |
+
<children>
|
| 11 |
+
<oms translate="title" module="oms">
|
| 12 |
+
<title>Saleswarp Oms Section</title>
|
| 13 |
+
<sort_order>0</sort_order>
|
| 14 |
+
</oms>
|
| 15 |
+
</children>
|
| 16 |
+
</config>
|
| 17 |
+
</children>
|
| 18 |
+
</system>
|
| 19 |
+
</children>
|
| 20 |
+
</admin>
|
| 21 |
+
</resources>
|
| 22 |
+
</acl>
|
| 23 |
</config>
|
app/code/local/Saleswarp/Oms/etc/config.xml
CHANGED
|
@@ -1,93 +1,93 @@
|
|
| 1 |
-
<?xml version="1.0"?>
|
| 2 |
-
<config>
|
| 3 |
-
<modules>
|
| 4 |
-
<Saleswarp_Oms>
|
| 5 |
-
<version>0.1.2</version>
|
| 6 |
-
</Saleswarp_Oms>
|
| 7 |
-
</modules>
|
| 8 |
-
<frontend>
|
| 9 |
-
<routers>
|
| 10 |
-
<oms>
|
| 11 |
-
<use>standard</use>
|
| 12 |
-
<args>
|
| 13 |
-
<module>Saleswarp_Oms</module>
|
| 14 |
-
<frontName>customapi</frontName>
|
| 15 |
-
</args>
|
| 16 |
-
</oms>
|
| 17 |
-
</routers>
|
| 18 |
-
</frontend>
|
| 19 |
-
<global>
|
| 20 |
-
<helpers>
|
| 21 |
-
<oms>
|
| 22 |
-
<class>Saleswarp_Oms_Helper</class>
|
| 23 |
-
</oms>
|
| 24 |
-
</helpers>
|
| 25 |
-
<blocks>
|
| 26 |
-
<oms>
|
| 27 |
-
<class>Saleswarp_Oms_Block</class>
|
| 28 |
-
</oms>
|
| 29 |
-
</blocks>
|
| 30 |
-
<resources>
|
| 31 |
-
<oms_setup>
|
| 32 |
-
<setup>
|
| 33 |
-
<module>Saleswarp_Oms</module>
|
| 34 |
-
</setup>
|
| 35 |
-
<connection>
|
| 36 |
-
<use>core_setup</use>
|
| 37 |
-
</connection>
|
| 38 |
-
</oms_setup>
|
| 39 |
-
<oms_write>
|
| 40 |
-
<connection>
|
| 41 |
-
<use>core_write</use>
|
| 42 |
-
</connection>
|
| 43 |
-
</oms_write>
|
| 44 |
-
<oms_read>
|
| 45 |
-
<connection>
|
| 46 |
-
<use>core_read</use>
|
| 47 |
-
</connection>
|
| 48 |
-
</oms_read>
|
| 49 |
-
</resources>
|
| 50 |
-
<models>
|
| 51 |
-
<oms>
|
| 52 |
-
<class>Saleswarp_Oms_Model</class>
|
| 53 |
-
</oms>
|
| 54 |
-
<catalog>
|
| 55 |
-
<rewrite>
|
| 56 |
-
<product_api>Saleswarp_Oms_Model_Catalog_Product_Api</product_api>
|
| 57 |
-
</rewrite>
|
| 58 |
-
</catalog>
|
| 59 |
-
</models>
|
| 60 |
-
<fieldsets>
|
| 61 |
-
<sales_convert_quote_payment>
|
| 62 |
-
<transction_no>
|
| 63 |
-
<to_order_payment>*</to_order_payment>
|
| 64 |
-
</transction_no>
|
| 65 |
-
<payment_method>
|
| 66 |
-
<to_order_payment>*</to_order_payment>
|
| 67 |
-
</payment_method>
|
| 68 |
-
</sales_convert_quote_payment>
|
| 69 |
-
</fieldsets>
|
| 70 |
-
</global>
|
| 71 |
-
<default>
|
| 72 |
-
<payment>
|
| 73 |
-
<saleswarp>
|
| 74 |
-
<active>1</active>
|
| 75 |
-
<model>oms/saleswarp</model>
|
| 76 |
-
<order_status>processing</order_status>
|
| 77 |
-
<title>Saleswarp Payment</title>
|
| 78 |
-
<message>Used for Orders created in Saleswarp.</message>
|
| 79 |
-
</saleswarp>
|
| 80 |
-
</payment>
|
| 81 |
-
</default>
|
| 82 |
-
<admin>
|
| 83 |
-
<routers>
|
| 84 |
-
<oms>
|
| 85 |
-
<use>admin</use>
|
| 86 |
-
<args>
|
| 87 |
-
<module>Saleswarp_Oms</module>
|
| 88 |
-
<frontName>admin_oms</frontName>
|
| 89 |
-
</args>
|
| 90 |
-
</oms>
|
| 91 |
-
</routers>
|
| 92 |
-
</admin>
|
| 93 |
</config>
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<modules>
|
| 4 |
+
<Saleswarp_Oms>
|
| 5 |
+
<version>0.1.2</version>
|
| 6 |
+
</Saleswarp_Oms>
|
| 7 |
+
</modules>
|
| 8 |
+
<frontend>
|
| 9 |
+
<routers>
|
| 10 |
+
<oms>
|
| 11 |
+
<use>standard</use>
|
| 12 |
+
<args>
|
| 13 |
+
<module>Saleswarp_Oms</module>
|
| 14 |
+
<frontName>customapi</frontName>
|
| 15 |
+
</args>
|
| 16 |
+
</oms>
|
| 17 |
+
</routers>
|
| 18 |
+
</frontend>
|
| 19 |
+
<global>
|
| 20 |
+
<helpers>
|
| 21 |
+
<oms>
|
| 22 |
+
<class>Saleswarp_Oms_Helper</class>
|
| 23 |
+
</oms>
|
| 24 |
+
</helpers>
|
| 25 |
+
<blocks>
|
| 26 |
+
<oms>
|
| 27 |
+
<class>Saleswarp_Oms_Block</class>
|
| 28 |
+
</oms>
|
| 29 |
+
</blocks>
|
| 30 |
+
<resources>
|
| 31 |
+
<oms_setup>
|
| 32 |
+
<setup>
|
| 33 |
+
<module>Saleswarp_Oms</module>
|
| 34 |
+
</setup>
|
| 35 |
+
<connection>
|
| 36 |
+
<use>core_setup</use>
|
| 37 |
+
</connection>
|
| 38 |
+
</oms_setup>
|
| 39 |
+
<oms_write>
|
| 40 |
+
<connection>
|
| 41 |
+
<use>core_write</use>
|
| 42 |
+
</connection>
|
| 43 |
+
</oms_write>
|
| 44 |
+
<oms_read>
|
| 45 |
+
<connection>
|
| 46 |
+
<use>core_read</use>
|
| 47 |
+
</connection>
|
| 48 |
+
</oms_read>
|
| 49 |
+
</resources>
|
| 50 |
+
<models>
|
| 51 |
+
<oms>
|
| 52 |
+
<class>Saleswarp_Oms_Model</class>
|
| 53 |
+
</oms>
|
| 54 |
+
<catalog>
|
| 55 |
+
<rewrite>
|
| 56 |
+
<product_api>Saleswarp_Oms_Model_Catalog_Product_Api</product_api>
|
| 57 |
+
</rewrite>
|
| 58 |
+
</catalog>
|
| 59 |
+
</models>
|
| 60 |
+
<fieldsets>
|
| 61 |
+
<sales_convert_quote_payment>
|
| 62 |
+
<transction_no>
|
| 63 |
+
<to_order_payment>*</to_order_payment>
|
| 64 |
+
</transction_no>
|
| 65 |
+
<payment_method>
|
| 66 |
+
<to_order_payment>*</to_order_payment>
|
| 67 |
+
</payment_method>
|
| 68 |
+
</sales_convert_quote_payment>
|
| 69 |
+
</fieldsets>
|
| 70 |
+
</global>
|
| 71 |
+
<default>
|
| 72 |
+
<payment>
|
| 73 |
+
<saleswarp>
|
| 74 |
+
<active>1</active>
|
| 75 |
+
<model>oms/saleswarp</model>
|
| 76 |
+
<order_status>processing</order_status>
|
| 77 |
+
<title>Saleswarp Payment</title>
|
| 78 |
+
<message>Used for Orders created in Saleswarp.</message>
|
| 79 |
+
</saleswarp>
|
| 80 |
+
</payment>
|
| 81 |
+
</default>
|
| 82 |
+
<admin>
|
| 83 |
+
<routers>
|
| 84 |
+
<oms>
|
| 85 |
+
<use>admin</use>
|
| 86 |
+
<args>
|
| 87 |
+
<module>Saleswarp_Oms</module>
|
| 88 |
+
<frontName>admin_oms</frontName>
|
| 89 |
+
</args>
|
| 90 |
+
</oms>
|
| 91 |
+
</routers>
|
| 92 |
+
</admin>
|
| 93 |
</config>
|
app/code/local/Saleswarp/Oms/etc/system.xml
CHANGED
|
@@ -1,97 +1,97 @@
|
|
| 1 |
-
<?xml version="1.0" encoding="UTF-8"?>
|
| 2 |
-
<config>
|
| 3 |
-
<tabs>
|
| 4 |
-
<saleswarp translate="label" module="oms">
|
| 5 |
-
<label>Saleswarp</label>
|
| 6 |
-
<sort_order>10</sort_order>
|
| 7 |
-
</saleswarp>
|
| 8 |
-
</tabs>
|
| 9 |
-
<sections>
|
| 10 |
-
<oms translate="label" module="oms">
|
| 11 |
-
<label>Settings</label>
|
| 12 |
-
<tab>saleswarp</tab>
|
| 13 |
-
<frontend_type>text</frontend_type>
|
| 14 |
-
<sort_order>0</sort_order>
|
| 15 |
-
<show_in_default>1</show_in_default>
|
| 16 |
-
<show_in_website>1</show_in_website>
|
| 17 |
-
<show_in_store>1</show_in_store>
|
| 18 |
-
<groups>
|
| 19 |
-
<registration translate="label">
|
| 20 |
-
<label>Generate Unique SalesWarp Registration Key</label>
|
| 21 |
-
<frontend_type>text</frontend_type>
|
| 22 |
-
<sort_order>10</sort_order>
|
| 23 |
-
<show_in_default>1</show_in_default>
|
| 24 |
-
<show_in_website>0</show_in_website>
|
| 25 |
-
<show_in_store>0</show_in_store>
|
| 26 |
-
<fields>
|
| 27 |
-
<key translate="label">
|
| 28 |
-
<label>SalesWarp Registration Unique Key</label>
|
| 29 |
-
<frontend_type>text</frontend_type>
|
| 30 |
-
<frontend_model>Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Key</frontend_model>
|
| 31 |
-
<sort_order>10</sort_order>
|
| 32 |
-
<show_in_default>1</show_in_default>
|
| 33 |
-
<show_in_website>0</show_in_website>
|
| 34 |
-
<show_in_store>0</show_in_store>
|
| 35 |
-
</key>
|
| 36 |
-
<check translate="label">
|
| 37 |
-
<label> </label>
|
| 38 |
-
<frontend_type>button</frontend_type>
|
| 39 |
-
<frontend_model>Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Button</frontend_model>
|
| 40 |
-
<sort_order>20</sort_order>
|
| 41 |
-
<show_in_default>1</show_in_default>
|
| 42 |
-
<show_in_website>0</show_in_website>
|
| 43 |
-
<show_in_store>0</show_in_store>
|
| 44 |
-
</check>
|
| 45 |
-
</fields>
|
| 46 |
-
</registration>
|
| 47 |
-
</groups>
|
| 48 |
-
</oms>
|
| 49 |
-
<payment>
|
| 50 |
-
<groups>
|
| 51 |
-
<saleswarp translate="label">
|
| 52 |
-
<label>Saleswarp Payment Module</label>
|
| 53 |
-
<sort_order>670</sort_order>
|
| 54 |
-
<show_in_default>1</show_in_default>
|
| 55 |
-
<show_in_website>1</show_in_website>
|
| 56 |
-
<show_in_store>0</show_in_store>
|
| 57 |
-
<fields>
|
| 58 |
-
<active translate="label">
|
| 59 |
-
<label>Enabled</label>
|
| 60 |
-
<frontend_type>select</frontend_type>
|
| 61 |
-
<source_model>adminhtml/system_config_source_yesno</source_model>
|
| 62 |
-
<sort_order>1</sort_order>
|
| 63 |
-
<show_in_default>1</show_in_default>
|
| 64 |
-
<show_in_website>1</show_in_website>
|
| 65 |
-
<show_in_store>0</show_in_store>
|
| 66 |
-
</active>
|
| 67 |
-
<order_status translate="label">
|
| 68 |
-
<label>New order status</label>
|
| 69 |
-
<frontend_type>select</frontend_type>
|
| 70 |
-
<source_model>adminhtml/system_config_source_order_status_processing</source_model>
|
| 71 |
-
<sort_order>2</sort_order>
|
| 72 |
-
<show_in_default>1</show_in_default>
|
| 73 |
-
<show_in_website>1</show_in_website>
|
| 74 |
-
<show_in_store>0</show_in_store>
|
| 75 |
-
</order_status>
|
| 76 |
-
<title translate="label">
|
| 77 |
-
<label>Title</label>
|
| 78 |
-
<frontend_type>text</frontend_type>
|
| 79 |
-
<sort_order>3</sort_order>
|
| 80 |
-
<show_in_default>1</show_in_default>
|
| 81 |
-
<show_in_website>1</show_in_website>
|
| 82 |
-
<show_in_store>0</show_in_store>
|
| 83 |
-
</title>
|
| 84 |
-
<message translate="label">
|
| 85 |
-
<label>Displayed Message</label>
|
| 86 |
-
<frontend_type>textarea</frontend_type>
|
| 87 |
-
<sort_order>4</sort_order>
|
| 88 |
-
<show_in_default>1</show_in_default>
|
| 89 |
-
<show_in_website>1</show_in_website>
|
| 90 |
-
<show_in_store>1</show_in_store>
|
| 91 |
-
</message>
|
| 92 |
-
</fields>
|
| 93 |
-
</saleswarp>
|
| 94 |
-
</groups>
|
| 95 |
-
</payment>
|
| 96 |
-
</sections>
|
| 97 |
</config>
|
| 1 |
+
<?xml version="1.0" encoding="UTF-8"?>
|
| 2 |
+
<config>
|
| 3 |
+
<tabs>
|
| 4 |
+
<saleswarp translate="label" module="oms">
|
| 5 |
+
<label>Saleswarp</label>
|
| 6 |
+
<sort_order>10</sort_order>
|
| 7 |
+
</saleswarp>
|
| 8 |
+
</tabs>
|
| 9 |
+
<sections>
|
| 10 |
+
<oms translate="label" module="oms">
|
| 11 |
+
<label>Settings</label>
|
| 12 |
+
<tab>saleswarp</tab>
|
| 13 |
+
<frontend_type>text</frontend_type>
|
| 14 |
+
<sort_order>0</sort_order>
|
| 15 |
+
<show_in_default>1</show_in_default>
|
| 16 |
+
<show_in_website>1</show_in_website>
|
| 17 |
+
<show_in_store>1</show_in_store>
|
| 18 |
+
<groups>
|
| 19 |
+
<registration translate="label">
|
| 20 |
+
<label>Generate Unique SalesWarp Registration Key</label>
|
| 21 |
+
<frontend_type>text</frontend_type>
|
| 22 |
+
<sort_order>10</sort_order>
|
| 23 |
+
<show_in_default>1</show_in_default>
|
| 24 |
+
<show_in_website>0</show_in_website>
|
| 25 |
+
<show_in_store>0</show_in_store>
|
| 26 |
+
<fields>
|
| 27 |
+
<key translate="label">
|
| 28 |
+
<label>SalesWarp Registration Unique Key</label>
|
| 29 |
+
<frontend_type>text</frontend_type>
|
| 30 |
+
<frontend_model>Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Key</frontend_model>
|
| 31 |
+
<sort_order>10</sort_order>
|
| 32 |
+
<show_in_default>1</show_in_default>
|
| 33 |
+
<show_in_website>0</show_in_website>
|
| 34 |
+
<show_in_store>0</show_in_store>
|
| 35 |
+
</key>
|
| 36 |
+
<check translate="label">
|
| 37 |
+
<label> </label>
|
| 38 |
+
<frontend_type>button</frontend_type>
|
| 39 |
+
<frontend_model>Saleswarp_Oms_Block_Adminhtml_System_Config_Form_Button</frontend_model>
|
| 40 |
+
<sort_order>20</sort_order>
|
| 41 |
+
<show_in_default>1</show_in_default>
|
| 42 |
+
<show_in_website>0</show_in_website>
|
| 43 |
+
<show_in_store>0</show_in_store>
|
| 44 |
+
</check>
|
| 45 |
+
</fields>
|
| 46 |
+
</registration>
|
| 47 |
+
</groups>
|
| 48 |
+
</oms>
|
| 49 |
+
<payment>
|
| 50 |
+
<groups>
|
| 51 |
+
<saleswarp translate="label">
|
| 52 |
+
<label>Saleswarp Payment Module</label>
|
| 53 |
+
<sort_order>670</sort_order>
|
| 54 |
+
<show_in_default>1</show_in_default>
|
| 55 |
+
<show_in_website>1</show_in_website>
|
| 56 |
+
<show_in_store>0</show_in_store>
|
| 57 |
+
<fields>
|
| 58 |
+
<active translate="label">
|
| 59 |
+
<label>Enabled</label>
|
| 60 |
+
<frontend_type>select</frontend_type>
|
| 61 |
+
<source_model>adminhtml/system_config_source_yesno</source_model>
|
| 62 |
+
<sort_order>1</sort_order>
|
| 63 |
+
<show_in_default>1</show_in_default>
|
| 64 |
+
<show_in_website>1</show_in_website>
|
| 65 |
+
<show_in_store>0</show_in_store>
|
| 66 |
+
</active>
|
| 67 |
+
<order_status translate="label">
|
| 68 |
+
<label>New order status</label>
|
| 69 |
+
<frontend_type>select</frontend_type>
|
| 70 |
+
<source_model>adminhtml/system_config_source_order_status_processing</source_model>
|
| 71 |
+
<sort_order>2</sort_order>
|
| 72 |
+
<show_in_default>1</show_in_default>
|
| 73 |
+
<show_in_website>1</show_in_website>
|
| 74 |
+
<show_in_store>0</show_in_store>
|
| 75 |
+
</order_status>
|
| 76 |
+
<title translate="label">
|
| 77 |
+
<label>Title</label>
|
| 78 |
+
<frontend_type>text</frontend_type>
|
| 79 |
+
<sort_order>3</sort_order>
|
| 80 |
+
<show_in_default>1</show_in_default>
|
| 81 |
+
<show_in_website>1</show_in_website>
|
| 82 |
+
<show_in_store>0</show_in_store>
|
| 83 |
+
</title>
|
| 84 |
+
<message translate="label">
|
| 85 |
+
<label>Displayed Message</label>
|
| 86 |
+
<frontend_type>textarea</frontend_type>
|
| 87 |
+
<sort_order>4</sort_order>
|
| 88 |
+
<show_in_default>1</show_in_default>
|
| 89 |
+
<show_in_website>1</show_in_website>
|
| 90 |
+
<show_in_store>1</show_in_store>
|
| 91 |
+
</message>
|
| 92 |
+
</fields>
|
| 93 |
+
</saleswarp>
|
| 94 |
+
</groups>
|
| 95 |
+
</payment>
|
| 96 |
+
</sections>
|
| 97 |
</config>
|
app/code/local/Saleswarp/Oms/sql/oms_setup/mysql4-install-0.1.1.php
CHANGED
|
@@ -1,265 +1,265 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
$installer = $this;
|
| 16 |
-
$setup = new Mage_Eav_Model_Entity_Setup('core_setup');
|
| 17 |
-
$installer->startSetup();
|
| 18 |
-
|
| 19 |
-
$constants = array(
|
| 20 |
-
'saleswarp_api_url' => 'http://accounts.saleswarp.com/key/get',
|
| 21 |
-
'saleswarp_create_url' => 'https://www.saleswarp.com/30-day-free-trial-sign-up/',
|
| 22 |
-
'saleswarp_login_url' => 'https://www.saleswarp.com/SMB_login',
|
| 23 |
-
);
|
| 24 |
-
|
| 25 |
-
foreach($constants as $code => $value) {
|
| 26 |
-
Mage::getModel('core/variable')
|
| 27 |
-
->setCode($code)
|
| 28 |
-
->setName($code)
|
| 29 |
-
->setPlainValue($value)
|
| 30 |
-
->save();
|
| 31 |
-
}
|
| 32 |
-
|
| 33 |
-
$setup->addAttribute('catalog_product', 'saleswarp_prod_id', array(
|
| 34 |
-
'group' => 'SalesWarp',
|
| 35 |
-
'type' => 'int',
|
| 36 |
-
'input' => 'text',
|
| 37 |
-
'label' => 'SalesWarp ID',
|
| 38 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 39 |
-
'visible' => 1,
|
| 40 |
-
'required' => 0,
|
| 41 |
-
'visible_on_front' => 0,
|
| 42 |
-
'is_html_allowed_on_front' => 0,
|
| 43 |
-
'is_configurable' => 0,
|
| 44 |
-
'searchable' => 0,
|
| 45 |
-
'filterable' => 0,
|
| 46 |
-
'comparable' => 0,
|
| 47 |
-
'unique' => true,
|
| 48 |
-
'user_defined' => true,
|
| 49 |
-
'is_user_defined' => false,
|
| 50 |
-
'used_in_product_listing' => false
|
| 51 |
-
));
|
| 52 |
-
|
| 53 |
-
$setup->addAttribute('catalog_product', 'saleswarp_prod_add_date', array(
|
| 54 |
-
'group' => 'SalesWarp',
|
| 55 |
-
'type' => 'datetime',
|
| 56 |
-
'input' => 'date',
|
| 57 |
-
'label' => 'SalesWarp Add Date',
|
| 58 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 59 |
-
'visible' => 1,
|
| 60 |
-
'required' => 0,
|
| 61 |
-
'visible_on_front' => 0,
|
| 62 |
-
'is_html_allowed_on_front' => 0,
|
| 63 |
-
'is_configurable' => 0,
|
| 64 |
-
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 65 |
-
'searchable' => 0,
|
| 66 |
-
'filterable' => 0,
|
| 67 |
-
'comparable' => 0,
|
| 68 |
-
'unique' => false,
|
| 69 |
-
'user_defined' => true,
|
| 70 |
-
'is_user_defined' => false,
|
| 71 |
-
'used_in_product_listing' => false
|
| 72 |
-
));
|
| 73 |
-
|
| 74 |
-
$setup->addAttribute('catalog_product', 'saleswarp_prod_code', array(
|
| 75 |
-
'group' => 'SalesWarp',
|
| 76 |
-
'type' => 'varchar',
|
| 77 |
-
'input' => 'text',
|
| 78 |
-
'label' => 'SalesWarp Code',
|
| 79 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 80 |
-
'visible' => 1,
|
| 81 |
-
'required' => 0,
|
| 82 |
-
'visible_on_front' => 0,
|
| 83 |
-
'is_html_allowed_on_front' => 0,
|
| 84 |
-
'is_configurable' => 0,
|
| 85 |
-
'searchable' => 0,
|
| 86 |
-
'filterable' => 0,
|
| 87 |
-
'comparable' => 0,
|
| 88 |
-
'unique' => false,
|
| 89 |
-
'user_defined' => true,
|
| 90 |
-
'is_user_defined' => false,
|
| 91 |
-
'used_in_product_listing' => false
|
| 92 |
-
));
|
| 93 |
-
|
| 94 |
-
$setup->addAttribute('catalog_product', 'saleswarp_prod_sync_date', array(
|
| 95 |
-
'group' => 'SalesWarp',
|
| 96 |
-
'type' => 'datetime',
|
| 97 |
-
'input' => 'date',
|
| 98 |
-
'label' => 'SalesWarp Sync Date',
|
| 99 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 100 |
-
'visible' => 1,
|
| 101 |
-
'required' => 0,
|
| 102 |
-
'visible_on_front' => 0,
|
| 103 |
-
'is_html_allowed_on_front' => 0,
|
| 104 |
-
'is_configurable' => 0,
|
| 105 |
-
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 106 |
-
'searchable' => 0,
|
| 107 |
-
'filterable' => 0,
|
| 108 |
-
'comparable' => 0,
|
| 109 |
-
'unique' => false,
|
| 110 |
-
'user_defined' => false,
|
| 111 |
-
'is_user_defined' => false,
|
| 112 |
-
'used_in_product_listing' => false
|
| 113 |
-
));
|
| 114 |
-
|
| 115 |
-
$setup->addAttribute('catalog_product', 'saleswarp_prod_last_inv_upd', array(
|
| 116 |
-
'group' => 'SalesWarp',
|
| 117 |
-
'type' => 'datetime',
|
| 118 |
-
'input' => 'date',
|
| 119 |
-
'label' => 'SalesWarp Last Inventory Update',
|
| 120 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 121 |
-
'visible' => 1,
|
| 122 |
-
'required' => 0,
|
| 123 |
-
'visible_on_front' => 0,
|
| 124 |
-
'is_html_allowed_on_front' => 0,
|
| 125 |
-
'is_configurable' => 0,
|
| 126 |
-
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 127 |
-
'searchable' => 0,
|
| 128 |
-
'filterable' => 0,
|
| 129 |
-
'comparable' => 0,
|
| 130 |
-
'unique' => false,
|
| 131 |
-
'user_defined' => false,
|
| 132 |
-
'is_user_defined' => false,
|
| 133 |
-
'used_in_product_listing' => false
|
| 134 |
-
));
|
| 135 |
-
|
| 136 |
-
$setup->addAttribute('catalog_category', 'saleswarp_cat_id', array(
|
| 137 |
-
'group' => 'SalesWarp',
|
| 138 |
-
'type' => 'int',
|
| 139 |
-
'input' => 'text',
|
| 140 |
-
'label' => 'SalesWarp ID',
|
| 141 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 142 |
-
'visible' => 1,
|
| 143 |
-
'required' => 0,
|
| 144 |
-
'visible_on_front' => 0,
|
| 145 |
-
'is_html_allowed_on_front' => 0,
|
| 146 |
-
'is_configurable' => 0,
|
| 147 |
-
'searchable' => 0,
|
| 148 |
-
'filterable' => 0,
|
| 149 |
-
'comparable' => 0,
|
| 150 |
-
'unique' => false,
|
| 151 |
-
'user_defined' => false,
|
| 152 |
-
'is_user_defined' => false,
|
| 153 |
-
'used_in_product_listing' => false
|
| 154 |
-
));
|
| 155 |
-
|
| 156 |
-
$setup->addAttribute('catalog_category', 'saleswarp_cat_name', array(
|
| 157 |
-
'group' => 'SalesWarp',
|
| 158 |
-
'type' => 'varchar',
|
| 159 |
-
'input' => 'text',
|
| 160 |
-
'label' => 'SalesWarp Name',
|
| 161 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 162 |
-
'visible' => 1,
|
| 163 |
-
'required' => 0,
|
| 164 |
-
'visible_on_front' => 0,
|
| 165 |
-
'is_html_allowed_on_front' => 0,
|
| 166 |
-
'is_configurable' => 0,
|
| 167 |
-
'searchable' => 0,
|
| 168 |
-
'filterable' => 0,
|
| 169 |
-
'comparable' => 0,
|
| 170 |
-
'unique' => false,
|
| 171 |
-
'user_defined' => false,
|
| 172 |
-
'is_user_defined' => false,
|
| 173 |
-
'used_in_product_listing' => false
|
| 174 |
-
));
|
| 175 |
-
|
| 176 |
-
$setup->addAttribute('catalog_category', 'saleswarp_cat_code', array(
|
| 177 |
-
'group' => 'SalesWarp',
|
| 178 |
-
'type' => 'int',
|
| 179 |
-
'input' => 'text',
|
| 180 |
-
'label' => 'SalesWarp Code',
|
| 181 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 182 |
-
'visible' => 1,
|
| 183 |
-
'required' => 0,
|
| 184 |
-
'visible_on_front' => 0,
|
| 185 |
-
'is_html_allowed_on_front' => 0,
|
| 186 |
-
'is_configurable' => 0,
|
| 187 |
-
'searchable' => 0,
|
| 188 |
-
'filterable' => 0,
|
| 189 |
-
'comparable' => 0,
|
| 190 |
-
'unique' => false,
|
| 191 |
-
'user_defined' => false,
|
| 192 |
-
'is_user_defined' => false,
|
| 193 |
-
'used_in_product_listing' => false
|
| 194 |
-
));
|
| 195 |
-
|
| 196 |
-
$setup->addAttribute('catalog_category', 'saleswarp_cat_add_date', array(
|
| 197 |
-
'group' => 'SalesWarp',
|
| 198 |
-
'type' => 'datetime',
|
| 199 |
-
'input' => 'date',
|
| 200 |
-
'label' => 'SalesWarp Add Date',
|
| 201 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 202 |
-
'visible' => 1,
|
| 203 |
-
'required' => 0,
|
| 204 |
-
'visible_on_front' => 0,
|
| 205 |
-
'is_html_allowed_on_front' => 0,
|
| 206 |
-
'is_configurable' => 0,
|
| 207 |
-
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 208 |
-
'searchable' => 0,
|
| 209 |
-
'filterable' => 0,
|
| 210 |
-
'comparable' => 0,
|
| 211 |
-
'unique' => false,
|
| 212 |
-
'user_defined' => false,
|
| 213 |
-
'is_user_defined' => false,
|
| 214 |
-
'used_in_product_listing' => false
|
| 215 |
-
));
|
| 216 |
-
|
| 217 |
-
$setup->addAttribute('catalog_category', 'saleswarp_cat_sync_date', array(
|
| 218 |
-
'group' => 'SalesWarp',
|
| 219 |
-
'type' => 'datetime',
|
| 220 |
-
'input' => 'date',
|
| 221 |
-
'label' => 'SalesWarp Sync Date',
|
| 222 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 223 |
-
'visible' => 1,
|
| 224 |
-
'required' => 0,
|
| 225 |
-
'visible_on_front' => 0,
|
| 226 |
-
'is_html_allowed_on_front' => 0,
|
| 227 |
-
'is_configurable' => 0,
|
| 228 |
-
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 229 |
-
'searchable' => 0,
|
| 230 |
-
'filterable' => 0,
|
| 231 |
-
'comparable' => 0,
|
| 232 |
-
'unique' => false,
|
| 233 |
-
'user_defined' => false,
|
| 234 |
-
'is_user_defined' => false,
|
| 235 |
-
'used_in_product_listing' => false
|
| 236 |
-
));
|
| 237 |
-
|
| 238 |
-
|
| 239 |
-
$productTable = $this->getTable('catalog_product_entity');
|
| 240 |
-
// Add new text fields product tables
|
| 241 |
-
$installer->getConnection()->addColumn($productTable, 'saleswarp_category_ids', 'varchar(64) NULL');
|
| 242 |
-
|
| 243 |
-
// ADD SALESWARP ATTRIBUTES FOR PRODUCTS
|
| 244 |
-
$setup->addAttribute('catalog_product', 'managed_by_saleswarp', array(
|
| 245 |
-
'group' => 'General',
|
| 246 |
-
'type' => 'int',
|
| 247 |
-
'input' => 'boolean',
|
| 248 |
-
'label' => 'Manage Product with SalesWarp',
|
| 249 |
-
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 250 |
-
'visible' => 1,
|
| 251 |
-
'default' => '0',
|
| 252 |
-
'required' => 1,
|
| 253 |
-
'visible_on_front' => 0,
|
| 254 |
-
'is_html_allowed_on_front' => 0,
|
| 255 |
-
'is_configurable' => 0,
|
| 256 |
-
'searchable' => 0,
|
| 257 |
-
'filterable' => 0,
|
| 258 |
-
'comparable' => 0,
|
| 259 |
-
'unique' => false,
|
| 260 |
-
'user_defined' => false,
|
| 261 |
-
'is_user_defined' => false,
|
| 262 |
-
'used_in_product_listing' => false
|
| 263 |
-
));
|
| 264 |
-
|
| 265 |
-
$installer->endSetup();
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
$installer = $this;
|
| 16 |
+
$setup = new Mage_Eav_Model_Entity_Setup('core_setup');
|
| 17 |
+
$installer->startSetup();
|
| 18 |
+
|
| 19 |
+
$constants = array(
|
| 20 |
+
'saleswarp_api_url' => 'http://accounts.saleswarp.com/key/get',
|
| 21 |
+
'saleswarp_create_url' => 'https://www.saleswarp.com/30-day-free-trial-sign-up/',
|
| 22 |
+
'saleswarp_login_url' => 'https://www.saleswarp.com/SMB_login',
|
| 23 |
+
);
|
| 24 |
+
|
| 25 |
+
foreach($constants as $code => $value) {
|
| 26 |
+
Mage::getModel('core/variable')
|
| 27 |
+
->setCode($code)
|
| 28 |
+
->setName($code)
|
| 29 |
+
->setPlainValue($value)
|
| 30 |
+
->save();
|
| 31 |
+
}
|
| 32 |
+
|
| 33 |
+
$setup->addAttribute('catalog_product', 'saleswarp_prod_id', array(
|
| 34 |
+
'group' => 'SalesWarp',
|
| 35 |
+
'type' => 'int',
|
| 36 |
+
'input' => 'text',
|
| 37 |
+
'label' => 'SalesWarp ID',
|
| 38 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 39 |
+
'visible' => 1,
|
| 40 |
+
'required' => 0,
|
| 41 |
+
'visible_on_front' => 0,
|
| 42 |
+
'is_html_allowed_on_front' => 0,
|
| 43 |
+
'is_configurable' => 0,
|
| 44 |
+
'searchable' => 0,
|
| 45 |
+
'filterable' => 0,
|
| 46 |
+
'comparable' => 0,
|
| 47 |
+
'unique' => true,
|
| 48 |
+
'user_defined' => true,
|
| 49 |
+
'is_user_defined' => false,
|
| 50 |
+
'used_in_product_listing' => false
|
| 51 |
+
));
|
| 52 |
+
|
| 53 |
+
$setup->addAttribute('catalog_product', 'saleswarp_prod_add_date', array(
|
| 54 |
+
'group' => 'SalesWarp',
|
| 55 |
+
'type' => 'datetime',
|
| 56 |
+
'input' => 'date',
|
| 57 |
+
'label' => 'SalesWarp Add Date',
|
| 58 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 59 |
+
'visible' => 1,
|
| 60 |
+
'required' => 0,
|
| 61 |
+
'visible_on_front' => 0,
|
| 62 |
+
'is_html_allowed_on_front' => 0,
|
| 63 |
+
'is_configurable' => 0,
|
| 64 |
+
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 65 |
+
'searchable' => 0,
|
| 66 |
+
'filterable' => 0,
|
| 67 |
+
'comparable' => 0,
|
| 68 |
+
'unique' => false,
|
| 69 |
+
'user_defined' => true,
|
| 70 |
+
'is_user_defined' => false,
|
| 71 |
+
'used_in_product_listing' => false
|
| 72 |
+
));
|
| 73 |
+
|
| 74 |
+
$setup->addAttribute('catalog_product', 'saleswarp_prod_code', array(
|
| 75 |
+
'group' => 'SalesWarp',
|
| 76 |
+
'type' => 'varchar',
|
| 77 |
+
'input' => 'text',
|
| 78 |
+
'label' => 'SalesWarp Code',
|
| 79 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 80 |
+
'visible' => 1,
|
| 81 |
+
'required' => 0,
|
| 82 |
+
'visible_on_front' => 0,
|
| 83 |
+
'is_html_allowed_on_front' => 0,
|
| 84 |
+
'is_configurable' => 0,
|
| 85 |
+
'searchable' => 0,
|
| 86 |
+
'filterable' => 0,
|
| 87 |
+
'comparable' => 0,
|
| 88 |
+
'unique' => false,
|
| 89 |
+
'user_defined' => true,
|
| 90 |
+
'is_user_defined' => false,
|
| 91 |
+
'used_in_product_listing' => false
|
| 92 |
+
));
|
| 93 |
+
|
| 94 |
+
$setup->addAttribute('catalog_product', 'saleswarp_prod_sync_date', array(
|
| 95 |
+
'group' => 'SalesWarp',
|
| 96 |
+
'type' => 'datetime',
|
| 97 |
+
'input' => 'date',
|
| 98 |
+
'label' => 'SalesWarp Sync Date',
|
| 99 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 100 |
+
'visible' => 1,
|
| 101 |
+
'required' => 0,
|
| 102 |
+
'visible_on_front' => 0,
|
| 103 |
+
'is_html_allowed_on_front' => 0,
|
| 104 |
+
'is_configurable' => 0,
|
| 105 |
+
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 106 |
+
'searchable' => 0,
|
| 107 |
+
'filterable' => 0,
|
| 108 |
+
'comparable' => 0,
|
| 109 |
+
'unique' => false,
|
| 110 |
+
'user_defined' => false,
|
| 111 |
+
'is_user_defined' => false,
|
| 112 |
+
'used_in_product_listing' => false
|
| 113 |
+
));
|
| 114 |
+
|
| 115 |
+
$setup->addAttribute('catalog_product', 'saleswarp_prod_last_inv_upd', array(
|
| 116 |
+
'group' => 'SalesWarp',
|
| 117 |
+
'type' => 'datetime',
|
| 118 |
+
'input' => 'date',
|
| 119 |
+
'label' => 'SalesWarp Last Inventory Update',
|
| 120 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 121 |
+
'visible' => 1,
|
| 122 |
+
'required' => 0,
|
| 123 |
+
'visible_on_front' => 0,
|
| 124 |
+
'is_html_allowed_on_front' => 0,
|
| 125 |
+
'is_configurable' => 0,
|
| 126 |
+
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 127 |
+
'searchable' => 0,
|
| 128 |
+
'filterable' => 0,
|
| 129 |
+
'comparable' => 0,
|
| 130 |
+
'unique' => false,
|
| 131 |
+
'user_defined' => false,
|
| 132 |
+
'is_user_defined' => false,
|
| 133 |
+
'used_in_product_listing' => false
|
| 134 |
+
));
|
| 135 |
+
|
| 136 |
+
$setup->addAttribute('catalog_category', 'saleswarp_cat_id', array(
|
| 137 |
+
'group' => 'SalesWarp',
|
| 138 |
+
'type' => 'int',
|
| 139 |
+
'input' => 'text',
|
| 140 |
+
'label' => 'SalesWarp ID',
|
| 141 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 142 |
+
'visible' => 1,
|
| 143 |
+
'required' => 0,
|
| 144 |
+
'visible_on_front' => 0,
|
| 145 |
+
'is_html_allowed_on_front' => 0,
|
| 146 |
+
'is_configurable' => 0,
|
| 147 |
+
'searchable' => 0,
|
| 148 |
+
'filterable' => 0,
|
| 149 |
+
'comparable' => 0,
|
| 150 |
+
'unique' => false,
|
| 151 |
+
'user_defined' => false,
|
| 152 |
+
'is_user_defined' => false,
|
| 153 |
+
'used_in_product_listing' => false
|
| 154 |
+
));
|
| 155 |
+
|
| 156 |
+
$setup->addAttribute('catalog_category', 'saleswarp_cat_name', array(
|
| 157 |
+
'group' => 'SalesWarp',
|
| 158 |
+
'type' => 'varchar',
|
| 159 |
+
'input' => 'text',
|
| 160 |
+
'label' => 'SalesWarp Name',
|
| 161 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 162 |
+
'visible' => 1,
|
| 163 |
+
'required' => 0,
|
| 164 |
+
'visible_on_front' => 0,
|
| 165 |
+
'is_html_allowed_on_front' => 0,
|
| 166 |
+
'is_configurable' => 0,
|
| 167 |
+
'searchable' => 0,
|
| 168 |
+
'filterable' => 0,
|
| 169 |
+
'comparable' => 0,
|
| 170 |
+
'unique' => false,
|
| 171 |
+
'user_defined' => false,
|
| 172 |
+
'is_user_defined' => false,
|
| 173 |
+
'used_in_product_listing' => false
|
| 174 |
+
));
|
| 175 |
+
|
| 176 |
+
$setup->addAttribute('catalog_category', 'saleswarp_cat_code', array(
|
| 177 |
+
'group' => 'SalesWarp',
|
| 178 |
+
'type' => 'int',
|
| 179 |
+
'input' => 'text',
|
| 180 |
+
'label' => 'SalesWarp Code',
|
| 181 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 182 |
+
'visible' => 1,
|
| 183 |
+
'required' => 0,
|
| 184 |
+
'visible_on_front' => 0,
|
| 185 |
+
'is_html_allowed_on_front' => 0,
|
| 186 |
+
'is_configurable' => 0,
|
| 187 |
+
'searchable' => 0,
|
| 188 |
+
'filterable' => 0,
|
| 189 |
+
'comparable' => 0,
|
| 190 |
+
'unique' => false,
|
| 191 |
+
'user_defined' => false,
|
| 192 |
+
'is_user_defined' => false,
|
| 193 |
+
'used_in_product_listing' => false
|
| 194 |
+
));
|
| 195 |
+
|
| 196 |
+
$setup->addAttribute('catalog_category', 'saleswarp_cat_add_date', array(
|
| 197 |
+
'group' => 'SalesWarp',
|
| 198 |
+
'type' => 'datetime',
|
| 199 |
+
'input' => 'date',
|
| 200 |
+
'label' => 'SalesWarp Add Date',
|
| 201 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 202 |
+
'visible' => 1,
|
| 203 |
+
'required' => 0,
|
| 204 |
+
'visible_on_front' => 0,
|
| 205 |
+
'is_html_allowed_on_front' => 0,
|
| 206 |
+
'is_configurable' => 0,
|
| 207 |
+
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 208 |
+
'searchable' => 0,
|
| 209 |
+
'filterable' => 0,
|
| 210 |
+
'comparable' => 0,
|
| 211 |
+
'unique' => false,
|
| 212 |
+
'user_defined' => false,
|
| 213 |
+
'is_user_defined' => false,
|
| 214 |
+
'used_in_product_listing' => false
|
| 215 |
+
));
|
| 216 |
+
|
| 217 |
+
$setup->addAttribute('catalog_category', 'saleswarp_cat_sync_date', array(
|
| 218 |
+
'group' => 'SalesWarp',
|
| 219 |
+
'type' => 'datetime',
|
| 220 |
+
'input' => 'date',
|
| 221 |
+
'label' => 'SalesWarp Sync Date',
|
| 222 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 223 |
+
'visible' => 1,
|
| 224 |
+
'required' => 0,
|
| 225 |
+
'visible_on_front' => 0,
|
| 226 |
+
'is_html_allowed_on_front' => 0,
|
| 227 |
+
'is_configurable' => 0,
|
| 228 |
+
'backend' => 'eav/entity_attribute_backend_datetime',
|
| 229 |
+
'searchable' => 0,
|
| 230 |
+
'filterable' => 0,
|
| 231 |
+
'comparable' => 0,
|
| 232 |
+
'unique' => false,
|
| 233 |
+
'user_defined' => false,
|
| 234 |
+
'is_user_defined' => false,
|
| 235 |
+
'used_in_product_listing' => false
|
| 236 |
+
));
|
| 237 |
+
|
| 238 |
+
|
| 239 |
+
$productTable = $this->getTable('catalog_product_entity');
|
| 240 |
+
// Add new text fields product tables
|
| 241 |
+
$installer->getConnection()->addColumn($productTable, 'saleswarp_category_ids', 'varchar(64) NULL');
|
| 242 |
+
|
| 243 |
+
// ADD SALESWARP ATTRIBUTES FOR PRODUCTS
|
| 244 |
+
$setup->addAttribute('catalog_product', 'managed_by_saleswarp', array(
|
| 245 |
+
'group' => 'General',
|
| 246 |
+
'type' => 'int',
|
| 247 |
+
'input' => 'boolean',
|
| 248 |
+
'label' => 'Manage Product with SalesWarp',
|
| 249 |
+
'global' => Mage_Catalog_Model_Resource_Eav_Attribute::SCOPE_GLOBAL,
|
| 250 |
+
'visible' => 1,
|
| 251 |
+
'default' => '0',
|
| 252 |
+
'required' => 1,
|
| 253 |
+
'visible_on_front' => 0,
|
| 254 |
+
'is_html_allowed_on_front' => 0,
|
| 255 |
+
'is_configurable' => 0,
|
| 256 |
+
'searchable' => 0,
|
| 257 |
+
'filterable' => 0,
|
| 258 |
+
'comparable' => 0,
|
| 259 |
+
'unique' => false,
|
| 260 |
+
'user_defined' => false,
|
| 261 |
+
'is_user_defined' => false,
|
| 262 |
+
'used_in_product_listing' => false
|
| 263 |
+
));
|
| 264 |
+
|
| 265 |
+
$installer->endSetup();
|
app/code/local/Saleswarp/Oms/sql/oms_setup/mysql4-upgrade-0.1.2.php
CHANGED
|
@@ -1,28 +1,28 @@
|
|
| 1 |
-
<?php
|
| 2 |
-
/**
|
| 3 |
-
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
-
*
|
| 5 |
-
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
-
* @version 0.1.2
|
| 7 |
-
* @author David Potts
|
| 8 |
-
* @license http://www.saleswarp.com/license-saas
|
| 9 |
-
* @category SalesWarp
|
| 10 |
-
* @since File available since Release 0.1.2
|
| 11 |
-
* @link https://www.SalesWarp.com
|
| 12 |
-
*
|
| 13 |
-
*/
|
| 14 |
-
|
| 15 |
-
$installer = $this;
|
| 16 |
-
/* @var $installer Mage_Customer_Model_Entity_Setup */
|
| 17 |
-
|
| 18 |
-
$installer->startSetup();
|
| 19 |
-
$installer->run("
|
| 20 |
-
|
| 21 |
-
ALTER TABLE `{$installer->getTable('sales/quote_payment')}` ADD `transction_no` VARCHAR( 255 ) NOT NULL ;
|
| 22 |
-
ALTER TABLE `{$installer->getTable('sales/quote_payment')}` ADD `payment_method` VARCHAR( 255 ) NOT NULL ;
|
| 23 |
-
|
| 24 |
-
ALTER TABLE `{$installer->getTable('sales/order_payment')}` ADD `transction_no` VARCHAR( 255 ) NOT NULL ;
|
| 25 |
-
ALTER TABLE `{$installer->getTable('sales/order_payment')}` ADD `payment_method` VARCHAR( 255 ) NOT NULL ;
|
| 26 |
-
|
| 27 |
-
");
|
| 28 |
-
$installer->endSetup();
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* This module connects Magento to the SalesWarp Advanced Order Management System.
|
| 4 |
+
*
|
| 5 |
+
* @copyright Copyright (c) 2015 6th Street Inc, dba SalesWarp.
|
| 6 |
+
* @version 0.1.2
|
| 7 |
+
* @author David Potts
|
| 8 |
+
* @license http://www.saleswarp.com/license-saas
|
| 9 |
+
* @category SalesWarp
|
| 10 |
+
* @since File available since Release 0.1.2
|
| 11 |
+
* @link https://www.SalesWarp.com
|
| 12 |
+
*
|
| 13 |
+
*/
|
| 14 |
+
|
| 15 |
+
$installer = $this;
|
| 16 |
+
/* @var $installer Mage_Customer_Model_Entity_Setup */
|
| 17 |
+
|
| 18 |
+
$installer->startSetup();
|
| 19 |
+
$installer->run("
|
| 20 |
+
|
| 21 |
+
ALTER TABLE `{$installer->getTable('sales/quote_payment')}` ADD `transction_no` VARCHAR( 255 ) NOT NULL ;
|
| 22 |
+
ALTER TABLE `{$installer->getTable('sales/quote_payment')}` ADD `payment_method` VARCHAR( 255 ) NOT NULL ;
|
| 23 |
+
|
| 24 |
+
ALTER TABLE `{$installer->getTable('sales/order_payment')}` ADD `transction_no` VARCHAR( 255 ) NOT NULL ;
|
| 25 |
+
ALTER TABLE `{$installer->getTable('sales/order_payment')}` ADD `payment_method` VARCHAR( 255 ) NOT NULL ;
|
| 26 |
+
|
| 27 |
+
");
|
| 28 |
+
$installer->endSetup();
|
app/code/local/Saleswarp/Publish/Helper/Data.php
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Publish_Helper_Data extends Mage_Core_Helper_Abstract
|
| 3 |
+
{
|
| 4 |
+
}
|
| 5 |
+
|
app/code/local/Saleswarp/Publish/Model/Category/Api.php
ADDED
|
@@ -0,0 +1,326 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* CUSTOM API EXTENSION - 6th Street Inc
|
| 4 |
+
* @author David Potts
|
| 5 |
+
* @copyright 6th Street Inc.
|
| 6 |
+
* @license none
|
| 7 |
+
*
|
| 8 |
+
*/
|
| 9 |
+
class Saleswarp_Publish_Model_Category_Api extends Saleswarp_Oms_Model_Category_Api
|
| 10 |
+
{
|
| 11 |
+
public $category_required_storeIds = array();
|
| 12 |
+
|
| 13 |
+
/**
|
| 14 |
+
* Update saleswarp Category Id in Magento
|
| 15 |
+
*
|
| 16 |
+
* @params Magento Product Id, Saleswarp categroy Id
|
| 17 |
+
* @return bool( TRUE|FALSE)
|
| 18 |
+
*/
|
| 19 |
+
public function update_slwp_category_id($entityId, $slwpCatId)
|
| 20 |
+
{
|
| 21 |
+
return $this->rest_save_attribute($entityId, 'saleswarp_cat_id', $slwpCatId);
|
| 22 |
+
}
|
| 23 |
+
|
| 24 |
+
/**
|
| 25 |
+
* Update catalog/category attribute value
|
| 26 |
+
*
|
| 27 |
+
* @params Magento Product id, attibure name, value
|
| 28 |
+
* @return query response
|
| 29 |
+
*/
|
| 30 |
+
function rest_save_attribute($entity_id, $code, $value, $store_id = 0)
|
| 31 |
+
{
|
| 32 |
+
$resource = Mage::getSingleton('core/resource');
|
| 33 |
+
|
| 34 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_category')->getTypeId();
|
| 35 |
+
|
| 36 |
+
$query = "SELECT attribute_id, backend_type, frontend_input FROM `" . $resource->getTableName('eav_attribute') . "`
|
| 37 |
+
WHERE `attribute_code` LIKE :code AND entity_type_id = :entityTypeId";
|
| 38 |
+
|
| 39 |
+
$binds = array(
|
| 40 |
+
'code' => $code,
|
| 41 |
+
'entityTypeId' => $entity_type_id
|
| 42 |
+
);
|
| 43 |
+
|
| 44 |
+
$result = $resource->getConnection('core_read')->query($query, $binds);
|
| 45 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 46 |
+
return $this->save_attribute($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 47 |
+
}
|
| 48 |
+
|
| 49 |
+
|
| 50 |
+
/**
|
| 51 |
+
* special attribute saves for select and multiselect types (frontend_type in Magento)
|
| 52 |
+
*
|
| 53 |
+
* @param mixed $product_id
|
| 54 |
+
* @param mixed $attribute_id
|
| 55 |
+
* @param mixed $attribute_code
|
| 56 |
+
*/
|
| 57 |
+
function save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id)
|
| 58 |
+
{
|
| 59 |
+
$resource = Mage::getSingleton('core/resource');
|
| 60 |
+
$write = $resource->getConnection('core_write');
|
| 61 |
+
$read = $resource->getConnection('core_read');
|
| 62 |
+
|
| 63 |
+
|
| 64 |
+
if ((!empty($row)) && ($row['backend_type'] != '') && ($row['backend_type'] != null)) {
|
| 65 |
+
|
| 66 |
+
$categroyBakTable = $resource->getTableName('catalog_category_entity_' . $row['backend_type']);
|
| 67 |
+
|
| 68 |
+
// does this exist
|
| 69 |
+
$query = "SELECT * FROM `" . $categroyBakTable . "`
|
| 70 |
+
WHERE attribute_id = :attributeId
|
| 71 |
+
AND entity_id = :entityId
|
| 72 |
+
AND store_id = 0
|
| 73 |
+
AND entity_type_id = :entityTypeId";
|
| 74 |
+
$binds = array(
|
| 75 |
+
'attributeId' => $row['attribute_id'],
|
| 76 |
+
'entityId' => $entity_id,
|
| 77 |
+
'entityTypeId' => $entity_type_id
|
| 78 |
+
);
|
| 79 |
+
|
| 80 |
+
$result = $read->query($query, $binds);
|
| 81 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 82 |
+
|
| 83 |
+
if (empty($chk)) {
|
| 84 |
+
// If key is in array $this->product_required_storeIds, then create an Admin store_id entry (store_id = 0)
|
| 85 |
+
if (!empty($value) && $value != "") {
|
| 86 |
+
$key1 = "catalog_category_entity_" . $row['backend_type'];
|
| 87 |
+
if (array_key_exists($key1, $this->category_required_storeIds)) {
|
| 88 |
+
|
| 89 |
+
$sql = "INSERT INTO `" . $categroyBakTable . "` (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 90 |
+
VALUES (NULL ,:etype,:attr,0,:eid,:val) ";
|
| 91 |
+
$binds = array(
|
| 92 |
+
'etype' => $entity_type_id,
|
| 93 |
+
'attr' => $row['attribute_id'],
|
| 94 |
+
'eid' => $entity_id,
|
| 95 |
+
'val' => $value
|
| 96 |
+
);
|
| 97 |
+
|
| 98 |
+
$write->query($sql, $binds);
|
| 99 |
+
}
|
| 100 |
+
}
|
| 101 |
+
} else { // update
|
| 102 |
+
$sql = "UPDATE `" . $categroyBakTable . "`
|
| 103 |
+
SET value = :value
|
| 104 |
+
WHERE value_id = :value_id";
|
| 105 |
+
|
| 106 |
+
$binds = array(
|
| 107 |
+
'value' => $value,
|
| 108 |
+
'value_id' => $chk['value_id']
|
| 109 |
+
);
|
| 110 |
+
$result = $write->query($sql, $binds);
|
| 111 |
+
}
|
| 112 |
+
|
| 113 |
+
// check for store id = 1
|
| 114 |
+
$query = "SELECT * FROM `" . $categroyBakTable . "`
|
| 115 |
+
WHERE attribute_id = :attributeId
|
| 116 |
+
AND entity_id = :entityId
|
| 117 |
+
AND store_id = :storeId
|
| 118 |
+
AND entity_type_id = :entityTypeId";
|
| 119 |
+
$binds = array(
|
| 120 |
+
'attributeId' => $row['attribute_id'],
|
| 121 |
+
'entityId' => $entity_id,
|
| 122 |
+
'storeId' => $store_id,
|
| 123 |
+
'entityTypeId' => $entity_type_id
|
| 124 |
+
);
|
| 125 |
+
$result = $read->query($query, $binds);
|
| 126 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 127 |
+
|
| 128 |
+
if (empty($chk)) {
|
| 129 |
+
if (!empty($value) && $value != "") {
|
| 130 |
+
$sql = "INSERT INTO `" . $categroyBakTable . "` (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 131 |
+
VALUES (NULL , :entity_type_id, :attribute_id, :store_id, :entity_id,:value)";
|
| 132 |
+
|
| 133 |
+
$binds = array(
|
| 134 |
+
'entity_type_id'=> $entity_type_id,
|
| 135 |
+
'attribute_id' => $row['attribute_id'],
|
| 136 |
+
'store_id' => $store_id,
|
| 137 |
+
'entity_id' => $entity_id,
|
| 138 |
+
'value' => $value
|
| 139 |
+
);
|
| 140 |
+
|
| 141 |
+
$write->query($sql, $binds);
|
| 142 |
+
}
|
| 143 |
+
} else { // update
|
| 144 |
+
if (!empty($value) && $value != "") {
|
| 145 |
+
$sql = "UPDATE `" . $categroyBakTable . "`
|
| 146 |
+
SET value = :value
|
| 147 |
+
WHERE value_id = :value_id";
|
| 148 |
+
|
| 149 |
+
$binds = array(
|
| 150 |
+
'value' => $value,
|
| 151 |
+
'value_id' => $chk['value_id']
|
| 152 |
+
);
|
| 153 |
+
$result = $write->query($sql, $binds);
|
| 154 |
+
}
|
| 155 |
+
}
|
| 156 |
+
}
|
| 157 |
+
return "pass";
|
| 158 |
+
}
|
| 159 |
+
|
| 160 |
+
|
| 161 |
+
/**
|
| 162 |
+
* Get category collection by default root category
|
| 163 |
+
*
|
| 164 |
+
* @params Magento root category Id
|
| 165 |
+
* @return Mage Category Collection
|
| 166 |
+
*/
|
| 167 |
+
public function get_category_collection($mageRootId)
|
| 168 |
+
{
|
| 169 |
+
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
|
| 170 |
+
$collection = Mage::getModel('catalog/category')
|
| 171 |
+
->getCollection()
|
| 172 |
+
->addAttributeToSelect('entity_id')
|
| 173 |
+
->addAttributeToSelect('name')
|
| 174 |
+
->addAttributeToSelect('saleswarp_cat_id')
|
| 175 |
+
->addFieldToFilter('parent_id', $mageRootId);
|
| 176 |
+
|
| 177 |
+
if ($collection) {
|
| 178 |
+
$data = array();
|
| 179 |
+
foreach ($collection as $category) {
|
| 180 |
+
$data[] = $category->getData();
|
| 181 |
+
}
|
| 182 |
+
return $data;
|
| 183 |
+
}
|
| 184 |
+
return false;
|
| 185 |
+
}
|
| 186 |
+
|
| 187 |
+
|
| 188 |
+
/**
|
| 189 |
+
* Check if category exists in magento ( serach by name )
|
| 190 |
+
*
|
| 191 |
+
* @params id and saleswarp value
|
| 192 |
+
* @return bool
|
| 193 |
+
*/
|
| 194 |
+
public function check_category_exists($attr_id, $warehouse_cat_code)
|
| 195 |
+
{
|
| 196 |
+
$resource = Mage::getSingleton('core/resource');
|
| 197 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_category')->getTypeId();
|
| 198 |
+
|
| 199 |
+
$sql = "SELECT * FROM " . $resource->getTableName('catalog_category_entity_int') . "
|
| 200 |
+
WHERE attribute_id = :attributeId
|
| 201 |
+
and value = :value
|
| 202 |
+
and entity_type_id = :entityTypeId";
|
| 203 |
+
$binds = array(
|
| 204 |
+
'attributeId' => $attr_id,
|
| 205 |
+
'value' => $warehouse_cat_code,
|
| 206 |
+
'entityTypeId' => $entity_type_id
|
| 207 |
+
);
|
| 208 |
+
$cat = $resource->getConnection('core_read')->fetchAll($sql, $binds);
|
| 209 |
+
|
| 210 |
+
if (!empty($cat)) {
|
| 211 |
+
return $cat[0]['entity_id'];
|
| 212 |
+
} else {
|
| 213 |
+
return false;
|
| 214 |
+
}
|
| 215 |
+
}
|
| 216 |
+
|
| 217 |
+
/**
|
| 218 |
+
* Get category names
|
| 219 |
+
*
|
| 220 |
+
* @param mixed $store_cat_id
|
| 221 |
+
* @return mixed
|
| 222 |
+
*/
|
| 223 |
+
public function get_category_name($cat_ids)
|
| 224 |
+
{
|
| 225 |
+
$resource = Mage::getSingleton('core/resource');
|
| 226 |
+
$category = '';
|
| 227 |
+
|
| 228 |
+
foreach ($cat_ids as $cat_id) {
|
| 229 |
+
$sql = "SELECT value from " . $resource->getTableName('catalog_category_entity_varchar') . " as a
|
| 230 |
+
JOIN " . $resource->getTableName('eav_attribute') . " as b ON a.attribute_id = b.attribute_id
|
| 231 |
+
WHERE a.entity_id = :catId AND b.attribute_code = 'name'";
|
| 232 |
+
|
| 233 |
+
$binds = array(
|
| 234 |
+
'catId' => $cat_id
|
| 235 |
+
);
|
| 236 |
+
$cats = $resource->getConnection('core_read')->fetchAll($sql, $binds);
|
| 237 |
+
$category = $cats[0]['value'] . ',' . $category;
|
| 238 |
+
}
|
| 239 |
+
|
| 240 |
+
$category = substr_replace($category, "", -1);
|
| 241 |
+
return $category;
|
| 242 |
+
}
|
| 243 |
+
|
| 244 |
+
/**
|
| 245 |
+
* Check_Category_Exists_Id:
|
| 246 |
+
*
|
| 247 |
+
* @param mixed $store_cat_id
|
| 248 |
+
* @return mixed
|
| 249 |
+
*/
|
| 250 |
+
public function check_parent_cat($store_cat_id, $root_cat_id)
|
| 251 |
+
{
|
| 252 |
+
$resource = Mage::getSingleton('core/resource');
|
| 253 |
+
$sql = "SELECT path FROM " . $resource->getTableName('catalog_category_entity') . "
|
| 254 |
+
WHERE entity_id = :catId ";
|
| 255 |
+
$binds = array(
|
| 256 |
+
'catId' => $store_cat_id
|
| 257 |
+
);
|
| 258 |
+
$cats = $resource->getConnection('core_read')->fetchRow($sql, $binds);
|
| 259 |
+
|
| 260 |
+
$parent_cat = array();
|
| 261 |
+
if ($cats) {
|
| 262 |
+
$catIds = substr($cats['path'], 4);
|
| 263 |
+
$parent_cat = explode('/', $catIds);
|
| 264 |
+
return $parent_cat;
|
| 265 |
+
} else {
|
| 266 |
+
return false;
|
| 267 |
+
}
|
| 268 |
+
}
|
| 269 |
+
|
| 270 |
+
/**
|
| 271 |
+
* Get all categories by parent category
|
| 272 |
+
*
|
| 273 |
+
* @params category id and root category id
|
| 274 |
+
* @return category (array)
|
| 275 |
+
*/
|
| 276 |
+
public function check_parent_cat_new($store_cat_id, $root_cat_id)
|
| 277 |
+
{
|
| 278 |
+
$resource = Mage::getSingleton('core/resource');
|
| 279 |
+
|
| 280 |
+
$sql = "SELECT path FROM " . $resource->getConnection('core_read') . "
|
| 281 |
+
WHERE entity_id = :catId ";
|
| 282 |
+
$binds = array(
|
| 283 |
+
'catId' => $store_cat_id
|
| 284 |
+
);
|
| 285 |
+
$cats = $resource->getConnection('core_read')->fetchRow($sql, $binds);
|
| 286 |
+
|
| 287 |
+
$parent_cat = array();
|
| 288 |
+
if ($cats) {
|
| 289 |
+
$parent_cat = explode('/', $cats['path']);
|
| 290 |
+
$i = 0;
|
| 291 |
+
foreach ($parent_cat as $cats) {
|
| 292 |
+
if ($i > 1) {
|
| 293 |
+
$cat[] = $cats;
|
| 294 |
+
}
|
| 295 |
+
$i++;
|
| 296 |
+
}
|
| 297 |
+
return $cat;
|
| 298 |
+
} else {
|
| 299 |
+
return false;
|
| 300 |
+
}
|
| 301 |
+
}
|
| 302 |
+
|
| 303 |
+
/**
|
| 304 |
+
* Check_Category_Exists_Id:
|
| 305 |
+
*
|
| 306 |
+
* @param mixed $store_cat_id
|
| 307 |
+
* @return mixed
|
| 308 |
+
*/
|
| 309 |
+
public function check_category_exists_id($store_cat_id)
|
| 310 |
+
{
|
| 311 |
+
$resource = Mage::getSingleton('core/resource');
|
| 312 |
+
|
| 313 |
+
$sql = "SELECT * FROM " . $resource->getTableName('catalog_category_entity') . "
|
| 314 |
+
WHERE entity_id = :catId ";
|
| 315 |
+
$binds = array(
|
| 316 |
+
'catId' => $store_cat_id
|
| 317 |
+
);
|
| 318 |
+
$cats = $resource->getConnection('core_read')->fetchAll($sql, $binds);
|
| 319 |
+
if (!empty($cat)) {
|
| 320 |
+
return true;
|
| 321 |
+
} else {
|
| 322 |
+
return false;
|
| 323 |
+
}
|
| 324 |
+
}
|
| 325 |
+
}
|
| 326 |
+
?>
|
app/code/local/Saleswarp/Publish/Model/Config/Api.php
ADDED
|
@@ -0,0 +1,83 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* Use this API to get/set key config data for the storefronts
|
| 4 |
+
*/
|
| 5 |
+
class Saleswarp_Publish_Model_Config_Api extends Saleswarp_Oms_Model_Config_Api
|
| 6 |
+
{
|
| 7 |
+
public $activeStoreId = null;
|
| 8 |
+
|
| 9 |
+
/**
|
| 10 |
+
* get all attributes in form of saleswarp_xxx and xxx_saleswarp
|
| 11 |
+
*/
|
| 12 |
+
public function getSaleswarpAttributeIds()
|
| 13 |
+
{
|
| 14 |
+
$resource = Mage::getSingleton('core/resource');
|
| 15 |
+
$sql = "SELECT * from " . $resource->getTableName('eav_attribute') . " WHERE attribute_code = %saleswarp%";
|
| 16 |
+
$atts = $resource->getConnection('core_read')->fetchAll($sql);
|
| 17 |
+
return $atts;
|
| 18 |
+
}
|
| 19 |
+
|
| 20 |
+
/**
|
| 21 |
+
* get all product attributes
|
| 22 |
+
*/
|
| 23 |
+
public function getProductAttributesIds()
|
| 24 |
+
{
|
| 25 |
+
$eavAttrTable = Mage::getSingleton( 'core/resource' )->getTableName( 'eav_attribute' );
|
| 26 |
+
$entity_type_id = Mage::getModel('eav/entity')
|
| 27 |
+
->setType('catalog_product')
|
| 28 |
+
->getTypeId();
|
| 29 |
+
$sql = "SELECT * from ". $eavAttrTable ."
|
| 30 |
+
WHERE entity_type_id = '".(int)$entity_type_id."' ";
|
| 31 |
+
$atts = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 32 |
+
return $atts;
|
| 33 |
+
}
|
| 34 |
+
|
| 35 |
+
/**
|
| 36 |
+
* Get all category attibute id
|
| 37 |
+
*/
|
| 38 |
+
public function getCategoryAttributesIds()
|
| 39 |
+
{
|
| 40 |
+
$resource = Mage::getSingleton('core/resource');
|
| 41 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_category')->getTypeId();
|
| 42 |
+
$sql = "SELECT * from " . $resource->getTableName('eav_attribute') . "
|
| 43 |
+
WHERE entity_type_id = '" . (int) $entity_type_id . "'";
|
| 44 |
+
$atts = $resource->getConnection('core_read')->fetchAll($sql);
|
| 45 |
+
return $atts;
|
| 46 |
+
}
|
| 47 |
+
|
| 48 |
+
/**
|
| 49 |
+
* with Magento EAV architecture we need to retrieve key Attributes Key ID's before publishing any
|
| 50 |
+
* product or category info
|
| 51 |
+
*
|
| 52 |
+
*/
|
| 53 |
+
public function getAttributeIds()
|
| 54 |
+
{
|
| 55 |
+
$resource = Mage::getSingleton('core/resource');
|
| 56 |
+
$sql = "SELECT * from " . $resource->getTableName('eav_entity_type') . " WHERE 1";
|
| 57 |
+
$entities = $resource->getConnection('core_read')->fetchAll($sql);
|
| 58 |
+
return $entities;
|
| 59 |
+
}
|
| 60 |
+
|
| 61 |
+
/**
|
| 62 |
+
* Function Not in use
|
| 63 |
+
*/
|
| 64 |
+
public function getStoreInfo($storeId = null)
|
| 65 |
+
{
|
| 66 |
+
if ($storeId == null) {
|
| 67 |
+
if ($this->activeStoreId != null) {
|
| 68 |
+
$storeId = $this->activeStoreId;
|
| 69 |
+
} else {
|
| 70 |
+
return false;
|
| 71 |
+
}
|
| 72 |
+
}
|
| 73 |
+
}
|
| 74 |
+
|
| 75 |
+
/**
|
| 76 |
+
* get Store configs
|
| 77 |
+
*/
|
| 78 |
+
public function getSetupConfigs()
|
| 79 |
+
{
|
| 80 |
+
return Mage::getSingleton('core/resource')->getConnection('core_read')->getConfig();
|
| 81 |
+
}
|
| 82 |
+
}
|
| 83 |
+
?>
|
app/code/local/Saleswarp/Publish/Model/Customer/Api.php
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* Use this API to get/set key config data for the storefronts
|
| 4 |
+
*/
|
| 5 |
+
class Saleswarp_Publish_Model_Customer_Api extends Saleswarp_Oms_Model_Customer_Api
|
| 6 |
+
{
|
| 7 |
+
|
| 8 |
+
public $activeStoreId = null;
|
| 9 |
+
|
| 10 |
+
/**
|
| 11 |
+
* Test function
|
| 12 |
+
*/
|
| 13 |
+
public function customer_api_test()
|
| 14 |
+
{
|
| 15 |
+
return "called Saleswarp_Publish_Model_Customer_Api, method->customer_api_test";
|
| 16 |
+
}
|
| 17 |
+
|
| 18 |
+
/**
|
| 19 |
+
* Get Items
|
| 20 |
+
*/
|
| 21 |
+
public function items()
|
| 22 |
+
{
|
| 23 |
+
return parent::items();
|
| 24 |
+
}
|
| 25 |
+
}
|
| 26 |
+
?>
|
app/code/local/Saleswarp/Publish/Model/Product/Api.php
ADDED
|
@@ -0,0 +1,2191 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
/**
|
| 3 |
+
* @copyright 2011 6th Street Inc, all rights reserved
|
| 4 |
+
* @author David Potts
|
| 5 |
+
* @version 1.0
|
| 6 |
+
* @package SalesWarp
|
| 7 |
+
* @subpackage Product_API
|
| 8 |
+
*
|
| 9 |
+
* @license commercial, unauthorized copies are prohibited
|
| 10 |
+
*
|
| 11 |
+
*
|
| 12 |
+
* Attributes needed in Magento
|
| 13 |
+
*
|
| 14 |
+
* warehouse_id: warehouse_prod_id
|
| 15 |
+
* warehouse_prod_add_date: w_prod_add_date
|
| 16 |
+
* warehouse_prod_code: warehouse_prod_code
|
| 17 |
+
* warehouse_prod_sync_date: w_prod_sync_date
|
| 18 |
+
*
|
| 19 |
+
* supplier_id: supplier_id
|
| 20 |
+
* supplier_name: Seller
|
| 21 |
+
*
|
| 22 |
+
* last_inventory_update: last_inventory_update
|
| 23 |
+
* last_price_update: last_price_update
|
| 24 |
+
* last_update: last_update
|
| 25 |
+
*
|
| 26 |
+
* CREATE WAREHOUSE ATTRIBUTE SET.
|
| 27 |
+
*
|
| 28 |
+
* @todo - set enable_logs and log_filename as API config in system.xml
|
| 29 |
+
*
|
| 30 |
+
*
|
| 31 |
+
*/
|
| 32 |
+
|
| 33 |
+
class Saleswarp_Publish_Model_Product_Api extends Saleswarp_Oms_Model_Product_Api
|
| 34 |
+
{
|
| 35 |
+
var $enable_logs = true;
|
| 36 |
+
var $log_level = 2;
|
| 37 |
+
var $log_filename = 'saleswarp_product_api.log';
|
| 38 |
+
var $truncate_test = array('catalog_product_entity');
|
| 39 |
+
var $product_tables = array(
|
| 40 |
+
'catalogindex_eav' => 'entity_id',
|
| 41 |
+
'cataloginventory_stock_item' => 'product_id',
|
| 42 |
+
'cataloginventory_stock_status' => 'product_id',
|
| 43 |
+
'cataloginventory_stock_status_idx' => 'product_id',
|
| 44 |
+
'catalogrule_product' => 'product_id',
|
| 45 |
+
'catalogrule_product_price' => 'product_id',
|
| 46 |
+
'catalogsearch_fulltext' => 'product_id',
|
| 47 |
+
'catalogsearch_result' => 'product_id',
|
| 48 |
+
'catalog_product_enabled_index' => 'product_id',
|
| 49 |
+
'catalog_product_entity' => 'entity_id',
|
| 50 |
+
'catalog_product_entity_datetime' => 'entity_id',
|
| 51 |
+
'catalog_product_entity_decimal' => 'entity_id',
|
| 52 |
+
'catalog_product_entity_gallery' => 'entity_id',
|
| 53 |
+
'catalog_product_entity_int' => 'entity_id',
|
| 54 |
+
'catalog_product_entity_media_gallery' => 'entity_id',
|
| 55 |
+
'catalog_product_entity_text' => 'entity_id',
|
| 56 |
+
'catalog_product_entity_tier_price' => 'entity_id',
|
| 57 |
+
'catalog_product_entity_varchar' => 'entity_id',
|
| 58 |
+
'catalog_product_index_eav' => 'entity_id',
|
| 59 |
+
'catalog_product_index_eav_decimal' => 'entity_id',
|
| 60 |
+
'catalog_product_index_eav_decimal_idx' => 'entity_id',
|
| 61 |
+
'catalog_product_index_eav_idx' => 'entity_id',
|
| 62 |
+
'catalog_product_index_price' => 'entity_id',
|
| 63 |
+
'catalog_product_index_price_bundle_idx' => 'entity_id',
|
| 64 |
+
'catalog_product_index_price_bundle_opt_idx' => 'entity_id',
|
| 65 |
+
'catalog_product_index_price_bundle_sel_idx' => 'entity_id',
|
| 66 |
+
'catalog_product_index_price_cfg_opt_agr_idx' => 'parent_id',
|
| 67 |
+
'catalog_product_index_price_cfg_opt_idx' => 'entity_id',
|
| 68 |
+
'catalog_product_index_price_downlod_idx' => 'entity_id',
|
| 69 |
+
'catalog_product_index_price_final_idx' => 'entity_id',
|
| 70 |
+
'catalog_product_index_price_idx' => 'entity_id',
|
| 71 |
+
'catalog_product_index_price_opt_agr_idx' => 'entity_id',
|
| 72 |
+
'catalog_product_index_price_opt_idx' => 'entity_id',
|
| 73 |
+
'catalog_product_index_tier_price' => 'entity_id',
|
| 74 |
+
'catalog_product_relation' => 'child_id',
|
| 75 |
+
'catalog_product_website' => 'product_id',
|
| 76 |
+
'catalog_category_product' => 'product_id',
|
| 77 |
+
'catalog_category_product_index' => 'product_id',
|
| 78 |
+
'catalog_compare_item' => 'product_id'
|
| 79 |
+
);
|
| 80 |
+
|
| 81 |
+
var $product_required_storeIds = array(
|
| 82 |
+
'catalog_product_entity_datetime' => '0',
|
| 83 |
+
'catalog_product_entity_decimal' => '0',
|
| 84 |
+
'catalog_product_entity_int' => '0',
|
| 85 |
+
'catalog_product_entity_text' => '0',
|
| 86 |
+
'catalog_product_entity_varchar' => '0',
|
| 87 |
+
);
|
| 88 |
+
|
| 89 |
+
var $product_required_websiteIds = array(
|
| 90 |
+
'catalog_product_entity_tier_price' => '1',
|
| 91 |
+
'catalog_product_index_price' => '1',
|
| 92 |
+
'catalog_product_index_price_bundle_idx' => '1',
|
| 93 |
+
'catalog_product_index_price_bundle_opt_idx' => '1',
|
| 94 |
+
'catalog_product_index_price_bundle_sel_idx' => '1',
|
| 95 |
+
'catalog_product_index_price_cfg_opt_idx' => '1',
|
| 96 |
+
'catalog_product_index_price_downlod_idx' => '1',
|
| 97 |
+
'catalog_product_index_price_final_idx' => '1',
|
| 98 |
+
'catalog_product_index_price_idx' => '1',
|
| 99 |
+
'catalog_product_index_price_opt_agr_idx' => '1',
|
| 100 |
+
'catalog_product_index_price_opt_idx' => '1',
|
| 101 |
+
'catalog_product_index_tier_price' => '1',
|
| 102 |
+
'catalog_product_website' => '1',
|
| 103 |
+
'cataloginventory_stock_status' => '1',
|
| 104 |
+
'cataloginventory_stock_status_idx' => '1'
|
| 105 |
+
);
|
| 106 |
+
|
| 107 |
+
/**
|
| 108 |
+
* Get Attribute Id By name
|
| 109 |
+
*
|
| 110 |
+
*/
|
| 111 |
+
public function get_attr_id_by_name($attributeSetName = 'Default')
|
| 112 |
+
{
|
| 113 |
+
$entityTypeId = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 114 |
+
//$attributeSetName = 'Default';
|
| 115 |
+
$attributeSetId = Mage::getModel('eav/entity_attribute_set')->getCollection()->setEntityTypeFilter($entityTypeId)->addFieldToFilter('attribute_set_name', $attributeSetName)->getFirstItem()->getAttributeSetId();
|
| 116 |
+
if ($attributeSetId) {
|
| 117 |
+
return $attributeSetId;
|
| 118 |
+
} else {
|
| 119 |
+
return false;
|
| 120 |
+
}
|
| 121 |
+
}
|
| 122 |
+
|
| 123 |
+
/**
|
| 124 |
+
* Update Product
|
| 125 |
+
* @param product data array
|
| 126 |
+
*/
|
| 127 |
+
function product_slwp_update($data)
|
| 128 |
+
{
|
| 129 |
+
if (empty($data)) {
|
| 130 |
+
return 'no data';
|
| 131 |
+
}
|
| 132 |
+
$code = 'saleswarp_prod_id';
|
| 133 |
+
foreach ($data as $prod) {
|
| 134 |
+
$prod = $prod['BaseProductsBaseStore'];
|
| 135 |
+
if ($this->check_prod_exists($prod['merchant_sku'])) {
|
| 136 |
+
$this->rest_save_attribute($prod['merchant_sku'], $code, $prod['base_product_id'], 1);
|
| 137 |
+
}
|
| 138 |
+
}
|
| 139 |
+
return "success";
|
| 140 |
+
}
|
| 141 |
+
|
| 142 |
+
|
| 143 |
+
/**
|
| 144 |
+
* Read and populate product entity
|
| 145 |
+
*/
|
| 146 |
+
function product_list($type = 'simple', $offset = 0, $limit = 50000)
|
| 147 |
+
{
|
| 148 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 149 |
+
$sql = "select entity_id,sku,attribute_set_id from " . $productTable . "
|
| 150 |
+
where type_id = '" . $type . "'
|
| 151 |
+
order by entity_id asc limit $offset,$limit";
|
| 152 |
+
$data = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 153 |
+
return $data;
|
| 154 |
+
}
|
| 155 |
+
|
| 156 |
+
|
| 157 |
+
|
| 158 |
+
/**
|
| 159 |
+
* Check if Configurable Product Exists
|
| 160 |
+
*
|
| 161 |
+
**/
|
| 162 |
+
function check_configurable_option_exists($attribute_code, $saleswp_option)
|
| 163 |
+
{
|
| 164 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 165 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 166 |
+
|
| 167 |
+
$eavAttrOptValTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option_value');
|
| 168 |
+
$eavAttrOptTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option');
|
| 169 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 170 |
+
|
| 171 |
+
$sql_option = "SELECT b.option_id FROM " . $eavAttrOptValTable . " as a
|
| 172 |
+
JOIN " . $eavAttrOptTable . " as b ON a.option_id = b.option_id
|
| 173 |
+
JOIN " . $eavAttrTable . " as c ON b.attribute_id = c.attribute_id
|
| 174 |
+
WHERE a.value = :saleswp_option AND c.attribute_code = :attribute_code ";
|
| 175 |
+
$binds = array(
|
| 176 |
+
'saleswp_option' => $saleswp_option,
|
| 177 |
+
'attribute_code' => $attribute_code
|
| 178 |
+
);
|
| 179 |
+
|
| 180 |
+
$connection = $read->fetchAll($sql_option, $binds);
|
| 181 |
+
|
| 182 |
+
if (!empty($connection)) {
|
| 183 |
+
$value = $connection[0]['option_id'];
|
| 184 |
+
} else {
|
| 185 |
+
$attr_model = Mage::getModel('catalog/resource_eav_attribute');
|
| 186 |
+
$attr = $attr_model->loadByCode('catalog_product', $attribute_code);
|
| 187 |
+
|
| 188 |
+
$attr_id = $attr->getAttributeId();
|
| 189 |
+
|
| 190 |
+
$option = array();
|
| 191 |
+
|
| 192 |
+
$sql = 'INSERT INTO ' . $eavAttrOptTable . '(attribute_id, sort_order) VALUES (' . (int) $attr_id . ',0)';
|
| 193 |
+
$write->query($sql);
|
| 194 |
+
|
| 195 |
+
$lastInsertId = $write->lastInsertId();
|
| 196 |
+
|
| 197 |
+
$sql2 = "INSERT INTO " . $eavAttrOptValTable . "(option_id, store_id , value) VALUES (:lastInsertId, 0, :saleswp_option)";
|
| 198 |
+
$binds2 = array(
|
| 199 |
+
'lastInsertId' => $lastInsertId,
|
| 200 |
+
'saleswp_option' => $saleswp_option
|
| 201 |
+
);
|
| 202 |
+
$attr_value_insertion = $write->query($sql2, $binds2);
|
| 203 |
+
|
| 204 |
+
$value = $lastInsertId;
|
| 205 |
+
}
|
| 206 |
+
|
| 207 |
+
return $value;
|
| 208 |
+
}
|
| 209 |
+
|
| 210 |
+
/**
|
| 211 |
+
* Create Product Option in MAGENTO
|
| 212 |
+
*/
|
| 213 |
+
function add_product_option($product_id, $attribute_code, $value)
|
| 214 |
+
{
|
| 215 |
+
$product = Mage::getModel("catalog/product")->load($product_id);
|
| 216 |
+
$product->setData($attribute_code, $value);
|
| 217 |
+
if($product->save()) {
|
| 218 |
+
return true;
|
| 219 |
+
} else {
|
| 220 |
+
return false;
|
| 221 |
+
}
|
| 222 |
+
}
|
| 223 |
+
|
| 224 |
+
/**
|
| 225 |
+
* Create Configurable Attributes in magento
|
| 226 |
+
*/
|
| 227 |
+
function create_configurable_attribute($code, $label, $attribute_type, $product_type)
|
| 228 |
+
{
|
| 229 |
+
$_attribute_data = array(
|
| 230 |
+
'attribute_code' => $code,
|
| 231 |
+
'is_global' => '1',
|
| 232 |
+
'frontend_input' => $attribute_type, //'boolean',
|
| 233 |
+
'default_value_text' => '',
|
| 234 |
+
'default_value_yesno' => '0',
|
| 235 |
+
'default_value_date' => '',
|
| 236 |
+
'default_value_textarea' => '',
|
| 237 |
+
'is_unique' => '1',
|
| 238 |
+
'is_required' => '0',
|
| 239 |
+
'apply_to' => $product_type, //array('grouped')
|
| 240 |
+
'is_configurable' => '1',
|
| 241 |
+
'is_searchable' => '1',
|
| 242 |
+
'is_filterable' => '1',
|
| 243 |
+
'is_visible_in_advanced_search' => '0',
|
| 244 |
+
'is_comparable' => '0',
|
| 245 |
+
'is_used_for_price_rules' => '0',
|
| 246 |
+
'is_wysiwyg_enabled' => '0',
|
| 247 |
+
'is_html_allowed_on_front' => '1',
|
| 248 |
+
'is_visible_on_front' => '0',
|
| 249 |
+
'used_in_product_listing' => '0',
|
| 250 |
+
'used_for_sort_by' => '0',
|
| 251 |
+
'frontend_label' => array(
|
| 252 |
+
$label
|
| 253 |
+
)
|
| 254 |
+
);
|
| 255 |
+
|
| 256 |
+
$model = Mage::getModel('catalog/resource_eav_attribute');
|
| 257 |
+
|
| 258 |
+
|
| 259 |
+
if (is_null($model->getIsUserDefined()) || $model->getIsUserDefined() != 0) {
|
| 260 |
+
$_attribute_data['backend_type'] = $model->getBackendTypeByInput($_attribute_data['frontend_input']);
|
| 261 |
+
}
|
| 262 |
+
|
| 263 |
+
$defaultValueField = $model->getDefaultValueByInput($_attribute_data['frontend_input']);
|
| 264 |
+
|
| 265 |
+
if ($defaultValueField) {
|
| 266 |
+
$_attribute_data['default_value'] = $this->getRequest()->getParam($defaultValueField);
|
| 267 |
+
}
|
| 268 |
+
|
| 269 |
+
$model->addData($_attribute_data);
|
| 270 |
+
$model->setEntityTypeId(Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId());
|
| 271 |
+
$model->setIsUserDefined(1);
|
| 272 |
+
|
| 273 |
+
try {
|
| 274 |
+
$model->save();
|
| 275 |
+
return true;
|
| 276 |
+
}
|
| 277 |
+
catch (Exception $e) {
|
| 278 |
+
$msg = "error : " . $e->getMessage();
|
| 279 |
+
Mage::log($msg, null, "product_api.log", true);
|
| 280 |
+
$this->_fault($msg, $e->getMessage());
|
| 281 |
+
return false;
|
| 282 |
+
}
|
| 283 |
+
}
|
| 284 |
+
|
| 285 |
+
/**
|
| 286 |
+
* Create Configure Product
|
| 287 |
+
*/
|
| 288 |
+
function create_product_configurable($configurable_product_id, $configurable_child_id)
|
| 289 |
+
{
|
| 290 |
+
$msg = "Parent conf Id:" . $configurable_product_id;
|
| 291 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 292 |
+
$config_product = Mage::getModel('catalog/product')->load($configurable_product_id);
|
| 293 |
+
$new_ids = array();
|
| 294 |
+
$used_products = $config_product->getTypeInstance()->getUsedProductIds();
|
| 295 |
+
|
| 296 |
+
foreach ($used_products as $used_product) {
|
| 297 |
+
$current_ids[] = $used_product;
|
| 298 |
+
}
|
| 299 |
+
|
| 300 |
+
$current_ids[] = $configurable_child_id;
|
| 301 |
+
$current_ids = array_unique($current_ids);
|
| 302 |
+
|
| 303 |
+
foreach ($current_ids as $temp_id) {
|
| 304 |
+
parse_str("position=", $new_ids[$temp_id]);
|
| 305 |
+
}
|
| 306 |
+
$config_product->setConfigurableProductsData($new_ids)->save();
|
| 307 |
+
}
|
| 308 |
+
|
| 309 |
+
/**
|
| 310 |
+
* Create Configure Product super attributes
|
| 311 |
+
*
|
| 312 |
+
* @params $data array super attribute data array
|
| 313 |
+
*
|
| 314 |
+
* Note :: This is not the magento recomended way, as there are alot of API calls eecuted in order to save the
|
| 315 |
+
* single configurable product. Therefore writing the custom query in order to achieve the expected functionality.
|
| 316 |
+
*/
|
| 317 |
+
public function create_configurable_product_super_attribute($data) {
|
| 318 |
+
$return = [];
|
| 319 |
+
|
| 320 |
+
foreach($data as $sku => $super_attributes) {
|
| 321 |
+
$product_id = Mage::getModel('catalog/product')->getIdBySku($sku);
|
| 322 |
+
if($product_id) {
|
| 323 |
+
$return[$product_id] = [];
|
| 324 |
+
foreach($super_attributes as $code => $pricing) {
|
| 325 |
+
$attribute = Mage::getModel('eav/entity_attribute')->loadByCode('catalog_product', $code);
|
| 326 |
+
$attribute_id = $attribute->getId();
|
| 327 |
+
|
| 328 |
+
if($attribute_id) {
|
| 329 |
+
$return[$product_id][$code]['attribute_id'] = $attribute_id;
|
| 330 |
+
$values = Mage::getResourceModel('eav/entity_attribute_option_collection')
|
| 331 |
+
->setStoreFilter($storeId)
|
| 332 |
+
->setAttributeFilter($attribute_id)
|
| 333 |
+
->toOptionArray();
|
| 334 |
+
|
| 335 |
+
$pricing = array_change_key_case($pricing);
|
| 336 |
+
|
| 337 |
+
foreach($values as $value) {
|
| 338 |
+
if(isset($pricing[strtolower($value['label'])])) {
|
| 339 |
+
$return[$product_id][$code]['pricing'][$value['value']] = $pricing[strtolower($value['label'])];
|
| 340 |
+
}
|
| 341 |
+
}
|
| 342 |
+
}
|
| 343 |
+
}
|
| 344 |
+
} else {
|
| 345 |
+
$return[$sku] = 'Product not found';
|
| 346 |
+
}
|
| 347 |
+
}
|
| 348 |
+
|
| 349 |
+
foreach($return as $product_id => $attributes) {
|
| 350 |
+
foreach($attributes as $code => $attribute) {
|
| 351 |
+
$attribute_id = $attribute['attribute_id'];
|
| 352 |
+
$product_super_attribute_id = $this->getProductSuperAttributeId($product_id, $attribute_id);
|
| 353 |
+
|
| 354 |
+
$value_id = $this->createCatalogProductSuperAttributeLabel($product_super_attribute_id, $code);
|
| 355 |
+
|
| 356 |
+
foreach($attribute['pricing'] as $value_index => $pricing_value) {
|
| 357 |
+
$this->createCatalogProductSuperAttributePricing($product_super_attribute_id, $value_index, $pricing_value);
|
| 358 |
+
}
|
| 359 |
+
}
|
| 360 |
+
}
|
| 361 |
+
return $return;
|
| 362 |
+
}
|
| 363 |
+
|
| 364 |
+
|
| 365 |
+
/**
|
| 366 |
+
* Inserting the pricing values corresponding to the configurable attributes
|
| 367 |
+
*
|
| 368 |
+
* @params $product_super_attribute_id int magento configurable product super attribute id
|
| 369 |
+
* @params $value_index int magento product attribute option id
|
| 370 |
+
* @params $pricing_value int magento configurable product price value
|
| 371 |
+
*
|
| 372 |
+
* Note :: This is not the magento recomended way, as there are alot of API calls eecuted in order to save the
|
| 373 |
+
* single configurable product. Therefore writing the custom query in order to achieve the expected functionality.
|
| 374 |
+
*/
|
| 375 |
+
private function createCatalogProductSuperAttributePricing($product_super_attribute_id, $value_index, $pricing_value) {
|
| 376 |
+
$resource = Mage::getSingleton('core/resource');
|
| 377 |
+
$dbSource = $resource->getConnection('core_write');
|
| 378 |
+
|
| 379 |
+
$catalog_product_super_attribute_pricing = $resource->getTableName('catalog_product_super_attribute_pricing');
|
| 380 |
+
|
| 381 |
+
$sql = "SELECT * FROM `" . $catalog_product_super_attribute_pricing . "`
|
| 382 |
+
WHERE `product_super_attribute_id` = '" . $product_super_attribute_id . "'
|
| 383 |
+
and value_index = '" . $value_index . "' ";
|
| 384 |
+
$value_id = $dbSource->fetchOne($sql);
|
| 385 |
+
|
| 386 |
+
if($value_id) {
|
| 387 |
+
$sql = "update " . $catalog_product_super_attribute_pricing . "
|
| 388 |
+
set pricing_value = '".$pricing_value."'
|
| 389 |
+
WHERE `product_super_attribute_id` = '" . $product_super_attribute_id . "'
|
| 390 |
+
and value_index = '" . $value_index . "' ";
|
| 391 |
+
$dbSource->query($sql);
|
| 392 |
+
} else {
|
| 393 |
+
$sql = "Insert into " . $catalog_product_super_attribute_pricing . "(product_super_attribute_id, value_index, is_percent, pricing_value, website_id)
|
| 394 |
+
values('".$product_super_attribute_id."', '".$value_index."', '0', '".$pricing_value."', '0')";
|
| 395 |
+
$dbSource->query($sql);
|
| 396 |
+
}
|
| 397 |
+
}
|
| 398 |
+
|
| 399 |
+
/**
|
| 400 |
+
* Get the configurable product supper attribute id
|
| 401 |
+
*
|
| 402 |
+
* @params $product_id int magento product id
|
| 403 |
+
* @params $attribute_id int magento product attribute id
|
| 404 |
+
*
|
| 405 |
+
* Note :: This is not the magento recomended way, as there are alot of API calls eecuted in order to save the
|
| 406 |
+
* single configurable product. Therefore writing the custom query in order to achieve the expected functionality.
|
| 407 |
+
*/
|
| 408 |
+
private function getProductSuperAttributeId($product_id, $attribute_id) {
|
| 409 |
+
$resource = Mage::getSingleton('core/resource');
|
| 410 |
+
$dbSource = $resource->getConnection('core_write');
|
| 411 |
+
|
| 412 |
+
$catalog_product_super_attribute = $resource->getTableName('catalog_product_super_attribute');
|
| 413 |
+
|
| 414 |
+
$sql = "SELECT * FROM `" . $catalog_product_super_attribute . "`
|
| 415 |
+
WHERE `product_id` = '" . $product_id . "'
|
| 416 |
+
and attribute_id = '" . $attribute_id . "' ";
|
| 417 |
+
$product_super_attribute_id = $dbSource->fetchOne($sql);
|
| 418 |
+
if($product_super_attribute_id) {
|
| 419 |
+
return $product_super_attribute_id;
|
| 420 |
+
} else {
|
| 421 |
+
$sql = "Insert into " . $catalog_product_super_attribute . "(product_id, attribute_id, position) values('".$product_id."', '".$attribute_id."', '0')";
|
| 422 |
+
$dbSource->query($sql);
|
| 423 |
+
|
| 424 |
+
$sql = "SELECT * FROM `" . $catalog_product_super_attribute . "`
|
| 425 |
+
WHERE `product_id` = '" . $product_id . "'
|
| 426 |
+
and attribute_id = '" . $attribute_id . "' ";
|
| 427 |
+
return $dbSource->fetchOne($sql);
|
| 428 |
+
}
|
| 429 |
+
}
|
| 430 |
+
|
| 431 |
+
/**
|
| 432 |
+
* Generating configurable product supper attribute label
|
| 433 |
+
*
|
| 434 |
+
* @params $product_super_attribute_id int magento configurable product super atribute id
|
| 435 |
+
* @params $value string attribute label
|
| 436 |
+
*
|
| 437 |
+
* Note :: This is not the magento recomended way, as there are alot of API calls eecuted in order to save the
|
| 438 |
+
* single configurable product. Therefore writing the custom query in order to achieve the expected functionality.
|
| 439 |
+
*/
|
| 440 |
+
private function createCatalogProductSuperAttributeLabel($product_super_attribute_id, $value) {
|
| 441 |
+
$resource = Mage::getSingleton('core/resource');
|
| 442 |
+
$dbSource = $resource->getConnection('core_write');
|
| 443 |
+
|
| 444 |
+
$catalog_product_super_attribute_label = $resource->getTableName('catalog_product_super_attribute_label');
|
| 445 |
+
|
| 446 |
+
$sql = "SELECT * FROM `" . $catalog_product_super_attribute_label . "`
|
| 447 |
+
WHERE `product_super_attribute_id` = '" . $product_super_attribute_id . "'
|
| 448 |
+
and value = '" . $value . "' ";
|
| 449 |
+
$value_id = $dbSource->fetchOne($sql);
|
| 450 |
+
if($value_id) {
|
| 451 |
+
return $value_id;
|
| 452 |
+
} else {
|
| 453 |
+
$sql = "Insert into " . $catalog_product_super_attribute_label . "(product_super_attribute_id, store_id, value) values('".$product_super_attribute_id."', '0', '".$value."')";
|
| 454 |
+
$dbSource->query($sql);
|
| 455 |
+
}
|
| 456 |
+
}
|
| 457 |
+
|
| 458 |
+
/**
|
| 459 |
+
* Check Attribute Exists
|
| 460 |
+
*/
|
| 461 |
+
function check_attribute_exists($attr_code)
|
| 462 |
+
{
|
| 463 |
+
$attribute = Mage::getSingleton('eav/config')->getAttribute('catalog_product', $attr_code);
|
| 464 |
+
|
| 465 |
+
if ($attribute) {
|
| 466 |
+
return $attribute->getData('attribute_id');
|
| 467 |
+
} else {
|
| 468 |
+
return false;
|
| 469 |
+
}
|
| 470 |
+
}
|
| 471 |
+
|
| 472 |
+
/**
|
| 473 |
+
* a comprehensive delete function for products, checks all related tables for hanging entity_ids and
|
| 474 |
+
* does full clean
|
| 475 |
+
*
|
| 476 |
+
* relies on array of tables & corresponding product key; usually product_id or entity_id. affected
|
| 477 |
+
* tables varies by both Magento release and customizations to the store, ie. if a table is added
|
| 478 |
+
* by any extensions, it can be cleaned up easily through delete_full
|
| 479 |
+
*
|
| 480 |
+
* @param mixed $productId
|
| 481 |
+
* @param mixed $identifierType
|
| 482 |
+
**/
|
| 483 |
+
public function delete_full($productId, $identifierType = null)
|
| 484 |
+
// load array of tables & fields to check for matching data
|
| 485 |
+
{
|
| 486 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 487 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 488 |
+
$cnt = 0;
|
| 489 |
+
foreach ($this->product_tables as $table => $field) {
|
| 490 |
+
$table = Mage::getSingleton('core/resource')->getTableName($table);
|
| 491 |
+
$sql = "DELETE FROM " . $table . " WHERE " . $field . " = '" . (int) $productId . "'";
|
| 492 |
+
$msg = "Calling delete_full: sql = " . $sql;
|
| 493 |
+
Mage::log($msg, null, "product_api.log");
|
| 494 |
+
try {
|
| 495 |
+
$result = $write->query($sql);
|
| 496 |
+
$cnt++;
|
| 497 |
+
}
|
| 498 |
+
catch (Mage_Core_Exception $e) {
|
| 499 |
+
$msg = "error : " . $e->getMessage();
|
| 500 |
+
Mage::log($msg, null, "product_api.log", true);
|
| 501 |
+
$msg = 'inside delete full, not_deleted on table: ' . $table . ', product_id: ' . $productId;
|
| 502 |
+
$this->_fault($msg, $e->getMessage());
|
| 503 |
+
Mage::log($msg, null, "product_api.log", true);
|
| 504 |
+
}
|
| 505 |
+
}
|
| 506 |
+
return $cnt;
|
| 507 |
+
}
|
| 508 |
+
|
| 509 |
+
/**
|
| 510 |
+
* Add new attribute to a set
|
| 511 |
+
*/
|
| 512 |
+
function add_configurable_attribute_to_default($attribute_set_name, $group_name, $attribute_code)
|
| 513 |
+
{
|
| 514 |
+
$setup = new Mage_Eav_Model_Entity_Setup('core_setup');
|
| 515 |
+
|
| 516 |
+
//-------------- add attribute to set and group
|
| 517 |
+
$attribute_set_id = $setup->getAttributeSetId('catalog_product', $attribute_set_name);
|
| 518 |
+
$attribute_group_id = $setup->getAttributeGroupId('catalog_product', $attribute_set_id, $group_name);
|
| 519 |
+
$attribute_id = $setup->getAttributeId('catalog_product', $attribute_code);
|
| 520 |
+
$setup->addAttributeToSet('catalog_product', $attribute_set_id, $attribute_group_id, $attribute_id);
|
| 521 |
+
}
|
| 522 |
+
|
| 523 |
+
/**
|
| 524 |
+
* To check configured product exists or not
|
| 525 |
+
*/
|
| 526 |
+
public function check_configured_exists($attr_id, $base_product_id)
|
| 527 |
+
{
|
| 528 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 529 |
+
$sql = "select m.entity_id,m.type_id from " . $productTable . " m
|
| 530 |
+
left join catalog_product_entity_int mi ON m.entity_id = mi.entity_id
|
| 531 |
+
where mi.attribute_id = '" . (int) $attr_id . "'
|
| 532 |
+
and mi.value = '" . (int) $base_product_id . "'";
|
| 533 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 534 |
+
|
| 535 |
+
if (!empty($prod)) {
|
| 536 |
+
$pid = $prod['entity_id'];
|
| 537 |
+
unset($prod);
|
| 538 |
+
return $pid;
|
| 539 |
+
} else {
|
| 540 |
+
return false;
|
| 541 |
+
}
|
| 542 |
+
}
|
| 543 |
+
|
| 544 |
+
/**
|
| 545 |
+
* public function to check configured product exists or not
|
| 546 |
+
*/
|
| 547 |
+
public function check_configured_exists_by_group_string($attr_id, $groupString)
|
| 548 |
+
{
|
| 549 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 550 |
+
$sql = "SELECT m.entity_id,m.type_id FROM " . $productTable . " m
|
| 551 |
+
LEFT JOIN catalog_product_entity_text mi ON m.entity_id = mi.entity_id
|
| 552 |
+
WHERE mi.attribute_id = :attr_id AND mi.value = :groupString ";
|
| 553 |
+
$binds = array(
|
| 554 |
+
'attr_id' => $attr_id,
|
| 555 |
+
'groupString' => $groupString
|
| 556 |
+
);
|
| 557 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql, $binds);
|
| 558 |
+
|
| 559 |
+
if (!empty($prod)) {
|
| 560 |
+
$pid = $prod['entity_id'];
|
| 561 |
+
unset($prod);
|
| 562 |
+
return $pid;
|
| 563 |
+
} else {
|
| 564 |
+
return false;
|
| 565 |
+
}
|
| 566 |
+
}
|
| 567 |
+
|
| 568 |
+
/**
|
| 569 |
+
* update update_category_product table with this product_id and category_id
|
| 570 |
+
*
|
| 571 |
+
* @param mixed $entity_id
|
| 572 |
+
* @param int|array $cat_ids
|
| 573 |
+
*/
|
| 574 |
+
public function update_category_product($entity_id, $cat_ids)
|
| 575 |
+
{
|
| 576 |
+
// Ensure $cat_ids is an array because we may receive an array
|
| 577 |
+
// No matter what, we're only dealing with the primary category here, and assuming its index is 0
|
| 578 |
+
if (!is_array($cat_ids)) {
|
| 579 |
+
$cat_ids = array($cat_ids);
|
| 580 |
+
}
|
| 581 |
+
|
| 582 |
+
$categoryProdTable = Mage::getSingleton('core/resource')->getTableName('catalog_category_product');
|
| 583 |
+
foreach ($cat_ids as $cat_id) {
|
| 584 |
+
$sql = sprintf("select * from " . $categoryProdTable . " WHERE product_id = '%d' AND category_id = '%d';", $entity_id, $cat_id);
|
| 585 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 586 |
+
if (!empty($prod)) {
|
| 587 |
+
return true;
|
| 588 |
+
} else {
|
| 589 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 590 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 591 |
+
$sql = sprintf("INSERT INTO `" . $categoryProdTable . "` (product_id, category_id, position) VALUES ('%d', '%d', 0);", $entity_id, $cat_id);
|
| 592 |
+
$result = $write->query($sql);
|
| 593 |
+
}
|
| 594 |
+
}
|
| 595 |
+
return true;
|
| 596 |
+
}
|
| 597 |
+
|
| 598 |
+
/**
|
| 599 |
+
* update the catalog_category_product_index tables for this product and category
|
| 600 |
+
*
|
| 601 |
+
* @param mixed $prod_id
|
| 602 |
+
* @param int|array $cat_ids
|
| 603 |
+
* @param mixed $store_id
|
| 604 |
+
*/
|
| 605 |
+
public function update_cat_prod_indx($prod_id, $cat_ids, $store_id = 1)
|
| 606 |
+
{
|
| 607 |
+
// $cat_ids will be assumed to be an array
|
| 608 |
+
if (!is_array($cat_ids)) {
|
| 609 |
+
$cat_ids = array($cat_ids);
|
| 610 |
+
}
|
| 611 |
+
|
| 612 |
+
$categoryTable = Mage::getSingleton('core/resource')->getTableName('catalog_category_entity');
|
| 613 |
+
$categoryIndxTable = Mage::getSingleton('core/resource')->getTableName('catalog_category_product_index');
|
| 614 |
+
$sql = sprintf("select * from " . $categoryTable . " WHERE entity_id ='%d' LIMIT 1", $cat_ids[0]);
|
| 615 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 616 |
+
|
| 617 |
+
if (empty($prod)) {
|
| 618 |
+
echo "ERROR Category-Entity NOT found. \n";
|
| 619 |
+
return false;
|
| 620 |
+
}
|
| 621 |
+
|
| 622 |
+
$path1 = explode('/', $prod[0]['path']);
|
| 623 |
+
|
| 624 |
+
foreach ($path1 as $path) {
|
| 625 |
+
if ($path != 1) {
|
| 626 |
+
$is_parent = ($path == $cat_ids[0]) ? 1 : 0;
|
| 627 |
+
|
| 628 |
+
$sql = sprintf("select * from " . $categoryIndxTable . " WHERE product_id = '%d' AND category_id = '%d' AND store_id = '%d'", $prod_id, $path, $store_id);
|
| 629 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 630 |
+
|
| 631 |
+
if (!empty($prod)) {
|
| 632 |
+
// skip
|
| 633 |
+
echo "Category-Product-Index confirmed. <br>\n";
|
| 634 |
+
} else {
|
| 635 |
+
// echo "no existing Category-Product found, continuing insert. <br>\n";
|
| 636 |
+
$w = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 637 |
+
|
| 638 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 639 |
+
$sql = "INSERT INTO `" . $categoryIndxTable . "` (product_id, category_id, position, store_id, is_parent, visibility) VALUES (%d, %d, 0, %d, %d, 4);";
|
| 640 |
+
$result = $w->query(sprintf($sql, $prod_id, $path, $store_id, $is_parent));
|
| 641 |
+
}
|
| 642 |
+
} // end $path !=1
|
| 643 |
+
}
|
| 644 |
+
return true;
|
| 645 |
+
}
|
| 646 |
+
|
| 647 |
+
/**
|
| 648 |
+
* Create New Product in magento
|
| 649 |
+
*/
|
| 650 |
+
public function create_fast($type, $attr_set_id, $sku, $productData, $qty, $websites, $cat_id, $store = 0)
|
| 651 |
+
{
|
| 652 |
+
$this->log_filename = 'create_fast.log';
|
| 653 |
+
if ($this->enable_logs) {
|
| 654 |
+
$starttime = time();
|
| 655 |
+
$msg = "Called saleswarp_product_api -> create_fast";
|
| 656 |
+
$msg .= "\n TIMESTAMP CREATE START: " . time();
|
| 657 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 658 |
+
}
|
| 659 |
+
|
| 660 |
+
$msg = "prod type=" . $type;
|
| 661 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 662 |
+
|
| 663 |
+
try {
|
| 664 |
+
/**
|
| 665 |
+
* $out = array('status'=>"pass",
|
| 666 |
+
'id'=>$entity_id,
|
| 667 |
+
'msg'=>"passed insert into catalog_product_entity");
|
| 668 |
+
*
|
| 669 |
+
* @var mixed
|
| 670 |
+
*/
|
| 671 |
+
$result = $this->fast_save($type, $sku, $productData, $qty, $attr_set_id, $websites, $cat_id);
|
| 672 |
+
|
| 673 |
+
// update category_ids
|
| 674 |
+
if ($result['status'] == "pass") {
|
| 675 |
+
$new_id = $result['id'];
|
| 676 |
+
$this->update_category_ids($new_id, $cat_id);
|
| 677 |
+
} else {
|
| 678 |
+
return $result;
|
| 679 |
+
}
|
| 680 |
+
|
| 681 |
+
if ($this->enable_logs) {
|
| 682 |
+
$msg = "After SAVE TIMESTAMP: " . time();
|
| 683 |
+
$msg .= "\n ELAPSE TIME: " . (time() - $starttime);
|
| 684 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 685 |
+
}
|
| 686 |
+
|
| 687 |
+
}
|
| 688 |
+
catch (Mage_Core_Exception $e) {
|
| 689 |
+
if ($this->enable_logs) {
|
| 690 |
+
$msg = "EXCEPTION CAUGHT in CREATE_FAST. ErrorMsg = " . $e->getMessage();
|
| 691 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 692 |
+
}
|
| 693 |
+
$this->_fault('data_invalid', $e->getMessage());
|
| 694 |
+
}
|
| 695 |
+
return $result;
|
| 696 |
+
}
|
| 697 |
+
|
| 698 |
+
/**
|
| 699 |
+
* use this to assign product to single or muliple category_ids
|
| 700 |
+
*/
|
| 701 |
+
function update_category_ids($store_product_id, $category_ids)
|
| 702 |
+
{
|
| 703 |
+
$w = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 704 |
+
|
| 705 |
+
// Ensure we have an array for category_ids
|
| 706 |
+
if (!$category_ids) {
|
| 707 |
+
return false;
|
| 708 |
+
}
|
| 709 |
+
|
| 710 |
+
if (!is_array($category_ids)) {
|
| 711 |
+
$category_ids = array($category_ids);
|
| 712 |
+
}
|
| 713 |
+
|
| 714 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 715 |
+
$sql = "UPDATE `" . $productTable . "`
|
| 716 |
+
SET `saleswarp_category_ids` = '" . (int) $category_ids[0] . "'
|
| 717 |
+
WHERE `entity_id` = '" . (int) $store_product_id . "'";
|
| 718 |
+
$result = $w->query($sql);
|
| 719 |
+
if (!$result) {
|
| 720 |
+
return false;
|
| 721 |
+
}
|
| 722 |
+
|
| 723 |
+
// Update Catalog_Category_Product
|
| 724 |
+
$r1 = $this->update_category_product($store_product_id, $category_ids);
|
| 725 |
+
|
| 726 |
+
// Update Catalog_Category_Product_Indx
|
| 727 |
+
$r2 = $this->update_cat_prod_indx($store_product_id, $category_ids);
|
| 728 |
+
|
| 729 |
+
return $r1 && $r2;
|
| 730 |
+
}
|
| 731 |
+
|
| 732 |
+
/**
|
| 733 |
+
* Update Product Qty to 1
|
| 734 |
+
*
|
| 735 |
+
*/
|
| 736 |
+
function set_in_stock($store_product_id, $stock_id, $status)
|
| 737 |
+
{
|
| 738 |
+
$invStockItemTable = Mage::getSingleton('core/resource')->getTableName('cataloginventory_stock_item');
|
| 739 |
+
$sql = "UPDATE " . $invStockItemTable . " SET is_in_stock = '1' WHERE product_id = '" . (int) $store_product_id . "'";
|
| 740 |
+
$connection = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 741 |
+
$connection->query($sql);
|
| 742 |
+
return true;
|
| 743 |
+
}
|
| 744 |
+
|
| 745 |
+
/**
|
| 746 |
+
* function get attibute details
|
| 747 |
+
*/
|
| 748 |
+
function get_attribute_details($attribute_code)
|
| 749 |
+
{
|
| 750 |
+
$attribute_details = Mage::getSingleton("eav/config")->getAttribute("catalog_product", $attribute_code);
|
| 751 |
+
$options = $attribute_details->getSource()->getAllOptions(false);
|
| 752 |
+
return $options;
|
| 753 |
+
}
|
| 754 |
+
|
| 755 |
+
/**
|
| 756 |
+
* Set Product ATTRIBUTE
|
| 757 |
+
*/
|
| 758 |
+
function set_product_config_attr($product_id, $configAttrCodes)
|
| 759 |
+
{
|
| 760 |
+
$configProduct = Mage::getModel("catalog/product")->load($product_id);
|
| 761 |
+
$attr_ids = [];
|
| 762 |
+
foreach ($configAttrCodes as $attrCode) {
|
| 763 |
+
$super_attribute= Mage::getModel('eav/entity_attribute')->loadByCode('catalog_product', $attrCode);
|
| 764 |
+
$attr_ids[] = $super_attribute->getId();
|
| 765 |
+
}
|
| 766 |
+
$configProduct->getTypeInstance()->setUsedProductAttributeIds($attr_ids);
|
| 767 |
+
$configurableAttributesData = $configProduct->getTypeInstance()->getConfigurableAttributesAsArray();
|
| 768 |
+
$configProduct->setCanSaveConfigurableAttributes(true);
|
| 769 |
+
$configProduct->setConfigurableAttributesData($configurableAttributesData);
|
| 770 |
+
$configProduct->save();
|
| 771 |
+
return true;
|
| 772 |
+
}
|
| 773 |
+
|
| 774 |
+
/**
|
| 775 |
+
* Save Product Data
|
| 776 |
+
*/
|
| 777 |
+
function fast_save($product_type, $sku, $data, $qty = 0, $attribute_set_id = 4, $websites, $cat_ids, $store_id = 1, $entity_type_id = 10)
|
| 778 |
+
{
|
| 779 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 780 |
+
if (!is_array($cat_ids)) {
|
| 781 |
+
$cat_ids = array(
|
| 782 |
+
$cat_ids
|
| 783 |
+
);
|
| 784 |
+
}
|
| 785 |
+
|
| 786 |
+
$w = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 787 |
+
|
| 788 |
+
$out = array(
|
| 789 |
+
'status' => "fail",
|
| 790 |
+
'id' => 0,
|
| 791 |
+
'msg' => ""
|
| 792 |
+
);
|
| 793 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 794 |
+
|
| 795 |
+
if ($this->enable_logs) {
|
| 796 |
+
$msg = "Inside fast_save, calling first catalog_product_entity insert";
|
| 797 |
+
;
|
| 798 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 799 |
+
}
|
| 800 |
+
|
| 801 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 802 |
+
|
| 803 |
+
$sql = "INSERT INTO `" . $productTable . "` (entity_id, entity_type_id, attribute_set_id,
|
| 804 |
+
type_id, sku, saleswarp_category_ids, created_at, updated_at, has_options) VALUES (NULL, %d, %d, '%s', '%s', %d, '%s', '%s', 0);";
|
| 805 |
+
|
| 806 |
+
$sql = sprintf($sql, $entity_type_id, $attribute_set_id, $product_type, $sku, $cat_ids[0], $datetime, $datetime);
|
| 807 |
+
|
| 808 |
+
Mage::log($sql, $this->log_level, $this->log_filename);
|
| 809 |
+
$result = $w->query($sql);
|
| 810 |
+
|
| 811 |
+
$result = $w->query(sprintf("select entity_id from " . $productTable . " where sku ='%s';", $sku));
|
| 812 |
+
if (!$result) {
|
| 813 |
+
if ($this->enable_logs) {
|
| 814 |
+
$msg = "FAILED: INSERT PRODUCT INTO CATALOG_PRODUCT ENTITY FAILED";
|
| 815 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 816 |
+
}
|
| 817 |
+
return $out;
|
| 818 |
+
} else {
|
| 819 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 820 |
+
$entity_id = $row['entity_id'];
|
| 821 |
+
$out = array(
|
| 822 |
+
'status' => "pass",
|
| 823 |
+
'id' => $entity_id,
|
| 824 |
+
'msg' => "passed insert into catalog_product_entity"
|
| 825 |
+
);
|
| 826 |
+
}
|
| 827 |
+
|
| 828 |
+
if ($this->enable_logs) {
|
| 829 |
+
$msg = "PASSED: INSERT PRODUCT INTO CATALOG_PRODUCT ENTITY ";
|
| 830 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 831 |
+
}
|
| 832 |
+
|
| 833 |
+
if ($entity_id == null) {
|
| 834 |
+
var_dump($row);
|
| 835 |
+
die('epic fail');
|
| 836 |
+
}
|
| 837 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 838 |
+
|
| 839 |
+
foreach ($data as $code => $value) {
|
| 840 |
+
switch ($code) {
|
| 841 |
+
// Add special groups here
|
| 842 |
+
case "age_groups":
|
| 843 |
+
foreach ($value as $v) {
|
| 844 |
+
$code = "age_group";
|
| 845 |
+
$result = $w->query("SELECT attribute_id, backend_type, frontend_input
|
| 846 |
+
FROM `" . $eavAttrTable . "` WHERE `attribute_code` LIKE '" . $code . "'
|
| 847 |
+
AND entity_type_id = '" . $entity_type_id . "'");
|
| 848 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 849 |
+
|
| 850 |
+
$result = $this->save_attribute_multiselect($row, $entity_id, $entity_type_id, $code, $v, $store_id);
|
| 851 |
+
if ($result != "pass") {
|
| 852 |
+
$out = array(
|
| 853 |
+
'status' => "fail",
|
| 854 |
+
'id' => $entity_id,
|
| 855 |
+
'msg' => "failed during age_group attribute save"
|
| 856 |
+
);
|
| 857 |
+
return $out;
|
| 858 |
+
}
|
| 859 |
+
}
|
| 860 |
+
break;
|
| 861 |
+
default:
|
| 862 |
+
if ($this->enable_logs) {
|
| 863 |
+
$msg = "Inserting attributes: attribute_code = " . $code . ", value = " . $value . ", entity_type_id = " . $entity_type_id;
|
| 864 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 865 |
+
}
|
| 866 |
+
|
| 867 |
+
$result = $w->query("SELECT attribute_id, backend_type, frontend_input, is_user_defined FROM `" . $eavAttrTable . "`
|
| 868 |
+
WHERE `attribute_code` LIKE '" . $code . "'
|
| 869 |
+
AND entity_type_id = '" . $entity_type_id . "'");
|
| 870 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 871 |
+
|
| 872 |
+
|
| 873 |
+
if ($row['frontend_input'] == 'select') {
|
| 874 |
+
$result = $this->save_attribute_select($row, $entity_id, $entity_type_id, $code, $value, $store_id, $row['is_user_defined']);
|
| 875 |
+
|
| 876 |
+
if ($result != "pass") {
|
| 877 |
+
$out = array(
|
| 878 |
+
'status' => "fail",
|
| 879 |
+
'id' => $entity_id,
|
| 880 |
+
'msg' => "failed during save_attribute_select for code: $code; value: $value"
|
| 881 |
+
);
|
| 882 |
+
return $out;
|
| 883 |
+
}
|
| 884 |
+
|
| 885 |
+
} elseif ($row['frontend_input'] == 'multiselect') {
|
| 886 |
+
$result = $this->save_attribute_multiselect($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 887 |
+
if ($result != "pass") {
|
| 888 |
+
$out = array(
|
| 889 |
+
'status' => "fail",
|
| 890 |
+
'id' => $entity_id,
|
| 891 |
+
'msg' => "failed during save_attribute_multiselect for code: $code; value: $value"
|
| 892 |
+
);
|
| 893 |
+
return $out;
|
| 894 |
+
}
|
| 895 |
+
} else {
|
| 896 |
+
$result = $this->save_attribute($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 897 |
+
if ($result != "pass") {
|
| 898 |
+
$out = array(
|
| 899 |
+
'status' => "fail",
|
| 900 |
+
'id' => $entity_id,
|
| 901 |
+
'msg' => "failed during save_attribute for code: $code; value: $value"
|
| 902 |
+
);
|
| 903 |
+
return $out;
|
| 904 |
+
}
|
| 905 |
+
}
|
| 906 |
+
break;
|
| 907 |
+
|
| 908 |
+
}
|
| 909 |
+
}
|
| 910 |
+
|
| 911 |
+
$invStockItemTable = Mage::getSingleton('core/resource')->getTableName('cataloginventory_stock_item');
|
| 912 |
+
|
| 913 |
+
if ($qty > 0) {
|
| 914 |
+
try {
|
| 915 |
+
if ($this->enable_logs) {
|
| 916 |
+
$msg = "calling cataloginventory_stock_item insert";
|
| 917 |
+
;
|
| 918 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 919 |
+
}
|
| 920 |
+
|
| 921 |
+
$w->query("INSERT INTO `" . $invStockItemTable . "`
|
| 922 |
+
(`product_id` ,`stock_id`,qty,
|
| 923 |
+
is_in_stock,
|
| 924 |
+
manage_stock,
|
| 925 |
+
use_config_min_qty,
|
| 926 |
+
use_config_min_sale_qty,
|
| 927 |
+
use_config_backorders,
|
| 928 |
+
use_config_notify_stock_qty,
|
| 929 |
+
use_config_manage_stock)VALUES($entity_id,1,$qty,1,1,1,1,1,1,0)");
|
| 930 |
+
|
| 931 |
+
$this->update_inventory($entity_id, $qty, 0, 1, 1, 1);
|
| 932 |
+
}
|
| 933 |
+
catch (Exception $e) {
|
| 934 |
+
if ($this->enable_logs) {
|
| 935 |
+
$msg = "EXCEPTION CAUGHT in FAST_SAVE, cataloginventory_stock_item QTY > 0. ErrorMsg = " . $e->getMessage();
|
| 936 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 937 |
+
}
|
| 938 |
+
$out = array(
|
| 939 |
+
'status' => "fail",
|
| 940 |
+
'id' => $entity_id,
|
| 941 |
+
'msg' => "failed during update_inventory, Exception " . $e->getMessage()
|
| 942 |
+
);
|
| 943 |
+
return $out;
|
| 944 |
+
}
|
| 945 |
+
} else {
|
| 946 |
+
try {
|
| 947 |
+
$w->query("INSERT INTO `" . $invStockItemTable . "`
|
| 948 |
+
(`product_id` ,`stock_id`,qty,is_in_stock,manage_stock,use_config_min_qty,
|
| 949 |
+
use_config_min_sale_qty, use_config_backorders, use_config_notify_stock_qty,
|
| 950 |
+
use_config_manage_stock)VALUES($entity_id,1,$qty,0,1,1,1,1,1,0)");
|
| 951 |
+
|
| 952 |
+
$this->update_inventory($entity_id, 0, 0, 1, 1, 1);
|
| 953 |
+
}
|
| 954 |
+
catch (Exception $e) {
|
| 955 |
+
if ($this->enable_logs) {
|
| 956 |
+
$msg = "EXCEPTION CAUGHT in FAST_SAVE, cataloginventory_stock_item QTY = 0. ErrorMsg = " . $e->getMessage();
|
| 957 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 958 |
+
}
|
| 959 |
+
$out = array(
|
| 960 |
+
'status' => "fail",
|
| 961 |
+
'id' => $entity_id,
|
| 962 |
+
'msg' => "failed during update_inventory, Exception " . $e->getMessage()
|
| 963 |
+
);
|
| 964 |
+
return $out;
|
| 965 |
+
}
|
| 966 |
+
}
|
| 967 |
+
|
| 968 |
+
try {
|
| 969 |
+
foreach ($websites as $website_id) {
|
| 970 |
+
// sometimes the entity_id & website_id combo already exists as Magento
|
| 971 |
+
// does not do a good job cleaning via Magento Admin, check for existing
|
| 972 |
+
// and reuse it if it exists
|
| 973 |
+
if ($this->enable_logs) {
|
| 974 |
+
$msg = "checking for catalog_product_website exists for product_id: " . $entity_id . ", website_id = " . $website_id;
|
| 975 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 976 |
+
}
|
| 977 |
+
$webTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_website');
|
| 978 |
+
$sql = "select * from
|
| 979 |
+
" . $webTable . "
|
| 980 |
+
WHERE product_id = '" . (int) $entity_id . "'
|
| 981 |
+
AND website_id = '" . (int) $website_id . "'";
|
| 982 |
+
$chk10 = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchAll($sql);
|
| 983 |
+
|
| 984 |
+
if (empty($chk10)) {
|
| 985 |
+
if ($this->enable_logs) {
|
| 986 |
+
$msg = "calling catalog_product_website insert";
|
| 987 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 988 |
+
}
|
| 989 |
+
|
| 990 |
+
$w->query("INSERT INTO `" . $webTable . "` (`product_id`,`website_id`)VALUES($entity_id, $website_id)");
|
| 991 |
+
}
|
| 992 |
+
}
|
| 993 |
+
}
|
| 994 |
+
catch (Exception $e) {
|
| 995 |
+
if ($this->enable_logs) {
|
| 996 |
+
$msg = "EXCEPTION CAUGHT in FAST_SAVE, catalog_product_website. ErrorMsg = " . $e->getMessage();
|
| 997 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 998 |
+
}
|
| 999 |
+
$out = array(
|
| 1000 |
+
'status' => "fail",
|
| 1001 |
+
'id' => $entity_id,
|
| 1002 |
+
'msg' => "failed during Website update, Exception " . $e->getMessage()
|
| 1003 |
+
);
|
| 1004 |
+
return $out;
|
| 1005 |
+
}
|
| 1006 |
+
return $out;
|
| 1007 |
+
}
|
| 1008 |
+
|
| 1009 |
+
/**
|
| 1010 |
+
* get media image gallery for a entity id
|
| 1011 |
+
* @params $entityId int Magento Product Id
|
| 1012 |
+
* @return product data or bool(false)
|
| 1013 |
+
*/
|
| 1014 |
+
function get_product_image_collection($entityId)
|
| 1015 |
+
{
|
| 1016 |
+
$data = array();
|
| 1017 |
+
$collection = Mage::getModel('catalog/product')->load($entityId)->getMediaGalleryImages();
|
| 1018 |
+
if ($collection) {
|
| 1019 |
+
foreach ($collection as $img) {
|
| 1020 |
+
$data[] = $img->getData();
|
| 1021 |
+
}
|
| 1022 |
+
return $data;
|
| 1023 |
+
}
|
| 1024 |
+
return false;
|
| 1025 |
+
}
|
| 1026 |
+
|
| 1027 |
+
/**
|
| 1028 |
+
* get category ids for a entity id
|
| 1029 |
+
*
|
| 1030 |
+
* @params $entityId int Magento Product Id
|
| 1031 |
+
* @return array category ids
|
| 1032 |
+
*/
|
| 1033 |
+
function get_category_for_product($entityId)
|
| 1034 |
+
{
|
| 1035 |
+
$prod = Mage::getModel('catalog/product')->load($entityId);
|
| 1036 |
+
$catIds = $prod->getCategoryIds();
|
| 1037 |
+
return $catIds;
|
| 1038 |
+
}
|
| 1039 |
+
|
| 1040 |
+
/**
|
| 1041 |
+
* get quantity by entity id
|
| 1042 |
+
*
|
| 1043 |
+
* @params $entityId int Magento Product Id
|
| 1044 |
+
* @return int quantity of product
|
| 1045 |
+
*/
|
| 1046 |
+
function get_qty_by_product($entityId)
|
| 1047 |
+
{
|
| 1048 |
+
$prod = Mage::getModel('catalog/product')->load($entityId);
|
| 1049 |
+
$qty = Mage::getModel('cataloginventory/stock_item')->loadByProduct($prod)->getQty();
|
| 1050 |
+
return $qty;
|
| 1051 |
+
}
|
| 1052 |
+
|
| 1053 |
+
|
| 1054 |
+
|
| 1055 |
+
/**
|
| 1056 |
+
* function to get product by sku
|
| 1057 |
+
*
|
| 1058 |
+
* @params $mageSku string Magento Product Sku
|
| 1059 |
+
* @return array products data
|
| 1060 |
+
*/
|
| 1061 |
+
function getProductBySKU($mageSku)
|
| 1062 |
+
{
|
| 1063 |
+
$product = Mage::getModel('catalog/product')->loadByAttribute('sku', $mageSku);
|
| 1064 |
+
$data = $product->getData();
|
| 1065 |
+
return $data;
|
| 1066 |
+
}
|
| 1067 |
+
|
| 1068 |
+
|
| 1069 |
+
|
| 1070 |
+
/**
|
| 1071 |
+
* check product exists in magento
|
| 1072 |
+
*
|
| 1073 |
+
* @params $entity_id int Magento Product id
|
| 1074 |
+
* @return boolean
|
| 1075 |
+
*/
|
| 1076 |
+
function check_prod_exists($entity_id)
|
| 1077 |
+
{
|
| 1078 |
+
$productTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity');
|
| 1079 |
+
$sql = "select entity_id from " . $productTable . "
|
| 1080 |
+
where entity_id = '" . (int) $entity_id . "'";
|
| 1081 |
+
$prod = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 1082 |
+
if ($prod) {
|
| 1083 |
+
return true;
|
| 1084 |
+
} else {
|
| 1085 |
+
return false;
|
| 1086 |
+
}
|
| 1087 |
+
}
|
| 1088 |
+
|
| 1089 |
+
/**
|
| 1090 |
+
* Save product attribute value
|
| 1091 |
+
*
|
| 1092 |
+
* @params $entity_id int Magento Product id
|
| 1093 |
+
* @params $code string Magento product attribute code
|
| 1094 |
+
* @params $value string Magento product attribute value
|
| 1095 |
+
* @params $store_id int Magento Product store id
|
| 1096 |
+
* @return boolean
|
| 1097 |
+
*/
|
| 1098 |
+
function rest_save_attribute($entity_id, $code, $value, $store_id)
|
| 1099 |
+
{
|
| 1100 |
+
$entity_type_id = Mage::getModel('eav/entity')->setType('catalog_product')->getTypeId();
|
| 1101 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1102 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1103 |
+
|
| 1104 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1105 |
+
WHERE `attribute_code` LIKE :code
|
| 1106 |
+
AND entity_type_id = :entity_type_id ";
|
| 1107 |
+
|
| 1108 |
+
$binds = array(
|
| 1109 |
+
'code' => $code,
|
| 1110 |
+
'entity_type_id' => $entity_type_id
|
| 1111 |
+
);
|
| 1112 |
+
|
| 1113 |
+
$result = $read->query($sql, $binds);
|
| 1114 |
+
|
| 1115 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1116 |
+
return $this->save_attribute($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 1117 |
+
}
|
| 1118 |
+
|
| 1119 |
+
/**
|
| 1120 |
+
* special attribute saves for select and multiselect types (frontend_type in Magento)
|
| 1121 |
+
*
|
| 1122 |
+
* @params $row string
|
| 1123 |
+
* @params $entity_id string Magento product id
|
| 1124 |
+
* @params $entity_type_id string Magento product type
|
| 1125 |
+
* @params $attribute_code string Magento product attribute code
|
| 1126 |
+
* @params $value string Magento product attribute value
|
| 1127 |
+
* @params $store_id int Magento Product store id
|
| 1128 |
+
* @return boolean
|
| 1129 |
+
*/
|
| 1130 |
+
function save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id)
|
| 1131 |
+
{
|
| 1132 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1133 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1134 |
+
|
| 1135 |
+
if ((!empty($row)) && ($row['backend_type'] != '') && ($row['backend_type'] != null)) {
|
| 1136 |
+
|
| 1137 |
+
$msg = "Backend_Type = " . $row['backend_type'];
|
| 1138 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 1139 |
+
|
| 1140 |
+
// does this exist
|
| 1141 |
+
$productBakTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity_' . $row['backend_type']);
|
| 1142 |
+
$sql = "SELECT * FROM `" . $productBakTable . "`
|
| 1143 |
+
WHERE attribute_id = :attribute_id
|
| 1144 |
+
AND entity_id = :entity_id
|
| 1145 |
+
AND store_id = 0
|
| 1146 |
+
AND entity_type_id = :entity_type_id ";
|
| 1147 |
+
$binds = array(
|
| 1148 |
+
'attribute_id' => $row['attribute_id'],
|
| 1149 |
+
'entity_id' => $entity_id,
|
| 1150 |
+
'entity_type_id' => $entity_type_id
|
| 1151 |
+
);
|
| 1152 |
+
|
| 1153 |
+
$result = $read->query($sql, $binds);
|
| 1154 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 1155 |
+
|
| 1156 |
+
if (empty($chk)) {
|
| 1157 |
+
// If key is in array $this->product_required_storeIds, then create an Admin store_id entry (store_id = 0)
|
| 1158 |
+
if (!empty($value) && $value != "") {
|
| 1159 |
+
$key1 = "catalog_product_entity_" . $row['backend_type'];
|
| 1160 |
+
|
| 1161 |
+
|
| 1162 |
+
if (array_key_exists($key1, $this->product_required_storeIds)) {
|
| 1163 |
+
$sql = "INSERT INTO `" . $productBakTable . "` (value_id, entity_type_id, attribute_id, store_id, entity_id,value)
|
| 1164 |
+
VALUES (NULL ,:etype,:attr,0,:eid,:val) ";
|
| 1165 |
+
|
| 1166 |
+
$binds = array(
|
| 1167 |
+
'etype' => $entity_type_id,
|
| 1168 |
+
'attr' => $row['attribute_id'],
|
| 1169 |
+
'eid' => $entity_id,
|
| 1170 |
+
'val' => $value
|
| 1171 |
+
);
|
| 1172 |
+
|
| 1173 |
+
$msg = "SQL QUERY = " . $sql;
|
| 1174 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 1175 |
+
$write->query($sql, $binds);
|
| 1176 |
+
}
|
| 1177 |
+
}
|
| 1178 |
+
} else { // update
|
| 1179 |
+
$sql = "UPDATE `" . $productBakTable . "`
|
| 1180 |
+
SET value = :value
|
| 1181 |
+
WHERE value_id = :value_id ";
|
| 1182 |
+
|
| 1183 |
+
$binds = array(
|
| 1184 |
+
'value' => $value,
|
| 1185 |
+
'value_id' => $chk['value_id']
|
| 1186 |
+
);
|
| 1187 |
+
|
| 1188 |
+
$write->query($sql, $binds);
|
| 1189 |
+
}
|
| 1190 |
+
// does this exist
|
| 1191 |
+
|
| 1192 |
+
$sql = "SELECT * FROM `" . $productBakTable . "`
|
| 1193 |
+
WHERE attribute_id = :attribute_id
|
| 1194 |
+
AND entity_id = :entity_id
|
| 1195 |
+
AND store_id = :store_id
|
| 1196 |
+
AND entity_type_id = :entity_type_id ";
|
| 1197 |
+
|
| 1198 |
+
$binds = array(
|
| 1199 |
+
'attribute_id' => $row['attribute_id'],
|
| 1200 |
+
'entity_id' => $entity_id,
|
| 1201 |
+
'store_id' => $store_id,
|
| 1202 |
+
'entity_type_id' => $entity_type_id
|
| 1203 |
+
);
|
| 1204 |
+
|
| 1205 |
+
$result = $write->query($sql, $binds);
|
| 1206 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 1207 |
+
|
| 1208 |
+
if (empty($chk)) {
|
| 1209 |
+
if (!empty($value) && $value != "") {
|
| 1210 |
+
$sql = "INSERT INTO `" . $productBakTable . "` (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 1211 |
+
VALUES (NULL, :etype, :attr, :sid, :eid, :val) ";
|
| 1212 |
+
|
| 1213 |
+
$binds = array(
|
| 1214 |
+
'etype' => $entity_type_id,
|
| 1215 |
+
'attr' => $row['attribute_id'],
|
| 1216 |
+
'sid' => $store_id,
|
| 1217 |
+
'eid' => $entity_id,
|
| 1218 |
+
'val' => $value
|
| 1219 |
+
);
|
| 1220 |
+
|
| 1221 |
+
$msg = "SQL QUERY = " . $sql;
|
| 1222 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 1223 |
+
|
| 1224 |
+
$write->query($sql, $binds);
|
| 1225 |
+
}
|
| 1226 |
+
} else { // update
|
| 1227 |
+
if (!empty($value) && $value != "") {
|
| 1228 |
+
$sql = "UPDATE `" . $productBakTable . "`
|
| 1229 |
+
SET value = :value
|
| 1230 |
+
WHERE value_id = :value_id ";
|
| 1231 |
+
|
| 1232 |
+
$binds = array(
|
| 1233 |
+
'value' => $value,
|
| 1234 |
+
'value_id' => $chk['value_id']
|
| 1235 |
+
);
|
| 1236 |
+
|
| 1237 |
+
$result = $write->query($sql, $binds);
|
| 1238 |
+
}
|
| 1239 |
+
}
|
| 1240 |
+
|
| 1241 |
+
}
|
| 1242 |
+
return "pass";
|
| 1243 |
+
}
|
| 1244 |
+
|
| 1245 |
+
/**
|
| 1246 |
+
* special attribute saves for select and multiselect types (frontend_type in Magento)
|
| 1247 |
+
*
|
| 1248 |
+
* @params $row string
|
| 1249 |
+
* @params $entity_id string Magento product id
|
| 1250 |
+
* @params $entity_type_id string Magento product type
|
| 1251 |
+
* @params $attribute_code string Magento product attribute code
|
| 1252 |
+
* @params $value string Magento product attribute value
|
| 1253 |
+
* @params $store_id int Magento Product store id
|
| 1254 |
+
* @params $isCustomAttribute boolean Is the field a custom attribute or core field
|
| 1255 |
+
* @return boolean
|
| 1256 |
+
*/
|
| 1257 |
+
function save_attribute_select($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id, $isCustomAttribute = null)
|
| 1258 |
+
{
|
| 1259 |
+
$result = "pass";
|
| 1260 |
+
|
| 1261 |
+
// The switch statment is not really nedded anymore becuase we just need to know
|
| 1262 |
+
// if the field is a custom or core field, but keeping it there for backwards compatibility
|
| 1263 |
+
// if the $isCustomAttribute is not passed in
|
| 1264 |
+
if (null !== $isCustomAttribute && !$isCustomAttribute) {
|
| 1265 |
+
$this->save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1266 |
+
return $result;
|
| 1267 |
+
}
|
| 1268 |
+
|
| 1269 |
+
// Magento hard codes values for some selects
|
| 1270 |
+
switch ($attribute_code) {
|
| 1271 |
+
case "tax_class_id":
|
| 1272 |
+
$this->save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1273 |
+
break;
|
| 1274 |
+
case "status":
|
| 1275 |
+
$this->save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1276 |
+
break;
|
| 1277 |
+
case "visibility":
|
| 1278 |
+
$this->save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1279 |
+
break;
|
| 1280 |
+
case "enable_googlecheckout":
|
| 1281 |
+
$this->save_attribute($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1282 |
+
break;
|
| 1283 |
+
default:
|
| 1284 |
+
$result = $this->save_attribute_select2($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id);
|
| 1285 |
+
break;
|
| 1286 |
+
}
|
| 1287 |
+
return $result;
|
| 1288 |
+
}
|
| 1289 |
+
|
| 1290 |
+
/**
|
| 1291 |
+
* special attribute saves for select and multiselect types (frontend_type in Magento)
|
| 1292 |
+
*
|
| 1293 |
+
* @params $row string
|
| 1294 |
+
* @params $entity_id string Magento product id
|
| 1295 |
+
* @params $entity_type_id string Magento product type
|
| 1296 |
+
* @params $attribute_code string Magento product attribute code
|
| 1297 |
+
* @params $value string Magento product attribute value
|
| 1298 |
+
* @params $store_id int Magento Product store id
|
| 1299 |
+
* @return string pass
|
| 1300 |
+
*/
|
| 1301 |
+
function save_attribute_select2($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id)
|
| 1302 |
+
{
|
| 1303 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1304 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1305 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1306 |
+
|
| 1307 |
+
// First get attribute_id
|
| 1308 |
+
$sql = "SELECT attribute_id, backend_type FROM " . $eavAttrTable . "
|
| 1309 |
+
WHERE attribute_code LIKE :attribute_code
|
| 1310 |
+
AND entity_type_id = :entity_type_id ";
|
| 1311 |
+
|
| 1312 |
+
$binds = array(
|
| 1313 |
+
'attribute_code' => $attribute_code,
|
| 1314 |
+
'entity_type_id' => $entity_type_id
|
| 1315 |
+
);
|
| 1316 |
+
$result = $read->query($sql, $binds);
|
| 1317 |
+
$row1 = $result->fetch(PDO::FETCH_ASSOC);
|
| 1318 |
+
|
| 1319 |
+
$eavAttrOptTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option');
|
| 1320 |
+
$eavAttrOptValTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option_value');
|
| 1321 |
+
|
| 1322 |
+
$sql = "SELECT EAOV.*, EAO.*
|
| 1323 |
+
FROM " . $eavAttrOptValTable . " as EAOV, " . $eavAttrOptTable . " as EAO
|
| 1324 |
+
WHERE EAO.attribute_id = :attribute_id
|
| 1325 |
+
AND EAOV.option_id = EAO.option_id";
|
| 1326 |
+
|
| 1327 |
+
$binds = array(
|
| 1328 |
+
'attribute_id' => $row1['attribute_id']
|
| 1329 |
+
);
|
| 1330 |
+
$result = $read->query($sql, $binds);
|
| 1331 |
+
$row2 = $result->fetchAll(); // correct, returns all option_values in array
|
| 1332 |
+
|
| 1333 |
+
// LOOK FOR A MATCH, THEN ADD THIS OPTION TO THE PRODUCT
|
| 1334 |
+
$match = false;
|
| 1335 |
+
$matchId = null;
|
| 1336 |
+
$value = trim($value);
|
| 1337 |
+
|
| 1338 |
+
foreach ($row2 as $selectOption) {
|
| 1339 |
+
if (strcasecmp($selectOption['value'], $value) == 0) {
|
| 1340 |
+
$match = true;
|
| 1341 |
+
$matchId = $selectOption['option_id'];
|
| 1342 |
+
}
|
| 1343 |
+
}
|
| 1344 |
+
|
| 1345 |
+
// if we coulden't find a matching value by checking the label name
|
| 1346 |
+
// attempt to find matching option ID
|
| 1347 |
+
if (!$match) {
|
| 1348 |
+
foreach ($row2 as $selectOption) {
|
| 1349 |
+
if ($value == $selectOption['option_id']) {
|
| 1350 |
+
$match = true;
|
| 1351 |
+
$matchId = $selectOption['option_id'];
|
| 1352 |
+
}
|
| 1353 |
+
}
|
| 1354 |
+
}
|
| 1355 |
+
|
| 1356 |
+
if ($match) {
|
| 1357 |
+
// IF Match
|
| 1358 |
+
// catalog_product_index_eav.value - one for each value
|
| 1359 |
+
|
| 1360 |
+
// query for existing entry in catalog_product_index_eav
|
| 1361 |
+
$prodIndxEavTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_index_eav');
|
| 1362 |
+
|
| 1363 |
+
$sql = "SELECT * FROM " . $prodIndxEavTable . "
|
| 1364 |
+
WHERE attribute_id = :attribute_id
|
| 1365 |
+
AND entity_id = :entity_id
|
| 1366 |
+
AND value = :matchId
|
| 1367 |
+
AND store_id = :store_id ";
|
| 1368 |
+
$binds = array(
|
| 1369 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1370 |
+
'entity_id' => $entity_id,
|
| 1371 |
+
'matchId' => $matchId,
|
| 1372 |
+
'store_id' => $store_id
|
| 1373 |
+
);
|
| 1374 |
+
|
| 1375 |
+
$result = $read->query($sql, $binds);
|
| 1376 |
+
$chk2 = $result->fetch(PDO::FETCH_ASSOC);
|
| 1377 |
+
|
| 1378 |
+
if (empty($chk2)) { // none, existing, insert it
|
| 1379 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1380 |
+
$sql = "INSERT INTO " . $prodIndxEavTable . "(entity_id, attribute_id, store_id, value )
|
| 1381 |
+
VALUES (:entity_id, :attribute_id, :store_id, :value)";
|
| 1382 |
+
$binds = array(
|
| 1383 |
+
'entity_id' => $entity_id,
|
| 1384 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1385 |
+
'store_id' => $store_id,
|
| 1386 |
+
'value' => $matchId
|
| 1387 |
+
);
|
| 1388 |
+
$result = $write->query($sql, $binds);
|
| 1389 |
+
}
|
| 1390 |
+
} else {
|
| 1391 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1392 |
+
$sql = "UPDATE " . $prodIndxEavTable . "
|
| 1393 |
+
SET value = :value
|
| 1394 |
+
WHERE entity_id = :entity_id
|
| 1395 |
+
AND store_id = :store_id
|
| 1396 |
+
AND attribute_id = :attribute_id ";
|
| 1397 |
+
$binds = array(
|
| 1398 |
+
'entity_id' => $entity_id,
|
| 1399 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1400 |
+
'store_id' => $store_id,
|
| 1401 |
+
'value' => $matchId
|
| 1402 |
+
);
|
| 1403 |
+
$result = $write->query($sql, $binds);
|
| 1404 |
+
}
|
| 1405 |
+
}
|
| 1406 |
+
|
| 1407 |
+
// Insert Select into catalog_product_ent_int
|
| 1408 |
+
// query for existing entry in catalog_product_index_eav
|
| 1409 |
+
$productIntTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity_int');
|
| 1410 |
+
$sql = "SELECT * FROM " . $productIntTable . "
|
| 1411 |
+
WHERE attribute_id = :attribute_id
|
| 1412 |
+
AND entity_id = :entity_id
|
| 1413 |
+
AND store_id = 0 ";
|
| 1414 |
+
|
| 1415 |
+
$binds = array(
|
| 1416 |
+
'entity_id' => $entity_id,
|
| 1417 |
+
'attribute_id' => $row1['attribute_id']
|
| 1418 |
+
);
|
| 1419 |
+
|
| 1420 |
+
$result = $read->query($sql, $binds);
|
| 1421 |
+
// AND value = '" . $matchId . "'");
|
| 1422 |
+
$chk3 = $result->fetch(PDO::FETCH_ASSOC);
|
| 1423 |
+
|
| 1424 |
+
if (empty($chk3)) { // none, existing, insert it
|
| 1425 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1426 |
+
$sql = "INSERT INTO " . $productIntTable . " (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 1427 |
+
VALUES (NULL, :entity_type_id, :attribute_id, 0, :entity_id, :matchId)";
|
| 1428 |
+
|
| 1429 |
+
$binds = array(
|
| 1430 |
+
'entity_type_id' => $entity_type_id,
|
| 1431 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1432 |
+
'entity_id' => $entity_id,
|
| 1433 |
+
'matchId' => $matchId
|
| 1434 |
+
);
|
| 1435 |
+
$result = $write->query($sql, $binds);
|
| 1436 |
+
}
|
| 1437 |
+
} else { //update it
|
| 1438 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1439 |
+
$sql = "UPDATE " . $productIntTable . "
|
| 1440 |
+
SET value = :value
|
| 1441 |
+
WHERE value_id = :value_id ";
|
| 1442 |
+
|
| 1443 |
+
$binds = array(
|
| 1444 |
+
'value' => $matchId,
|
| 1445 |
+
'value_id' => $chk3['value_id']
|
| 1446 |
+
);
|
| 1447 |
+
$result = $write->query($sql, $binds);
|
| 1448 |
+
}
|
| 1449 |
+
}
|
| 1450 |
+
} else { // NO MATCH, LOG IT IN MISSING OPTION VALUES LOG
|
| 1451 |
+
if (!empty($value) && ($value != " " || $value != "")) {
|
| 1452 |
+
$msg = "<h2>This OPTION is not defined in your storefront and may need added manually,
|
| 1453 |
+
you need to review your Magento attributes for consistency.</h2><br>";
|
| 1454 |
+
$msg .= "<h1>OPTION: " . $attribute_code . "</h1><h1>VALUE = " . $value . "</h1><hr>";
|
| 1455 |
+
}
|
| 1456 |
+
}
|
| 1457 |
+
return "pass";
|
| 1458 |
+
}
|
| 1459 |
+
|
| 1460 |
+
/**
|
| 1461 |
+
* special attribute saves for select and multiselect types (frontend_type in Magento)
|
| 1462 |
+
*
|
| 1463 |
+
* @params $row string
|
| 1464 |
+
* @params $entity_id string Magento product id
|
| 1465 |
+
* @params $entity_type_id string Magento product type
|
| 1466 |
+
* @params $attribute_code string Magento product attribute code
|
| 1467 |
+
* @params $value string Magento product attribute value
|
| 1468 |
+
* @params $store_id int Magento Product store id
|
| 1469 |
+
* @return string pass
|
| 1470 |
+
*/
|
| 1471 |
+
function save_attribute_multiselect($row, $entity_id, $entity_type_id, $attribute_code, $value, $store_id)
|
| 1472 |
+
{
|
| 1473 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1474 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1475 |
+
|
| 1476 |
+
// First get attribute_id, but
|
| 1477 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1478 |
+
|
| 1479 |
+
$sql = "SELECT attribute_id, backend_type FROM " . $eavAttrTable . "
|
| 1480 |
+
WHERE attribute_code LIKE :attribute_code
|
| 1481 |
+
AND entity_type_id = :entity_type_id ";
|
| 1482 |
+
|
| 1483 |
+
$binds = array(
|
| 1484 |
+
'attribute_code' => $attribute_code,
|
| 1485 |
+
'entity_type_id' => $entity_type_id
|
| 1486 |
+
);
|
| 1487 |
+
$result = $read->query($sql, $binds);
|
| 1488 |
+
$row1 = $result->fetch(PDO::FETCH_ASSOC);
|
| 1489 |
+
|
| 1490 |
+
$eavAttrOptTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option');
|
| 1491 |
+
$eavAttrOptValTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute_option_value');
|
| 1492 |
+
$sql = "SELECT EAOV.*, EAO.*
|
| 1493 |
+
FROM " . $eavAttrOptValTable . " as EAOV, " . $eavAttrOptTable . " as EAO
|
| 1494 |
+
WHERE EAO.attribute_id = :attribute_id
|
| 1495 |
+
AND EAOV.option_id = EAO.option_id";
|
| 1496 |
+
$binds = array(
|
| 1497 |
+
'attribute_id' => $row1['attribute_id']
|
| 1498 |
+
);
|
| 1499 |
+
|
| 1500 |
+
$result = $read->query($sql, $binds);
|
| 1501 |
+
$row2 = $result->fetchAll(); // correct, returns all option_values in array
|
| 1502 |
+
|
| 1503 |
+
// LOOK FOR A MATCH, THEN ADD THIS OPTION TO THE PRODUCT
|
| 1504 |
+
$match = false;
|
| 1505 |
+
$matchId = null;
|
| 1506 |
+
foreach ($row2 as $r) {
|
| 1507 |
+
if (strcasecmp($r['value'], rtrim(ltrim($value))) == 0) {
|
| 1508 |
+
$match = true;
|
| 1509 |
+
$matchId = $r['option_id'];
|
| 1510 |
+
}
|
| 1511 |
+
}
|
| 1512 |
+
|
| 1513 |
+
$productVarTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity_varchar');
|
| 1514 |
+
|
| 1515 |
+
if ($match && $matchId != null) {
|
| 1516 |
+
// IF Match
|
| 1517 |
+
// catalog_product_entity_varchar.value - one listing with all options
|
| 1518 |
+
// catalog_product_index_eav.value - one for each value
|
| 1519 |
+
// STORE 0 first
|
| 1520 |
+
// query for existing entry in catalog_product_entity_varchar
|
| 1521 |
+
$sql = "SELECT * FROM " . $productVarTable . "
|
| 1522 |
+
WHERE attribute_id = :attribute_id
|
| 1523 |
+
AND entity_type_id = :entity_type_id
|
| 1524 |
+
AND entity_id = :entity_id
|
| 1525 |
+
AND store_id = 0";
|
| 1526 |
+
$binds = array(
|
| 1527 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1528 |
+
'entity_type_id' => $entity_type_id,
|
| 1529 |
+
'entity_id' => $entity_id
|
| 1530 |
+
);
|
| 1531 |
+
$result = $read->query($sql, $binds);
|
| 1532 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 1533 |
+
|
| 1534 |
+
if (empty($chk)) { // none, existing, insert it
|
| 1535 |
+
if (!empty($value) && $value != "") {
|
| 1536 |
+
echo "doing insert on catalog_product_entity_varchar: " . " attribute_id = " . $row1['attribute_id'] . " entity_id = " . $entity_id . " store_id = 0" . " value/MatchId = " . $matchId . "<br>";
|
| 1537 |
+
|
| 1538 |
+
$sql = "INSERT INTO " . $productVarTable . " (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 1539 |
+
VALUES (NULL, :entity_type_id, :attribute_id, 0, :entity_id, :value)";
|
| 1540 |
+
|
| 1541 |
+
$binds = array(
|
| 1542 |
+
'entity_type_id' => $entity_type_id,
|
| 1543 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1544 |
+
'entity_id' => $entity_id,
|
| 1545 |
+
'value' => $matchId
|
| 1546 |
+
);
|
| 1547 |
+
|
| 1548 |
+
$result = $write->query($sql, $binds);
|
| 1549 |
+
}
|
| 1550 |
+
} else { // explode the value, see if this one is included, update if needed
|
| 1551 |
+
$vals = explode(',', $chk['value']);
|
| 1552 |
+
|
| 1553 |
+
$match2 = false;
|
| 1554 |
+
foreach ($vals as $val) {
|
| 1555 |
+
if (strcasecmp($val, $matchId) == 0) {
|
| 1556 |
+
$match2 = true;
|
| 1557 |
+
}
|
| 1558 |
+
}
|
| 1559 |
+
|
| 1560 |
+
// If Match2 == false; append it
|
| 1561 |
+
if ($match2 == false) {
|
| 1562 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1563 |
+
$new_value = $chk['value'] . "," . $matchId;
|
| 1564 |
+
|
| 1565 |
+
echo "doing UPDATE on catalog_product_entity_varchar with new_value = " . $new_value . "<br>";
|
| 1566 |
+
|
| 1567 |
+
$sql = "UPDATE " . $productVarTable . "
|
| 1568 |
+
SET value = :value
|
| 1569 |
+
WHERE value_id = :value_id ";
|
| 1570 |
+
|
| 1571 |
+
$binds = array(
|
| 1572 |
+
'value' => $new_value,
|
| 1573 |
+
'value_id' => $chk['value_id']
|
| 1574 |
+
);
|
| 1575 |
+
$result = $write->query($sql, $binds);
|
| 1576 |
+
}
|
| 1577 |
+
} else {
|
| 1578 |
+
echo "found match in catalog_entity_varchar for StoreID: 0, no update needed. <br> ";
|
| 1579 |
+
}
|
| 1580 |
+
|
| 1581 |
+
}
|
| 1582 |
+
|
| 1583 |
+
|
| 1584 |
+
// TARGET STORE NEXT
|
| 1585 |
+
// query for existing entry in catalog_product_entity_varchar
|
| 1586 |
+
$sql = "SELECT * FROM " . $productVarTable . "
|
| 1587 |
+
WHERE attribute_id = :attribute_id
|
| 1588 |
+
AND entity_type_id = :entity_type_id
|
| 1589 |
+
AND entity_id = :entity_id
|
| 1590 |
+
AND store_id = :store_id ";
|
| 1591 |
+
$binds = array(
|
| 1592 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1593 |
+
'entity_type_id' => $entity_type_id,
|
| 1594 |
+
'entity_id' => $entity_id,
|
| 1595 |
+
'store_id' => $store_id
|
| 1596 |
+
);
|
| 1597 |
+
|
| 1598 |
+
$result = $read->query($sql, $binds);
|
| 1599 |
+
$chk = $result->fetch(PDO::FETCH_ASSOC);
|
| 1600 |
+
|
| 1601 |
+
if (empty($chk)) { // none, existing, insert it
|
| 1602 |
+
if (!empty($value) && $value != "") {
|
| 1603 |
+
echo "doing insert on catalog_product_entity_varchar: " . " attribute_id = " . $row1['attribute_id'] . " entity_id = " . $entity_id . " store_id = " . $store_id . " value/MatchId = " . $matchId . "<br>";
|
| 1604 |
+
|
| 1605 |
+
$sql = "INSERT INTO " . $productVarTable . " (value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 1606 |
+
VALUES (NULL, :entity_type_id, :attribute_id, :store_id, :entity_id, :value)";
|
| 1607 |
+
$binds = array(
|
| 1608 |
+
'entity_type_id' => $entity_type_id,
|
| 1609 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1610 |
+
'store_id' => $store_id,
|
| 1611 |
+
'entity_id' => $entity_id,
|
| 1612 |
+
'value' => $matchId
|
| 1613 |
+
);
|
| 1614 |
+
$result = $write->query($sql, $binds);
|
| 1615 |
+
}
|
| 1616 |
+
} else { // explode the value, see if this one is included, update if needed
|
| 1617 |
+
$vals = explode(',', $chk['value']);
|
| 1618 |
+
|
| 1619 |
+
$match2 = false;
|
| 1620 |
+
foreach ($vals as $val) {
|
| 1621 |
+
if (strcasecmp($val, $matchId) == 0) {
|
| 1622 |
+
$match2 = true;
|
| 1623 |
+
}
|
| 1624 |
+
}
|
| 1625 |
+
|
| 1626 |
+
// If Match2 == false; append it
|
| 1627 |
+
if ($match2 == false) {
|
| 1628 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1629 |
+
$new_value = $chk['value'] . "," . $matchId;
|
| 1630 |
+
|
| 1631 |
+
echo "doing UPDATE on catalog_product_entity_varchar with new_value = " . $new_value . "<br>";
|
| 1632 |
+
|
| 1633 |
+
$sql = "UPDATE " . $productVarTable . "
|
| 1634 |
+
SET value = '" . $new_value . "'
|
| 1635 |
+
WHERE value_id = :value_id ";
|
| 1636 |
+
|
| 1637 |
+
$binds = array(
|
| 1638 |
+
'value_id' => $chk['value_id']
|
| 1639 |
+
);
|
| 1640 |
+
$result = $write->query($sql, $binds);
|
| 1641 |
+
}
|
| 1642 |
+
|
| 1643 |
+
} else {
|
| 1644 |
+
echo "found match in catalog_entity_varchar for StoreID: $store_id, no update needed. <br> ";
|
| 1645 |
+
}
|
| 1646 |
+
|
| 1647 |
+
}
|
| 1648 |
+
$prodIndxEavTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_index_eav');
|
| 1649 |
+
|
| 1650 |
+
// query for existing entry in catalog_product_index_eav
|
| 1651 |
+
$sql = "SELECT * FROM " . $prodIndxEavTable . "
|
| 1652 |
+
WHERE attribute_id = :attribute_id
|
| 1653 |
+
AND entity_id = :entity_id
|
| 1654 |
+
AND value = :value
|
| 1655 |
+
AND store_id = :store_id ";
|
| 1656 |
+
|
| 1657 |
+
$binds = array(
|
| 1658 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1659 |
+
'entity_id' => $entity_id,
|
| 1660 |
+
'value' => $matchId,
|
| 1661 |
+
'store_id' => $store_id
|
| 1662 |
+
);
|
| 1663 |
+
$result = $read->query($sql, $binds);
|
| 1664 |
+
$chk2 = $result->fetch(PDO::FETCH_ASSOC);
|
| 1665 |
+
|
| 1666 |
+
if (empty($chk2)) { // none, existing, insert it
|
| 1667 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1668 |
+
echo "doing insert on catalog_product_index_eav,
|
| 1669 |
+
entity_id = $entity_id, attribute = " . $row1['attribute_id'] . " store_id = $store_id , matchid = $matchId<br>";
|
| 1670 |
+
|
| 1671 |
+
$sql = "INSERT INTO " . $prodIndxEavTable . "(entity_id, attribute_id, store_id, value)
|
| 1672 |
+
VALUES(:entity_id, :attribute_id, :store_id, :value)";
|
| 1673 |
+
$binds = array(
|
| 1674 |
+
'entity_id' => $entity_id,
|
| 1675 |
+
'attribute_id' => $row1['attribute_id'],
|
| 1676 |
+
'store_id' => $store_id,
|
| 1677 |
+
'value' => $matchId
|
| 1678 |
+
);
|
| 1679 |
+
$result = $write->query($sql, $binds);
|
| 1680 |
+
echo "complete catalog_product_index_eav insert<br>";
|
| 1681 |
+
}
|
| 1682 |
+
} else { // exist, update only
|
| 1683 |
+
if (!empty($matchId) && $matchId != "") {
|
| 1684 |
+
echo "doing UDPATE on catalog_product_index_eav,
|
| 1685 |
+
entity_id = $entity_id, attribute = " . $row1['attribute_id'] . " store_id = $store_id , matchid = $matchId<br>";
|
| 1686 |
+
$sql = "UPDATE " . $prodIndxEavTable . "
|
| 1687 |
+
SET value = :value
|
| 1688 |
+
WHERE entity_id = :entity_id
|
| 1689 |
+
AND store_id = :store_id
|
| 1690 |
+
AND attribute_id = :attribute_id ";
|
| 1691 |
+
|
| 1692 |
+
$binds = array(
|
| 1693 |
+
'value' => $matchId,
|
| 1694 |
+
'entity_id' => $entity_id,
|
| 1695 |
+
'store_id' => $store_id,
|
| 1696 |
+
'attribute_id' => $row1['attribute_id']
|
| 1697 |
+
);
|
| 1698 |
+
$result = $write->query($sql, $binds);
|
| 1699 |
+
echo "complete catalog_product_index_eav<br>";
|
| 1700 |
+
}
|
| 1701 |
+
}
|
| 1702 |
+
} else { // NO MATCH, LOG IT IN MISSING OPTION VALUES LOG
|
| 1703 |
+
if (!empty($value) && ($value != " " || $value != "")) {
|
| 1704 |
+
$msg = "<h2>This OPTION is not defined in your storefront and may need added manually,
|
| 1705 |
+
you need to review your Magento attributes for consistency.</h2><br>";
|
| 1706 |
+
$msg .= "<h1>OPTION: " . $attribute_code . "</h1><h1> VALUE = " . $value . "</h1><hr>";
|
| 1707 |
+
echo $msg;
|
| 1708 |
+
Mage::log($msg, $this->log_level, "ERROR_saleswarp_product_api-missing_options.log");
|
| 1709 |
+
}
|
| 1710 |
+
}
|
| 1711 |
+
return "pass";
|
| 1712 |
+
}
|
| 1713 |
+
|
| 1714 |
+
/**
|
| 1715 |
+
* update product name
|
| 1716 |
+
*
|
| 1717 |
+
* @param $store_prod_id int product id
|
| 1718 |
+
* @param $store_id int store id
|
| 1719 |
+
* @param $value string attribute value
|
| 1720 |
+
* @param $code string attribute code
|
| 1721 |
+
* @param $entity_type_id int entity type id
|
| 1722 |
+
* @return
|
| 1723 |
+
*/
|
| 1724 |
+
function update_name($store_prod_id, $store_id, $value, $code = "name", $entity_type_id = 4)
|
| 1725 |
+
{
|
| 1726 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1727 |
+
|
| 1728 |
+
if ($this->enable_logs) {
|
| 1729 |
+
$msg = "Updating Name: attribute_code = " . $code . ", value = " . $value . ", entity_type_id = " . $entity_type_id;
|
| 1730 |
+
Mage::log($msg, $this->log_level, $this->log_filename);
|
| 1731 |
+
}
|
| 1732 |
+
|
| 1733 |
+
$w = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 1734 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 1735 |
+
|
| 1736 |
+
$result = $w->query("SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1737 |
+
WHERE `attribute_code` LIKE '" . $code . "'
|
| 1738 |
+
AND entity_type_id = '" . $entity_type_id . "'");
|
| 1739 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1740 |
+
|
| 1741 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $value, $store_id);
|
| 1742 |
+
if ($result != "pass") {
|
| 1743 |
+
return "fail";
|
| 1744 |
+
}
|
| 1745 |
+
return $result;
|
| 1746 |
+
}
|
| 1747 |
+
|
| 1748 |
+
/**
|
| 1749 |
+
* update product name
|
| 1750 |
+
*
|
| 1751 |
+
* @param $store_prod_id int product id
|
| 1752 |
+
* @param $store_id int store id
|
| 1753 |
+
* @param $value string attribute value
|
| 1754 |
+
* @param $code string attribute code
|
| 1755 |
+
* @param $entity_type_id int entity type id
|
| 1756 |
+
* @return
|
| 1757 |
+
*/
|
| 1758 |
+
function update_description($store_prod_id, $store_id, $value, $code = "description", $entity_type_id = 4)
|
| 1759 |
+
{
|
| 1760 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1761 |
+
|
| 1762 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1763 |
+
|
| 1764 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1765 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1766 |
+
AND entity_type_id = :entity_type_id ";
|
| 1767 |
+
|
| 1768 |
+
$binds = array(
|
| 1769 |
+
'attribute_code' => $attribute_code,
|
| 1770 |
+
'entity_type_id' => $entity_type_id
|
| 1771 |
+
);
|
| 1772 |
+
$result = $read->query($sql, $binds);
|
| 1773 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1774 |
+
|
| 1775 |
+
|
| 1776 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $value, $store_id);
|
| 1777 |
+
if ($result != "pass") {
|
| 1778 |
+
return "fail";
|
| 1779 |
+
}
|
| 1780 |
+
return $result;
|
| 1781 |
+
}
|
| 1782 |
+
|
| 1783 |
+
/**
|
| 1784 |
+
* update product name
|
| 1785 |
+
*
|
| 1786 |
+
* @param $store_prod_id int product id
|
| 1787 |
+
* @param $store_id int store id
|
| 1788 |
+
* @param $value string attribute value
|
| 1789 |
+
* @param $code string attribute code
|
| 1790 |
+
* @param $entity_type_id int entity type id
|
| 1791 |
+
* @return
|
| 1792 |
+
*/
|
| 1793 |
+
function update_short_description($store_prod_id, $store_id, $value, $code = "short_description", $entity_type_id = 4)
|
| 1794 |
+
{
|
| 1795 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1796 |
+
|
| 1797 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1798 |
+
|
| 1799 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1800 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1801 |
+
AND entity_type_id = :entity_type_id ";
|
| 1802 |
+
|
| 1803 |
+
$binds = array(
|
| 1804 |
+
'attribute_code' => $attribute_code,
|
| 1805 |
+
'entity_type_id' => $entity_type_id
|
| 1806 |
+
);
|
| 1807 |
+
$result = $read->query($sql, $binds);
|
| 1808 |
+
|
| 1809 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1810 |
+
|
| 1811 |
+
|
| 1812 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $value, $store_id);
|
| 1813 |
+
if ($result != "pass") {
|
| 1814 |
+
return "fail";
|
| 1815 |
+
}
|
| 1816 |
+
return $result;
|
| 1817 |
+
}
|
| 1818 |
+
|
| 1819 |
+
/**
|
| 1820 |
+
* update product price
|
| 1821 |
+
*
|
| 1822 |
+
* @param $store_prod_id int product id
|
| 1823 |
+
* @param $store_id int store id
|
| 1824 |
+
* @param $msrp float market selling price
|
| 1825 |
+
* @param $saleprice float sale price
|
| 1826 |
+
* @param $salefrom date sale from date
|
| 1827 |
+
* @param $saleto date sale to date
|
| 1828 |
+
* @param $entity_type_id int entity type id
|
| 1829 |
+
* @return
|
| 1830 |
+
*/
|
| 1831 |
+
function update_prices($store_prod_id, $store_id, $msrp, $saleprice, $salefrom = null, $saleto = null, $entity_type_id = 4)
|
| 1832 |
+
{
|
| 1833 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1834 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1835 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 1836 |
+
|
| 1837 |
+
// Price first
|
| 1838 |
+
$code = "price";
|
| 1839 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1840 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1841 |
+
AND entity_type_id = :entity_type_id ";
|
| 1842 |
+
|
| 1843 |
+
$binds = array(
|
| 1844 |
+
'attribute_code' => $code,
|
| 1845 |
+
'entity_type_id' => $entity_type_id
|
| 1846 |
+
);
|
| 1847 |
+
$result = $read->query($sql, $binds);
|
| 1848 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1849 |
+
|
| 1850 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $msrp, $store_id);
|
| 1851 |
+
|
| 1852 |
+
if ($result != "pass") {
|
| 1853 |
+
return "fail";
|
| 1854 |
+
}
|
| 1855 |
+
// SalePrice
|
| 1856 |
+
$code = "special_price";
|
| 1857 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1858 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1859 |
+
AND entity_type_id = :entity_type_id ";
|
| 1860 |
+
|
| 1861 |
+
$binds = array(
|
| 1862 |
+
'attribute_code' => $code,
|
| 1863 |
+
'entity_type_id' => $entity_type_id
|
| 1864 |
+
);
|
| 1865 |
+
$result = $read->query($sql, $binds);
|
| 1866 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1867 |
+
|
| 1868 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $saleprice, $store_id);
|
| 1869 |
+
if ($result != "pass") {
|
| 1870 |
+
return "fail";
|
| 1871 |
+
}
|
| 1872 |
+
|
| 1873 |
+
if ($salefrom != null) { // special_from_date
|
| 1874 |
+
$code = "special_from_date";
|
| 1875 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1876 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1877 |
+
AND entity_type_id = :entity_type_id ";
|
| 1878 |
+
|
| 1879 |
+
$binds = array(
|
| 1880 |
+
'attribute_code' => $code,
|
| 1881 |
+
'entity_type_id' => $entity_type_id
|
| 1882 |
+
);
|
| 1883 |
+
$result = $read->query($sql, $binds);
|
| 1884 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1885 |
+
|
| 1886 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $salefrom, $store_id);
|
| 1887 |
+
if ($result != "pass") {
|
| 1888 |
+
return "fail";
|
| 1889 |
+
}
|
| 1890 |
+
}
|
| 1891 |
+
|
| 1892 |
+
if ($saleto != null) {
|
| 1893 |
+
// special_from_date
|
| 1894 |
+
$code = "special_to_date";
|
| 1895 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1896 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1897 |
+
AND entity_type_id = :entity_type_id ";
|
| 1898 |
+
|
| 1899 |
+
$binds = array(
|
| 1900 |
+
'attribute_code' => $code,
|
| 1901 |
+
'entity_type_id' => $entity_type_id
|
| 1902 |
+
);
|
| 1903 |
+
$result = $read->query($sql, $binds);
|
| 1904 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1905 |
+
|
| 1906 |
+
$result = $this->save_attribute($row, $store_prod_id, $entity_type_id, $code, $saleto, $store_id);
|
| 1907 |
+
if ($result != "pass") {
|
| 1908 |
+
return "fail";
|
| 1909 |
+
}
|
| 1910 |
+
}
|
| 1911 |
+
|
| 1912 |
+
return $result;
|
| 1913 |
+
}
|
| 1914 |
+
|
| 1915 |
+
/**
|
| 1916 |
+
* update codes
|
| 1917 |
+
*
|
| 1918 |
+
* @param $store_prod_id int product id
|
| 1919 |
+
* @param $store_id int store id
|
| 1920 |
+
* @param $codes array attribute and value
|
| 1921 |
+
* @param $entity_type_id int entity type id
|
| 1922 |
+
* @return
|
| 1923 |
+
*/
|
| 1924 |
+
function update_codes($store_prod_id, $store_id, $codes, $entity_type_id = 4)
|
| 1925 |
+
{
|
| 1926 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1927 |
+
|
| 1928 |
+
$pass = "pass";
|
| 1929 |
+
$entity_id = $store_prod_id;
|
| 1930 |
+
|
| 1931 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1932 |
+
|
| 1933 |
+
foreach ($codes as $code => $value) {
|
| 1934 |
+
|
| 1935 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1936 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1937 |
+
AND entity_type_id = :entity_type_id ";
|
| 1938 |
+
|
| 1939 |
+
$binds = array(
|
| 1940 |
+
'attribute_code' => $code,
|
| 1941 |
+
'entity_type_id' => $entity_type_id
|
| 1942 |
+
);
|
| 1943 |
+
$result = $read->query($sql, $binds);
|
| 1944 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1945 |
+
|
| 1946 |
+
$result = $this->save_attribute($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 1947 |
+
if ($result != "pass") {
|
| 1948 |
+
return "fail";
|
| 1949 |
+
}
|
| 1950 |
+
|
| 1951 |
+
}
|
| 1952 |
+
return $pass;
|
| 1953 |
+
|
| 1954 |
+
}
|
| 1955 |
+
|
| 1956 |
+
|
| 1957 |
+
/**
|
| 1958 |
+
* update attributes
|
| 1959 |
+
*
|
| 1960 |
+
* @param $store_prod_id int product id
|
| 1961 |
+
* @param $store_id int store id
|
| 1962 |
+
* @param $attributes array attribute and value
|
| 1963 |
+
* @param $entity_type_id int entity type id
|
| 1964 |
+
* @return
|
| 1965 |
+
*/
|
| 1966 |
+
function update_attributes($store_prod_id, $store_id, $attributes, $entity_type_id = 4)
|
| 1967 |
+
{
|
| 1968 |
+
$eavAttrTable = Mage::getSingleton('core/resource')->getTableName('eav_attribute');
|
| 1969 |
+
|
| 1970 |
+
|
| 1971 |
+
$result = "pass";
|
| 1972 |
+
$entity_id = $store_prod_id;
|
| 1973 |
+
|
| 1974 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 1975 |
+
$datetime = strftime('%Y-%m-%d %H:%M:%S', time());
|
| 1976 |
+
|
| 1977 |
+
foreach ($attributes as $code => $value) {
|
| 1978 |
+
|
| 1979 |
+
switch ($code) { // Add special groups here
|
| 1980 |
+
case "age_groups":
|
| 1981 |
+
foreach ($value as $v) {
|
| 1982 |
+
if (!empty($v) && $v != '') {
|
| 1983 |
+
$code = "age_group";
|
| 1984 |
+
|
| 1985 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input FROM `" . $eavAttrTable . "`
|
| 1986 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 1987 |
+
AND entity_type_id = :entity_type_id ";
|
| 1988 |
+
|
| 1989 |
+
$binds = array(
|
| 1990 |
+
'attribute_code' => $code,
|
| 1991 |
+
'entity_type_id' => $entity_type_id
|
| 1992 |
+
);
|
| 1993 |
+
$result = $read->query($sql, $binds);
|
| 1994 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 1995 |
+
if ($this->enable_logs) {
|
| 1996 |
+
$msg = "calling save_attribute_multiselect for Age Groups, Code : " . $code . "; Value: " . $v;
|
| 1997 |
+
Mage::log($msg, $this->log_level, "saleswarp_update_products");
|
| 1998 |
+
}
|
| 1999 |
+
|
| 2000 |
+
$result = $this->save_attribute_multiselect($row, $entity_id, $entity_type_id, $code, $v, $store_id);
|
| 2001 |
+
if ($result != "pass") {
|
| 2002 |
+
return "fail";
|
| 2003 |
+
}
|
| 2004 |
+
}
|
| 2005 |
+
}
|
| 2006 |
+
break;
|
| 2007 |
+
default:
|
| 2008 |
+
if (!empty($value) && $value != '') {
|
| 2009 |
+
|
| 2010 |
+
$sql = "SELECT attribute_id, backend_type, frontend_input, is_user_defined FROM `" . $eavAttrTable . "`
|
| 2011 |
+
WHERE `attribute_code` LIKE :attribute_code
|
| 2012 |
+
AND entity_type_id = :entity_type_id ";
|
| 2013 |
+
|
| 2014 |
+
$binds = array(
|
| 2015 |
+
'attribute_code' => $code,
|
| 2016 |
+
'entity_type_id' => $entity_type_id
|
| 2017 |
+
);
|
| 2018 |
+
$result = $read->query($sql, $binds);
|
| 2019 |
+
$row = $result->fetch(PDO::FETCH_ASSOC);
|
| 2020 |
+
|
| 2021 |
+
if ($row['frontend_input'] == 'select') {
|
| 2022 |
+
|
| 2023 |
+
$result = $this->save_attribute_select($row, $entity_id, $entity_type_id, $code, $value, $store_id, $row['is_user_defined']);
|
| 2024 |
+
if ($result != "pass") {
|
| 2025 |
+
return "fail";
|
| 2026 |
+
}
|
| 2027 |
+
|
| 2028 |
+
} elseif ($row['frontend_input'] == 'multiselect') {
|
| 2029 |
+
|
| 2030 |
+
$result = $this->save_attribute_multiselect($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 2031 |
+
if ($result != "pass") {
|
| 2032 |
+
return "fail";
|
| 2033 |
+
}
|
| 2034 |
+
|
| 2035 |
+
} else {
|
| 2036 |
+
$result = $this->save_attribute($row, $entity_id, $entity_type_id, $code, $value, $store_id);
|
| 2037 |
+
if ($result != "pass") {
|
| 2038 |
+
return "fail";
|
| 2039 |
+
}
|
| 2040 |
+
}
|
| 2041 |
+
}
|
| 2042 |
+
break;
|
| 2043 |
+
}
|
| 2044 |
+
}
|
| 2045 |
+
return $result;
|
| 2046 |
+
}
|
| 2047 |
+
|
| 2048 |
+
/**
|
| 2049 |
+
* light weight inventory update when product is detected out of stock or discontinued and full
|
| 2050 |
+
* update info (cogs, weight, price) not longer apply
|
| 2051 |
+
*
|
| 2052 |
+
* @param mixed $store_prod_id
|
| 2053 |
+
* @param mixed $store_qty
|
| 2054 |
+
* @param mixed $discontinued
|
| 2055 |
+
* @param mixed $status
|
| 2056 |
+
* @return mixed
|
| 2057 |
+
*/
|
| 2058 |
+
function update_inventory($store_prod_id, $store_qty, $discontinued, $attribute_id, $status = 1, $website_id = 1, $stock_id = 1)
|
| 2059 |
+
{
|
| 2060 |
+
$invStockItemTable = Mage::getSingleton('core/resource')->getTableName('cataloginventory_stock_item');
|
| 2061 |
+
$invStockStatusTable = Mage::getSingleton('core/resource')->getTableName('cataloginventory_stock_status');
|
| 2062 |
+
$prodDateTimeTable = Mage::getSingleton('core/resource')->getTableName('catalog_product_entity_datetime');
|
| 2063 |
+
|
| 2064 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 2065 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 2066 |
+
|
| 2067 |
+
if ($store_qty <= 0 || $discontinued == 1) {
|
| 2068 |
+
$status = 0;
|
| 2069 |
+
} else {
|
| 2070 |
+
$status = 1;
|
| 2071 |
+
}
|
| 2072 |
+
|
| 2073 |
+
if (is_null($store_qty)) {
|
| 2074 |
+
$store_qty = 0;
|
| 2075 |
+
$status = 0;
|
| 2076 |
+
}
|
| 2077 |
+
|
| 2078 |
+
$sql = "UPDATE " . $invStockItemTable . "
|
| 2079 |
+
SET qty = :qty,
|
| 2080 |
+
is_in_stock = :is_in_stock
|
| 2081 |
+
WHERE product_id = :product_id ";
|
| 2082 |
+
$binds = array(
|
| 2083 |
+
'qty' => $store_qty,
|
| 2084 |
+
'is_in_stock' => $status,
|
| 2085 |
+
'product_id' => $store_prod_id
|
| 2086 |
+
);
|
| 2087 |
+
$result = $write->query($sql, $binds);
|
| 2088 |
+
|
| 2089 |
+
$sql = "SELECT * FROM " . $invStockStatusTable . "
|
| 2090 |
+
WHERE product_id = :product_id
|
| 2091 |
+
AND website_id = :website_id
|
| 2092 |
+
AND stock_id = :stock_id ";
|
| 2093 |
+
$binds = array(
|
| 2094 |
+
'product_id' => $store_prod_id,
|
| 2095 |
+
'website_id' => $website_id,
|
| 2096 |
+
'stock_id' => $stock_id
|
| 2097 |
+
);
|
| 2098 |
+
$chk = $read->fetchRow($sql, $binds);
|
| 2099 |
+
if (empty($chk)) {
|
| 2100 |
+
$sql = "INSERT INTO " . $invStockStatusTable . "
|
| 2101 |
+
SET qty = :qty,
|
| 2102 |
+
stock_status = :stock_status,
|
| 2103 |
+
stock_id = :stock_id,
|
| 2104 |
+
website_id = :website_id,
|
| 2105 |
+
product_id = :product_id ";
|
| 2106 |
+
|
| 2107 |
+
$binds = array(
|
| 2108 |
+
'qty' => $store_qty,
|
| 2109 |
+
'stock_status' => $status,
|
| 2110 |
+
'stock_id' => $stock_id,
|
| 2111 |
+
'website_id' => $website_id,
|
| 2112 |
+
'product_id' => $store_prod_id
|
| 2113 |
+
);
|
| 2114 |
+
$result2 = $write->query($sql, $binds);
|
| 2115 |
+
} else { // do update
|
| 2116 |
+
$sql = "UPDATE " . $invStockStatusTable . "
|
| 2117 |
+
SET qty = :qty, stock_status = :stock_status
|
| 2118 |
+
WHERE product_id = :product_id ";
|
| 2119 |
+
$binds = array(
|
| 2120 |
+
'qty' => $store_qty,
|
| 2121 |
+
'stock_status' => $status,
|
| 2122 |
+
'product_id' => $store_prod_id
|
| 2123 |
+
);
|
| 2124 |
+
$result2 = $write->query($sql, $binds);
|
| 2125 |
+
}
|
| 2126 |
+
|
| 2127 |
+
// Update saleswarp_last_inventory_update fields
|
| 2128 |
+
$sql = "SELECT * FROM " . $prodDateTimeTable . "
|
| 2129 |
+
WHERE entity_type_id = 4
|
| 2130 |
+
AND entity_id = $store_prod_id
|
| 2131 |
+
AND attribute_id = $attribute_id";
|
| 2132 |
+
$chk = $read->fetchAll($sql);
|
| 2133 |
+
|
| 2134 |
+
if (empty($chk)) { // insert it
|
| 2135 |
+
$sql = "INSERT INTO " . $prodDateTimeTable . "
|
| 2136 |
+
SET value = NOW(),
|
| 2137 |
+
entity_type_id = 4,
|
| 2138 |
+
store_id = 0,
|
| 2139 |
+
entity_id = $store_prod_id,
|
| 2140 |
+
attribute_id = $attribute_id";
|
| 2141 |
+
$insert_result = $write->query($sql);
|
| 2142 |
+
} else { // update it
|
| 2143 |
+
$sql = "UPDATE " . $prodDateTimeTable . "
|
| 2144 |
+
SET value = NOW()
|
| 2145 |
+
WHERE entity_type_id = 4
|
| 2146 |
+
AND entity_id = $store_prod_id
|
| 2147 |
+
AND attribute_id = $attribute_id";
|
| 2148 |
+
$update_result = $write->query($sql);
|
| 2149 |
+
}
|
| 2150 |
+
|
| 2151 |
+
if ($result && $result2) {
|
| 2152 |
+
return "Saved inventory record";
|
| 2153 |
+
} else {
|
| 2154 |
+
return "FAILED save() inventory update";
|
| 2155 |
+
}
|
| 2156 |
+
}
|
| 2157 |
+
|
| 2158 |
+
/**
|
| 2159 |
+
* get default store root category id
|
| 2160 |
+
*/
|
| 2161 |
+
public function get_default_store_root_cat_id()
|
| 2162 |
+
{
|
| 2163 |
+
$coreStorGroupTable = Mage::getSingleton('core/resource')->getTableName('core_store_group');
|
| 2164 |
+
$coreWebTable = Mage::getSingleton('core/resource')->getTableName('core_website');
|
| 2165 |
+
|
| 2166 |
+
$sql = "SELECT s.root_category_id FROM " . $coreStorGroupTable . " s
|
| 2167 |
+
LEFT JOIN " . $coreWebTable . " w ON s.website_id=w.website_id
|
| 2168 |
+
WHERE w.is_default=1";
|
| 2169 |
+
$prods = Mage::getSingleton('core/resource')->getConnection('core_read')->fetchRow($sql);
|
| 2170 |
+
return $prods['root_category_id'];
|
| 2171 |
+
}
|
| 2172 |
+
|
| 2173 |
+
/**
|
| 2174 |
+
* superadmin feature, don't keep on in production or you will regret it...
|
| 2175 |
+
*/
|
| 2176 |
+
function super_scary_fast_magento_delete_all_products()
|
| 2177 |
+
{
|
| 2178 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 2179 |
+
$cnt = 0;
|
| 2180 |
+
$write->query('SET FOREIGN_KEY_CHECKS = 0');
|
| 2181 |
+
foreach ($this->product_truncate_all_tables as $t1) {
|
| 2182 |
+
$tmpTable = Mage::getSingleton('core/resource')->getTableName($t1);
|
| 2183 |
+
// truncate this table
|
| 2184 |
+
echo "truncating table : " . $t1 . "<br>";
|
| 2185 |
+
$result2 = $write->query('TRUNCATE ' . $tmpTable . ';');
|
| 2186 |
+
$cnt++;
|
| 2187 |
+
}
|
| 2188 |
+
$w1->query('SET FOREIGN_KEY_CHECKS = 1');
|
| 2189 |
+
return "products have been cleared, # tables cleared = " . $cnt;
|
| 2190 |
+
}
|
| 2191 |
+
}
|
app/code/local/Saleswarp/Publish/Model/Product/Attribute/Api.php
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Publish_Model_Product_Attribute_Api extends Saleswarp_Oms_Model_Product_Attribute_Api
|
| 3 |
+
{
|
| 4 |
+
/**
|
| 5 |
+
* Add manufacturer
|
| 6 |
+
**/
|
| 7 |
+
function add_manf($attributeId = 102, $saleswarp_manf_name, $store_id = 0)
|
| 8 |
+
{
|
| 9 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 10 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 11 |
+
|
| 12 |
+
$sql = "select option_id from eav_attribute_option_value
|
| 13 |
+
where value = :saleswarp_manf_name AND store_id = :store_id ";
|
| 14 |
+
|
| 15 |
+
$binds = array(
|
| 16 |
+
'saleswarp_manf_name' => $saleswarp_manf_name,
|
| 17 |
+
'store_id' => $store_id
|
| 18 |
+
);
|
| 19 |
+
$data = $read->fetchAll($sql, $binds);
|
| 20 |
+
|
| 21 |
+
if (count($data) == 0) {
|
| 22 |
+
$write->query("insert into eav_attribute_option (attribute_id) values (" . (int) $attributeId . ")");
|
| 23 |
+
$option_id = $connection->lastInsertId();
|
| 24 |
+
$sql = "insert into eav_attribute_option_value(option_id,value,store_id)
|
| 25 |
+
values(:option_id, :saleswarp_manf_name, :store_id)";
|
| 26 |
+
|
| 27 |
+
$binds = array(
|
| 28 |
+
'option_id' => $option_id,
|
| 29 |
+
'saleswarp_manf_name' => $saleswarp_manf_name,
|
| 30 |
+
'store_id' => $store_id
|
| 31 |
+
);
|
| 32 |
+
$write->query($sql, $binds);
|
| 33 |
+
} else {
|
| 34 |
+
$option_id = $data[0]['option_id'];
|
| 35 |
+
}
|
| 36 |
+
return $option_id;
|
| 37 |
+
}
|
| 38 |
+
}
|
app/code/local/Saleswarp/Publish/Model/Product/Attribute/Media/Api.php
ADDED
|
@@ -0,0 +1,153 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_Publish_Model_Product_Attribute_Media_Api extends Saleswarp_Oms_Model_Product_Attribute_Media_Api
|
| 3 |
+
{
|
| 4 |
+
/**
|
| 5 |
+
* QUICK Update image data
|
| 6 |
+
* CAUTION: removed check for existing image, useful for mass ports
|
| 7 |
+
*
|
| 8 |
+
* @author David Potts, 6th Street Inc.
|
| 9 |
+
*
|
| 10 |
+
* @param int|string $productId
|
| 11 |
+
* @param string $file
|
| 12 |
+
* @param array $data
|
| 13 |
+
* @param string|int $store
|
| 14 |
+
* @return boolean
|
| 15 |
+
*/
|
| 16 |
+
public function quick_update($attr_id, $productId, $file, $img_type, $position = 0, $store = 0)
|
| 17 |
+
{
|
| 18 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 19 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 20 |
+
|
| 21 |
+
$result = true;
|
| 22 |
+
$sql = "select value_id from catalog_product_entity_media_gallery
|
| 23 |
+
where attribute_id = :attrId
|
| 24 |
+
and value = :file
|
| 25 |
+
and entity_id = :productId ";
|
| 26 |
+
$binds = array(
|
| 27 |
+
'attrId' => $attr_id,
|
| 28 |
+
'file' => $file,
|
| 29 |
+
'productId' => $productId
|
| 30 |
+
);
|
| 31 |
+
$data = $read->fetchAll($sql, $binds);
|
| 32 |
+
|
| 33 |
+
if (count($data) == 0) {
|
| 34 |
+
if ($img_type == 'image' || $img_type == 'alt_image') {
|
| 35 |
+
// only include image & alt_image in media gallery
|
| 36 |
+
$disable = 0;
|
| 37 |
+
} else {
|
| 38 |
+
$disable = 1;
|
| 39 |
+
}
|
| 40 |
+
|
| 41 |
+
$sql = "insert into catalog_product_entity_media_gallery(value_id, attribute_id, entity_id, value)
|
| 42 |
+
values(value_id, :attrId, :productId, :file)";
|
| 43 |
+
|
| 44 |
+
$write->query($sql, $binds);
|
| 45 |
+
$value_id = $write->lastInsertId();
|
| 46 |
+
|
| 47 |
+
$sql = "insert into catalog_product_entity_media_gallery_value(value_id, store_id, label, position, disabled)
|
| 48 |
+
values(:valueId, :store, :imgType, :position, :disable)";
|
| 49 |
+
unset($binds);
|
| 50 |
+
$binds = array(
|
| 51 |
+
'valueId' => $value_id,
|
| 52 |
+
'store' => $store,
|
| 53 |
+
'imgType' => $img_type,
|
| 54 |
+
'position' => $position,
|
| 55 |
+
'disable' => $disable
|
| 56 |
+
);
|
| 57 |
+
$write->query($sql, $binds);
|
| 58 |
+
|
| 59 |
+
// put in thumbnail & base references
|
| 60 |
+
switch ($img_type) {
|
| 61 |
+
case "image":
|
| 62 |
+
$upd1 = $this->update_entity_varchar("4", "85", $store, $productId, $file);
|
| 63 |
+
// check store 0 as
|
| 64 |
+
$upd2 = $this->update_entity_varchar("4", "85", "0", $productId, $file);
|
| 65 |
+
|
| 66 |
+
if ($upd1 == false || $upd2 == false) {
|
| 67 |
+
$result = false;
|
| 68 |
+
}
|
| 69 |
+
break;
|
| 70 |
+
case "thumbnail":
|
| 71 |
+
$upd1 = $this->update_entity_varchar("4", "87", $store, $productId, $file);
|
| 72 |
+
$upd2 = $this->update_entity_varchar("4", "87", "0", $productId, $file);
|
| 73 |
+
if ($upd1 == false || $upd2 == false) {
|
| 74 |
+
$result = false;
|
| 75 |
+
}
|
| 76 |
+
break;
|
| 77 |
+
case "small_image":
|
| 78 |
+
$upd1 = $this->update_entity_varchar("4", "86", $store, $productId, $file);
|
| 79 |
+
$upd2 = $this->update_entity_varchar("4", "86", "0", $productId, $file);
|
| 80 |
+
if ($upd1 == false || $upd2 == false) {
|
| 81 |
+
$result = false;
|
| 82 |
+
}
|
| 83 |
+
break;
|
| 84 |
+
default:
|
| 85 |
+
$upd1 = $this->update_entity_varchar("4", "85", $store, $productId, $file);
|
| 86 |
+
$upd2 = $this->update_entity_varchar("4", "85", "0", $productId, $file);
|
| 87 |
+
if ($upd1 == false || $upd2 == false) {
|
| 88 |
+
$result = false;
|
| 89 |
+
}
|
| 90 |
+
break;
|
| 91 |
+
}
|
| 92 |
+
}
|
| 93 |
+
return $result;
|
| 94 |
+
}
|
| 95 |
+
|
| 96 |
+
protected function update_entity_varchar($entity_type_id, $attribute_id, $store_id, $entity_id, $value)
|
| 97 |
+
{
|
| 98 |
+
$result = true;
|
| 99 |
+
$read = Mage::getSingleton('core/resource')->getConnection('core_read');
|
| 100 |
+
$write = Mage::getSingleton('core/resource')->getConnection('core_write');
|
| 101 |
+
$sql = "select value_id from catalog_product_entity_varchar
|
| 102 |
+
where entity_type_id = :entityTypeId
|
| 103 |
+
and attribute_id = :attributeId
|
| 104 |
+
and store_id = :storeId
|
| 105 |
+
and entity_id = :entityId ";
|
| 106 |
+
|
| 107 |
+
$binds = array(
|
| 108 |
+
'entityTypeId' => $entity_type_id,
|
| 109 |
+
'attributeId' => $attribute_id,
|
| 110 |
+
'storeId' => $store_id,
|
| 111 |
+
'entityId' => $entity_id
|
| 112 |
+
);
|
| 113 |
+
|
| 114 |
+
$data1 = $read->fetchRow($sql, $binds);
|
| 115 |
+
if (empty($data1)) {
|
| 116 |
+
$sql = "insert into catalog_product_entity_varchar(value_id, entity_type_id, attribute_id, store_id, entity_id, value)
|
| 117 |
+
values(value_id, :entityTypeId, :attributeId, :storeId, :entityId, :value) ";
|
| 118 |
+
$binds = array(
|
| 119 |
+
'entityTypeId' => $entity_type_id,
|
| 120 |
+
'attributeId' => $attribute_id,
|
| 121 |
+
'storeId' => $store_id,
|
| 122 |
+
'entityId' => $entity_id,
|
| 123 |
+
'value' => $value
|
| 124 |
+
);
|
| 125 |
+
$qresult = $write->query($sql, $binds);
|
| 126 |
+
if ($qresult == false) {
|
| 127 |
+
$result = false;
|
| 128 |
+
}
|
| 129 |
+
} else {
|
| 130 |
+
// do an update only
|
| 131 |
+
$value_id = $data1['value_id'];
|
| 132 |
+
$sql = "UPDATE catalog_product_entity_varchar
|
| 133 |
+
SET
|
| 134 |
+
entity_type_id = :entityTypeId,
|
| 135 |
+
attribute_id = :attributeId,
|
| 136 |
+
store_id = :storeId,
|
| 137 |
+
entity_id = :entityId,
|
| 138 |
+
value = :value
|
| 139 |
+
WHERE value_id = :valueId LIMIT 1";
|
| 140 |
+
$binds = array(
|
| 141 |
+
'entityTypeId' => $entity_type_id,
|
| 142 |
+
'attributeId' => $attribute_id,
|
| 143 |
+
'storeId' => $store_id,
|
| 144 |
+
'entityId' => $entity_id,
|
| 145 |
+
'value' => $value,
|
| 146 |
+
'valueId' => $value_id
|
| 147 |
+
);
|
| 148 |
+
$qresult = $write->query($sql, $binds);
|
| 149 |
+
}
|
| 150 |
+
return $result;
|
| 151 |
+
}
|
| 152 |
+
}
|
| 153 |
+
?>
|
app/code/local/Saleswarp/Publish/etc/config.xml
ADDED
|
@@ -0,0 +1,30 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<modules>
|
| 4 |
+
<Saleswarp_Publish>
|
| 5 |
+
<version>0.1.0</version>
|
| 6 |
+
</Saleswarp_Publish>
|
| 7 |
+
</modules>
|
| 8 |
+
<global>
|
| 9 |
+
<helpers>
|
| 10 |
+
<publish>
|
| 11 |
+
<class>Saleswarp_Publish_Helper</class>
|
| 12 |
+
</publish>
|
| 13 |
+
</helpers>
|
| 14 |
+
<models>
|
| 15 |
+
<publish>
|
| 16 |
+
<class>Saleswarp_Publish_Model</class>
|
| 17 |
+
</publish>
|
| 18 |
+
<oms>
|
| 19 |
+
<rewrite>
|
| 20 |
+
<config_api>Saleswarp_Publish_Model_Config_Api</config_api>
|
| 21 |
+
<product_api>Saleswarp_Publish_Model_Product_Api</product_api>
|
| 22 |
+
<category_api>Saleswarp_Publish_Model_Category_Api</category_api>
|
| 23 |
+
<customer_api>Saleswarp_Publish_Model_Customer_Api</customer_api>
|
| 24 |
+
<product_attribute_api>Saleswarp_Publish_Model_Product_Attribute_Media_Api</product_attribute_api>
|
| 25 |
+
<product_attribute_media_api>Saleswarp_Publish_Model_Product_Attribute_Media_Api</product_attribute_media_api>
|
| 26 |
+
</rewrite>
|
| 27 |
+
</oms>
|
| 28 |
+
</models>
|
| 29 |
+
</global>
|
| 30 |
+
</config>
|
app/code/local/Saleswarp/WhitelistIP/Helper/Data.php
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
class Saleswarp_WhitelistIP_Helper_Data extends Mage_Core_Helper_Abstract
|
| 3 |
+
{
|
| 4 |
+
}
|
| 5 |
+
|
app/code/local/Saleswarp/WhitelistIP/controllers/FastapiController.php
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?php
|
| 2 |
+
require_once Mage::getModuleDir('controllers', 'Saleswarp_Oms') . DS . "FastapiController.php";
|
| 3 |
+
|
| 4 |
+
class Saleswarp_WhitelistIP_FastapiController extends Saleswarp_Oms_FastapiController {
|
| 5 |
+
|
| 6 |
+
/**
|
| 7 |
+
* Authentication API request
|
| 8 |
+
*
|
| 9 |
+
* @params string hash key
|
| 10 |
+
* @return bool(trur or false)
|
| 11 |
+
*/
|
| 12 |
+
public function ApiAuthentication($hash = null)
|
| 13 |
+
{
|
| 14 |
+
if(empty($hash)) {
|
| 15 |
+
$this->authError = 'No hash key supplied';
|
| 16 |
+
return false;
|
| 17 |
+
} else {
|
| 18 |
+
$mageHash = Mage::getStoreConfig('oms/registration/key');
|
| 19 |
+
$useIpWhitelist = Mage::getStoreConfig('oms/ipwhitelist/enable');
|
| 20 |
+
$allowedIPs = Mage::getStoreConfig('oms/ipwhitelist/list');
|
| 21 |
+
|
| 22 |
+
// get user ip address
|
| 23 |
+
$remoteIP = Mage::helper('core/http')->getRemoteAddr(false);
|
| 24 |
+
if (!empty($mageHash) && $hash == $mageHash) {
|
| 25 |
+
if ($useIpWhitelist && !in_array($remoteIP, explode(',',$allowedIPs))) {
|
| 26 |
+
$this->authError = 'IP not allowed';
|
| 27 |
+
return false;
|
| 28 |
+
}
|
| 29 |
+
return true;
|
| 30 |
+
} else {
|
| 31 |
+
$this->authError = 'Incorrect Hash key';
|
| 32 |
+
return false;
|
| 33 |
+
}
|
| 34 |
+
}
|
| 35 |
+
}
|
| 36 |
+
}
|
app/code/local/Saleswarp/WhitelistIP/etc/config.xml
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<modules>
|
| 4 |
+
<Saleswarp_WhitelistIP>
|
| 5 |
+
<version>0.1.0</version>
|
| 6 |
+
</Saleswarp_WhitelistIP>
|
| 7 |
+
</modules>
|
| 8 |
+
<frontend>
|
| 9 |
+
<routers>
|
| 10 |
+
<oms>
|
| 11 |
+
<args>
|
| 12 |
+
<modules>
|
| 13 |
+
<saleswarp_whitelistip before="Saleswarp_Oms">Saleswarp_WhitelistIP</saleswarp_whitelistip>
|
| 14 |
+
</modules>
|
| 15 |
+
</args>
|
| 16 |
+
</oms>
|
| 17 |
+
</routers>
|
| 18 |
+
</frontend>
|
| 19 |
+
</config>
|
app/code/local/Saleswarp/WhitelistIP/etc/system.xml
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<sections>
|
| 4 |
+
<oms translate="label">
|
| 5 |
+
<groups>
|
| 6 |
+
<ipwhitelist translate="label">
|
| 7 |
+
<label>IP Whitelist</label>
|
| 8 |
+
<frontend_type>text</frontend_type>
|
| 9 |
+
<sort_order>100</sort_order>
|
| 10 |
+
<show_in_default>1</show_in_default>
|
| 11 |
+
<show_in_website>0</show_in_website>
|
| 12 |
+
<show_in_store>0</show_in_store>
|
| 13 |
+
<fields>
|
| 14 |
+
<enable translate="label">
|
| 15 |
+
<label>Enable IP Whitelist</label>
|
| 16 |
+
<frontend_type>select</frontend_type>
|
| 17 |
+
<source_model>adminhtml/system_config_source_yesno</source_model>
|
| 18 |
+
<sort_order>10</sort_order>
|
| 19 |
+
<show_in_default>1</show_in_default>
|
| 20 |
+
<show_in_website>0</show_in_website>
|
| 21 |
+
<show_in_store>0</show_in_store>
|
| 22 |
+
</enable>
|
| 23 |
+
<list translate="label">
|
| 24 |
+
<label>Allowed IPs:</label>
|
| 25 |
+
<frontend_type>text</frontend_type>
|
| 26 |
+
<sort_order>20</sort_order>
|
| 27 |
+
<show_in_default>1</show_in_default>
|
| 28 |
+
<show_in_website>0</show_in_website>
|
| 29 |
+
<show_in_store>0</show_in_store>
|
| 30 |
+
<comment>Enter IP List( 8.8.8.8, 4.4.4.4)</comment>
|
| 31 |
+
</list>
|
| 32 |
+
</fields>
|
| 33 |
+
</ipwhitelist>
|
| 34 |
+
</groups>
|
| 35 |
+
</oms>
|
| 36 |
+
</sections>
|
| 37 |
+
</config>
|
app/design/adminhtml/default/default/template/oms/form/saleswarp.phtml
CHANGED
|
@@ -1,17 +1,17 @@
|
|
| 1 |
-
<div class="form-list" id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none;">
|
| 2 |
-
<div>
|
| 3 |
-
<label><?php echo $this->__('Transction No') ?>*</label>
|
| 4 |
-
<span>
|
| 5 |
-
<input type="text" title="<?php echo $this->__('Transction No') ?>" name="payment[transction_no]" value="<?php echo $this->htmlEscape($this->getInfoData('transction_no')) ?>" />
|
| 6 |
-
</span>
|
| 7 |
-
</div>
|
| 8 |
-
<div>
|
| 9 |
-
<label><?php echo $this->__('Payment Method') ?>*</label>
|
| 10 |
-
<span>
|
| 11 |
-
<input type="text" title="<?php echo $this->__('Payment Method') ?>" name="payment[payment_method]" value="<?php echo $this->htmlEscape($this->getInfoData('payment_method')) ?>" />
|
| 12 |
-
</span>
|
| 13 |
-
</div>
|
| 14 |
-
</div>
|
| 15 |
-
<div>
|
| 16 |
-
<?php echo $this->getMethod()->getConfigData('message');?>
|
| 17 |
</div>
|
| 1 |
+
<div class="form-list" id="payment_form_<?php echo $this->getMethodCode() ?>" style="display:none;">
|
| 2 |
+
<div>
|
| 3 |
+
<label><?php echo $this->__('Transction No') ?>*</label>
|
| 4 |
+
<span>
|
| 5 |
+
<input type="text" title="<?php echo $this->__('Transction No') ?>" name="payment[transction_no]" value="<?php echo $this->htmlEscape($this->getInfoData('transction_no')) ?>" />
|
| 6 |
+
</span>
|
| 7 |
+
</div>
|
| 8 |
+
<div>
|
| 9 |
+
<label><?php echo $this->__('Payment Method') ?>*</label>
|
| 10 |
+
<span>
|
| 11 |
+
<input type="text" title="<?php echo $this->__('Payment Method') ?>" name="payment[payment_method]" value="<?php echo $this->htmlEscape($this->getInfoData('payment_method')) ?>" />
|
| 12 |
+
</span>
|
| 13 |
+
</div>
|
| 14 |
+
</div>
|
| 15 |
+
<div>
|
| 16 |
+
<?php echo $this->getMethod()->getConfigData('message');?>
|
| 17 |
</div>
|
app/design/adminhtml/default/default/template/oms/system/config/button.phtml
CHANGED
|
@@ -1,36 +1,36 @@
|
|
| 1 |
-
<?php if($this->isKeyAvailable()) { ?>
|
| 2 |
-
<?php $data = $this->getKeyData(); ?>
|
| 3 |
-
<a href="<?php echo $data['create_url']; ?>" target="_blank">Create New Account</a>
|
| 4 |
-
|
|
| 5 |
-
<a href="<?php echo $data['login_url']; ?>" target="_blank">Login to existing Account</a>
|
| 6 |
-
<?php } else { ?>
|
| 7 |
-
<script type="text/javascript">
|
| 8 |
-
//<![CDATA[
|
| 9 |
-
function getKey() {
|
| 10 |
-
new Ajax.Request('<?php echo $this->getAjaxCheckUrl() ?>', {
|
| 11 |
-
method: 'get',
|
| 12 |
-
onSuccess: function(transport){
|
| 13 |
-
var data = transport.responseText.evalJSON(true);
|
| 14 |
-
if (data.success == 1) {
|
| 15 |
-
$('layer_get_key').innerHTML = "";
|
| 16 |
-
$('layer_get_key_links').style.display = 'block';
|
| 17 |
-
$('oms_registration_key').value = data.key;
|
| 18 |
-
configForm.submit();
|
| 19 |
-
} else {
|
| 20 |
-
alert('Error while making the key request, kindly confirm that the api URL and other details under custom variables.');
|
| 21 |
-
}
|
| 22 |
-
}
|
| 23 |
-
});
|
| 24 |
-
}
|
| 25 |
-
//]]>
|
| 26 |
-
</script>
|
| 27 |
-
<div id="layer_get_key">
|
| 28 |
-
<?php echo $this->getButtonHtml() ?>
|
| 29 |
-
</div>
|
| 30 |
-
<div id="layer_get_key_links" style="display:none;">
|
| 31 |
-
<?php $data = $this->getKeyData(); ?>
|
| 32 |
-
<a href="<?php echo $data['create_url']; ?>" target="_blank">Create New Account</a>
|
| 33 |
-
|
|
| 34 |
-
<a href="<?php echo $data['login_url']; ?>" target="_blank">Login to existing Account</a>
|
| 35 |
-
</div>
|
| 36 |
<?php } ?>
|
| 1 |
+
<?php if($this->isKeyAvailable()) { ?>
|
| 2 |
+
<?php $data = $this->getKeyData(); ?>
|
| 3 |
+
<a href="<?php echo $data['create_url']; ?>" target="_blank">Create New Account</a>
|
| 4 |
+
|
|
| 5 |
+
<a href="<?php echo $data['login_url']; ?>" target="_blank">Login to existing Account</a>
|
| 6 |
+
<?php } else { ?>
|
| 7 |
+
<script type="text/javascript">
|
| 8 |
+
//<![CDATA[
|
| 9 |
+
function getKey() {
|
| 10 |
+
new Ajax.Request('<?php echo $this->getAjaxCheckUrl() ?>', {
|
| 11 |
+
method: 'get',
|
| 12 |
+
onSuccess: function(transport){
|
| 13 |
+
var data = transport.responseText.evalJSON(true);
|
| 14 |
+
if (data.success == 1) {
|
| 15 |
+
$('layer_get_key').innerHTML = "";
|
| 16 |
+
$('layer_get_key_links').style.display = 'block';
|
| 17 |
+
$('oms_registration_key').value = data.key;
|
| 18 |
+
configForm.submit();
|
| 19 |
+
} else {
|
| 20 |
+
alert('Error while making the key request, kindly confirm that the api URL and other details under custom variables.');
|
| 21 |
+
}
|
| 22 |
+
}
|
| 23 |
+
});
|
| 24 |
+
}
|
| 25 |
+
//]]>
|
| 26 |
+
</script>
|
| 27 |
+
<div id="layer_get_key">
|
| 28 |
+
<?php echo $this->getButtonHtml() ?>
|
| 29 |
+
</div>
|
| 30 |
+
<div id="layer_get_key_links" style="display:none;">
|
| 31 |
+
<?php $data = $this->getKeyData(); ?>
|
| 32 |
+
<a href="<?php echo $data['create_url']; ?>" target="_blank">Create New Account</a>
|
| 33 |
+
|
|
| 34 |
+
<a href="<?php echo $data['login_url']; ?>" target="_blank">Login to existing Account</a>
|
| 35 |
+
</div>
|
| 36 |
<?php } ?>
|
app/etc/modules/Saleswarp_Oms.xml
CHANGED
|
@@ -1,10 +1,10 @@
|
|
| 1 |
-
<?xml version="1.0"?>
|
| 2 |
-
<config>
|
| 3 |
-
<modules>
|
| 4 |
-
<Saleswarp_Oms>
|
| 5 |
-
<active>true</active>
|
| 6 |
-
<codePool>local</codePool>
|
| 7 |
-
<version>0.1.0</version>
|
| 8 |
-
</Saleswarp_Oms>
|
| 9 |
-
</modules>
|
| 10 |
</config>
|
| 1 |
+
<?xml version="1.0"?>
|
| 2 |
+
<config>
|
| 3 |
+
<modules>
|
| 4 |
+
<Saleswarp_Oms>
|
| 5 |
+
<active>true</active>
|
| 6 |
+
<codePool>local</codePool>
|
| 7 |
+
<version>0.1.0</version>
|
| 8 |
+
</Saleswarp_Oms>
|
| 9 |
+
</modules>
|
| 10 |
</config>
|
package.xml
CHANGED
|
@@ -1,18 +1,18 @@
|
|
| 1 |
<?xml version="1.0"?>
|
| 2 |
<package>
|
| 3 |
<name>Saleswarp_Oms</name>
|
| 4 |
-
<version>0.1.
|
| 5 |
<stability>stable</stability>
|
| 6 |
-
<license uri="https://www.saleswarp.com/license-saas/">
|
| 7 |
<channel>community</channel>
|
| 8 |
<extends/>
|
| 9 |
<summary>Saleswarp Order Management System</summary>
|
| 10 |
<description>This module connects Magento to the Saleswarp Advanced Order Management Software for omnichannel management. See our website for more details.</description>
|
| 11 |
<notes>Production version</notes>
|
| 12 |
<authors><author><name>David Potts</name><user>David</user><email>sales@saleswarp.com</email></author></authors>
|
| 13 |
-
<date>
|
| 14 |
-
<time>
|
| 15 |
-
<contents><target name="
|
| 16 |
<compatible/>
|
| 17 |
<dependencies><required><php><min>5.0.0</min><max>6.0.0</max></php></required></dependencies>
|
| 18 |
</package>
|
| 1 |
<?xml version="1.0"?>
|
| 2 |
<package>
|
| 3 |
<name>Saleswarp_Oms</name>
|
| 4 |
+
<version>0.1.3</version>
|
| 5 |
<stability>stable</stability>
|
| 6 |
+
<license uri="https://www.saleswarp.com/license-saas/">commercial</license>
|
| 7 |
<channel>community</channel>
|
| 8 |
<extends/>
|
| 9 |
<summary>Saleswarp Order Management System</summary>
|
| 10 |
<description>This module connects Magento to the Saleswarp Advanced Order Management Software for omnichannel management. See our website for more details.</description>
|
| 11 |
<notes>Production version</notes>
|
| 12 |
<authors><author><name>David Potts</name><user>David</user><email>sales@saleswarp.com</email></author></authors>
|
| 13 |
+
<date>2017-01-06</date>
|
| 14 |
+
<time>17:45:59</time>
|
| 15 |
+
<contents><target name="magelocal"><dir name="Saleswarp"><dir name="Oms"><dir name="Block"><dir name="Adminhtml"><dir name="System"><dir name="Config"><dir name="Form"><file name="Button.php" hash="fcb650f22b9d384b31b90405000d5b56"/><file name="Key.php" hash="4a8e3c9111fee50573c6e07fc56d0153"/></dir></dir></dir></dir><dir name="Form"><file name="Saleswarp.php" hash="965669ba0523ccb8ecc5677bb249924f"/></dir><dir name="Info"><file name="Saleswarp.php" hash="600aefd58cdf840fb7a5019563621993"/></dir></dir><dir name="Helper"><file name="Data.php" hash="87e8f9369c3a149fda35b50630d0315f"/></dir><dir name="Model"><dir name="Category"><file name="Api.php" hash="dc0a5ffc89fab4ac0465907f947c301e"/></dir><dir name="Config"><file name="Api.php" hash="b25087d2a3607663158a10eaa8eccae1"/></dir><dir name="Customer"><file name="Api.php" hash="cd09e73655269bf8a76461010c0ece7a"/></dir><dir name="Order"><file name="Api.php" hash="c8bd9f3fcc60e61550bb25021766d47e"/></dir><dir name="Product"><file name="Api.php" hash="11bd9d9c46efcdc9a23b57963e123f35"/><dir name="Attribute"><file name="Api.php" hash="52a64badb47619eb3a15a7f2ed6b6a40"/><dir name="Media"><file name="Api.php" hash="7333cf13a3500779a737bfee9f4fe676"/></dir></dir></dir><file name="Saleswarp.php" hash="7227d0c22a4aadf06b0cfa59895062ee"/></dir><dir name="controllers"><dir name="Adminhtml"><file name="GetkeyController.php" hash="a110882cd28cebe8354a9a2788c8252b"/></dir><file name="FastapiController.php" hash="8b1c8c5a832630402fde8400fd195ebf"/></dir><dir name="etc"><file name="adminhtml.xml" hash="065c0883d726cf19b87b19509859f668"/><file name="config.xml" hash="57af03d54703905462369b9caf510f5d"/><file name="system.xml" hash="b38eeac0d69ea52d857dcae421f57644"/></dir><dir name="sql"><dir name="oms_setup"><file name="mysql4-install-0.1.1.php" hash="44d2a6b20d56f29001c02c739d02bb51"/><file name="mysql4-upgrade-0.1.2.php" hash="e02de13c86fae519a362a9951881f055"/></dir></dir></dir><dir name="Publish"><dir name="Helper"><file name="Data.php" hash="c89ac5bf5870771030f2b0a320683ad4"/></dir><dir name="Model"><dir name="Category"><file name="Api.php" hash="e75c88dc2f9fc17556a27bed43c43daa"/></dir><dir name="Config"><file name="Api.php" hash="563ffd735d56faf8421c510aeb3c397e"/></dir><dir name="Customer"><file name="Api.php" hash="34dcdfed7c4bcefde4bf438b4311d705"/></dir><dir name="Product"><file name="Api.php" hash="fc7822a6da6e74b059e6944433ab6696"/><dir name="Attribute"><file name="Api.php" hash="b3d99a16223c88b721a338943722d26f"/><dir name="Media"><file name="Api.php" hash="f94406d8cf2afc06304bbfcd0f0a592f"/></dir></dir></dir></dir><dir name="etc"><file name="config.xml" hash="9488190e3433b6794682b3df613bd366"/></dir></dir><dir name="WhitelistIP"><dir name="Helper"><file name="Data.php" hash="8540c7d74bff5a7498f6263625b2dcd1"/></dir><dir name="controllers"><file name="FastapiController.php" hash="8deea48340058253fc765d909e190727"/></dir><dir name="etc"><file name="config.xml" hash="e65962723b4151a92c01f484f78c874b"/><file name="system.xml" hash="ba40514d68fdc6d30456c3622e9b1f40"/></dir></dir></dir></target><target name="magedesign"><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="template"><dir name="oms"><dir name="form"><file name="saleswarp.phtml" hash="a4cf6bc4ceb31feb254701d57710ad4d"/></dir><dir name="system"><dir name="config"><file name="button.phtml" hash="0914b2e4793fed8f54b9fd033d05575e"/></dir></dir></dir></dir></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="Saleswarp_Oms.xml" hash="798e9d50c381b103bde3958dd3a87580"/></dir></target></contents>
|
| 16 |
<compatible/>
|
| 17 |
<dependencies><required><php><min>5.0.0</min><max>6.0.0</max></php></required></dependencies>
|
| 18 |
</package>
|
