From 8ff50bf92d925c346f753aaf50352a763e7ae374 Mon Sep 17 00:00:00 2001 From: Maicon Antonio Date: Wed, 17 May 2023 23:37:26 +0000 Subject: [PATCH 1/3] fix: correction of api invoice order and add origin zip code in the intelipost shipments --- Api/Data/InvoiceInterface.php | 2 ++ Api/Data/ShipmentInterface.php | 13 +++++++++++++ .../Order/View/Tab/Intelipost/Labels.php | 2 +- Client/AbstractShipment.php | 3 +-- Client/ShipmentOrder.php | 9 +++++---- Client/ShipmentOrder/Invoice.php | 12 ++++++------ Cron/ImportLabels.php | 6 ++++++ Model/Invoice.php | 16 ++++++++++++++++ Model/ResourceModel/InvoiceRepository.php | 7 ++++++- Model/Shipment.php | 16 ++++++++++++++++ composer.json | 2 +- etc/adminhtml/system.xml | 2 +- etc/db_schema.xml | 8 ++++++++ etc/module.xml | 2 +- 14 files changed, 83 insertions(+), 17 deletions(-) diff --git a/Api/Data/InvoiceInterface.php b/Api/Data/InvoiceInterface.php index 2e039b2..c963157 100644 --- a/Api/Data/InvoiceInterface.php +++ b/Api/Data/InvoiceInterface.php @@ -16,6 +16,8 @@ interface InvoiceInterface const ENTITY_ID = 'entity_id'; const NUMBER = 'number'; const ORDER_INCREMENT_ID = 'order_increment_id'; + + const INTELIPOST_SHIPMENT_ID = 'intelipost_shipment_id'; const SERIES = 'series'; const KEY = 'key'; const DATE = 'date'; diff --git a/Api/Data/ShipmentInterface.php b/Api/Data/ShipmentInterface.php index f6dae7d..e35aa3d 100644 --- a/Api/Data/ShipmentInterface.php +++ b/Api/Data/ShipmentInterface.php @@ -31,6 +31,8 @@ interface ShipmentInterface const TRACKING_URL = 'tracking_url'; const INTELIPOST_MESSAGE = 'intelipost_message'; const PRODUCTS_IDS = 'products_ids'; + + const ORIGIN_ZIP_CODE = 'origin_zip_code'; const DELIVERY_ESTIMATE_DATE_EXACT_ISO = 'delivery_estimate_date_exact_iso'; const SELECTED_SCHEDULING_DATE = 'selected_scheduling_date'; const CREATED_AT = 'created_at'; @@ -278,6 +280,17 @@ public function getProductsIds(); */ public function setProductsIds($productsIds); + /** + * @return string + */ + public function getOriginZipCode(); + + /** + * @param $originZipCode + * @return void + */ + public function setOriginZipCode($originZipCode); + /** * @return string */ diff --git a/Block/Adminhtml/Order/View/Tab/Intelipost/Labels.php b/Block/Adminhtml/Order/View/Tab/Intelipost/Labels.php index 246e3bc..ccd485f 100644 --- a/Block/Adminhtml/Order/View/Tab/Intelipost/Labels.php +++ b/Block/Adminhtml/Order/View/Tab/Intelipost/Labels.php @@ -71,7 +71,7 @@ public function hasOrderCreated() public function getLabelsCollection() { $collection = $this->labelsCollectionFactory->create(); - $collection->addFieldToFilter('order_increment_id', $this->getOrder()->getIncrementId()); + $collection->addFieldToFilter('order_increment_id', ['like' => '%' . $this->getOrder()->getIncrementId() . '%']); return $collection; } } diff --git a/Client/AbstractShipment.php b/Client/AbstractShipment.php index 4d6621f..45f6200 100644 --- a/Client/AbstractShipment.php +++ b/Client/AbstractShipment.php @@ -64,8 +64,7 @@ public function prepareRequestBody($shipment) if (!$byShipment) { $body->order_number = $shipment->getData('order_increment_id'); } else { - $body->order_number = $shipment->getData('intelipost_shipment_id') - ?: $shipment->getData('order_increment_id'); + $body->order_number = $shipment->getData('intelipost_shipment_id'); } $body->event_date = str_replace(' ', 'T', $eventDate); diff --git a/Client/ShipmentOrder.php b/Client/ShipmentOrder.php index 9664bb2..89cf2ab 100644 --- a/Client/ShipmentOrder.php +++ b/Client/ShipmentOrder.php @@ -135,8 +135,8 @@ public function getShipment($shipment) $estimateDate = (string) $shipment->getData('delivery_estimate_date_exact_iso'); $body = new \stdClass(); - $body->order_number = $shipment->getData('intelipost_shipment_id') - ?: $shipment->getData('order_increment_id'); + $body->order_number = $shipment->getData('intelipost_shipment_id'); + $body->origin_zip_code = $shipment->getData('origin_zip_code'); $body->quote_id = $shipment->getData('quote_id'); $body->sales_order_number = $shipment->getData('increment_id'); $body->delivery_method_id = $shipment->getData('delivery_method_id'); @@ -162,7 +162,7 @@ public function getShipment($shipment) */ public function getVolumes($shipment) { - $volume = $this->shipmentInvoice->getInformation($shipment->getData('order_increment_id')); + $volume = $this->shipmentInvoice->getInformation($shipment->getData('intelipost_shipment_id')); return $this->shipmentVolume->getInformation( $shipment->getData('volumes'), $volume @@ -179,6 +179,7 @@ public function sendShipmentRequest($requestBody, $shipment) $trackingCode = null; $trackingUrl = null; $incrementId = $shipment->getData('order_increment_id'); + $intelipostShipmentId = $shipment->getData('intelipost_shipment_id'); $response = $this->helperApi->apiRequest('POST', 'shipment_order', $requestBody); $result = $this->helper->unserializeData($response); @@ -217,7 +218,7 @@ public function sendShipmentRequest($requestBody, $shipment) $trackingCode = implode(', ', $trackingCodes); } - $this->requestLabel->importPrintingLabels($incrementId, $volume['shipment_order_volume_number']); + $this->requestLabel->importPrintingLabels($intelipostShipmentId, $volume['shipment_order_volume_number']); } $status = $this->helper->getConfig('created_status', 'order_status', 'intelipost_push'); diff --git a/Client/ShipmentOrder/Invoice.php b/Client/ShipmentOrder/Invoice.php index 0158e0e..18f4da5 100644 --- a/Client/ShipmentOrder/Invoice.php +++ b/Client/ShipmentOrder/Invoice.php @@ -24,12 +24,12 @@ public function __construct(CollectionFactory $collectionFactory) } /** - * @param $orderNumber + * @param $intelipostNumber * @return \stdClass */ - public function getInformation($orderNumber) + public function getInformation($intelipostNumber) { - $invoiceCollection = $this->getInvoiceCollection($orderNumber); + $invoiceCollection = $this->getInvoiceCollection($intelipostNumber); $invoiceObj = new \stdClass(); foreach ($invoiceCollection as $invoice) { $invoiceDate = $invoice->getData('date'); @@ -47,13 +47,13 @@ public function getInformation($orderNumber) } /** - * @param $orderNumber + * @param $intelipostNumber * @return \Intelipost\Shipping\Model\ResourceModel\Invoice\Collection */ - public function getInvoiceCollection($orderNumber) + public function getInvoiceCollection($intelipostNumber) { $collection = $this->collectionFactory->create(); - $collection->addFieldToFilter('order_increment_id', $orderNumber); + $collection->addFieldToFilter('intelipost_shipment_id', $intelipostNumber); return $collection; } } diff --git a/Cron/ImportLabels.php b/Cron/ImportLabels.php index 72bc0d6..d74a922 100644 --- a/Cron/ImportLabels.php +++ b/Cron/ImportLabels.php @@ -81,6 +81,12 @@ public function execute() foreach ($collection as $order) { try { $incrementId = $order->getData('increment_id'); + $intelipostShipmentId = $order->getData('intelipost_shipment_id'); + + if (!empty($intelipostShipmentId) && $byShipment) { + $incrementId = $intelipostShipmentId; + } + $volumes = $this->requestLabel->getVolumes($incrementId); if (!empty($volumes)) { foreach ($volumes as $volume) { diff --git a/Model/Invoice.php b/Model/Invoice.php index b8c34bb..c581c22 100644 --- a/Model/Invoice.php +++ b/Model/Invoice.php @@ -79,6 +79,22 @@ public function getOrderIncrementId() return $this->getData(self::ORDER_INCREMENT_ID); } + /** + * @inheritDoc + */ + public function setIntelipostShipmentId($intelipostNumber) + { + $this->setData(self::INTELIPOST_SHIPMENT_ID, $intelipostNumber); + } + + /** + * @inheritDoc + */ + public function getIntelipostShipmentId() + { + return $this->getData(self::INTELIPOST_SHIPMENT_ID); + } + /** * @inheritDoc */ diff --git a/Model/ResourceModel/InvoiceRepository.php b/Model/ResourceModel/InvoiceRepository.php index e6d04ed..204d9b1 100644 --- a/Model/ResourceModel/InvoiceRepository.php +++ b/Model/ResourceModel/InvoiceRepository.php @@ -86,13 +86,18 @@ public function save( */ public function saveInvoices($invoices) { + foreach ($invoices as $nfe) { + $orderNumber = explode('-', $nfe->getOrderIncrementId()); + $orderNumber = $orderNumber[0]; + /** @var \Intelipost\Shipping\Model\Invoice $invoice */ $invoice = $this->invoiceFactory->create(); $invoice->setId($nfe->getId()); - $invoice->setOrderIncrementId($nfe->getOrderIncrementId()); + $invoice->setOrderIncrementId($orderNumber); + $invoice->setIntelipostShipmentId($nfe->getOrderIncrementId()); $invoice->setSeries($nfe->getSeries()); $invoice->setNumber($nfe->getNumber()); $invoice->setKey($nfe->getKey()); diff --git a/Model/Shipment.php b/Model/Shipment.php index 610afad..ed982bd 100644 --- a/Model/Shipment.php +++ b/Model/Shipment.php @@ -378,6 +378,22 @@ public function setProductsIds($productsIds) $this->setData(self::PRODUCTS_IDS, $productsIds); } + /** + * @inheritDoc + */ + public function getOriginZipCode() + { + return $this->getData(self::ORIGIN_ZIP_CODE); + } + + /** + * @inheritDoc + */ + public function setOriginZipCode($originZipCode) + { + $this->setData(self::ORIGIN_ZIP_CODE, $originZipCode); + } + /** * @inheritDoc */ diff --git a/composer.json b/composer.json index 529637f..4b29fe5 100644 --- a/composer.json +++ b/composer.json @@ -2,7 +2,7 @@ "name": "intelipost/magento2", "description": "Intelipost Shipping", "type": "magento2-module", - "version": "2.6.1", + "version": "2.6.2", "require": { "guzzlehttp/guzzle": ">=6.3.3" }, diff --git a/etc/adminhtml/system.xml b/etc/adminhtml/system.xml index 1172280..e747f49 100644 --- a/etc/adminhtml/system.xml +++ b/etc/adminhtml/system.xml @@ -12,7 +12,7 @@
- In order to use our module, you need Intelipost Credentials and a valid Intelipost account + In order to use our module, you need Intelipost Credentials and a valid Intelipost account (Version 2.6.2) diff --git a/etc/db_schema.xml b/etc/db_schema.xml index 7b939f8..8963f9b 100644 --- a/etc/db_schema.xml +++ b/etc/db_schema.xml @@ -54,6 +54,7 @@ + @@ -72,6 +73,9 @@ + + + @@ -100,6 +104,7 @@ + @@ -110,6 +115,9 @@ + + +
diff --git a/etc/module.xml b/etc/module.xml index efa06a3..426e992 100644 --- a/etc/module.xml +++ b/etc/module.xml @@ -7,7 +7,7 @@ */ --> - + From 9f6784444de69bf2d07010cf14288273aa65dc9d Mon Sep 17 00:00:00 2001 From: Maicon Antonio Date: Thu, 18 May 2023 09:28:05 -0300 Subject: [PATCH 2/3] fix: adjusting validations of the increment id --- Client/AbstractShipment.php | 3 ++- Client/ShipmentOrder.php | 7 +++++-- Client/ShipmentOrder/Invoice.php | 21 ++++++++++++++++++--- Cron/ImportLabels.php | 8 ++------ 4 files changed, 27 insertions(+), 12 deletions(-) diff --git a/Client/AbstractShipment.php b/Client/AbstractShipment.php index 45f6200..4d6621f 100644 --- a/Client/AbstractShipment.php +++ b/Client/AbstractShipment.php @@ -64,7 +64,8 @@ public function prepareRequestBody($shipment) if (!$byShipment) { $body->order_number = $shipment->getData('order_increment_id'); } else { - $body->order_number = $shipment->getData('intelipost_shipment_id'); + $body->order_number = $shipment->getData('intelipost_shipment_id') + ?: $shipment->getData('order_increment_id'); } $body->event_date = str_replace(' ', 'T', $eventDate); diff --git a/Client/ShipmentOrder.php b/Client/ShipmentOrder.php index 89cf2ab..2cea254 100644 --- a/Client/ShipmentOrder.php +++ b/Client/ShipmentOrder.php @@ -162,7 +162,9 @@ public function getShipment($shipment) */ public function getVolumes($shipment) { - $volume = $this->shipmentInvoice->getInformation($shipment->getData('intelipost_shipment_id')); + $incrementId = $shipment->getData('intelipost_shipment_id') + ?: $shipment->getData('order_increment_id'); + $volume = $this->shipmentInvoice->getInformation($incrementId); return $this->shipmentVolume->getInformation( $shipment->getData('volumes'), $volume @@ -179,7 +181,8 @@ public function sendShipmentRequest($requestBody, $shipment) $trackingCode = null; $trackingUrl = null; $incrementId = $shipment->getData('order_increment_id'); - $intelipostShipmentId = $shipment->getData('intelipost_shipment_id'); + $intelipostShipmentId = $shipment->getData('intelipost_shipment_id') + ?: $shipment->getData('order_increment_id');; $response = $this->helperApi->apiRequest('POST', 'shipment_order', $requestBody); $result = $this->helper->unserializeData($response); diff --git a/Client/ShipmentOrder/Invoice.php b/Client/ShipmentOrder/Invoice.php index 18f4da5..6723a59 100644 --- a/Client/ShipmentOrder/Invoice.php +++ b/Client/ShipmentOrder/Invoice.php @@ -9,18 +9,27 @@ namespace Intelipost\Shipping\Client\ShipmentOrder; use Intelipost\Shipping\Model\ResourceModel\Invoice\CollectionFactory; +use Intelipost\Shipping\Helper\Data; class Invoice { + + /** @var Data */ + protected $helper; + /** @var CollectionFactory */ protected $collectionFactory; /** * @param CollectionFactory $collectionFactory + * @param Data $helper */ - public function __construct(CollectionFactory $collectionFactory) - { + public function __construct( + CollectionFactory $collectionFactory, + Data $helper + ) { $this->collectionFactory = $collectionFactory; + $this->helper = $helper; } /** @@ -52,8 +61,14 @@ public function getInformation($intelipostNumber) */ public function getInvoiceCollection($intelipostNumber) { + $byShipment = (boolean) $this->helper->getConfig('order_by_shipment', 'order_status', 'intelipost_push'); + $collection = $this->collectionFactory->create(); - $collection->addFieldToFilter('intelipost_shipment_id', $intelipostNumber); + if ($byShipment) { + $collection->addFieldToFilter('intelipost_shipment_id', $intelipostNumber); + } else { + $collection->addFieldToFilter('order_increment_id', $intelipostNumber); + } return $collection; } } diff --git a/Cron/ImportLabels.php b/Cron/ImportLabels.php index d74a922..b8deae7 100644 --- a/Cron/ImportLabels.php +++ b/Cron/ImportLabels.php @@ -80,12 +80,8 @@ public function execute() foreach ($collection as $order) { try { - $incrementId = $order->getData('increment_id'); - $intelipostShipmentId = $order->getData('intelipost_shipment_id'); - - if (!empty($intelipostShipmentId) && $byShipment) { - $incrementId = $intelipostShipmentId; - } + $incrementId = $order->getData('intelipost_shipment_id') + ?: $order->getData('increment_id'); $volumes = $this->requestLabel->getVolumes($incrementId); if (!empty($volumes)) { From c47cff302e81eccb3a121c4b4ae332de992e4aef Mon Sep 17 00:00:00 2001 From: Maicon Antonio Date: Thu, 18 May 2023 09:30:43 -0300 Subject: [PATCH 3/3] fix: adjusting validations of the increment id 2 --- Client/ShipmentOrder.php | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Client/ShipmentOrder.php b/Client/ShipmentOrder.php index 2cea254..4e1377b 100644 --- a/Client/ShipmentOrder.php +++ b/Client/ShipmentOrder.php @@ -135,7 +135,8 @@ public function getShipment($shipment) $estimateDate = (string) $shipment->getData('delivery_estimate_date_exact_iso'); $body = new \stdClass(); - $body->order_number = $shipment->getData('intelipost_shipment_id'); + $body->order_number = $shipment->getData('intelipost_shipment_id') + ?: $shipment->getData('order_increment_id'); $body->origin_zip_code = $shipment->getData('origin_zip_code'); $body->quote_id = $shipment->getData('quote_id'); $body->sales_order_number = $shipment->getData('increment_id');