2024-05-13 14:43:33 +02:00
< ? php
2024-06-28 13:14:57 +02:00
use Xentral\Components\Logger\Logger ;
2024-05-13 14:43:33 +02:00
/*
* SPDX - FileCopyrightText : 2022 Andreas Palm
2024-05-24 10:10:59 +02:00
* SPDX - FileCopyrightText : 2024 OpenXE project
2024-05-13 14:43:33 +02:00
*
* SPDX - License - Identifier : LicenseRef - EGPL - 3.1
*/
2024-05-22 11:25:35 +02:00
class Shopimporter_Mirakl extends ShopimporterBase {
private $app ;
2024-06-28 13:14:57 +02:00
public $logger ;
2024-05-22 11:25:35 +02:00
private $intern ;
private $shopid ;
private $protocol ;
private $apiKey ;
private $shopUrl ;
2024-05-24 10:53:49 +02:00
private $mirakl_shopid ;
2024-05-22 11:25:35 +02:00
private $idbearbeitung ;
private $idabgeschlossen ;
public $data ;
// TODO
private $langidToIso = [ 3 => 'de' , 1 => 'en' ];
private $taxationByDestinationCountry ;
private $orderSearchLimit ;
2024-06-21 18:07:33 +02:00
private $configuration_identifier ;
2024-06-13 15:51:30 +02:00
2024-06-17 13:09:30 +02:00
private $mirakl_error_text_product_missing ;
2024-08-29 18:09:04 +02:00
private $configuration_order_fetch_status ;
2024-06-17 13:09:30 +02:00
2024-06-18 15:19:19 +02:00
private $normalTaxId ;
private $reducedTaxId ;
2024-06-24 14:45:19 +02:00
private $offer_configuration ;
private $product_configuration ;
2024-05-22 11:25:35 +02:00
public function __construct ( $app , $intern = false ) {
$this -> app = $app ;
2024-06-28 13:14:57 +02:00
$this -> logger = $app -> Container -> get ( 'Logger' );
2024-05-22 11:25:35 +02:00
$this -> intern = $intern ;
if ( $intern )
return ;
2024-05-13 14:43:33 +02:00
}
2024-05-22 11:25:35 +02:00
/*
2024-06-13 15:51:30 +02:00
* See widget . shopexport . php , ShowExtraeinstellungen ()
2024-05-22 11:25:35 +02:00
*/
public function EinstellungenStruktur () {
2024-06-13 15:51:30 +02:00
$einstellungen = [
2024-05-22 11:25:35 +02:00
'ausblenden' => [ 'abholmodus' => [ 'ab_nummer' , 'zeitbereich' ]],
'functions' => [ 'getarticlelist' ],
'felder' => [
'apikey' => [
'typ' => 'text' ,
'bezeichnung' => '{|API Key|}:' ,
'size' => 40 ,
],
'shopurl' => [
'typ' => 'text' ,
'bezeichnung' => '{|Shop URL|}:' ,
'size' => 40 ,
],
2024-05-24 10:53:49 +02:00
'mirakl_shopid' => [
2024-05-22 11:25:35 +02:00
'typ' => 'text' ,
'bezeichnung' => '{|Shop ID des Shops|}:' ,
'size' => 40 ,
'info' => 'optional, int64'
],
2024-06-21 18:07:33 +02:00
'configuration_identifier_source' => [
2024-05-22 11:25:35 +02:00
'typ' => 'select' ,
2024-06-21 18:07:33 +02:00
'bezeichnung' => '{|Konfigurationsidentifizierer-Typ|}:' ,
2024-05-22 11:25:35 +02:00
'size' => 40 ,
2024-06-21 18:07:33 +02:00
'info' => 'Woher soll die Konfiguration des jeweiligen Artikels bezogen werden?' ,
2024-06-13 15:51:30 +02:00
'default' => 'feld' ,
'optionen' => [ 'feld' => '{|Feld|}' , 'freifeld' => '{|Freifeld|}' , 'eigenschaft' => '{|Eigenschaft|}' , 'wert' => '{|Fester Wert|}' ]
2024-05-22 11:25:35 +02:00
],
2024-06-21 18:07:33 +02:00
'configuration_identifier_source_value' => [
2024-05-22 11:25:35 +02:00
'typ' => 'text' ,
2024-06-21 18:07:33 +02:00
'bezeichnung' => '{|Konfigurationsidentifizierer-Wert|}:' ,
2024-05-22 11:25:35 +02:00
'size' => 40 ,
2024-06-13 15:51:30 +02:00
'info' => '' ,
'default' => 'kategoriename'
2024-05-22 11:25:35 +02:00
],
2024-06-17 13:09:30 +02:00
'mirakl_error_text_product_missing' => [
'typ' => 'text' ,
'bezeichnung' => '{|Fehlertext Produkt fehlt|}:' ,
'size' => 40 ,
'info' => 'Der Fehlertext der anzeigt dass das Produkt nicht existiert (Angebotsimport, Fehlerbericht)' ,
'default' => 'The product does not exist'
],
2024-08-29 18:09:04 +02:00
'configuration_order_fetch_status' => [
'typ' => 'text' ,
'bezeichnung' => '{|Status für abzuholende Aufträge|}:' ,
'size' => 40 ,
'info' => 'STAGING, WAITING_ACCEPTANCE, WAITING_DEBIT, WAITING_DEBIT_PAYMENT, SHIPPING, SHIPPED, TO_COLLECT, RECEIVED, CLOSED, REFUSED, CANCELED' ,
'default' => 'WAITING_ACCEPTANCE'
],
2024-06-18 15:19:19 +02:00
'normalTaxId' => [
'typ' => 'text' ,
'bezeichnung' => '{|TaxId für Steuersatz "normal"|}' ,
'size' => 40 ,
],
'reducedTaxId' => [
'typ' => 'text' ,
'bezeichnung' => '{|TaxId für Steuersatz "ermäßigt"|}' ,
'size' => 40 ,
],
2024-06-24 14:45:19 +02:00
'product_configuration' => [
2024-06-15 18:52:46 +02:00
'typ' => 'textarea' ,
2024-06-21 18:07:33 +02:00
'bezeichnung' => '{|Zuordnung Produkt-Felder je Konfiguration (JSON)|}:' ,
2024-06-15 18:52:46 +02:00
'cols' => 80 ,
'rows' => 20 ,
2024-06-21 18:07:33 +02:00
'info' => 'Die Felder werden vom Mirakl-Betreiber vorgegeben. Ist keine Konfiguration definiert, gilt der Eintrag für alle Artikel. Jedes Feld kann wie folgt zugeordnet werden:<br>Artikelfeld: "Mirakel-Feldname": {"feld": "xyz"} oder kurz "Mirakel-Feldname": "xyz",<br>Freifeld: "Mirakel-Feldname": {"freifeld": "Bezeichnung in Shop"} (Siehe Reiter "Freifelder"),<br>Eigenschaft: "Mirakel-Feldname": {"eigenschaft": "Eigenschaftenname xyz"},<br>Fester Wert: "Mirakel-Feldname": {"wert": "xyz"}<br><br>Optionen:<br>Text voranstellen: "praefix: "Dieser Text vorne",<br>Text hinten anstellen: "postfix: "Dieser Text hinten",<br>Standardwert: "standardwert: "Dieser Wert wenn nichts gefunden wurde",<br>Als Zusatzfeld senden: "zusatzfeld": true' ,
2024-06-15 18:52:46 +02:00
'placeholder' => ' [
{
2024-06-21 18:07:33 +02:00
& quot ; konfigurationen & quot ; : [
2024-06-15 18:52:46 +02:00
& quot ; Schuhe & quot ;, & quot ; Hosen & quot ;
],
& quot ; felder & quot ; : {
& quot ; category & quot ; : { & quot ; freifeld & quot ; : & quot ; Kategorie & quot ;},
& quot ; Product . SellerProductID & quot ; : { & quot ; feld & quot ; : & quot ; nummer & quot ;},
& quot ; SHOP . PRODUCT . TITLE & quot ; : { & quot ; feld & quot ; : & quot ; nummer & quot ;},
& quot ; ATT . GLOBAL . Brandname & quot ; : { & quot ; feld & quot ; : & quot ; preis & quot ;},
& quot ; Product . BaseUnit & quot ; : { & quot ; freifeld & quot ; : & quot ; Kategorie & quot ;},
2024-06-21 18:07:33 +02:00
& quot ; ATT . GLOBAL . NoCUperOU & quot ; : { & quot ; eigenschaft & quot ; : & quot ; Mirakl Steuertext & quot ;, & quot ; praefix & quot ; : & quot ; ST -& quot ;},
2024-06-15 18:52:46 +02:00
& quot ; ATT . GLOBAL . NoCUperOU__UNIT & quot ; : { & quot ; wert & quot ; : & quot ; false & quot ;, & quot ; zusatzfeld & quot ; : true },
& quot ; Product . TaxIndicator & quot ; : { & quot ; wert & quot ; : & quot ; 1 & quot ;, & quot ; zusatzfeld & quot ; : true }
}
}
] '
],
2024-06-24 14:45:19 +02:00
'offer_configuration' => [
2024-05-22 11:25:35 +02:00
'typ' => 'textarea' ,
2024-06-21 18:07:33 +02:00
'bezeichnung' => '{|Zuordnung Angebots-Felder je Konfiguration (JSON)|}:' ,
2024-06-13 15:51:30 +02:00
'cols' => 80 ,
'rows' => 20 ,
2024-06-21 18:07:33 +02:00
'info' => '' ,
2024-06-13 15:51:30 +02:00
'placeholder' => ' [
{
2024-06-21 18:07:33 +02:00
& quot ; konfigurationen & quot ; : [
2024-06-13 15:51:30 +02:00
& quot ; Schuhe & quot ;, & quot ; Hosen & quot ;
],
& quot ; felder & quot ; : {
& quot ; product_id_type & quot ; : { & quot ; wert & quot ; : & quot ; SHOP_SKU & quot ;},
& quot ; product_id & quot ; : { & quot ; feld & quot ; : & quot ; nummer & quot ;},
& quot ; shop_sku & quot ; : { & quot ; feld & quot ; : & quot ; nummer & quot ;},
& quot ; price & quot ; : { & quot ; feld & quot ; : & quot ; preis & quot ;},
& quot ; description & quot ; : { & quot ; freifeld & quot ; : & quot ; Kategorie & quot ;},
& quot ; internal_description & quot ; : { & quot ; eigenschaft & quot ; : & quot ; Mirakl Steuertext & quot ;},
& quot ; reversecharge & quot ; : { & quot ; wert & quot ; : & quot ; false & quot ;, & quot ; zusatzfeld & quot ; : true },
& quot ; warehouse & quot ; : { & quot ; wert & quot ; : & quot ; 1 & quot ;, & quot ; zusatzfeld & quot ; : true },
& quot ; quantity & quot ; : { & quot ; feld & quot ; : & quot ; anzahl_lager & quot ;}
}
}
] '
2024-05-22 11:25:35 +02:00
],
2024-06-13 15:51:30 +02:00
'Artikelfelder' => [
'heading' => 'Zusatzinformationen' ,
'typ' => 'info' ,
'text' => 'Folgende Artikelfelder stehen zur Verfügung:' ,
'bezeichnung' => null ,
'info' => 'artikel, artikelid, nummer, inaktiv, name_de, name_en, einheit, hersteller, herstellernummer, ean, artikelnummer_fremdnummern, kurztext_de, kurztext_en, anabregs_text, anabregs_text_en, beschreibung_de, beschreibung_en, uebersicht_de, uebersicht_en, herkunftsland, texteuebertragen, metadescription_de, metadescription_en, metakeywords_de, metakeywords_en, metatitle_de, metatitle_en, links_de, altersfreigabe, links_en, startseite_de, startseite_en, restmenge, startseite, standardbild, herstellerlink, lieferzeit, lieferzeitmanuell, gewicht, laenge, breite, hoehe, wichtig, porto, gesperrt, sperrgrund, gueltigbis, umsatzsteuer, ausverkauft, variante, variante_von_id, variantevon, pseudopreis, keinrabatterlaubt, einkaufspreis, pseudolager, downloadartikel, zolltarifnummer, freifeld_Kategorie, typ, kategoriename, steuer_art_produkt, steuer_art_produkt_download, anzahl_bilder, anzahl_lager, lagerkorrekturwert, autolagerlampe, waehrung, preis, steuersatz, bruttopreis, checksum, variantevorhanden'
]
2024-05-22 11:25:35 +02:00
]
];
2024-06-13 15:51:30 +02:00
return ( $einstellungen );
2024-05-13 14:43:33 +02:00
}
2024-05-22 11:25:35 +02:00
public function getKonfig ( $shopid , $data ) {
2024-06-13 15:51:30 +02:00
2024-05-22 11:25:35 +02:00
$this -> shopid = $shopid ;
$this -> data = $data ;
$importerSettings = $this -> app -> DB -> SelectArr ( " SELECT `einstellungen_json` FROM `shopexport` WHERE `id` = ' $shopid ' LIMIT 1 " );
$importerSettings = reset ( $importerSettings );
$einstellungen = [];
if ( ! empty ( $importerSettings [ 'einstellungen_json' ])) {
$einstellungen = json_decode ( $importerSettings [ 'einstellungen_json' ], true );
}
$this -> apiKey = $einstellungen [ 'felder' ][ 'apikey' ];
$this -> shopUrl = rtrim ( $einstellungen [ 'felder' ][ 'shopurl' ], '/' ) . '/' ;
2024-05-24 10:53:49 +02:00
$this -> mirakl_shopid = $einstellungen [ 'felder' ][ 'mirakl_shopid' ];
2024-06-18 15:19:19 +02:00
2024-06-21 18:07:33 +02:00
$this -> configuration_identifier = array ( $einstellungen [ 'felder' ][ 'configuration_identifier_source' ] => $einstellungen [ 'felder' ][ 'configuration_identifier_source_value' ]);
2024-06-13 15:51:30 +02:00
2024-06-17 13:09:30 +02:00
$this -> mirakl_error_text_product_missing = $einstellungen [ 'felder' ][ 'mirakl_error_text_product_missing' ];
2024-08-29 18:09:04 +02:00
$this -> configuration_order_fetch_status = $einstellungen [ 'felder' ][ 'configuration_order_fetch_status' ];
2024-06-17 13:09:30 +02:00
2024-06-18 15:19:19 +02:00
$this -> normalTaxId = $einstellungen [ 'felder' ][ 'normalTaxId' ];
$this -> reducedTaxId = $einstellungen [ 'felder' ][ 'reducedTaxId' ];
2024-06-24 14:45:19 +02:00
$this -> offer_configuration = json_decode ( $einstellungen [ 'felder' ][ 'offer_configuration' ], true , flags : JSON_THROW_ON_ERROR );
$this -> product_configuration = json_decode ( $einstellungen [ 'felder' ][ 'product_configuration' ], true , flags : JSON_THROW_ON_ERROR );
2024-06-17 13:09:30 +02:00
2024-05-14 11:00:56 +02:00
}
2024-06-15 18:52:46 +02:00
private function miraklRequest ( string $endpoint , $postdata = null , array $getdata = null , string $content_type = null , bool $raw = false , $debug = false , $debugurl = null ) {
2024-05-22 11:25:35 +02:00
$ch = curl_init ();
$url_addition = " " ;
$headers = array ( " Authorization: " . $this -> apiKey );
curl_setopt ( $ch , CURLOPT_RETURNTRANSFER , true );
2024-05-24 10:53:49 +02:00
if ( ! empty ( $this -> mirakl_shopid )) {
$getdata [ 'shop_id' ] = $this -> mirakl_shopid ;
}
2024-05-22 11:25:35 +02:00
if ( ! empty ( $getdata )) {
$url_addition = " ? " ;
$ampersand = " " ;
foreach ( $getdata as $key => $value ) {
$url_addition .= $ampersand . $key . " = " . $value ;
$ampersand = " & " ;
}
2024-05-24 10:53:49 +02:00
}
if ( ! empty ( $postdata )) {
2024-05-22 11:25:35 +02:00
curl_setopt ( $ch , CURLOPT_CUSTOMREQUEST , 'POST' );
curl_setopt ( $ch , CURLOPT_POSTFIELDS , $postdata );
2024-06-15 18:52:46 +02:00
2024-05-22 11:25:35 +02:00
$headers [] = 'Content-Type: ' . $content_type ;
}
2024-06-15 18:52:46 +02:00
if ( $debugurl ) {
$url = $debugurl ;
} else {
$url = $this -> shopUrl ;
}
curl_setopt ( $ch , CURLOPT_URL , $url . $endpoint . $url_addition );
2024-05-22 11:25:35 +02:00
curl_setopt ( $ch , CURLOPT_HTTPHEADER , $headers );
curl_setopt ( $ch , CURLINFO_HEADER_OUT , true );
curl_setopt ( $ch , CURLOPT_VERBOSE , true );
$response = curl_exec ( $ch );
if ( curl_error ( $ch )) {
$this -> error [] = curl_error ( $ch );
}
curl_close ( $ch );
$information = curl_getinfo ( $ch );
2024-05-24 10:53:49 +02:00
2024-06-15 18:52:46 +02:00
if ( $debug ) {
print_r ( $information );
print_r ( $postdata );
print_r ( $response );
}
2024-05-22 11:25:35 +02:00
if ( $raw )
return $response ;
return simplexml_load_string ( $response );
2024-05-14 11:00:56 +02:00
}
2024-05-22 11:25:35 +02:00
public function ImportAuth () {
$ch = curl_init ( $this -> shopUrl . " version " );
curl_setopt ( $ch , CURLOPT_HTTPHEADER , array ( " Authorization: " . $this -> apiKey ));
curl_setopt ( $ch , CURLOPT_RETURNTRANSFER , true );
$response = curl_exec ( $ch );
$code = curl_getinfo ( $ch , CURLINFO_RESPONSE_CODE );
if ( $code == 200 ) {
2024-06-18 15:19:19 +02:00
return 'success' ;
2024-05-22 11:25:35 +02:00
}
return $response ;
}
/*
* Fetches article list from the shop , puts them into table shopexport_getarticles , starts the prozessstarter getarticles which fetches details for each article via ImportGetArticle ()
*/
2024-05-17 16:50:19 +02:00
2024-05-22 11:25:35 +02:00
public function ImportGetArticleList () {
$result = [];
2024-05-14 11:00:56 +02:00
2024-05-22 11:25:35 +02:00
$response = $this -> miraklRequest ( 'offers' , raw : true );
2024-05-13 14:43:33 +02:00
2024-05-22 11:25:35 +02:00
$result_array = json_decode ( $response );
foreach ( $result_array -> offers as $offer ) {
$result [] = $offer -> shop_sku ;
}
2024-05-14 11:00:56 +02:00
2024-05-22 11:25:35 +02:00
array_unique ( $result );
return $result ;
2024-05-14 11:00:56 +02:00
}
2024-05-13 14:43:33 +02:00
2024-05-22 11:25:35 +02:00
/*
* Fetches article details from the shop
*/
2024-05-17 16:50:19 +02:00
2024-05-22 11:25:35 +02:00
public function ImportGetArticle () {
2024-05-14 11:00:56 +02:00
2024-06-28 13:14:57 +02:00
$articlelist = $this -> CatchRemoteCommand ( 'data' );
2024-05-14 11:00:56 +02:00
2024-05-22 11:25:35 +02:00
$parameters = array ( 'product_references' => 'productID' , 'product_' );
$response = $this -> miraklRequest ( 'products?' , raw : true );
throw new Exception ( " Not implemented " );
2024-05-13 14:43:33 +02:00
}
2024-05-23 20:12:05 +02:00
/*
* Gets a flexible mapped fieldvalue from feld , wert or eigenschaft
*/
public function GetFieldValue ( $article , $field_map_entry ) {
2024-06-21 18:07:33 +02:00
$prefix = null ;
$postfix = null ;
$returnval = null ;
2024-05-23 20:12:05 +02:00
foreach ( $field_map_entry as $key => $value ) {
switch ( $key ) {
case 'feld' :
2024-06-13 15:51:30 +02:00
if ( isset ( $article [ $value ])) {
2024-06-21 18:07:33 +02:00
$returnval = $article [ $value ];
2024-06-13 15:51:30 +02:00
} else {
throw new Exception ( " Artikelfeld existiert nicht: \" " . $value . " \" " );
}
break ;
case 'freifeld' :
if ( isset ( $article [ 'freifelder' ][ 'DE' ][ $value ])) {
2024-06-21 18:07:33 +02:00
$returnval = $article [ 'freifelder' ][ 'DE' ][ $value ];
2024-06-13 15:51:30 +02:00
} else {
throw new Exception ( " Freifeld existiert nicht: \" " . $value . " \" " );
}
2024-05-23 20:12:05 +02:00
break ;
case 'eigenschaft' :
$sql = " SELECT wert FROM artikeleigenschaften ae INNER JOIN artikeleigenschaftenwerte aew ON aew.artikeleigenschaften = ae.id WHERE aew.artikel = ' " . $article [ 'artikelid' ] . " ' AND ae.name = ' " . $value . " ' LIMIT 1 " ;
2024-06-21 18:07:33 +02:00
$result = $this -> app -> DB -> SelectRow ( $sql );
if ( ! empty ( $result )) {
$returnval = $result [ 'wert' ];
}
2024-05-23 20:12:05 +02:00
break ;
case 'wert' :
2024-06-21 18:07:33 +02:00
return ( $prefix . $value . $postfix );
break ;
case 'praefix' :
$prefix = $value ;
break ;
case 'postfix' :
$postfix = $value ;
break ;
case 'standardwert' :
if ( empty ( $returnval )) {
$returnval = $value ;
}
break ;
}
}
return ( $prefix . $returnval . $postfix );
2024-05-23 20:12:05 +02:00
}
2024-05-24 18:57:37 +02:00
public function ImportSendListLager () {
2024-06-24 14:45:19 +02:00
return $this -> mirakl_export_offers_and_products ( export_products : false );
}
public function ImportSendList () {
return $this -> mirakl_export_offers_and_products ( export_products : true );
2024-05-24 18:57:37 +02:00
}
2024-05-22 11:25:35 +02:00
/*
* Send articles to shop
*/
2024-06-24 14:45:19 +02:00
public function mirakl_export_offers_and_products ( bool $export_products ) {
2024-07-01 15:25:04 +02:00
// $this->Log(Logger::DEBUG, "mirakl_export_offers_and_products", array('export products' => $export_products));
2024-06-28 15:49:16 +02:00
2024-06-24 14:45:19 +02:00
$message = " " ;
$komma = " " ;
$status = true ;
2024-05-23 20:12:05 +02:00
2024-06-28 15:49:16 +02:00
$level = Logger :: NOTICE ;
$log_result = null ;
2024-06-28 13:14:57 +02:00
$articlelist = $this -> CatchRemoteCommand ( 'data' );
2024-06-24 14:45:19 +02:00
if ( $export_products ) {
2024-07-01 15:25:04 +02:00
$export_products_result = $this -> mirakl_export_products ( $articlelist );
if ( $export_products_result [ 'export_products_returncode' ] != 0 ) {
2024-06-28 15:49:16 +02:00
$level = Logger :: ERROR ;
2024-06-24 14:45:19 +02:00
$message = " Produktsync nach Mirakl hat Fehler " ;
$komma = " , " ;
2024-06-28 13:14:57 +02:00
$status = false ;
2024-06-24 14:45:19 +02:00
} else {
2024-06-28 15:49:16 +02:00
$level = Logger :: NOTICE ;
2024-07-01 15:25:04 +02:00
$this -> Log ( Logger :: INFO , " Produktsync nach Mirakl ok " , $export_products_result );
2024-06-24 14:45:19 +02:00
$message = " Produktimport in Mirakl ok " ;
$komma = " , " ;
}
}
2024-06-17 13:09:30 +02:00
2024-07-01 15:25:04 +02:00
$export_offers_result = $this -> mirakl_export_offers ( $articlelist );
2024-06-17 13:09:30 +02:00
2024-07-01 15:25:04 +02:00
if ( $export_offers_result [ 'returncode' ] != 0 ) {
2024-06-28 15:49:16 +02:00
$level = Logger :: ERROR ;
2024-06-24 14:45:19 +02:00
$message .= $komma . " Angebotsync in Mirakl hat Fehler " ;
2024-06-28 13:14:57 +02:00
$status = false ;
2024-06-24 14:45:19 +02:00
} else {
2024-07-01 15:25:04 +02:00
$this -> Log ( Logger :: INFO , " Angebotsync nach Mirakl ok " , $export_offers_result );
2024-06-24 14:45:19 +02:00
$message .= $komma . " Angebotsimport in Mirakl ok " ;
2024-06-17 13:09:30 +02:00
}
2024-07-01 15:25:04 +02:00
$this -> Log ( $level , $message , array ( 'export_products_result' => $export_products_result , 'export_offers_result' => $export_offers_result ));
2024-06-28 15:49:16 +02:00
2024-07-01 15:25:04 +02:00
foreach ( $articlelist as $key => $article ) {
$articlelist [ $key ] = ( array ) $export_products_result [ 'articlelist' ][ $key ] + ( array ) $export_offers_result [ 'articlelist' ][ $key ]; // This merges the fields for each article
}
return (
array (
'status' => $status ,
'message' => $message ,
'articlelist' => $articlelist
)
);
2024-06-24 14:45:19 +02:00
2024-06-17 13:09:30 +02:00
// Check for missing products and try to create
2024-06-24 14:45:19 +02:00
/* if ( $export_products ) {
2024-06-17 13:09:30 +02:00
2024-07-01 15:25:04 +02:00
$export_products_list = array ();
2024-06-15 18:52:46 +02:00
2024-07-01 15:25:04 +02:00
foreach ( $export_offers_result [ 'articlelist' ] as $key => $article ) {
2024-06-17 13:09:30 +02:00
if ( $article [ 'mirakl_export_offers_result' ][ 'returncode' ] == 12 ) {
switch ( $article [ 'mirakl_export_offers_result' ][ 'message' ]) {
case $this -> mirakl_error_text_product_missing :
2024-07-01 15:25:04 +02:00
$export_products_list [] = $article ;
2024-06-17 13:09:30 +02:00
break ;
}
}
}
2024-07-01 15:25:04 +02:00
if ( empty ( $export_products_list )) {
2024-06-17 13:09:30 +02:00
return ( array ( 'status' => false , 'message' => " Produktimport nicht möglich " ));
}
2024-07-01 15:25:04 +02:00
$export_products_result = $this -> mirakl_export_products ( $export_products_list );
2024-06-17 13:09:30 +02:00
2024-07-01 15:25:04 +02:00
if ( $export_products_result [ 'returncode' ] != 0 ) {
$this -> Log ( Logger :: DEBUG , " Produktimport in Mirakl hat Fehler " , $export_products_result );
2024-06-17 13:09:30 +02:00
return ( array ( 'status' => false , 'message' => " Produktimport in Mirakl hat Fehler " ));
}
// Retry offer import
2024-07-01 15:25:04 +02:00
$export_offers_result = $this -> mirakl_export_offers ( $articlelist );
if ( $export_offers_result [ 'returncode' ] == 0 ) {
2024-06-17 13:09:30 +02:00
return ( array ( 'status' => true , 'message' => " Angebots und Produktimport in Mirakl ok " ));
}
2024-06-28 13:14:57 +02:00
}
2024-07-01 15:25:04 +02:00
$this -> Log ( Logger :: DEBUG , " Angebotsimport in Mirakl hat Fehler " , $export_offers_result );
2024-06-17 13:09:30 +02:00
2024-06-24 14:45:19 +02:00
return ( array ( 'status' => false , 'message' => " Angebotsimport in Mirakl hat Fehler " )); */
2024-06-17 13:09:30 +02:00
}
2024-06-18 15:19:19 +02:00
// STAGING, WAITING_ACCEPTANCE, WAITING_DEBIT, WAITING_DEBIT_PAYMENT, SHIPPING, SHIPPED, TO_COLLECT, RECEIVED, CLOSED, REFUSED, CANCELED
public function ImportGetAuftraegeAnzahl () {
2024-08-29 18:09:04 +02:00
$response = $this -> miraklRequest ( 'orders' , getdata : array ( 'order_state_codes' => $this -> configuration_order_fetch_status ), raw : true );
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'ImportGetAuftraegeAnzahl' , $response );
2024-06-18 15:19:19 +02:00
$result_array = json_decode ( $response );
return ( $result_array -> total_count );
2024-06-17 13:09:30 +02:00
}
public function ImportGetAuftrag () {
2024-06-18 15:19:19 +02:00
2024-08-29 18:09:04 +02:00
$parameters = array ( 'order_state_codes' => $this -> configuration_order_fetch_status );
2024-06-18 15:19:19 +02:00
if ( ! empty ( $this -> data [ 'nummer' ])) {
$parameters [ 'order_ids' ] = $this -> data [ 'nummer' ];
}
2024-08-29 18:09:04 +02:00
$response = $this -> miraklRequest ( 'orders' , getdata : $parameters , raw : true );
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'ImportGetAuftrag' , $response );
2024-06-18 15:19:19 +02:00
$result_array = json_decode ( $response );
$fetchedOrders = [];
foreach ( $result_array -> orders as $order ) {
$cart = [];
$cart [ 'zeitstempel' ] = strval ( $order -> created_date );
$cart [ 'auftrag' ] = strval ( $order -> order_id );
$cart [ 'onlinebestellnummer' ] = strval ( $order -> commercial_id );
$cart [ 'gesamtsumme' ] = strval ( $order -> total_price );
$cart [ 'bestelldatum' ] = strval ( $order -> created_date );
$cart [ 'lieferung' ] = strval ( $order -> shipping_type_code );
$cart [ 'email' ] = strval ( $order -> customer_notification_email );
2024-06-19 21:33:49 +02:00
// $cart['kunde_sprache'] = '?';
2024-06-18 15:19:19 +02:00
$cart [ 'kundennummer' ] = $order -> customer -> customer_id ;
$cart [ 'name' ] = ( $order -> customer -> civility ? $order -> customer -> civility . " " : " " ) . $order -> customer -> firstname . " " . $order -> customer -> lastname ;
2024-06-20 14:18:20 +02:00
if ( ! empty ( $order -> customer -> billing_address -> company )) {
$cart [ 'anrede' ] = 'firma' ;
2024-06-18 15:19:19 +02:00
$cart [ 'ansprechpartner' ] = $cart [ 'name' ];
2024-06-20 14:18:20 +02:00
$cart [ 'name' ] = strval ( $order -> customer -> billing_address -> company );
2024-06-18 15:19:19 +02:00
}
2024-06-20 14:18:20 +02:00
2024-06-18 15:19:19 +02:00
$cart [ 'strasse' ] = strval ( $order -> customer -> billing_address -> street_1 );
$cart [ 'adresszusatz' ] = strval ( $order -> customer -> billing_address -> street_2 );
$cart [ 'telefon' ] = strval ( $order -> customer -> billing_address -> phone );
$cart [ 'plz' ] = strval ( $order -> customer -> billing_address -> zip_code );
$cart [ 'ort' ] = strval ( $order -> customer -> billing_address -> city );
2024-06-19 21:33:49 +02:00
// $cart['ustid'] = '?';
2024-08-01 14:04:48 +02:00
if ( $order -> customer -> billing_address -> country_iso_code ) {
$sql = " SELECT iso FROM laender WHERE iso3 = ' " . $order -> customer -> billing_address -> country_iso_code . " ' LIMIT 1 " ;
}
2024-06-19 21:33:49 +02:00
$cart [ 'land' ] = $this -> app -> DB -> Select ( $sql );
2024-06-18 15:19:19 +02:00
$cart [ 'abweichendelieferadresse' ] = 1 ;
2024-06-19 21:33:49 +02:00
$sql = " SELECT iso FROM laender WHERE iso3 = ' " . $order -> customer -> shipping_address -> country_iso_code . " ' " ;
$cart [ 'lieferadresse_land' ] = $this -> app -> DB -> Select ( $sql );
2024-06-18 15:19:19 +02:00
$cart [ 'lieferadresse_name' ] = ( $order -> customer -> shipping_address -> civility ? $order -> customer -> shipping_address -> civility . " " : " " ) . $order -> customer -> shipping_address -> firstname . " " . $order -> customer -> shipping_address -> lastname ;
2024-06-20 14:18:20 +02:00
2024-08-29 18:43:26 +02:00
if ( ! empty ( $order -> customer -> shipping_address -> company )) {
2024-06-18 15:19:19 +02:00
$cart [ 'lieferadresse_ansprechpartner' ] = $cart [ 'lieferadresse_name' ];
2024-08-29 18:43:26 +02:00
$cart [ 'lieferadresse_name' ] = strval ( $order -> customer -> shipping_address -> company );
2024-06-18 15:19:19 +02:00
}
2024-06-20 14:18:20 +02:00
2024-06-18 15:19:19 +02:00
$cart [ 'lieferadresse_strasse' ] = strval ( $order -> customer -> shipping_address -> street_1 );
$cart [ 'lieferadresse_adresszusatz' ] = strval ( $order -> customer -> shipping_address -> street_2 );
$cart [ 'lieferadresse_telefon' ] = strval ( $order -> customer -> shipping_address -> phone );
$cart [ 'lieferadresse_plz' ] = strval ( $order -> customer -> shipping_address -> zip_code );
$cart [ 'lieferadresse_ort' ] = strval ( $order -> customer -> shipping_address -> city );
2024-08-29 18:43:26 +02:00
$cart [ 'internebemerkung' ] = strval ( $order -> customer -> shipping_address -> additional_info );
if ( is_array ( $order -> order_additional_fields )) {
$order_reference = array_search ( 'customer-order-reference' , array_column ( $order -> order_additional_fields , 'code' ));
if ( $order_reference !== false ) {
$cart [ 'ihrebestellnummer' ] .= $order -> order_additional_fields [ $order_reference ] -> value ;
}
}
2024-06-18 15:19:19 +02:00
$cart [ 'zahlungsweise' ] = strval ( $order -> payment_type );
2024-06-19 21:33:49 +02:00
$cart [ 'waehrung' ] = strval ( $order -> currency_iso_code );
2024-06-18 15:19:19 +02:00
2024-06-19 21:33:49 +02:00
// $cart['ust_befreit'] = '?'; // 1, 2
2024-06-18 15:19:19 +02:00
2024-06-19 21:33:49 +02:00
// $cart['steuersatz_normal'] = 19;//strval($order->taxes[0]->amount);
// $cart['steuersatz_ermaessigt'] 07; // strval($order->taxes[0]->amount);
$cart [ 'articlelist' ] = [];
2024-06-18 15:19:19 +02:00
$shipping_tax_amount = 0 ;
foreach ( $order -> order_lines as $order_row ) {
2024-06-19 21:33:49 +02:00
$steuersatz = 0 ;
$umsatzsteuer_typ = 'normal' ;
foreach ( $order_row -> taxes as $tax ) {
if ( $tax -> rate > $steuersatz ) {
$steuersatz = $tax -> rate ;
}
2024-07-19 12:17:24 +02:00
switch ( $tax -> code ) {
2024-06-19 21:33:49 +02:00
case $this -> reducedTaxId :
$umsatzsteuer_typ = 'ermaessigt' ;
break ;
default :
case $this -> normalTaxId :
$umsatzsteuer_typ = 'normal' ;
break ;
}
2024-06-18 15:19:19 +02:00
}
$article = [
'articleid' => strval ( $order_row -> offer_sku ),
2024-06-19 21:33:49 +02:00
// 'name' => strval($order_row->product_title),
2024-06-18 15:19:19 +02:00
'quantity' => strval ( $order_row -> quantity ),
'price_netto' => strval ( $order_row -> price_unit ),
2024-06-19 21:33:49 +02:00
'umsatzsteuer' => $steuersatz
2024-06-18 15:19:19 +02:00
];
foreach ( $order_row -> shipping_taxes as $shipment_tax ) {
$shipping_tax_amount += $shipment_tax -> amount ;
}
$cart [ 'articlelist' ][] = $article ;
} // foreach articles
2024-06-19 21:33:49 +02:00
$cart [ 'versandkostennetto' ] = round ( strval ( $order -> shipping_price ), 2 );
$cart [ 'versandkostenbrutto' ] = round ( $cart [ 'versandkostennetto' ] + $shipping_tax_amount , 2 );
2024-06-18 15:19:19 +02:00
} // foreach orders
$fetchedOrders [] = [
'id' => $cart [ 'auftrag' ],
'sessionid' => $cart [ 'onlinebestellnummer' ],
'logdatei' => '' ,
'warenkorb' => base64_encode ( serialize ( $cart )),
'warenkorbjson' => base64_encode ( json_encode ( $cart ))
];
2024-06-17 13:09:30 +02:00
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'Auftragsimport' , $cart );
2024-06-18 15:19:19 +02:00
return $fetchedOrders ;
2024-06-17 13:09:30 +02:00
}
/*
* Send offer data to mirakl
2024-06-28 13:14:57 +02:00
* $articlelist = $this -> CatchRemoteCommand ( 'data' );
2024-06-17 13:09:30 +02:00
* Return
2024-06-28 13:14:57 +02:00
* array ( returncode , message , articlelist ) articlelist with added mirakl_export_offers_result element ( array ( returncode , message )) for further processing ( e . g . create product )
2024-06-17 13:09:30 +02:00
* returncode 0 = ok , 1 = not ok
2024-06-28 13:14:57 +02:00
* returncode articlelist 0 = ok , 10 = missing required attributes , 11 category not found , 12 rejected from mirakl
2024-06-17 13:09:30 +02:00
*/
2024-06-28 13:14:57 +02:00
private function mirakl_export_offers ( array $articlelist ) : array {
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value = array ();
$mirakl_export_offers_return_value [ 'returncode' ] = 0 ;
2024-07-01 15:25:04 +02:00
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'Angebotsexport Start' , $articlelist );
2024-05-23 20:12:05 +02:00
2024-05-22 11:25:35 +02:00
// First gather all articles as offers and send them
// Wait for import to finish
2024-06-17 13:09:30 +02:00
// Evaluate import
2024-05-22 11:25:35 +02:00
2024-06-28 13:14:57 +02:00
foreach ( $articlelist as $key => $article ) {
2024-05-22 11:25:35 +02:00
2024-07-01 15:25:04 +02:00
$return_article =
array (
'artikel' => $article [ 'artikel' ],
'nummer' => $article [ 'nummer' ]
);
2024-06-17 13:09:30 +02:00
$skip_article = false ;
2024-05-22 11:25:35 +02:00
/*
* Export offer
*/
2024-06-24 14:45:19 +02:00
$configuration_found = false ;
2024-05-22 11:25:35 +02:00
$additional_fields = array ();
2024-07-23 13:12:34 +02:00
// Prepare volume prices
$volume_prices = array ();
foreach ( $article [ 'staffelpreise_standard' ] as $volume_price ) {
if ( $volume_price [ 'ab_menge' ] > 1 ) {
$volume_prices [] = array (
'quantity_threshold' => ( int ) $volume_price [ 'ab_menge' ],
'unit_discount_price' => $volume_price [ 'preis' ],
'unit_origin_price' => $article [ 'preis' ]
);
}
}
$all_prices = array (
'volume_prices' => $volume_prices
);
2024-05-22 11:25:35 +02:00
$offer_for_mirakl = array (
2024-07-23 13:12:34 +02:00
'state_code' => '11' , // Condition new
'price' => $article [ 'preis' ],
'all_prices' => array ( $all_prices ),
2024-05-22 11:25:35 +02:00
'update_delete' => null // Update delete flag. Could be empty (means "update"), "update" or "delete".
);
2024-05-23 20:12:05 +02:00
2024-07-01 15:25:04 +02:00
$offer_configuration_name = $this -> GetFieldValue ( $article , $this -> configuration_identifier );
$return_article [ 'offer_configuration' ] = $offer_configuration_name ;
2024-06-13 15:51:30 +02:00
2024-06-24 14:45:19 +02:00
foreach ( $this -> offer_configuration as $offer_configuration_entry ) {
if ( $offer_configuration_entry [ 'konfigurationen' ] != null ) {
2024-07-01 15:25:04 +02:00
if ( ! in_array ( $offer_configuration_name , $offer_configuration_entry [ 'konfigurationen' ])) {
2024-05-24 10:10:59 +02:00
continue ;
}
2024-06-13 15:51:30 +02:00
}
2024-06-24 14:45:19 +02:00
$configuration_found = true ;
$offer_configuration = $offer_configuration_entry ;
break ;
}
2024-06-13 15:51:30 +02:00
2024-06-24 14:45:19 +02:00
if ( $configuration_found ) {
2024-06-17 13:09:30 +02:00
// Check required attributes
2024-05-23 20:12:05 +02:00
$required = [
'product_id_type' ,
'product_id' ,
2024-07-23 13:12:34 +02:00
'shop_sku'
2024-05-23 20:12:05 +02:00
];
$missing = null ;
foreach ( $required as $key ) {
2024-06-24 14:45:19 +02:00
if ( ! isset ( $offer_configuration [ 'felder' ][ $key ])) {
2024-05-23 20:12:05 +02:00
$missing [] = $key ;
}
}
if ( $missing ) {
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'returncode' ] = 1 ;
2024-07-01 15:25:04 +02:00
$return_article [ 'export_offers_returncode' ] = 10 ;
$return_article [ 'export_offers_message' ] = " Pflichtfelder fehlen in Angebotskonfiguration \" " . $offer_configuration_name . " \" : " . implode ( ', ' , $missing );
$mirakl_export_offers_return_value [ 'articlelist' ][] = $return_article ;
2024-06-17 13:09:30 +02:00
$skip_article = true ;
2024-05-22 13:37:30 +02:00
}
2024-05-23 20:12:05 +02:00
// Check Required attributes
2024-06-24 14:45:19 +02:00
foreach ( $offer_configuration [ 'felder' ] as $offer_field => $offer_field_source ) {
2024-05-23 20:12:05 +02:00
if ( ! is_array ( $offer_field_source )) {
$offer_field_source = array ( 'feld' => $offer_field_source );
}
$offer_field_value = null ;
$is_additional_field = false ;
$offer_field_value = $this -> GetFieldValue ( $article , $offer_field_source );
if ( in_array ( 'zusatzfeld' , $offer_field_source )) {
$is_additional_field = true ;
}
if ( $is_additional_field ) {
$additional_field = array (
" code " => $offer_field ,
" value " => $offer_field_value
);
$additional_fields [] = $additional_field ;
} else {
$offer_for_mirakl [ $offer_field ] = $offer_field_value ;
2024-06-21 18:07:33 +02:00
}
2024-05-23 20:12:05 +02:00
}
2024-06-24 14:45:19 +02:00
if ( $skip_article ) {
continue ;
}
if ( ! empty ( $additional_fields )) {
$offer_for_mirakl [ 'offer_additional_fields' ] = $additional_fields ;
}
$offers_for_mirakl [] = $offer_for_mirakl ;
2024-07-01 15:25:04 +02:00
$return_article [ 'export_offers_returncode' ] = 0 ;
$mirakl_export_offers_return_value [ 'articlelist' ][] = $return_article ;
2024-06-17 13:09:30 +02:00
2024-06-24 14:45:19 +02:00
} else { // configuration_found
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'returncode' ] = 1 ;
2024-07-01 15:25:04 +02:00
$return_article [ 'export_offers_returncode' ] = 11 ;
$return_article [ 'export_offers_message' ] = " Angebotskonfiguration für Artikel " . $article [ 'nummer' ] . " , Konfiguration \" " . $offer_configuration_name . " \" nicht gefunden " ;
$mirakl_export_offers_return_value [ 'articlelist' ][] = $return_article ;
2024-06-17 13:09:30 +02:00
continue ;
2024-06-24 14:45:19 +02:00
}
2024-06-17 13:09:30 +02:00
}
if ( empty ( $offers_for_mirakl )) {
$mirakl_export_offers_return_value [ 'returncode' ] = 1 ;
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Angebotsexport keine Artikel bereit' , $mirakl_export_offers_return_value );
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'message' ] = " Angebotsexport keine Artikel bereit " ;
return ( $mirakl_export_offers_return_value );
2024-05-22 11:25:35 +02:00
}
$data_for_mirakl = array ();
$data_for_mirakl [ 'offers' ] = $offers_for_mirakl ;
$json_for_mirakl = json_encode ( $data_for_mirakl );
2024-07-23 13:12:34 +02:00
$this -> Log ( Logger :: DEBUG , 'Angebotsexport Daten' , [ 'json' => $json_for_mirakl ]);
2024-06-15 18:52:46 +02:00
2024-05-22 11:25:35 +02:00
$result = [];
$response = $this -> miraklRequest ( 'offers' , postdata : $json_for_mirakl , content_type : 'application/json' , raw : true );
$result = json_decode ( $response );
if ( ! isset ( $result -> import_id )) {
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'returncode' ] = 1 ;
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Angebotsimport abgelehnt' , $response );
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'message' ] = " Angebotsimport abgelehnt: " . print_r ( $response , true );
return ( $mirakl_export_offers_return_value );
2024-05-22 11:25:35 +02:00
}
2024-05-17 16:50:19 +02:00
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: INFO , 'Angebotsimport angelegt' , $response );
2024-06-17 13:09:30 +02:00
2024-05-22 11:25:35 +02:00
$import_id = $result -> import_id ;
// Wait for import to finish
2024-05-17 16:50:19 +02:00
2024-05-22 11:25:35 +02:00
$status = null ;
/*
WAITING_SYNCHRONIZATION_PRODUCT , WAITING , RUNNING , COMPLETE , FAILED
*/
while ( $status != 'COMPLETE' && $status != 'FAILED' ) {
sleep ( 5 );
$response = $this -> miraklRequest ( 'offers/imports/' . $import_id , raw : true );
$result = json_decode ( $response );
$status = $result -> status ;
}
2024-06-17 13:09:30 +02:00
if ( $status == 'FAILED' ) {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Angebotsimport fehlgeschlagen' , $response );
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'returncode' ] = 2 ;
$mirakl_export_offers_return_value [ 'message' ] = " Angebotsimport fehlgeschlagen: " . print_r ( $response , true );
return ( $mirakl_export_offers_return_value );
2024-05-22 11:25:35 +02:00
}
2024-06-15 18:52:46 +02:00
2024-05-22 11:25:35 +02:00
if ( $result -> lines_in_error == 0 ) {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: INFO , 'Angebotsimport ok' , $response );
2024-06-17 13:09:30 +02:00
return ( $mirakl_export_offers_return_value );
2024-05-22 11:25:35 +02:00
}
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Angebotsimport meldet Fehler in ' . $result -> lines_in_error . ' Zeilen' , $response );
2024-06-15 18:52:46 +02:00
$result = array ();
// Check errors with CSV unfucking...
$response = $this -> miraklRequest ( 'offers/imports/' . $import_id . '/error_report' , raw : true );
$response_lines = preg_split ( '/\R/' , $response , flags : PREG_SPLIT_NO_EMPTY );
2024-06-17 13:09:30 +02:00
2024-06-15 18:52:46 +02:00
$error_message_key = null ;
$firstline = true ;
2024-06-17 13:09:30 +02:00
foreach ( $response_lines as $key => $response_line ) {
2024-06-15 18:52:46 +02:00
$response_array = str_getcsv ( $response_line , ';' , '"' );
if ( $firstline ) {
$error_message_key = array_search ( " error-message " , $response_array );
$firstline = false ;
continue ;
2024-06-17 13:09:30 +02:00
}
$article_key = array_search (
$response_array [ 'product_id' ],
array_column (
2024-06-28 13:14:57 +02:00
$mirakl_export_offers_return_value [ 'articlelist' ],
2024-06-17 13:09:30 +02:00
'product_id' )
);
2024-06-28 13:14:57 +02:00
$mirakl_export_offers_return_value [ 'articlelist' ][ $article_key ][ 'mirakl_export_offers_result' ] = array ( 'returncode' => 12 , 'message' => $response_array [ $error_message_key ]);
2024-06-17 13:09:30 +02:00
}
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Angebotsimport Fehlerbericht' , $response );
2024-06-17 13:09:30 +02:00
$mirakl_export_offers_return_value [ 'returncode' ] = 1 ;
return ( $mirakl_export_offers_return_value );
}
/*
* Create products
* Return
2024-07-01 15:25:04 +02:00
* array ( returncode , message , articlelist ) articlelist with added mirakl_export_offers_result element ( array ( returncode , message )) for further processing
2024-06-17 13:09:30 +02:00
* returncode 0 = ok , 1 = not ok
2024-07-01 15:25:04 +02:00
* returncode articlelist 0 = ok
2024-06-17 13:09:30 +02:00
*/
2024-07-01 15:25:04 +02:00
private function mirakl_export_products ( array $articlelist ) : array {
2024-06-27 21:38:18 +02:00
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value = array ();
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 0 ;
2024-06-27 21:38:18 +02:00
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'Produktexport Start' , $articlelist );
2024-07-01 15:25:04 +02:00
$articlelist_per_configuration = array ();
foreach ( $articlelist as $key => $article ) {
2024-06-26 17:01:40 +02:00
2024-07-01 15:25:04 +02:00
// Determine configuration
2024-06-24 14:45:19 +02:00
$configuration_found = false ;
2024-07-01 15:25:04 +02:00
$product_configuration_name = $this -> GetFieldValue ( $article , $this -> configuration_identifier );
2024-06-24 14:45:19 +02:00
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'articlelist' ][] =
array (
'artikel' => $article [ 'artikel' ],
'nummer' => $article [ 'nummer' ],
'product_configuration' => $product_configuration_name
);
foreach ( $this -> product_configuration as $product_configuration_id => $product_configuration ) {
2024-06-24 14:45:19 +02:00
if ( $product_configuration [ 'konfigurationen' ] != null ) {
2024-07-01 15:25:04 +02:00
if ( ! in_array ( $product_configuration_name , $product_configuration [ 'konfigurationen' ])) {
2024-06-24 14:45:19 +02:00
continue ;
}
}
$configuration_found = true ;
2024-07-01 15:25:04 +02:00
break ;
2024-06-24 14:45:19 +02:00
}
if ( ! $configuration_found ) {
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 1 ;
2024-07-02 11:10:49 +02:00
$mirakl_export_products_return_value [ 'articlelist' ][ $key ][ 'export_products_returncode' ] = 11 ;
$mirakl_export_products_return_value [ 'articlelist' ][ $key ][ 'export_products_message' ] = " Produktkonfiguration für Artikel " . $article [ 'nummer' ] . " , Konfiguration \" " . $product_configuration_name . " \" nicht gefunden " ;
2024-06-24 14:45:19 +02:00
continue ;
}
2024-07-01 15:25:04 +02:00
$articlelist_per_configuration [ $product_configuration_name ][ 'product_configuration' ] = $product_configuration ;
$articlelist_per_configuration [ $product_configuration_name ][ 'product_configuration_name' ] = $product_configuration_name ;
$articlelist_per_configuration [ $product_configuration_name ][ 'articles' ][] = $article ;
}
// $this->Log(Logger::DEBUG, 'Articlelist per config', $articlelist_per_configuration);
$komma = '' ;
foreach ( $articlelist_per_configuration as $articlelist_one_configuration ) {
$result = $this -> mirakl_export_products_one_configuration ( $articlelist_one_configuration );
// $this->Log(Logger::DEBUG, 'Articlelist per config result', $result);
if ( $result [ 'export_products_returncode' ]) {
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 1 ;
$mirakl_export_products_return_value [ 'message' ] .= $komma . $result [ 'message' ] . " ( " . $articlelist_one_configuration [ 'product_configuration_name' ] . " ) " ;
$komma = ', ' ;
}
foreach ( $result [ 'articlelist' ] as $article_result ) {
$article_key = array_search (
$article_result [ 'artikel' ],
array_column (
$mirakl_export_products_return_value [ 'articlelist' ],
'artikel' )
);
$mirakl_export_products_return_value [ 'articlelist' ][ $article_key ] += $article_result ;
}
// $this->Log(Logger::DEBUG, 'mirakl_export_products_return_value', $mirakl_export_products_return_value);
}
return ( $mirakl_export_products_return_value );
}
private function mirakl_export_products_one_configuration ( array $articlelist_one_configuration ) {
// Build CSV
$csv_header = " " ;
$newline = " " ;
$mirakl_export_products_return_value = array ();
foreach ( $articlelist_one_configuration [ 'articles' ] as $article ) {
$product_for_mirakl = array ();
$mirakl_export_products_return_value [ 'articlelist' ][] =
array (
'artikel' => $article [ 'artikel' ],
'nummer' => $article [ 'nummer' ],
'product_configuration' => $product_configuration_name ,
'export_products_returncode' => 0
);
foreach ( $articlelist_one_configuration [ 'product_configuration' ][ 'felder' ] as $product_field => $product_field_source ) {
if ( ! is_array ( $product_field_source )) {
$product_field_source = array ( 'feld' => $product_field_source );
}
$product_field_value = null ;
$product_field_value = $this -> GetFieldValue ( $article , $product_field_source );
$product_for_mirakl [ $product_field ] = $product_field_value ;
}
2024-06-17 13:09:30 +02:00
// Create CSV from array
if ( empty ( $csv_header )) {
$csv_header .= '"' . implode ( '";"' , array_keys ( $product_for_mirakl )) . '"' ;
}
$csv .= $newline . '"' . implode ( '";"' , $product_for_mirakl ) . '"' ;
$newline = " \r \n " ;
}
2024-06-24 14:45:19 +02:00
if ( ! $csv ) { // No articles found
2024-07-01 15:25:04 +02:00
return ( $mirakl_export_products_return_value );
2024-06-24 14:45:19 +02:00
}
2024-06-17 13:09:30 +02:00
$csv = $csv_header . $newline . $csv ;
$result = [];
2024-07-01 15:25:04 +02:00
$this -> Log ( Logger :: DEBUG , 'Produktexport Daten ' . $articlelist_one_configuration [ 'product_configuration_name' ], array ( 'csv' => $csv ));
2024-06-17 13:09:30 +02:00
$postdata = array ( 'file' => new CURLStringFile ( postname : 'import.csv' , data : $csv ));
$response = $this -> miraklRequest ( 'products/imports' , postdata : $postdata , content_type : 'multipart/form-data' , raw : true );
2024-06-15 18:52:46 +02:00
2024-06-17 13:09:30 +02:00
$result = json_decode ( $response );
2024-06-15 18:52:46 +02:00
2024-06-17 13:09:30 +02:00
if ( ! isset ( $result -> import_id )) {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Produktimport abgelehnt' , $response );
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 1 ;
$mirakl_export_products_return_value [ 'export_products_message' ] = 'Produktimport abgelehnt' ;
return ( $mirakl_export_products_return_value );
2024-06-17 13:09:30 +02:00
}
2024-06-15 18:52:46 +02:00
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: INFO , 'Produktimport angelegt' , $result );
2024-06-15 18:52:46 +02:00
2024-06-17 13:09:30 +02:00
$import_id = $result -> import_id ;
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
// Wait for import to finish
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
$status = null ;
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
/*
WAITING_SYNCHRONIZATION_PRODUCT , WAITING , RUNNING , COMPLETE , FAILED
*/
while ( $status != 'COMPLETE' && $status != 'FAILED' ) {
2024-06-24 14:45:19 +02:00
sleep ( 30 );
2024-06-17 13:09:30 +02:00
$response = $this -> miraklRequest ( 'products/imports/' . $import_id , raw : true );
$result = json_decode ( $response );
$status = $result -> import_status ;
2024-05-13 14:43:33 +02:00
}
2024-06-17 13:09:30 +02:00
if ( $status == 'FAILED' ) {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Produktimport fehlgeschlagen' , $response );
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 1 ;
return ( $mirakl_export_products_return_value );
2024-06-17 13:09:30 +02:00
}
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
if ( ! $result -> has_error_report && ! $result -> has_transformation_error_report ) {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: INFO , 'Produktimport ok' , $response );
2024-06-17 13:09:30 +02:00
} else {
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Produktimport meldet Fehler' , $response );
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'export_products_returncode' ] = 1 ;
2024-06-17 13:09:30 +02:00
}
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
if ( $result -> has_new_product_report ) {
$response = $this -> miraklRequest ( 'products/imports/' . $import_id . '/new_product_report' , raw : true );
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'Produktimport "Hinzugefügte Produkte"-Bericht' , $response );
2024-06-17 13:09:30 +02:00
}
2024-05-13 14:43:33 +02:00
2024-06-17 13:09:30 +02:00
if ( $result -> has_transformed_file ) {
$response = $this -> miraklRequest ( 'products/imports/' . $import_id . '/transformed_file' , raw : true );
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: DEBUG , 'Produktimport Datei im Marketplace-Format' , $response );
2024-07-01 15:25:04 +02:00
}
2024-06-17 13:09:30 +02:00
if ( $result -> has_error_report ) {
// Check errors with CSV unfucking...
$response = $this -> miraklRequest ( 'products/imports/' . $import_id . '/error_report' , raw : true );
$response_lines = preg_split ( '/\R/' , $response , flags : PREG_SPLIT_NO_EMPTY );
$error_message_key = null ;
$firstline = true ;
foreach ( $response_lines as $key => $response_line ) {
$response_array = str_getcsv ( $response_line , ';' , '"' );
if ( $firstline ) {
$error_message_key = array_search ( " ERRORS " , $response_array );
$firstline = false ;
continue ;
}
$article_key = array_search (
$response_array [ 'product_id' ],
array_column (
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'articlelist' ],
2024-06-17 13:09:30 +02:00
'product_id' )
);
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'articlelist' ][ $article_key ][ 'export_products_returncode' ] = 13 ;
$mirakl_export_products_return_value [ 'articlelist' ][ $article_key ][ 'export_products_message' ] = $response_array [ $error_message_key ];
2024-06-17 13:09:30 +02:00
}
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Produktimport Fehlerbericht' , $response );
2024-06-17 13:09:30 +02:00
}
if ( $result -> has_transformation_error_report ) {
// Check errors with CSV unfucking...
$response = $this -> miraklRequest ( 'products/imports/' . $import_id . '/transformation_error_report' , raw : true );
$response_lines = preg_split ( '/\R/' , $response , flags : PREG_SPLIT_NO_EMPTY );
$error_message_key = null ;
$firstline = true ;
foreach ( $response_lines as $key => $response_line ) {
$response_array = str_getcsv ( $response_line , ';' , '"' );
if ( $firstline ) {
$error_message_key = array_search ( " errors " , $response_array );
$firstline = false ;
continue ;
}
$article_key = array_search (
$response_array [ 'product_id' ],
array_column (
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'articlelist' ],
2024-06-17 13:09:30 +02:00
'product_id' )
);
2024-07-01 15:25:04 +02:00
$mirakl_export_products_return_value [ 'articlelist' ][ $article_key ][ 'export_products_returncode' ] = 14 ;
$mirakl_export_products_return_value [ 'articlelist' ][ $article_key ][ 'export_products_message' ] = $response_array [ $error_message_key ];
2024-06-17 13:09:30 +02:00
}
2024-06-28 15:49:16 +02:00
$this -> Log ( Logger :: ERROR , 'Produktimport Transformation-Fehlerbericht' , $response );
2024-06-17 13:09:30 +02:00
}
2024-07-01 15:25:04 +02:00
return ( $mirakl_export_products_return_value );
2024-05-22 11:25:35 +02:00
}
2024-06-28 15:49:16 +02:00
private function Log ( $level , $message , $dump = array ()) {
2024-07-01 15:25:04 +02:00
$this -> logger -> Log ( $level , 'Mirakl (Shop ' . $this -> shopid . ') ' . $message , ( array ) $dump );
2024-06-28 15:49:16 +02:00
}
private function getOrdersToProcess ( int $limit ) {
echo ( " getOrdersToProcess " );
exit ();
}
public function ImportDeleteAuftrag () {
echo ( " ImportDeleteAuftrag " );
exit ();
}
public function ImportUpdateAuftrag () {
echo ( " ImportUpdateAuftrag " );
exit ();
}
2024-05-13 14:43:33 +02:00
}
2024-05-22 11:25:35 +02:00