1
0
Fork 0
mirror of synced 2025-04-03 22:03:34 +03:00

Added support WooCommerce 8.2 (HPOS)

This commit is contained in:
Uryvskiy Dima 2023-12-04 09:47:07 +03:00
parent f49cc3870d
commit 617527035d
8 changed files with 162 additions and 267 deletions

View file

@ -144,11 +144,11 @@ abstract class WC_Retailcrm_Abstracts_Settings extends WC_Integration
),
];
foreach (get_post_statuses() as $status_key => $status_value) {
$this->form_fields['p_' . $status_key] = [
'title' => $status_value,
// Used to select product statuses
foreach (get_post_statuses() as $statusKey => $statusValue) {
$this->form_fields['p_' . $statusKey] = [
'title' => $statusValue,
'label' => ' ',
'description' => '',
'class' => 'checkbox',
'type' => 'checkbox',
'desc_tip' => true,
@ -875,6 +875,7 @@ abstract class WC_Retailcrm_Abstracts_Settings extends WC_Integration
*/
public function validate_whatsapp_number_field($key, $value)
{
// Checking the activity of the option for validating a phone number.
$post = $this->get_post_data();
if (!empty($post['woocommerce_integration-retailcrm_whatsapp_active'])) {

View file

@ -170,30 +170,32 @@ class WC_Retailcrm_Response implements \ArrayAccess
return $this->response[$offset];
}
/**
* Returns error string. If there's multiple errors present - they will be squashed into single string.
*
* @return string
*/
public function getErrorString()
{
if ($this->offsetExists('error')) {
return (string) $this->response['error'];
} elseif ($this->offsetExists('errors') && is_array($this->response['errors'])) {
$errorMessage = '';
/**
* Returns error string. If there's multiple errors present - they will be squashed into single string.
*
* @return string
*/
public function getErrorString()
{
if ($this->offsetExists('errorMsg')) {
return (string) $this->response['errorMsg'];
}
foreach ($this->response['errors'] as $error) {
$errorMessage .= $error . ' >';
}
if (is_array($this->response['errors']) && $this->offsetExists('errors')) {
$errorMessage = '';
if (strlen($errorMessage) > 2) {
return (string) substr($errorMessage, 0, strlen($errorMessage) - 2);
}
foreach ($this->response['errors'] as $error) {
$errorMessage .= $error . ' >';
}
return $errorMessage;
}
if (strlen($errorMessage) > 2) {
return (string) substr($errorMessage, 0, strlen($errorMessage) - 2);
}
return '';
return $errorMessage;
}
return '';
}
/**

View file

@ -72,34 +72,40 @@ if (!class_exists('WC_Retailcrm_Orders')) :
/**
* Create order. Returns wc_get_order data or error string.
*
* @param $order_id
* @param $orderId
*
* @return bool|WC_Order|WC_Order_Refund|string
* @return bool|WC_Order|string
* @throws \Exception
*/
public function orderCreate($order_id)
public function orderCreate($orderId)
{
if (!$this->retailcrm instanceof WC_Retailcrm_Proxy) {
return null;
}
$this->order_payment->resetData();
$wcOrder = wc_get_order($order_id);
$this->processOrder($wcOrder);
try {
$this->order_payment->resetData();
$wcOrder = wc_get_order($orderId);
$this->processOrder($wcOrder);
$response = $this->retailcrm->ordersCreate($this->order);
if ($response instanceof WC_Retailcrm_Proxy) {
if ($response->isSuccessful()) {
return $wcOrder;
}
if (!$response instanceof WC_Retailcrm_Response || !$response->isSuccessful()) {
return $response->getErrorString();
}
} catch (InvalidArgumentException $exception) {
return $exception->getMessage();
} catch (Throwable $exception) {
writeBaseLogs(
sprintf(
'Error message: %s, file: %s on line: %s',
$exception->getMessage(),
$exception->getFile(),
$exception->getLine()
)
);
return null;
}
return $wcOrder;
@ -252,25 +258,38 @@ if (!class_exists('WC_Retailcrm_Orders')) :
/**
* Edit order in CRM
*
* @param int $order_id
* @param int $orderId
*
* @return WC_Order $order | null
* @throws \Exception
*/
public function updateOrder($order_id)
public function updateOrder($orderId)
{
if (!$this->retailcrm instanceof WC_Retailcrm_Proxy) {
return null;
}
$wcOrder = wc_get_order($order_id);
try {
$wcOrder = wc_get_order($orderId);
$this->processOrder($wcOrder, true);
$this->processOrder($wcOrder, true);
$response = $this->retailcrm->ordersEdit($this->order);
$response = $this->retailcrm->ordersEdit($this->order);
if (!empty($response) && $response->isSuccessful()) {
$this->payment = $this->orderUpdatePaymentType($wcOrder);
if ($response instanceof WC_Retailcrm_Response && $response->isSuccessful()) {
$this->payment = $this->orderUpdatePaymentType($wcOrder);
}
} catch (Throwable $exception) {
writeBaseLogs(
sprintf(
'Error message: %s, file: %s on line: %s',
$exception->getMessage(),
$exception->getFile(),
$exception->getLine()
)
);
return null;
}
return $wcOrder;
@ -337,11 +356,11 @@ if (!class_exists('WC_Retailcrm_Orders')) :
return;
}
if ($order->get_status() == 'auto-draft') {
if ('auto-draft' === $order->get_status()) {
return;
}
if ($update === true) {
if ($update) {
$this->orders->is_new = false;
}

View file

@ -59,11 +59,13 @@ if (class_exists('WC_Retailcrm_Uploader') === false) {
*/
public function uploadSelectedOrders()
{
if (!empty($_GET['order_ids_retailcrm'])) {
$ids = array_unique(explode(',', $_GET['order_ids_retailcrm']));
if (!empty($ids)) {
$this->uploadArchiveOrders(0, $ids);
$ids = $_GET['order_ids_retailcrm'];
if (!empty($ids)) {
preg_match_all('/\d+/', $ids, $matches);
if (!empty($matches[0])) {
$this->uploadArchiveOrders(null, $matches[0]);
}
}
}
@ -71,29 +73,31 @@ if (class_exists('WC_Retailcrm_Uploader') === false) {
/**
* Uploads archive order in CRM
*
* @param int $page Number page uploads.
* @param array $ids Ids orders upload.
* @param null|int $page Number page uploads.
* @param array $ids Ids orders upload.
*
* @return void|null
* @throws Exception Invalid argument exception.
*/
public function uploadArchiveOrders($page, $ids = array())
public function uploadArchiveOrders($page, $ids = [])
{
if (!$this->retailcrm instanceof WC_Retailcrm_Proxy) {
return null;
}
$uploadErrors = array();
$ordersCms = $this->getCmsOrders($page, $ids);
$orderIds = [];
$uploadErrors = [];
foreach ($ordersCms as $dataOrder) {
$orderId = $dataOrder->ID;
if (null !== $page) {
$orderIds = $this->getCmsOrders($page);
} elseif ([] !== $ids) {
$orderIds = $ids;
}
foreach ($orderIds as $orderId) {
$errorMessage = $this->orders->orderCreate($orderId);
if (true === is_string($errorMessage)) {
$errorMessage = empty($errorMessage) === true
? 'Order exist. External id: ' . $orderId
: $errorMessage;
if (is_string($errorMessage)) {
$uploadErrors[$orderId] = $errorMessage;
}
}
@ -118,7 +122,7 @@ if (class_exists('WC_Retailcrm_Uploader') === false) {
$users = $this->getCmsUsers($page);
if (false === empty($users)) {
$dataCustomers = array();
$dataCustomers = [];
foreach ($users as $user) {
if ($this->customers->isCustomer($user) === false) {
@ -140,20 +144,19 @@ if (class_exists('WC_Retailcrm_Uploader') === false) {
* Return orders ids
*
* @param integer $page Number page uploads.
* @param array $ids Ids orders upload.
*
* @return mixed
*/
private function getCmsOrders($page, $ids = array())
private function getCmsOrders($page)
{
return get_posts(
array(
'numberposts' => self::RETAILCRM_COUNT_OBJECT_UPLOAD,
'offset' => self::RETAILCRM_COUNT_OBJECT_UPLOAD * $page,
'post_type' => wc_get_order_types('view-orders'),
'post_status' => array_keys(wc_get_order_statuses()),
'include' => $ids,
)
return wc_get_orders(
[
'type' => wc_get_order_types('view-orders'),
'limit' => self::RETAILCRM_COUNT_OBJECT_UPLOAD,
'status' => array_keys(wc_get_order_statuses()),
'offset' => self::RETAILCRM_COUNT_OBJECT_UPLOAD * $page,
'return' => 'ids',
]
);
}
@ -179,13 +182,13 @@ if (class_exists('WC_Retailcrm_Uploader') === false) {
*
* @return mixed
*/
private function getCmsUsers($page)
private function getCmsUsers(int $page)
{
return get_users(
array(
[
'number' => self::RETAILCRM_COUNT_OBJECT_UPLOAD,
'offset' => self::RETAILCRM_COUNT_OBJECT_UPLOAD * $page,
)
]
);
}

View file

@ -1,5 +1,7 @@
<?php
use Automattic\WooCommerce\Utilities\FeaturesUtil;
if (! defined('ABSPATH')) {
exit; // Exit if accessed directly
}
@ -189,5 +191,15 @@ function calculatePriceExcludingTax($priceIncludingTax, $rate)
*/
function writeBaseLogs($message)
{
WC_Retailcrm_Logger::addCaller(__METHOD__, $message);
WC_Retailcrm_Logger::debug(__METHOD__, $message);
}
// TODO добавить правильно
add_action('before_woocommerce_init', function() {
if ( class_exists( FeaturesUtil::class ) ) {
FeaturesUtil::declare_compatibility( 'custom_order_tables', 'retailcrm.php', true);
}
} );

View file

@ -327,26 +327,28 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
{
$this->deleteAllData();
$this->regenerateMocks();
$order_id = $this->history_order_create_for_changing_customer();
$this->assertNotEmpty($order_id);
$orderId = $this->history_order_create_for_changing_customer();
$this->assertNotEmpty($orderId);
$this->regenerateMocks();
$this->history_order_switch_customer($order_id);
$this->history_order_switch_customer($orderId);
$this->regenerateMocks();
$this->history_order_switch_customer_to_corporate($order_id);
$this->history_order_switch_customer_to_corporate($orderId);
$this->regenerateMocks();
$this->history_order_switch_customer_to_another_corporate($order_id);
$this->history_order_switch_customer_to_another_corporate($orderId);
$this->regenerateMocks();
$this->history_order_switch_only_company($order_id);
$this->history_order_switch_only_company($orderId);
$this->regenerateMocks();
$this->history_order_switch_only_contact($order_id);
$this->history_order_switch_only_contact($orderId);
$this->regenerateMocks();
$this->history_order_switch_back_to_individual($order_id);
$this->history_order_switch_back_to_individual($orderId);
}
public function history_order_create_for_changing_customer()
@ -376,16 +378,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_customer($order_id)
public function history_order_switch_customer(int $orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_to_another_individual($order_id)
DataHistoryRetailCrm::get_history_change_to_another_individual($orderId)
);
$this->ordersGetMock(
@ -396,31 +398,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('tester002', $order->get_billing_first_name());
$this->assertEquals('tester002', $order->get_billing_last_name());
@ -437,16 +415,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_customer_to_corporate($order_id)
public function history_order_switch_customer_to_corporate(int $orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_to_corporate($order_id)
DataHistoryRetailCrm::get_history_change_to_corporate($orderId)
);
$this->ordersGetMock(
@ -462,31 +440,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('psycho913', $order->get_billing_first_name());
$this->assertEquals('psycho913', $order->get_billing_last_name());
@ -500,16 +454,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_customer_to_another_corporate($order_id)
public function history_order_switch_customer_to_another_corporate($orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_to_another_corporate($order_id)
DataHistoryRetailCrm::get_history_change_to_another_corporate($orderId)
);
$this->ordersGetMock(
@ -525,31 +479,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('Tester4867', $order->get_billing_first_name());
$this->assertEquals('Tester4867', $order->get_billing_last_name());
@ -564,16 +494,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_only_company($order_id)
public function history_order_switch_only_company(int $orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_only_company($order_id)
DataHistoryRetailCrm::get_history_change_only_company($orderId)
);
$this->ordersGetMock(
@ -589,31 +519,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('Tester4867', $order->get_billing_first_name());
$this->assertEquals('Tester4867', $order->get_billing_last_name());
@ -628,16 +534,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_only_contact($order_id)
public function history_order_switch_only_contact(int $orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_only_contact($order_id)
DataHistoryRetailCrm::get_history_change_only_contact($orderId)
);
$this->ordersGetMock(
@ -653,31 +559,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('Tester2890', $order->get_billing_first_name());
$this->assertEquals('Tester2890', $order->get_billing_last_name());
@ -692,16 +574,16 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
}
/**
* @param int $order_id
* @param int $orderId
*
* @throws \Exception
*/
public function history_order_switch_back_to_individual($order_id)
public function history_order_switch_back_to_individual(int $orderId)
{
$this->mockHistory(
true,
DataHistoryRetailCrm::empty_history(),
DataHistoryRetailCrm::get_history_change_from_corporate_to_individual($order_id)
DataHistoryRetailCrm::get_history_change_from_corporate_to_individual($orderId)
);
$this->ordersGetMock(
@ -712,31 +594,7 @@ class WC_Retailcrm_History_Test extends WC_Retailcrm_Test_Case_Helper
$retailcrm_history = new \WC_Retailcrm_History($this->apiMock);
$retailcrm_history->getHistory();
try {
$order = new WC_Order($order_id);
} catch (\Exception $exception) {
$post = get_post($order_id);
if (!$post instanceof WP_Post) {
$this->fail(sprintf('Cannot find order with id=%d', $order_id));
}
if (!in_array($post->post_type, wc_get_order_types())) {
$this->fail(sprintf(
'Invalid order post type `%s`. Should be one of these: %s',
$post->post_type,
implode(', ', wc_get_order_types())
));
} else {
$this->fail(sprintf(
'Cannot determine what\'s wrong with order id=%d. Message from WooCommerce: %s',
$order_id,
$exception->getMessage()
));
}
return;
}
$order = new WC_Order($orderId);
$this->assertEquals('tester001', $order->get_billing_first_name());
$this->assertEquals('tester001', $order->get_billing_last_name());

View file

@ -55,6 +55,8 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
*/
public function test_order_create($retailcrm)
{
$this->createTestOrder();
if ($retailcrm) {
$responseMock = $this->createResponseMock();
$responseMockCustomers = $this->createResponseMock();
@ -68,13 +70,12 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
]
);
$this->setMockResponse($responseMock, 'isSuccessful', true);
$this->setMockResponse($retailcrm, 'ordersCreate', $responseMock);
$this->setMockResponse($retailcrm, 'customersCreate', $responseMock);
$this->setMockResponse($retailcrm, 'customersList', $responseMockCustomers);
}
$this->createTestOrder();
$retailcrmOrders = $this->getRetailcrmOrders($retailcrm);
$order = $retailcrmOrders->orderCreate($this->order->get_id());
$orderData = $retailcrmOrders->getOrder();
@ -132,6 +133,8 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
*/
public function test_order_create_with_corporate_customer($retailcrm)
{
$this->createTestOrder();
if ($retailcrm) {
$responseMock = $this->createResponseMock();
@ -170,6 +173,7 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
]
);
$this->setMockResponse($responseMock, 'isSuccessful', true);
$this->setMockResponse($retailcrm, 'ordersCreate', $responseMock);
$this->setMockResponse($retailcrm, 'getSingleSiteForKey', 'woo');
$this->setMockResponse($retailcrm, 'customersCorporateCreate', $responseMockCustomerCorporate);
@ -180,8 +184,6 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
$this->setMockResponse($retailcrm, 'customersCorporateCompanies', $responseMockCompany);
}
$this->createTestOrder();
$retailcrmOrders = $this->getRetailcrmOrders($retailcrm);
$order = $retailcrmOrders->orderCreate($this->order->get_id());
$orderData = $retailcrmOrders->getOrder();
@ -609,14 +611,12 @@ class WC_Retailcrm_Orders_Test extends WC_Retailcrm_Test_Case_Helper
}
}
$this->order->add_meta_data('woo_order', 'test_custom_fields');
$this->order->add_meta_data('crm_phone', '1111122222');
$this->order->add_meta_data('crm_address_text', 'crm_address_text_test');
$this->order->add_meta_data('crm_customer_comment', 'crm_customer_comment_test');
$this->order->save();
$orderId = $this->order->get_id();
update_post_meta($orderId, 'woo_order', 'test_custom_fields');
update_post_meta($orderId, 'crm_phone', '1111122222');
update_post_meta($orderId, 'crm_address_text', 'crm_address_text_test');
update_post_meta($orderId, 'crm_customer_comment', 'crm_customer_comment_test');
}
private function getResponseData($externalId)

View file

@ -87,7 +87,7 @@ class WC_Retailcrm_Uploader_Test extends WC_Retailcrm_Test_Case_Helper
public function test_order_upload($retailcrm)
{
$retailcrm_uploader = $this->getRetailcrmUploader($retailcrm);
$data = $retailcrm_uploader->uploadArchiveOrders(0);
$data = $retailcrm_uploader->uploadArchiveOrders(null);
$this->assertEquals(null, $data);
}