1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 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 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
<?php
/* --------------------------------------------------------------
GXParcelTrackingCodeWriter.php 2018-01-11
Gambio GmbH
http://www.gambio.de
Copyright (c) 2018 Gambio GmbH
Released under the GNU General Public License (Version 2)
[http://www.gnu.org/licenses/gpl-2.0.html]
--------------------------------------------------------------
*/
/**
* Class GXParcelTrackingCodeWriter
*/
class GXParcelTrackingCodeWriter
{
/**
* @var \CI_DB_query_builder
*/
protected $db;
/**
* @var string
*/
protected $table = 'orders_parcel_tracking_codes';
/**
* TrackingCodesWriter constructor.
*
* @param \CI_DB_query_builder $db
*/
public function __construct(CI_DB_query_builder $db)
{
$this->db = $db;
}
/**
* Saves the given order tracking code information in the order parcel tracking codes table.
* Data for parcel service name, url and comment is fetched from related tables.
*
* @param \ParcelTrackingCodeServiceId $parcelServiceId Id of parcel service.
* @param \ParcelTrackingCodeOrderId $orderId Id of order.
* @param \OrderParcelTrackingCode $trackingCode Tracking code for order.
* @param \ParcelTrackingCodeLanguageId $languageId Id of selected language.
*
* @return \ParcelTrackingCodeId Id of new order parcel tracking code.
*/
public function save(ParcelTrackingCodeServiceId $parcelServiceId,
ParcelTrackingCodeOrderId $orderId,
OrderParcelTrackingCode $trackingCode,
ParcelTrackingCodeLanguageId $languageId)
{
$parcelServiceDescription = $this->db->select('ps.name, psd.url, psd.comment')
->from('parcel_services as ps')
->join('parcel_services_description as psd',
'ps.parcel_service_id = psd.parcel_service_id')
->where('ps.parcel_service_id', $parcelServiceId->is())
->where('psd.language_id', $languageId->is())
->get()
->row_array();
if(!$parcelServiceDescription)
{
throw new InvalidArgumentException('Can not find related parcel service description for given parcel service id "'
. $parcelServiceId->is() . '" and language id "' . $languageId->is()
. '".');
}
$this->db->insert($this->table, [
'order_id' => $orderId->is(),
'tracking_code' => $trackingCode->is(),
'parcel_service_id' => $parcelServiceId->is(),
'language_id' => $languageId->is(),
'parcel_service_name' => $parcelServiceDescription['name'],
'url' => str_replace('{TRACKING_NUMBER}', $trackingCode->is(),
$parcelServiceDescription['url']),
'comment' => $parcelServiceDescription['comment']
]);
return ParcelTrackingCodeId::create($this->db->insert_id());
}
/**
* Saves the given order tracking code information in the order parcel tracking codes table.
* Only the provided data is stored in the database.
*
* @param \ParcelTrackingCodeOrderId $orderId Id of order.
* @param \ParcelTrackingCodeServiceName $name Name of parcel service.
* @param \ParcelTrackingCodeUrl $url Tracking code url for order.
* @param \ParcelTrackingCodeComment|null $comment Comment about tracking code.
*
* @return \ParcelTrackingCodeId Id of new order parcel tracking code.
*/
public function saveLightweight(ParcelTrackingCodeOrderId $orderId,
ParcelTrackingCodeServiceName $name,
ParcelTrackingCodeUrl $url,
ParcelTrackingCodeComment $comment = null)
{
$this->db->insert($this->table, [
'order_id' => $orderId->is(),
'parcel_service_name' => $name->is(),
'url' => $url->is(),
'comment' => $comment ? $comment->is() : ''
]);
return ParcelTrackingCodeId::create($this->db->insert_id());
}
}