mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-03 18:40:29 +01:00
2686 lines
142 KiB
PHP
2686 lines
142 KiB
PHP
<?php
|
|
|
|
/*
|
|
* SPDX-FileCopyrightText: 2022-2024 Andreas Palm
|
|
* SPDX-FileCopyrightText: 2024 OpenXE project
|
|
* SPDX-FileCopyrightText: 2019 Xentral (c) Xentral ERP Software GmbH, Fuggerstrasse 11, D-86150 Augsburg, Germany
|
|
*
|
|
* SPDX-License-Identifier: LicenseRef-EGPL-3.1
|
|
*/
|
|
|
|
/*
|
|
* *** COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
|
*
|
|
* Xentral (c) Xentral ERP Sorftware GmbH, Fuggerstrasse 11, D-86150 Augsburg, * Germany 2019
|
|
*
|
|
* This file is licensed under the Embedded Projects General Public License *Version 3.1.
|
|
*
|
|
* You should have received a copy of this license from your vendor and/or *along with this file; If not, please visit www.wawision.de/Lizenzhinweis
|
|
* to obtain the text of the corresponding license version.
|
|
*
|
|
* *** END OF COPYRIGHT & LICENSE NOTICE *** DO NOT REMOVE ****
|
|
*/
|
|
?>
|
|
<?php
|
|
|
|
use Xentral\Modules\Onlineshop\Data\OrderStatus;
|
|
use Xentral\Modules\Onlineshop\Data\OrderStatusUpdateRequest;
|
|
use Xentral\Modules\Onlineshop\Data\Shipment;
|
|
use Xentral\Modules\Onlineshop\Data\ShopConnectorResponseInterface;
|
|
use Xentral\Components\Logger\Logger;
|
|
|
|
class Remote {
|
|
|
|
/** @var ApplicationCore $app */
|
|
public $app;
|
|
|
|
/** @var Logger $logger */
|
|
public $logger;
|
|
|
|
public function __construct($app) {
|
|
$this->app = $app;
|
|
$this->logger = $app->Container->get('Logger');
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param null|bool $extra
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteConnection($shopId, $extra = null) {
|
|
$ret = $this->RemoteCommand($shopId, 'auth', $extra);
|
|
if ($ret !== 'success' && empty($extra) && method_exists($this->app->erp, 'setSystemHealth')) {
|
|
$this->app->erp->setSystemHealth(
|
|
'shopexport',
|
|
'auth',
|
|
'warning',
|
|
'Verbindung zu ' .
|
|
$this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT bezeichnung FROM shopexport WHERE id = %d',
|
|
$shopId
|
|
)
|
|
) . ' fehlgeschlagen.'
|
|
);
|
|
try {
|
|
/** @var Systemhealth $systemhealth */
|
|
$systemhealth = $this->app->erp->LoadModul('systemhealth');
|
|
if ($systemhealth !== null && method_exists($systemhealth, 'createEvent')) {
|
|
$systemhealth->createEvent('shopexport', 'auth', 'warning', 'shopexport', $shopId);
|
|
}
|
|
} catch (Exception $d) {
|
|
|
|
}
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetUpdateArticleList($shopId) {
|
|
return $this->RemoteCommand($shopId, 'getlist');
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetFileList($shopId) {
|
|
return $this->RemoteCommand($shopId, 'getfilelist');
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int|string $articleId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetFileListArticle($shopId, $article) {
|
|
$data['artikel'] = $article;
|
|
|
|
return $this->RemoteCommand($shopId, 'getfilelistarticle', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param array|string $data
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetAuftraegeAnzahl($shopId, $data = '') {
|
|
if (!empty($data)) {
|
|
return $this->RemoteCommand($shopId, 'getauftraegeanzahl', $data);
|
|
}
|
|
$data = array();
|
|
$shopexportArr = $this->app->DB->SelectRow(sprintf('SELECT * FROM shopexport WHERE id = %d LIMIT 1', $shopId));
|
|
$holealle = $shopexportArr['holealle'];
|
|
$holeallestati = $shopexportArr['holeallestati'];
|
|
$zeitraum = [
|
|
'datumvon' => $shopexportArr['datumvon'],
|
|
'datumbis' => $shopexportArr['datumbis'],
|
|
'tmpdatumvon' => $shopexportArr['tmpdatumvon'],
|
|
'tmpdatumbis' => $shopexportArr['tmpdatumbis'],
|
|
'anzgleichzeitig' => $shopexportArr['anzgleichzeitig'],
|
|
];
|
|
if (!empty($zeitraum)) {
|
|
$data['datumvon'] = $zeitraum['datumvon'];
|
|
$data['datumbis'] = $zeitraum['datumbis'];
|
|
//if(strtotime($zeitraum[0]['tmpdatumbis']) > 0)$data['datumbis'] = $zeitraum[0]['tmpdatumbis'];
|
|
//if(strtotime($zeitraum[0]['tmpdatumvon']) > 0)$data['datumvon'] = $zeitraum[0]['tmpdatumbis'];
|
|
if ($data['datumvon'] === null || $data['datumvon'] === '0000-00-00 00:00:00' || strtotime($data['datumvon']) <= 0) {
|
|
$data['datumvon'] = '2000-01-01 00:00:00';
|
|
}
|
|
if ($data['datumbis'] === null || $data['datumbis'] === '0000-00-00 00:00:00' || strtotime($data['datumbis']) <= 0) {
|
|
$data['datumbis'] = date('Y-m-d H:i:s');
|
|
$data['datumbis_utc'] = $this->app->DB->Select('select date_sub(UTC_TIMESTAMP, INTERVAL 0 MINUTE)');
|
|
}
|
|
$data['anzgleichzeitig'] = $zeitraum[0]['anzgleichzeitig'];
|
|
if ($holeallestati && $data['anzgleichzeitig'] > 1) {
|
|
$data['holeallestati'] = 1;
|
|
}
|
|
}
|
|
if ($holealle) {
|
|
$ab_nummer = $shopexportArr['ab_nummer'];
|
|
$data = array('ab_nummer' => $ab_nummer);
|
|
if ($holeallestati) {
|
|
$data['holeallestati'] = 1;
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftraegeanzahl', $data);
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftraegeanzahl');
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param string $nummer
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetAuftraegeAnzahlNummer($shopId, $nummer) {
|
|
$data = array('nummer' => $nummer);
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftraegeanzahl', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param null|array $data
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetAuftrag($shopId, $data = null) {
|
|
if (!empty($data)) {
|
|
return $this->RemoteCommand($shopId, 'getauftrag', $data);
|
|
}
|
|
$data = array();
|
|
|
|
$shopexportArr = $this->app->DB->SelectRow(
|
|
sprintf(
|
|
'SELECT * FROM shopexport WHERE id = %d LIMIT 1',
|
|
$shopId
|
|
)
|
|
);
|
|
$holealle = $shopexportArr['holealle'];
|
|
$holeallestati = $shopexportArr['holeallestati'];
|
|
$zeitraum = [
|
|
'datumvon' => $shopexportArr['datumvon'],
|
|
'datumbis' => $shopexportArr['datumbis'],
|
|
'tmpdatumvon' => $shopexportArr['tmpdatumvon'],
|
|
'tmpdatumbis' => $shopexportArr['tmpdatumbis'],
|
|
'anzgleichzeitig' => $shopexportArr['anzgleichzeitig'],
|
|
];
|
|
if (!empty($zeitraum)) {
|
|
$data['datumvon'] = $zeitraum['datumvon'];
|
|
$data['datumbis'] = $zeitraum['datumbis'];
|
|
if ($zeitraum['tmpdatumbis'] !== null && $zeitraum['tmpdatumbis'] !== '0000-00-00 00:00:00' &&
|
|
strtotime($zeitraum['tmpdatumbis']) > 0) {
|
|
$data['datumbis'] = $zeitraum['tmpdatumbis'];
|
|
}
|
|
//if(strtotime($zeitraum[0]['tmpdatumvon']) > 0)$data['datumvon'] = $zeitraum[0]['tmpdatumbis'];
|
|
if ($data['datumvon'] === null || $data['datumvon'] === '0000-00-00 00:00:00' || strtotime($data['datumvon']) <= 0) {
|
|
$data['datumvon'] = '2000-01-01 00:00:00';
|
|
}
|
|
if ($data['datumbis'] === null || $data['datumbis'] === '0000-00-00 00:00:00' || strtotime($data['datumbis']) <= 0) {
|
|
$data['datumbis'] = date('Y-m-d H:i:s');
|
|
$data['datumbis_utc'] = $this->app->DB->Select('select date_sub(UTC_TIMESTAMP, INTERVAL 0 MINUTE)');
|
|
}
|
|
$data['anzgleichzeitig'] = $zeitraum['anzgleichzeitig'];
|
|
if ($data['anzgleichzeitig'] > 1 && $shopexportArr['einzelsync']) {
|
|
$data['anzgleichzeitig'] = 1;
|
|
}
|
|
if ($holeallestati) {
|
|
$data['holeallestati'] = 1;
|
|
}
|
|
}
|
|
if ($holealle) {
|
|
$ab_nummer = $shopexportArr['ab_nummer'];
|
|
$data['ab_nummer'] = $ab_nummer;
|
|
if ($holeallestati) {
|
|
$data['holeallestati'] = 1;
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftrag', $data);
|
|
}
|
|
if (!empty($zeitraum)) {
|
|
return $this->RemoteCommand($shopId, 'getauftrag', $data);
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftrag');
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param string $nummer
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetAuftragNummer($shopId, $nummer) {
|
|
$holealle = $this->app->DB->Select("SELECT holealle FROM shopexport WHERE id = '$shopId' LIMIT 1");
|
|
if ($holealle) {
|
|
$data = array('nummer' => $nummer);
|
|
|
|
return $this->RemoteCommand($shopId, 'getauftrag', $data);
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendExportlink($shopId) {
|
|
// passwort erzeugen , daten verschluesseln, wenn passwort neu link an kunden senden
|
|
// alternativ artikel umfrage
|
|
// $all = $this->app->DB->SelectArr("SELECT * FROM artikelgruppen WHERE shop='$id'");
|
|
// alle artikelid = 38 die in einem auftrag sind
|
|
// usb90key
|
|
$artikelid = 38;
|
|
|
|
$all = $this->app->DB->SelectArr("SELECT a.id as auftrag, a.adresse as adresse
|
|
FROM auftrag_position ap
|
|
LEFT JOIN auftrag a ON a.id=ap.auftrag
|
|
WHERE ap.artikel='$artikelid' AND ap.geliefert_menge < ap.menge AND a.status!='storniert'
|
|
AND a.status!='abgeschlossen'");
|
|
// mail mit url senden
|
|
if (empty($all)) {
|
|
return '';
|
|
}
|
|
$loop = 0;
|
|
$call = (!empty($all) ? count($all) : 0);
|
|
for ($i = 0; $i < $call; $i++) {
|
|
$auftragid = $all[$i]['auftrag'];
|
|
$adresse = $all[$i]['adresse'];
|
|
|
|
$grund = 'artikel';
|
|
|
|
$check = $this->app->DB->Select("SELECT reg FROM exportlink_sent WHERE adresse='$adresse' AND objekt='$artikelid' AND ident='$auftragid' LIMIT 1");
|
|
|
|
if ($check == '') {
|
|
$checkreg = 1;
|
|
while ($checkreg != '') {
|
|
$token1 = md5(uniqid(rand(), true));
|
|
$token2 = md5(uniqid(rand(), true));
|
|
|
|
$token3 = md5(uniqid(rand(), true));
|
|
$token4 = md5(uniqid(rand(), true));
|
|
|
|
$zufall = $token1 . '-' . $token2;
|
|
$zufall = md5($zufall);
|
|
|
|
$zufall2 = $token3 . '-' . $token4;
|
|
$zufall2 = md5($zufall2);
|
|
|
|
$reg = md5($zufall2 . $zufall);
|
|
|
|
$checkreg = $this->app->DB->Select("SELECT reg FROM exportlink_sent WHERE reg='$reg' LIMIT 1");
|
|
}
|
|
|
|
// pruefen ob es zahl schon gibt sonst nochmal
|
|
|
|
$data[$loop]['reg'] = $reg;
|
|
$data[$loop]['grund'] = $grund;
|
|
$data[$loop]['objekt'] = $artikelid; // artikel id
|
|
$data[$loop]['ident'] = $auftragid; //
|
|
$loop++;
|
|
|
|
$this->app->DB->Insert("INSERT INTO exportlink_sent (reg,grund,objekt,ident,adresse,datum) VALUES ($reg','$grund','$artikelid','$auftragid','$adresse',NOW())");
|
|
}
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'exportlink', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendNavigation($shopId) {
|
|
//$data[0] = array('aasas','asddd');
|
|
|
|
$all = $this->app->DB->SelectArr("SELECT * FROM shopnavigation WHERE shop='$shopId'");
|
|
$call = $all ? count($all) : 0;
|
|
$data = $call > 0 ? array() : null;
|
|
for ($i = 0; $i < $call; $i++) {
|
|
$data[$i]['id'] = $all[$i]['id'];
|
|
$data[$i]['bezeichnung'] = $all[$i]['bezeichnung'];
|
|
$data[$i]['position'] = $all[$i]['position'];
|
|
$data[$i]['parent'] = $all[$i]['parent'];
|
|
$data[$i]['bezeichnung_en'] = $all[$i]['bezeichnung_en'];
|
|
$data[$i]['plugin'] = $all[$i]['plugin'];
|
|
$data[$i]['pluginparameter'] = $all[$i]['pluginparameter'];
|
|
$data[$i]['target'] = $all[$i]['target'];
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'navigation', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendArtikelgruppen($shopId) {
|
|
$all = $this->app->DB->SelectArr("SELECT id, bezeichnung,bezeichnung_en,beschreibung_de,beschreibung_en
|
|
FROM artikelgruppen WHERE shop='$shopId'");
|
|
if (empty($all)) {
|
|
return '';
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'artikelgruppen', $all);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendInhalt($shopId) {
|
|
$all = $this->app->DB->SelectArr("SELECT * FROM inhalt WHERE shop='$shopId' AND aktiv=1");
|
|
if (empty($all)) {
|
|
return '';
|
|
}
|
|
$call = (!empty($all) ? count($all) : 0);
|
|
|
|
$data = array();
|
|
for ($i = 0; $i < $call; $i++) {
|
|
$data[$i]['sprache'] = $all[$i]['sprache'];
|
|
$data[$i]['inhalt'] = $all[$i]['inhalt'];
|
|
$data[$i]['kurztext'] = $all[$i]['kurztext'];
|
|
$data[$i]['html'] = $all[$i]['html'];
|
|
$data[$i]['title'] = $all[$i]['title'];
|
|
$data[$i]['description'] = $all[$i]['description'];
|
|
$data[$i]['keywords'] = $all[$i]['keywords'];
|
|
$data[$i]['inhaltstyp'] = $all[$i]['inhaltstyp'];
|
|
$data[$i]['template'] = $all[$i]['template'];
|
|
$data[$i]['finalparse'] = $all[$i]['finalparse'];
|
|
$data[$i]['navigation'] = $all[$i]['navigation'];
|
|
$data[$i]['sichtbarbis'] = $all[$i]['sichtbarbis'];
|
|
$data[$i]['datum'] = $all[$i]['datum'];
|
|
$data[$i]['aktiv'] = $all[$i]['aktiv'];
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'inhalt', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendArtikelArtikelgruppen($shopId) {
|
|
$all = $this->app->DB->SelectArr('SELECT * FROM artikel_artikelgruppe');
|
|
$call = $all ? count($all) : 0;
|
|
if ($call > 0) {
|
|
$data = array();
|
|
for ($i = 0; $i < $call; $i++) {
|
|
$data[$i]['id'] = $all[$i]['id'];
|
|
$data[$i]['artikel'] = $all[$i]['artikel'];
|
|
$data[$i]['artikelgruppe'] = $all[$i]['artikelgruppe'];
|
|
$data[$i]['position'] = $all[$i]['position'];
|
|
}
|
|
|
|
return $this->RemoteCommand($shopId, 'artikelartikelgruppen', $data);
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param string $tabelle
|
|
* @param int $intid
|
|
* @param int $intid2
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function GetShopexportMappingExt($shopId, $tabelle, $intid, $intid2 = 0) {
|
|
return $this->app->DB->Select("SELECT extid
|
|
FROM shopexport_mapping
|
|
WHERE shop = '$shopId' AND tabelle = '$tabelle' AND intid = '$intid' " . ($intid2 ? " AND intid2 = '$intid2' " : '') . " LIMIT 1");
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param string $tabelle
|
|
* @param string $extid
|
|
* @param int $intid2
|
|
*
|
|
* @return mixed
|
|
*/
|
|
protected function GetShopexportMappingInt($shopId, $tabelle, $extid, $intid2 = 0) {
|
|
return $this->app->DB->Select("SELECT intid
|
|
FROM shopexport_mapping
|
|
WHERE shop = '$shopId' AND tabelle = '$tabelle' AND extid = '$extid' " . ($intid2 ? " AND intid2 = '$intid2' " : '') . "
|
|
LIMIT 1");
|
|
}
|
|
|
|
/**
|
|
* @param int $shop
|
|
* @param string $tabelle
|
|
* @param int $intid
|
|
* @param string $extid
|
|
* @param int $intid2
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public function ShopexportMappingSet($shop, $tabelle, $intid, $extid, $intid2 = 0) {
|
|
$check = $this->app->DB->Select("SELECT id FROM shopexport_mapping
|
|
WHERE shop = '$shop' AND tabelle = '$tabelle' AND intid = '$intid' AND intid2 = '$intid2' LIMIT 1");
|
|
if (!$check) {
|
|
$this->app->DB->Insert("INSERT INTO shopexport_mapping (shop, tabelle, intid, intid2, extid, zeitstempel)
|
|
VALUES ('$shop', '$tabelle', '$intid', '$intid2', '$extid', now())");
|
|
return $this->app->DB->GetInsertID();
|
|
}
|
|
$this->app->DB->Update("UPDATE shopexport_mapping SET extid = '$extid' WHERE id = '$check' LIMIT 1");
|
|
|
|
return $check;
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param string $nummer
|
|
* @param bool $create
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteGetArticle($id, $nummer, $create = false) {
|
|
if ($create) {
|
|
$data['nummerintern'] = $nummer;
|
|
} else {
|
|
$data['nummer'] = $nummer;
|
|
}
|
|
$ret = $this->RemoteCommand($id, 'getarticle', $data);
|
|
$variante_von = null;
|
|
//if(!$create)return $ret;
|
|
$_nummer = null;
|
|
$shopexportArr = $this->app->DB->SelectRow("SELECT * FROM shopexport WHERE id = '$id' LIMIT 1");
|
|
$projekt = $shopexportArr['projekt'];
|
|
$nurneueartikel = $shopexportArr['nurneueartikel'];
|
|
$artikelnummerbeimanlegenausshop = $shopexportArr['artikelnummerbeimanlegenausshop'];
|
|
if (!$create) {
|
|
$nurneueartikel = false;
|
|
}
|
|
if (!isset($ret['nummer']) && isset($ret[0]) && isset($ret[0]['nummer'])) {
|
|
$reta = $ret;
|
|
} elseif (isset($ret['nummer'])) {
|
|
$reta[] = $ret;
|
|
} elseif (isset($ret[0]) && isset($ret[0]['name'])) {
|
|
$ret[0]['nummer'] = ''; //$nummer;
|
|
$reta = $ret;
|
|
} elseif (isset($ret['name'])) {
|
|
$ret['nummer'] = ''; //$nummer;
|
|
$reta[] = $ret;
|
|
} else {
|
|
return $ret;
|
|
}
|
|
if (!$reta || !is_array($reta)) {
|
|
return $ret;
|
|
}
|
|
$stuecklistenmechanik = false;
|
|
$variantevonorig = null;
|
|
$steuersatz_normal = $this->app->erp->Firmendaten('steuersatz_normal');
|
|
$steuersatz_ermaessigt = $this->app->erp->Firmendaten('steuersatz_ermaessigt');
|
|
if (empty($steuersatz_ermaessigt)) {
|
|
$steuersatz_ermaessigt = 7;
|
|
}
|
|
if (empty($steuersatz_normal)) {
|
|
$steuersatz_normal = 19;
|
|
}
|
|
$crossellingInstalled = $this->app->erp->ModulVorhanden('crossselling');
|
|
foreach ($reta as $k => $ret) {
|
|
if (isset($ret['stueckliste'])) {
|
|
$stuecklistenmechanik = $ret['stueckliste'];
|
|
}
|
|
$ret['nummer'] = $this->app->DB->real_escape_string(trim($ret['nummer']));
|
|
$articleid = null;
|
|
if ($k == 0) {
|
|
$articleid = $this->app->erp->GetArticleIDFromShopnumber($id, $nummer, true);
|
|
if ($articleid) {
|
|
$variantevonorig = $this->app->DB->Select("SELECT variante_von
|
|
FROM artikel
|
|
WHERE id = '$articleid' AND variante = 1
|
|
LIMIT 1");
|
|
if (!$variantevonorig) {
|
|
$articleid = $this->app->DB->Select("SELECT id
|
|
FROM artikel
|
|
WHERE id = '$articleid' AND ifnull(geloescht,0) = 0 AND nummer <> 'DEL'
|
|
LIMIT 1");
|
|
}
|
|
}
|
|
}
|
|
if ((isset($ret['nummerintern']) && $ret['nummerintern'] != '') && !$articleid) {
|
|
$articleid = $this->app->erp->GetArticleIDFromShopnumber($id, $ret['nummerintern']);
|
|
}
|
|
if (($ret['nummer'] != '') && !$articleid) {
|
|
$articleid = $this->app->erp->GetArticleIDFromShopnumber($id, $ret['nummer']);
|
|
}
|
|
if (($ret['ean'] != '') && !$articleid) {
|
|
$articleid = $this->app->erp->GetArticleIDFromShopnumber($id, $ret['ean']);
|
|
}
|
|
if ($articleid) {
|
|
if (isset($ret['shoparticleid']) && $ret['shoparticleid'] != '' && trim($this->app->DB->real_escape_string($ret['shoparticleid'])) != '') {
|
|
if (!$this->app->DB->Select("SELECT id FROM `artikelnummer_fremdnummern` WHERE shopid = '$id' AND artikel = '$articleid' AND nummer = '" . trim($this->app->DB->real_escape_string($ret['shoparticleid'])) . "' LIMIT 1")) {
|
|
$this->app->DB->Insert("INSERT INTO `artikelnummer_fremdnummern` (artikel, shopid, aktiv, nummer, bezeichnung)
|
|
VALUES ('$articleid','$id','1','" . trim($this->app->DB->real_escape_string($ret['shoparticleid'])) . "','SHOPID')");
|
|
}
|
|
}
|
|
}
|
|
if (!$articleid && !$create) {
|
|
continue;
|
|
}
|
|
if (!$articleid || !$nurneueartikel) {
|
|
if ($articleid) {
|
|
$arr['id'] = $articleid;
|
|
$arr['nummer'] = $this->app->DB->Select("SELECT nummer FROM artikel WHERE id = '$articleid' LIMIT 1");
|
|
} elseif ($ret['nummer'] == '') {
|
|
$arr['nummer'] = $this->app->erp->GetNextArtikelnummer('', 1, $shopexportArr['projekt']);
|
|
}
|
|
/* if(isset($ret['nummer']) && $ret['nummer'] == '' && !is_null($variante_von))
|
|
{
|
|
$ret['nummer'] = $_nummer.'-'.$ret['nummer'];
|
|
$arr['nummer'] = $ret['nummer'];
|
|
} */
|
|
if (isset($ret['stueckliste']) && empty($variante_von)) {
|
|
$arr['stueckliste'] = $ret['stueckliste'];
|
|
}
|
|
$arr['projekt'] = $shopexportArr['projekt'];
|
|
$arr['name_de'] = $ret['name'];
|
|
$arr['uebersicht_de'] = $ret['uebersicht_de'] ?? '';
|
|
$arr['kurztext_de'] = $ret['kurztext_de'] ?? '';
|
|
$arr['name_en'] = $ret['name_en'];
|
|
$arr['uebersicht_en'] = $ret['uebersicht_en'] ?? '';
|
|
$arr['kurztext_en'] = $ret['kurztext_en'] ?? '';
|
|
$arr['metakeywords_de'] = $ret['metakeywords_de'] ?? '';
|
|
$arr['metakeywords_en'] = $ret['metakeywords_en'] ?? '';
|
|
$arr['metatitle_de'] = $ret['metatitle_de'] ?? '';
|
|
$arr['metatitle_en'] = $ret['metatitle_en'] ?? '';
|
|
$arr['metadescription_de'] = $ret['metadescription_de'] ?? '';
|
|
$arr['metadescription_en'] = $ret['metadescription_en'] ?? '';
|
|
//$arr['anabregs_text'] = isset($ret['uebersicht_de'])?$ret['uebersicht_de']:'';
|
|
if (isset($ret['ean']) && $ret['ean'] != '') {
|
|
$arr['ean'] = $ret['ean'];
|
|
}
|
|
if (isset($ret['gewicht']) && $ret['gewicht'] !== '') {
|
|
$arr['gewicht'] = $ret['gewicht'];
|
|
}
|
|
if (isset($ret['laenge']) && $ret['laenge'] !== '') {
|
|
$arr['laenge'] = $ret['laenge'];
|
|
}
|
|
if (isset($ret['hoehe']) && $ret['hoehe'] !== '') {
|
|
$arr['hoehe'] = $ret['hoehe'];
|
|
}
|
|
if (isset($ret['breite']) && $ret['breite'] !== '') {
|
|
$arr['breite'] = $ret['breite'];
|
|
}
|
|
|
|
if (!$articleid) {
|
|
$arr['lagerartikel'] = 1;
|
|
}
|
|
if (true) {
|
|
if (!empty($ret['umsatzsteuer'])) {
|
|
if (is_numeric($ret['umsatzsteuer'])) {
|
|
if ($ret['umsatzsteuer'] == $steuersatz_normal) {
|
|
$arr['umsatzsteuer'] = 'normal';
|
|
} elseif ($ret['umsatzsteuer'] == $steuersatz_ermaessigt) {
|
|
$arr['umsatzsteuer'] = 'ermaessigt';
|
|
}
|
|
} elseif (in_array($ret['umsatzsteuer'], array('normal', 'ermaessigt', 'befreit'))) {
|
|
$arr['umsatzsteuer'] = $ret['umsatzsteuer'];
|
|
}
|
|
}
|
|
}
|
|
|
|
$arr['hersteller'] = $ret['hersteller'];
|
|
if (!$stuecklistenmechanik && isset($ret['variante_von']) && !$articleid) {
|
|
$variantevon = $this->app->DB->Select("SELECT artikel
|
|
FROM `artikelnummer_fremdnummern`
|
|
WHERE shopid = '$id' AND aktiv = 1 AND nummer = '" . trim($ret['variante_von']) . "' AND nummer <> ''
|
|
LIMIT 1");
|
|
if (empty($variantevon)) {
|
|
$variantevon = $this->app->DB->Select("SELECT id
|
|
FROM artikel
|
|
WHERE ifnull(geloescht,0) = 0 AND nummer <> 'DEL' AND nummer <> '' AND nummer = '" . trim($ret['variante_von']) . "'
|
|
ORDER BY projekt = '$projekt' DESC
|
|
LIMIT 1");
|
|
}
|
|
if (empty($variantevon)) {
|
|
$variantevon = $variantevonorig;
|
|
}
|
|
if (!empty($variantevon)) {
|
|
$arr['variante'] = 1;
|
|
$arr['variante_von'] = $variantevon;
|
|
}
|
|
} elseif ($variante_von) {
|
|
if ($variante_von) {
|
|
$arr['variante'] = 1;
|
|
}
|
|
if ($variante_von) {
|
|
$arr['variante_von'] = $variante_von;
|
|
}
|
|
}
|
|
$freifeldmapping = $this->app->DB->SelectArr("SELECT *
|
|
FROM shopexport_freifelder
|
|
WHERE shop = '$id' AND aktiv = 1 AND freifeld_shop <> '' AND freifeld_wawi <> ''");
|
|
if (!empty($freifeldmapping)) {
|
|
foreach ($freifeldmapping as $freifeldval) {
|
|
$freifeldShopKey = 'freifeld_' . $freifeldval['freifeld_shop'];
|
|
if (isset($ret[$freifeldShopKey])) {
|
|
$arr[$freifeldval['freifeld_wawi']] = $ret[$freifeldShopKey];
|
|
}
|
|
}
|
|
}
|
|
$articleid = $this->app->erp->InsertUpdateArtikel($arr);
|
|
unset($arr);
|
|
if ($artikelnummerbeimanlegenausshop && !empty($ret['artikelnummerausshop'])) {
|
|
$this->app->DB->Update("UPDATE artikel SET nummer = '" . $ret['artikelnummerausshop'] . "' WHERE id = '$articleid'");
|
|
}
|
|
|
|
$ret['nummer'] = $this->app->DB->Select("SELECT nummer FROM artikel WHERE id = '$articleid' LIMIT 1");
|
|
if (isset($ret['bilder']) && $ret['bilder'] && is_array($ret['bilder'])) {
|
|
$dateien = $this->app->DB->SelectArr("SELECT * FROM datei_stichwoerter ds INNER JOIN datei_version dv ON ds.datei = dv.datei AND ds.parameter = '$articleid' AND ds.objekt LIKE 'Artikel' ORDER BY ds.sort");
|
|
if (empty($dateien)) {
|
|
foreach ($ret['bilder'] as $v) {
|
|
if ($v['path'] != '' && $v['content'] != '') {
|
|
$path_parts = pathinfo($v['path']);
|
|
$tmpfilename = tempnam($this->app->erp->GetTMP(), 'img');
|
|
file_put_contents($tmpfilename, base64_decode($v['content']));
|
|
$fileid = $this->app->erp->CreateDatei($path_parts['basename'], 'Shopbild', '', '', $tmpfilename, 'Cronjob');
|
|
$this->app->erp->AddDateiStichwort($fileid, 'Shopbild', 'artikel', $articleid);
|
|
if (@is_file($tmpfilename))
|
|
unlink($tmpfilename);
|
|
}
|
|
}
|
|
} elseif ($dateien[0]['subjekt'] === 'shopbild') {
|
|
$this->app->DB->Update("UPDATE datei_stichwoerter SET subjekt = 'Shopbild' WHERE id = '" . $dateien[0]['id'] . "' AND subjekt = 'shopbild' LIMIT 1");
|
|
}
|
|
}
|
|
if ($variante_von === null) {
|
|
$variante_von = $articleid;
|
|
$_nummer = $this->app->DB->Select("SELECT nummer FROM artikel WHERE id = '$articleid' LIMIT 1");
|
|
$nummer = isset($ret['nummerintern']) ? $ret['nummerintern'] : (isset($ret['nummer']) ? $ret['nummer'] : '');
|
|
}
|
|
if (!empty($ret['preis_netto']) && $ret['preis_netto'] > 0) {
|
|
$this->app->erp->AddVerkaufspreis($articleid, 1, 0, $ret['preis_netto']);
|
|
}
|
|
|
|
if (!empty($ret['bilder']) && is_array($ret['bilder'])) {
|
|
$dateien = $this->app->DB->SelectArr("SELECT *
|
|
FROM datei_stichwoerter ds
|
|
INNER JOIN datei_version dv ON ds.datei = dv.datei AND ds.parameter = '$articleid' AND ds.objekt LIKE 'Artikel'
|
|
ORDER BY ds.sort");
|
|
if (empty($dateien)) {
|
|
foreach ($ret['bilder'] as $v) {
|
|
if ($v['path'] != '' && $v['content'] != '') {
|
|
$path_parts = pathinfo($v['path']);
|
|
$tmpfilename = tempnam($this->app->erp->GetTMP(), 'img');
|
|
file_put_contents($tmpfilename, base64_decode($v['content']));
|
|
$fileid = $this->app->erp->CreateDatei($path_parts['basename'], 'Shopbild', '', '', $tmpfilename, 'Cronjob');
|
|
if (isset($v['id'])) {
|
|
$this->ShopexportMappingSet($id, 'datei', $fileid, $v['id'], $articleid);
|
|
}
|
|
$this->app->erp->AddDateiStichwort($fileid, 'Shopbild', 'artikel', $articleid);
|
|
if (@is_file($tmpfilename))
|
|
unlink($tmpfilename);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($crossellingInstalled) {
|
|
if (!empty($ret['crossselling'])) {
|
|
if (!empty($ret['crossselling']['similar'])) {
|
|
foreach ($ret['crossselling']['similar'] as $cskey => $csvalue) {
|
|
$crosssellingartikel = $this->app->DB->Select("SELECT id from artikel WHERE nummer= '" . $csvalue . "' and geloescht='0'");
|
|
if ($crosssellingartikel) {
|
|
if (!$this->app->DB->Select("SELECT id FROM crossselling_artikel WHERE artikel='$articleid' AND crosssellingartikel='$crosssellingartikel' AND shop='$id'")) {
|
|
$sort = $this->app->DB->Select("SELECT MAX(sort)+1 from crossselling_artikel WHERE artikel='$articleid' AND shop='$id'");
|
|
$this->app->DB->Insert("INSERT INTO crossselling_artikel (aktiv, art, artikel, crosssellingartikel, shop, sort, bemerkung) VALUES ('1','1','$articleid','$crosssellingartikel','$id','$sort','Über Artikelimport hinzugefügt')");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (!empty($ret['crossselling']['related'])) {
|
|
foreach ($ret['crossselling']['related'] as $cskey => $csvalue) {
|
|
$crosssellingartikel = $this->app->DB->Select("SELECT id from artikel WHERE nummer= '" . $csvalue . "' and geloescht='0'");
|
|
if ($crosssellingartikel) {
|
|
if (!$this->app->DB->Select("SELECT id FROM crossselling_artikel WHERE artikel='$articleid' AND crosssellingartikel='$crosssellingartikel' AND shop='$id'")) {
|
|
$sort = $this->app->DB->Select("SELECT MAX(sort)+1 from crossselling_artikel WHERE artikel='$articleid' AND shop='$id'");
|
|
$this->app->DB->Insert("INSERT INTO crossselling_artikel (aktiv, art, artikel, crosssellingartikel, shop, sort, bemerkung) VALUES ('1','2','$articleid','$crosssellingartikel','$id','$sort','Über Artikelimport hinzugefügt')");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$katext = 0;
|
|
if (isset($ret['kategorien_all']) && $ret['kategorien_all']) {
|
|
foreach ($ret['kategorien_all'] as $v) {
|
|
if ($katext == 0 && $v['parent'] == 0) {
|
|
$katext = $v['id'];
|
|
}
|
|
if (!$this->app->DB->Select("SELECT id
|
|
FROM shopexport_kategorien
|
|
WHERE shop = '$id' AND extid = '" . $this->app->DB->real_escape_string($v['id']) . "' LIMIT 1")) {
|
|
$this->app->DB->Insert("INSERT INTO shopexport_kategorien (shop, extid, aktiv,extname,extparent,extsort) VALUES
|
|
('$id','" . $this->app->DB->real_escape_string($v['id']) . "','" . (int) $v['aktiv'] . "','" . $this->app->DB->real_escape_string($v['name']) . "','" . $this->app->DB->real_escape_string($v['parent']) . "','" . (int) $v['sort'] . "')");
|
|
}
|
|
}
|
|
$shopkategorien = $this->getShopKatgeorien($id);
|
|
/** @var Onlineshops $onlineShopObj */
|
|
$onlineShopObj = $this->app->loadModule('onlineshops');
|
|
$categoryRootId = 0;
|
|
if (!empty($onlineShopObj) && method_exists($onlineShopObj, 'getJsonSettings')) {
|
|
$categoryRootId = (int) $onlineShopObj->getJsonSettings($id, 'category_root_id');
|
|
}
|
|
$kategorientoint = [$categoryRootId];
|
|
|
|
if (!empty($shopkategorien)) {
|
|
foreach ($shopkategorien as $v) {
|
|
if (!$v['kategorie']) {
|
|
$parentInXentral = $kategorientoint[$v['extparent']];
|
|
if (empty($parentInXentral)) {
|
|
$parentInXentral = $this->app->DB->Select("SELECT kategorie FROM shopexport_kategorien WHERE shop='$id' AND extid='" . $v['extparent'] . "' LIMIT 1");
|
|
}
|
|
$this->app->DB->Insert("INSERT INTO `artikelkategorien` (bezeichnung,parent)
|
|
VALUES ('" . $this->app->DB->real_escape_string($v['extname']) . "','$parentInXentral')");
|
|
$kategorientoint[$v['extid']] = $this->app->DB->GetInsertID();
|
|
$this->app->DB->Update("UPDATE shopexport_kategorien
|
|
SET kategorie = '" . $kategorientoint[$v['extid']] . "'
|
|
WHERE id = '" . $v['id'] . "' LIMIT 1");
|
|
$v['kategorie'] = $kategorientoint[$v['extid']];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (!empty($ret['kategorien'])) {
|
|
$shopkategorien = $this->app->DB->SelectArr("SELECT *
|
|
FROM shopexport_kategorien
|
|
WHERE shop = '$id' AND kategorie > 0
|
|
ORDER BY extparent, extsort");
|
|
if (!empty($shopkategorien)) {
|
|
foreach ($shopkategorien as $v) {
|
|
$kategorientoint[$v['extid']] = $v['kategorie'];
|
|
}
|
|
$kategoriezugewiesen = false;
|
|
foreach ($ret['kategorien'] as $v) {
|
|
if (!$kategoriezugewiesen) {
|
|
$kategorieid = $this->app->DB->Select("SELECT id FROM artikelkategorien WHERE bezeichnung='" . $v['name'] . "' AND parent=0 AND geloescht=0 LIMIT 1");
|
|
if ($kategorieid) {
|
|
$this->app->DB->Update("UPDATE artikel SET typ = '" . $kategorieid . "_kat' WHERE id = '$articleid' LIMIT 1");
|
|
$kategoriezugewiesen = true;
|
|
}
|
|
}
|
|
|
|
|
|
if (isset($kategorientoint[$v['id']]) && $kategorientoint[$v['id']]) {
|
|
if (!$this->app->DB->Select("SELECT id FROM artikelbaum_artikel WHERE artikel = '$articleid' AND kategorie = '" . $kategorientoint[$v['id']] . "' LIMIT 1")) {
|
|
$this->app->DB->Insert("INSERT INTO artikelbaum_artikel (artikel, kategorie)
|
|
VALUES ('$articleid', '" . $kategorientoint[$v['id']] . "')");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if (!empty($ret['eigenschaften'])) {
|
|
foreach ($ret['eigenschaften'] as $v) {
|
|
if ($v['name'] != '') {
|
|
$eigenschaft = $this->app->DB->Select("SELECT id
|
|
FROM `artikeleigenschaften`
|
|
WHERE name = '" . $this->app->DB->real_escape_string($v['name']) . "' AND geloescht = 0
|
|
LIMIT 1");
|
|
if (!$eigenschaft) {
|
|
$this->app->DB->Insert("INSERT INTO `artikeleigenschaften` (name)
|
|
VALUES ('" . $this->app->DB->real_escape_string($v['name']) . "')");
|
|
$eigenschaft = $this->app->DB->GetInsertID();
|
|
}
|
|
if ($eigenschaft) {
|
|
$wert = $this->app->DB->Select("SELECT id
|
|
FROM artikeleigenschaftenwerte
|
|
WHERE artikel = '$articleid' AND artikeleigenschaften = '$eigenschaft' AND wert = '" . $this->app->DB->real_escape_string($v['values']) . "'
|
|
LIMIT 1");
|
|
if (!$wert) {
|
|
$this->app->DB->Insert("INSERT INTO artikeleigenschaftenwerte (artikel,artikeleigenschaften,wert)
|
|
VALUES ('$articleid','$eigenschaft','" . $this->app->DB->real_escape_string($v['values']) . "')");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($ret['matrixprodukt_gruppe1'])) {
|
|
$query = sprintf("UPDATE artikel SET matrixprodukt=1 WHERE id='%s'", $articleid);
|
|
$this->app->DB->Update($query);
|
|
for ($m = 1; $m <= 3; $m++) {
|
|
if (empty($ret['matrixprodukt_gruppe' . $m])) {
|
|
continue;
|
|
}
|
|
|
|
$gruppeName = $this->app->DB->real_escape_string($ret['matrixprodukt_gruppe' . $m]);
|
|
$query = sprintf("SELECT id FROM matrixprodukt_eigenschaftengruppen_artikel WHERE artikel='%s' AND name='%s'",
|
|
$articleid, $gruppeName);
|
|
$gruppeId = $this->app->DB->Select($query);
|
|
if (empty($gruppeId)) {
|
|
$query = sprintf("SELECT MAX(sort) FROM matrixprodukt_eigenschaftengruppen_artikel WHERE artikel='%s' AND name='%s'",
|
|
$articleid, $gruppeName);
|
|
$sort = $this->app->DB->Select($query);
|
|
if (empty($sort)) {
|
|
$sort = '0';
|
|
}
|
|
$query = sprintf("INSERT INTO matrixprodukt_eigenschaftengruppen_artikel
|
|
(artikel, aktiv, name, name_ext,projekt,bearbeiter,erstellt,sort, pflicht, oeffentlich,typ) VALUES
|
|
('%s','1','%s','','0','','NOW()','%s','1','0','0')", $articleid, $gruppeName, $sort);
|
|
$this->app->DB->Insert($query);
|
|
$gruppeId = $this->app->DB->GetInsertID();
|
|
}
|
|
|
|
foreach ($ret['matrixprodukt_optionen' . $m] as $optionBezeichnung) {
|
|
$optionBezeichnung = $this->app->DB->real_escape_string($optionBezeichnung);
|
|
$query = sprintf("SELECT id FROM matrixprodukt_eigenschaftenoptionen_artikel WHERE artikel='%s' AND name='%s'",
|
|
$articleid, $optionBezeichnung);
|
|
$optionId = $this->app->DB->Select($query);
|
|
if (empty($optionId)) {
|
|
$query = sprintf("SELECT MAX(sort) FROM matrixprodukt_eigenschaftenoptionen_artikel WHERE artikel='%s' AND name='%s'",
|
|
$articleid, $optionBezeichnung);
|
|
$sort = $this->app->DB->Select($query);
|
|
if (empty($sort)) {
|
|
$sort = '1';
|
|
}
|
|
$query = sprintf("INSERT INTO matrixprodukt_eigenschaftenoptionen_artikel
|
|
(artikel, matrixprodukt_eigenschaftenoptionen, aktiv,name,name_ext,sort,erstellt,gruppe,bearbeiter,artikelnummer)
|
|
VALUES ('%s','0','1','%s','','%s','NOW()','%s','','')",
|
|
$articleid, $optionBezeichnung, $sort, $gruppeId);
|
|
$this->app->DB->Insert($query);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($ret['matrixprodukt_wert1'])) {
|
|
for ($m = 1; $m <= 3; $m++) {
|
|
if (empty($ret['matrixprodukt_wert' . $m])) {
|
|
continue;
|
|
}
|
|
|
|
$optionBezeichnung = $this->app->DB->real_escape_string($ret['matrixprodukt_wert' . $m]);
|
|
$query = sprintf("SELECT id FROM matrixprodukt_eigenschaftenoptionen_artikel WHERE artikel='%s' AND name='%s'",
|
|
$variante_von, $optionBezeichnung);
|
|
$optionId = $this->app->DB->Select($query);
|
|
if (!empty($optionId)) {
|
|
$query = sprintf("SELECT id FROM matrixprodukt_optionen_zu_artikel WHERE artikel='%s' AND option_id='%s'",
|
|
$articleid, $optionId);
|
|
$zuordnungId = $this->app->DB->Select($query);
|
|
if (empty($zuordnungId)) {
|
|
$query = sprintf("INSERT INTO matrixprodukt_optionen_zu_artikel (artikel,option_id) VALUES ('%s','%s')",
|
|
$articleid, $optionId);
|
|
$this->app->DB->Insert($query);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!$this->app->DB->Select("SELECT id FROM `artikel_onlineshops` WHERE artikel = '$articleid' AND shop = '$id' AND aktiv = 1 LIMIT 1")) {
|
|
$this->app->DB->Insert("INSERT INTO `artikel_onlineshops` (artikel, shop,aktiv, ausartikel) VALUES ('$articleid', '$id',1 ,1)");
|
|
}
|
|
if (isset($ret['nummerintern']) && trim($ret['nummerintern']) != '') {
|
|
$data['nummerintern'] = trim($ret['nummerintern']);
|
|
}
|
|
if (($ret['nummer'] != $data['nummerintern']) && $data['nummerintern'] != '' && trim($data['nummerintern']) != '') {
|
|
$data['nummerintern'] = trim($data['nummerintern']);
|
|
if (!$this->app->DB->Select("SELECT id FROM `artikelnummer_fremdnummern` WHERE artikel = '$articleid' AND shopid = '$id' AND nummer = '" . $this->app->DB->real_escape_string($data['nummerintern']) . "' AND nummer <> '' LIMIT 1")) {
|
|
$this->app->DB->Insert("INSERT INTO `artikelnummer_fremdnummern` (artikel, shopid, aktiv, bearbeiter, zeitstempel,nummer) VALUES ('$articleid','$id','1','Cronjob',now(),'" . $this->app->DB->real_escape_string($data['nummerintern']) . "')");
|
|
}
|
|
}
|
|
} elseif ($articleid) {
|
|
if (isset($ret['ean']) && ($ret['ean'] != '') && $this->app->DB->Select("SELECT id FROM artikel WHERE id = '$articleid' AND ifnull(ean,'') = '' LIMIT 1")) {
|
|
$this->app->DB->Update("UPDATE artikel SET ean = '" . $this->app->DB->real_escape_string($ret['ean']) . "' WHERE id = '$articleid' AND ifnull(ean,'') = '' LIMIT 1");
|
|
}
|
|
}
|
|
|
|
if ($stuecklistenmechanik && !empty($variante_von) && !$this->app->erp->IstStuecklistenZirkel($articleid, $variante_von)) {
|
|
$stuecklistenmenge = 1;
|
|
if (!empty($ret['stuecklistemenge'])) {
|
|
$stuecklistenmenge = $ret['stuecklistemenge'];
|
|
}
|
|
$query = sprintf('SELECT MAX(sort) FROM stueckliste WHERE stuecklistevonartikel=%d', $variante_von);
|
|
$sort = $this->app->DB->Select($query);
|
|
if ($sort !== NULL) {
|
|
$sort++;
|
|
} else {
|
|
$sort = 0;
|
|
}
|
|
$query = sprintf("INSERT INTO stueckliste (sort, artikel, referenz, place, layer, stuecklistevonartikel,
|
|
menge, firma, wert, bauform, alternative, zachse, xpos, ypos, art)
|
|
VALUES (%d, %d, '', 'DP', 'Top', %d, %d, 1, '', '', 0, '', '', '', 'et')",
|
|
$sort, $articleid, $variante_von, $stuecklistenmenge);
|
|
$this->app->DB->Insert($query);
|
|
}
|
|
|
|
if ($variante_von === null) {
|
|
if (!empty($articleid) && $stuecklistenmechanik) {
|
|
$query = sprintf('DELETE FROM stueckliste WHERE stuecklistevonartikel=%d', $articleid);
|
|
$this->app->DB->Delete($query);
|
|
}
|
|
$variante_von = $articleid;
|
|
}
|
|
|
|
if (isset($ret['inaktiv'])) {
|
|
$ret['aktiv'] = !$ret['inaktiv'];
|
|
}
|
|
|
|
if (isset($ret['aktiv'])) {
|
|
if ($ret['aktiv']) {
|
|
$this->app->DB->Update("UPDATE artikel SET inaktiv = '0' WHERE id = '$articleid' LIMIT 1");
|
|
} else {
|
|
$this->app->DB->Update("UPDATE artikel SET inaktiv = '1' WHERE id = '$articleid' LIMIT 1");
|
|
}
|
|
}
|
|
if (isset($ret['staffelpreise'])) {
|
|
$date = new DateTime();
|
|
$date->sub(new DateInterval('P1D'));
|
|
$gestern = $date->format('Y-m-d');
|
|
$this->app->DB->Update("UPDATE verkaufspreise SET gueltig_bis='$gestern' WHERE artikel='$articleid' AND adresse='0' AND art='Kunde'");
|
|
|
|
foreach ($ret['staffelpreise'] as $staffelpreis) {
|
|
$preis = $staffelpreis['preis'];
|
|
if ($staffelpreis['brutto']) {
|
|
$umsatzsteuer = $this->app->DB->Select("SELECT umsatzsteuer FROM artikel WHERE id='$articleid' LIMIT 1");
|
|
$steuersatz = 0;
|
|
if ($umsatzsteuer === 'ermaessigt') {
|
|
$steuersatz = $this->app->erp->Firmendaten('steuersatz_ermaessigt');
|
|
}
|
|
if ($umsatzsteuer === 'normal') {
|
|
$steuersatz = $this->app->erp->Firmendaten('steuersatz_normal');
|
|
}
|
|
$preis /= 1 + $steuersatz / 100;
|
|
}
|
|
$this->app->erp->AddVerkaufspreis($articleid, $staffelpreis['ab_menge'], 0, $preis);
|
|
}
|
|
}
|
|
if (isset($ret['fremdnummern']) && !empty($ret['fremdnummern'])) {
|
|
foreach ($ret['fremdnummern'] as $fremdnummer) {
|
|
$query = sprintf("SELECT id FROM artikelnummer_fremdnummern WHERE shopid=%d AND nummer='%s' AND bezeichnung='%s' AND aktiv=%d AND artikel=%s",
|
|
$id, $this->app->DB->real_escape_string($fremdnummer['nummer']), $this->app->DB->real_escape_string($fremdnummer['bezeichnung']), '1', $articleid);
|
|
$fremdnummerfehlt = empty($this->app->DB->Select($query));
|
|
|
|
if ($fremdnummerfehlt) {
|
|
$query = sprintf("INSERT INTO artikelnummer_fremdnummern
|
|
(artikel, bezeichnung, nummer, shopid, bearbeiter, aktiv) VALUES
|
|
(%d,'%s','%s',%d,'%s',%d)",
|
|
$articleid, $this->app->DB->real_escape_string($fremdnummer['bezeichnung']),
|
|
$this->app->DB->real_escape_string($fremdnummer['nummer']), $id, $this->app->User->GetName(), 1);
|
|
$this->app->DB->Insert($query);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (isset($ret['pseudopreis'])) {
|
|
$this->app->DB->Update(sprintf("UPDATE artikel SET pseudopreis='%s' WHERE id=%d", $ret['pseudopreis'], $articleid));
|
|
}
|
|
if (!$create) {
|
|
return $ret;
|
|
}
|
|
}
|
|
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $parent
|
|
* @param int $lvl
|
|
*
|
|
* @return array
|
|
*/
|
|
protected function getShopKatgeorien($shopId, $parent = 0, $lvl = 0) {
|
|
if ($lvl > 20) {
|
|
return [];
|
|
}
|
|
$ret = [];
|
|
$shopkategorien = $this->app->DB->SelectArr("SELECT * FROM shopexport_kategorien WHERE shop = '$shopId' AND extparent = '$parent' AND extid <> '' ORDER BY extsort");
|
|
if ($shopkategorien) {
|
|
foreach ($shopkategorien as $v) {
|
|
$ret[] = $v;
|
|
$subkategorien = $this->getShopKatgeorien($shopId, $v['extid'], $lvl + 1);
|
|
if (!empty($subkategorien)) {
|
|
foreach ($subkategorien as $v2) {
|
|
$ret[] = $v2;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param array $artikel_arr
|
|
* @param string|array $extnummer
|
|
* @param bool $nurlager
|
|
*
|
|
* @return mixed|null
|
|
* @throws Exception
|
|
*
|
|
* (NEW 2024-06-28)
|
|
*
|
|
* return value: (comes from Importsendlist or Importsendlistlager inside shopimporter_...)
|
|
* array (
|
|
* 'count' => int, // Number of successfully sent articles
|
|
* 'new' => array (artikelid, fremdnummer), // List of new articles with external number
|
|
* 'message' => string
|
|
* 'status' => bool, // false = failed
|
|
* 'articles' => array(
|
|
* 'id',
|
|
* 'status',
|
|
* 'message',
|
|
* ...
|
|
* )
|
|
* )
|
|
*
|
|
*/
|
|
public function RemoteSendArticleList($id, $artikel_arr, $extnummer = '', $nurlager = false) {
|
|
|
|
$this->logger->debug(
|
|
'RemoteSendArticleList',
|
|
[
|
|
'shop' => $id,
|
|
'artikel_arr' => $artikel_arr
|
|
]
|
|
);
|
|
|
|
if (!class_exists('ObjGenArtikel') &&
|
|
is_file(dirname(__DIR__) . '/objectapi/mysql/_gen/object.gen.artikel.php')) {
|
|
include_once dirname(__DIR__) . '/objectapi/mysql/_gen/object.gen.artikel.php';
|
|
}
|
|
$shopexportarr = $this->app->DB->SelectRow("SELECT * FROM shopexport WHERE id='$id' LIMIT 1");
|
|
$artikelexport = $shopexportarr['artikelexport'];
|
|
$translationpossible = false;
|
|
if ($this->app->erp->ModulVorhanden('artikel_texte')) {
|
|
$translationpossible = true;
|
|
}
|
|
$loadElements = [
|
|
'foreign_numbers' => true,
|
|
'article_descriptions' => true,
|
|
'translations' => true,
|
|
'categories' => true,
|
|
'properties' => true,
|
|
'pictures' => true,
|
|
'cross_selling' => true,
|
|
'bulk_prices' => true,
|
|
'standard_price' => true,
|
|
'variants' => true,
|
|
'free_fields' => true,
|
|
];
|
|
|
|
if (
|
|
($nurlager || empty($artikelexport)) && !empty($shopexportarr['modulename']) && !is_file(dirname(__DIR__) . '/pages/' . $shopexportarr['modulename'] . '_custom.php')
|
|
) {
|
|
$elementsNotNeededByModule = ShopimporterBase::storageNotNeededElements($shopexportarr['modulename']);
|
|
foreach ($elementsNotNeededByModule as $element) {
|
|
$loadElements[$element] = false;
|
|
}
|
|
}
|
|
|
|
//$lagerexport = $shopexportarr['lagerexport'];
|
|
$lagergrundlage = $shopexportarr['lagergrundlage'];
|
|
$shopbilderuebertragen = $shopexportarr['shopbilderuebertragen'];
|
|
$projekt = (int) $shopexportarr['projekt'];
|
|
$projektlager = $this->app->DB->Select("SELECT id FROM projekt WHERE id = $projekt AND projektlager = 1 LIMIT 1");
|
|
$tmp = new ObjGenArtikel($this->app);
|
|
$cartikel_arr = !empty($artikel_arr) ? count($artikel_arr) : 0;
|
|
|
|
for ($i = 0; $i < $cartikel_arr; $i++) {
|
|
$artikel = $artikel_arr[$i];
|
|
$lagerexport = $this->app->erp->GetArtikelShopEinstellung('autolagerlampe', $artikel, $shopexportarr);
|
|
$tmp->Select($artikel);
|
|
$data[$i] = ['artikel' => $artikel, 'artikelid' => $artikel];
|
|
$data[$i]['nummer'] = $tmp->GetNummer();
|
|
$projekt = $tmp->GetProjekt();
|
|
if (is_array($extnummer) && (!empty($extnummer) ? count($extnummer) : 0) > $i && !empty($extnummer[$i]) && trim($extnummer[$i]) != '') {
|
|
if ($data[$i]['nummer'] != trim($extnummer[$i])) {
|
|
$data[$i]['fremdnummer'] = trim($extnummer[$i]);
|
|
}
|
|
}
|
|
|
|
$data[$i]['inaktiv'] = $tmp->GetInaktiv();
|
|
|
|
if ($tmp->GetIntern_Gesperrt() == '1') {
|
|
$data[$i]['inaktiv'] = 1;
|
|
}
|
|
|
|
$data[$i]['name_de'] = $tmp->GetName_De();
|
|
$data[$i]['name_en'] = $tmp->GetName_En();
|
|
$data[$i]['einheit'] = $tmp->GetEinheit();
|
|
$data[$i]['hersteller'] = $tmp->GetHersteller();
|
|
$data[$i]['herstellernummer'] = $tmp->GetHerstellernummer();
|
|
$data[$i]['ean'] = $tmp->GetEan();
|
|
if (!empty($loadElements['foreign_numbers'])) {
|
|
$data[$i]['artikelnummer_fremdnummern'] = $this->app->DB->SelectArr("SELECT * FROM artikelnummer_fremdnummern WHERE artikel = '" . $tmp->GetId() . "' AND shopid = '$id' AND aktiv = '1' AND nummer <> '' ORDER BY bezeichnung = 'SHOPID' DESC");
|
|
if (!empty($data[$i]['artikelnummer_fremdnummern'])) {
|
|
foreach ($data[$i]['artikelnummer_fremdnummern'] as $fkey => $fval) {
|
|
$data[$i]['artikelnummer_fremdnummern'][$fkey]['nummer'] = trim($fval['nummer']);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($loadElements['article_descriptions'])) {
|
|
$data[$i]['kurztext_de'] = $tmp->GetKurztext_De();
|
|
$data[$i]['kurztext_en'] = $tmp->GetKurztext_En();
|
|
$data[$i]['anabregs_text'] = htmlspecialchars($tmp->GetAnabregs_Text(), ENT_QUOTES);
|
|
$data[$i]['anabregs_text_en'] = htmlspecialchars($tmp->GetAnabregs_Text_En(), ENT_QUOTES);
|
|
$data[$i]['beschreibung_de'] = $tmp->GetBeschreibung_De();
|
|
$data[$i]['beschreibung_en'] = $tmp->GetBeschreibung_En();
|
|
$data[$i]['uebersicht_de'] = htmlspecialchars($tmp->GetUebersicht_De(), ENT_QUOTES);
|
|
$data[$i]['uebersicht_en'] = htmlspecialchars($tmp->GetUebersicht_En(), ENT_QUOTES);
|
|
$data[$i]['herkunftsland'] = $tmp->GetHerkunftsland();
|
|
|
|
$data[$i]['texteuebertragen'] = $shopexportarr['texteuebertragen'];
|
|
|
|
if (method_exists($tmp, 'GetMetadescription_De')) {
|
|
$data[$i]['metadescription_de'] = $tmp->GetMetadescription_De();
|
|
}
|
|
if (method_exists($tmp, 'GetMetadescription_En')) {
|
|
$data[$i]['metadescription_en'] = $tmp->GetMetadescription_En();
|
|
}
|
|
if (method_exists($tmp, 'GetMetakeywords_De')) {
|
|
$data[$i]['metakeywords_de'] = $tmp->GetMetakeywords_De();
|
|
}
|
|
if (method_exists($tmp, 'GetMetakeywords_En')) {
|
|
$data[$i]['metakeywords_en'] = $tmp->GetMetakeywords_En();
|
|
}
|
|
if (method_exists($tmp, 'GetMetatitle_De')) {
|
|
$data[$i]['metatitle_de'] = $tmp->GetMetatitle_De();
|
|
}
|
|
if (method_exists($tmp, 'GetMetatitle_En')) {
|
|
$data[$i]['metatitle_en'] = $tmp->GetMetatitle_En();
|
|
}
|
|
}
|
|
if ($tmp->GetVariante()) {
|
|
$variante_von = $tmp->GetVariante_Von();
|
|
if ($variante_von) {
|
|
$tmp_2 = new ObjGenArtikel($this->app);
|
|
$tmp_2->Select($variante_von);
|
|
if ($data[$i]['kurztext_de'] == '') {
|
|
$data[$i]['kurztext_de'] = $tmp_2->GetKurztext_De();
|
|
}
|
|
if ($data[$i]['kurztext_en'] == '') {
|
|
$data[$i]['kurztext_en'] = $tmp_2->GetKurztext_En();
|
|
}
|
|
if ($data[$i]['beschreibung_de'] == '') {
|
|
$data[$i]['beschreibung_de'] = $tmp_2->GetBeschreibung_De();
|
|
}
|
|
if ($data[$i]['beschreibung_en'] == '') {
|
|
$data[$i]['beschreibung_en'] = $tmp_2->GetBeschreibung_En();
|
|
}
|
|
if ($data[$i]['uebersicht_de'] == '') {
|
|
$data[$i]['uebersicht_de'] = htmlspecialchars($tmp_2->GetUebersicht_De(), ENT_QUOTES);
|
|
}
|
|
if ($data[$i]['uebersicht_en'] == '') {
|
|
$data[$i]['uebersicht_en'] = htmlspecialchars($tmp_2->GetUebersicht_En(), ENT_QUOTES);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($data[$i]['uebersicht_de'] == '' && $data[$i]['beschreibung_de'] == '' && $data[$i]['kurztext_de'] == '') {
|
|
$data[$i]['uebersicht_de'] = $data[$i]['anabregs_text'];
|
|
}
|
|
|
|
$data[$i]['links_de'] = $tmp->GetLinks_De();
|
|
$data[$i]['altersfreigabe'] = $tmp->GetAltersfreigabe();
|
|
$data[$i]['links_en'] = $tmp->GetLinks_En();
|
|
$data[$i]['startseite_de'] = $tmp->GetStartseite_De();
|
|
$data[$i]['startseite_en'] = $tmp->GetStartseite_En();
|
|
$data[$i]['restmenge'] = $this->app->erp->GetArtikelShopEinstellung('restmenge', $artikel, $shopexportarr);
|
|
$data[$i]['startseite'] = $tmp->GetStartseite();
|
|
$data[$i]['standardbild'] = $tmp->GetStandardbild();
|
|
$data[$i]['herstellerlink'] = $tmp->GetHerstellerlink();
|
|
$data[$i]['herstellernummer'] = $tmp->GetHerstellernummer();
|
|
$data[$i]['hersteller'] = $tmp->GetHersteller();
|
|
$data[$i]['lieferzeit'] = $tmp->GetLieferzeit();
|
|
$data[$i]['lieferzeitmanuell'] = $this->app->erp->GetArtikelShopEinstellung('lieferzeitmanuell', $artikel, $shopexportarr);
|
|
$data[$i]['gewicht'] = $tmp->GetGewicht();
|
|
$data[$i]['laenge'] = $tmp->GetLaenge();
|
|
$data[$i]['breite'] = $tmp->GetBreite();
|
|
$data[$i]['hoehe'] = $tmp->GetHoehe();
|
|
|
|
$data[$i]['wichtig'] = $tmp->GetWichtig();
|
|
$data[$i]['porto'] = $tmp->GetPorto();
|
|
$data[$i]['gesperrt'] = $tmp->GetGesperrt();
|
|
$data[$i]['sperrgrund'] = $tmp->GetSperrgrund();
|
|
$data[$i]['gueltigbis'] = $tmp->GetGueltigbis();
|
|
$data[$i]['umsatzsteuer'] = $tmp->GetUmsatzsteuer();
|
|
if ($data[$i]['umsatzsteuer'] !== 'ermaessigt' && $data[$i]['umsatzsteuer'] !== 'befreit') {
|
|
$data[$i]['umsatzsteuer'] = "normal";
|
|
}
|
|
$data[$i]['ausverkauft'] = $tmp->GetAusverkauft();
|
|
$data[$i]['variante'] = $tmp->GetVariante();
|
|
$data[$i]['variante_von_id'] = $tmp->GetVariante_Von();
|
|
$data[$i]['variantevon'] = $this->app->DB->Select("SELECT nummer FROM artikel WHERE id='" . $tmp->GetVariante_Von() . "' LIMIT 1");
|
|
$data[$i]['variantevon_fremdnummer'] = trim($this->app->DB->Select("SELECT nummer FROM `artikelnummer_fremdnummern` WHERE shopid = '$id' AND aktiv = 1 AND artikel = '" . $tmp->GetVariante_Von() . "' AND trim(nummer) <> '' ORDER BY bezeichnung = 'SHOPID' DESC LIMIT 1"));
|
|
if ($data[$i]['variantevon_fremdnummer'] == '') {
|
|
unset($data[$i]['variantevon_fremdnummer']);
|
|
}
|
|
//$data[$i]['pseudopreis'] = $tmp->GetPseudopreis();
|
|
$data[$i]['pseudopreis'] = $this->app->erp->GetArtikelShopEinstellung('pseudopreis', $artikel, $shopexportarr);
|
|
$data[$i]['keinrabatterlaubt'] = $tmp->GetKeinrabatterlaubt();
|
|
$data[$i]['einkaufspreis'] = $this->app->erp->GetEinkaufspreis($artikel, 1);
|
|
//$data[$i]['pseudolager'] = $tmp->GetPseudolager();
|
|
$data[$i]['pseudolager'] = $this->app->erp->GetArtikelShopEinstellung('pseudolager', $artikel, $shopexportarr);
|
|
$this->app->erp->RunHook('remote_send_article_list_pseudostorage', 3, $id, $artikel, $data[$i]['pseudolager']);
|
|
if (is_numeric($data[$i]['pseudolager']) && $data[$i]['pseudolager'] < 0) {
|
|
$data[$i]['pseudolager'] = 0;
|
|
}
|
|
$data[$i]['downloadartikel'] = $tmp->GetDownloadartikel();
|
|
$data[$i]['zolltarifnummer'] = $tmp->GetZolltarifnummer();
|
|
$preisgruppe = $this->app->DB->Select("SELECT s.preisgruppe FROM shopexport s INNER JOIN gruppen g ON s.preisgruppe = g.id AND g.aktiv = 1 WHERE s.id='$id' LIMIT 1");
|
|
|
|
if (empty($loadElements['free_fields'])) {
|
|
$freifelder = null;
|
|
} else {
|
|
$freifelder = $this->app->DB->SelectArr("SELECT freifeld_wawi, freifeld_shop FROM shopexport_freifelder WHERE shop = '$id' AND aktiv = 1 AND freifeld_wawi <> '' AND freifeld_shop <> ''");
|
|
}
|
|
if ($freifelder) {
|
|
/**
|
|
* @deprecated 20.1
|
|
* AP
|
|
* Konstrunktion 'freifeld_Mappingname -> Wert' wird ersetzt durch 'Freifelder-> DE -> Mappingname -> Wert'
|
|
*/
|
|
foreach ($freifelder as $freifeld) {
|
|
if (method_exists($tmp, 'Get' . ucfirst($freifeld['freifeld_wawi']))) {
|
|
$_funktionsname = 'Get' . ucfirst($freifeld['freifeld_wawi']);
|
|
$data[$i]['freifeld_' . $freifeld['freifeld_shop']] = $tmp->$_funktionsname();
|
|
}
|
|
}
|
|
/**
|
|
* @deprecated Ende
|
|
*/
|
|
foreach ($freifelder as $freifeld) {
|
|
$_funktionsname = 'Get' . ucfirst($freifeld['freifeld_wawi']);
|
|
if (method_exists($tmp, $_funktionsname)) {
|
|
$data[$i]['freifelder']['DE'][$freifeld['freifeld_shop']] = $tmp->$_funktionsname();
|
|
}
|
|
}
|
|
|
|
//Freifeldübersetzungen
|
|
$freifelduebersetzungen = $this->app->DB->SelectArr("SELECT sf.freifeld_shop, af.sprache, af.nummer, af.wert FROM shopexport_freifelder sf JOIN artikel_freifelder af ON sf.freifeld_wawi = CONCAT('freifeld',af.nummer) WHERE sf.shop = '$id' AND af.artikel = '$artikel' AND sf.aktiv = 1 AND sf.freifeld_wawi <> '' AND sf.freifeld_shop <> '' AND af.wert <> ''");
|
|
if (!empty($freifelduebersetzungen)) {
|
|
foreach ($freifelduebersetzungen as $ffukey => $ffuvalue) {
|
|
$data[$i]['freifelder'][$ffuvalue['sprache']][] = array('mapping' => $ffuvalue['freifeld_shop'], 'freifeldnummer' => $ffuvalue['nummer'], 'wert' => $ffuvalue['wert']);
|
|
}
|
|
}
|
|
}
|
|
|
|
$data[$i]['typ'] = $tmp->GetTyp();
|
|
$data[$i]['kategoriename'] = $tmp->GetTyp();
|
|
if (strpos($data[$i]['typ'], '_kat')) {
|
|
$data[$i]['kategoriename'] = $this->app->DB->Select("SELECT bezeichnung FROM artikelkategorien WHERE id = '" . (int) str_replace('_kat', '', $data[$i]['typ']) . "' LIMIT 1");
|
|
}
|
|
|
|
$kategorienuebertragen = $shopexportarr['kategorienuebertragen']; //$this->app->DB->Select("SELECT kategorienuebertragen FROM shopexport WHERE id = '$id' LIMIT 1");
|
|
if (!empty($kategorienuebertragen) && !empty($loadElements['categories'])) {
|
|
$kategorienbaum = null;
|
|
/** @var Onlineshops $onlineShopObj */
|
|
$onlineShopObj = $this->app->loadModule('onlineshops');
|
|
$categoryRootId = 0;
|
|
if (!empty($onlineShopObj) && method_exists($onlineShopObj, 'getJsonSettings')) {
|
|
$categoryRootId = (int) $onlineShopObj->getJsonSettings($id, 'category_root_id');
|
|
}
|
|
$this->app->erp->GetKategorienbaum($kategorienbaum, $categoryRootId, 0, $id);
|
|
if (!empty($kategorienbaum)) {
|
|
$kategorien = $this->app->DB->SelectArr("SELECT ak.id, ak.bezeichnung FROM `artikelbaum_artikel` aa INNER JOIN `artikelkategorien` ak ON aa.kategorie = ak.id AND ak.geloescht <> 1 AND aa.artikel = '$artikel' ORDER by ak.bezeichnung");
|
|
if ($kategorien) {
|
|
foreach ($kategorien as $v) {
|
|
$katid[$v['id']] = true;
|
|
}
|
|
}
|
|
if (!empty($katid)) {
|
|
foreach ($kategorienbaum as $v) {
|
|
$data[$i]['kompletter_kategorienbaum'][] = array('name' => $v['bezeichnung'], 'parent' => $v['parent'], 'id' => $v['id'], 'lvl' => $v['lvl'], 'extid' => $v['extid']);
|
|
if (isset($katid[$v['id']])) {
|
|
$data[$i]['kategorien'][] = array('name' => $v['bezeichnung'], 'parent' => $v['parent'], 'id' => $v['id'], 'lvl' => $v['lvl'], 'extid' => $v['extid']);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
$eigenschaftenuebertragen = $shopexportarr['eigenschaftenuebertragen']; //$this->app->DB->Select("SELECT eigenschaftenuebertragen FROM shopexport WHERE id = '$id' LIMIT 1");
|
|
if (!empty($eigenschaftenuebertragen) && !empty($loadElements['properties'])) {
|
|
$eigenschaften = $this->app->DB->SelectArr("SELECT e.name, ew.wert FROM artikeleigenschaften e INNER JOIN artikeleigenschaftenwerte ew ON e.id = ew.artikeleigenschaften
|
|
WHERE ew.artikel = '$artikel' AND e.name <> '' AND ew.wert <> '' AND e.geloescht <> 1");
|
|
if (!empty($eigenschaften)) {
|
|
$eigenschaftind = 0;
|
|
foreach ($eigenschaften as $eigenschaft) {
|
|
$eigenschaftind++;
|
|
$data[$i]['eigenschaften'][] = array('name' => $eigenschaft['name'], 'values' => $eigenschaft['wert']);
|
|
}
|
|
}
|
|
|
|
$eigenschaftenuebersetzungen = $this->app->DB->SelectArr("SELECT language_from, language_to, property_from, property_to,property_value_from,property_value_to FROM article_property_translation WHERE article_id = '$artikel'");
|
|
$data[$i]['eigenschaftenuebersetzungen'] = $eigenschaftenuebersetzungen;
|
|
}
|
|
|
|
//Bilder
|
|
$dateien = null;
|
|
if ($shopbilderuebertragen && !empty($loadElements['pictures'])) {
|
|
$dateien = $this->getImagesForArticle($artikel);
|
|
if (!empty($dateien)) {
|
|
$data[$i]['Dateien'] = [];
|
|
foreach ($dateien as $datei) {
|
|
$filename = $this->app->erp->GetDateiName($datei['id']);
|
|
$path_info = pathinfo($filename);
|
|
$data[$i]['Dateien'][] = array(
|
|
'datei' => base64_encode($this->app->erp->GetDatei($datei['id'])),
|
|
'filename' => $filename,
|
|
'extension' => $path_info['extension'],
|
|
'titel' => $datei['titel'],
|
|
'beschreibung' => $datei['beschreibung'],
|
|
'id' => $datei['id'],
|
|
'version' => $datei['version'],
|
|
'stichwort' => $datei['subjekt'],
|
|
'extid' => $this->GetShopexportMappingExt($id, 'datei', $datei['id']));
|
|
}
|
|
}
|
|
$dateiengeloescht = $this->app->DB->SelectArr("SELECT s.extid FROM shopexport_mapping s LEFT JOIN datei d ON s.intid = d.id AND d.geloescht = 0 WHERE s.shop = '$id' AND s.tabelle = 'datei' AND s.intid2 = '$artikel' AND isnull(d.id)");
|
|
if (!empty($dateiengeloescht)) {
|
|
if (empty($dateien)) {
|
|
$data[$i]['Dateien'] = [];
|
|
}
|
|
foreach ($dateiengeloescht as $datei) {
|
|
$data[$i]['Dateien'][] = array('loeschen' => 1, 'extid' => $datei['extid']);
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
if (method_exists($tmp, 'GetSteuer_Art_Produkt')) {
|
|
$data[$i]['steuer_art_produkt'] = $tmp->GetSteuer_Art_Produkt();
|
|
}
|
|
if (method_exists($tmp, 'GetSteuer_Art_Produkt_Download')) {
|
|
$data[$i]['steuer_art_produkt_download'] = $tmp->GetSteuer_Art_Produkt_Download();
|
|
}
|
|
|
|
$projekt = $tmp->GetProjekt();
|
|
$projektlager = $this->app->DB->Select("SELECT id FROM projekt WHERE id = '$projekt' AND projektlager = 1 LIMIT 1");
|
|
$data[$i]['anzahl_bilder'] = $this->app->DB->Select("SELECT COUNT(datei) FROM datei_stichwoerter WHERE subjekt='Shopbild' AND objekt='Artikel' AND parameter='$artikel'");
|
|
|
|
$bestandalternativartikel = method_exists($tmp, 'GetBestandalternativartikel') ? $tmp->GetBestandalternativartikel() : 0;
|
|
|
|
if ($bestandalternativartikel) {
|
|
$data[$i]['anzahl_lager'] = floor($this->app->erp->ArtikelAnzahlVerkaufbar($bestandalternativartikel, 0, $projektlager, $id, $lagergrundlage));
|
|
$data[$i]['lagerkorrekturwert'] = floor(-($this->app->erp->ArtikelAnzahlVerkaufbar($bestandalternativartikel, 0, $projektlager, 0, $lagergrundlage) - $data[$i]['anzahl_lager']));
|
|
} else {
|
|
$data[$i]['anzahl_lager'] = floor($this->app->erp->ArtikelAnzahlVerkaufbar($artikel, 0, $projektlager, $id, $lagergrundlage));
|
|
$data[$i]['lagerkorrekturwert'] = floor(-($this->app->erp->ArtikelAnzahlVerkaufbar($artikel, 0, $projektlager, 0, $lagergrundlage) - $data[$i]['anzahl_lager']));
|
|
}
|
|
|
|
$data[$i]['pseudolager'] = $this->app->erp->GetArtikelShopEinstellung('pseudolager', $artikel, $shopexportarr);
|
|
$this->app->erp->RunHook('remote_send_article_list_pseudostorage', 3, $id, $artikel, $data[$i]['pseudolager']);
|
|
if (is_numeric($data[$i]['pseudolager']) && $data[$i]['pseudolager'] < 0) {
|
|
$data[$i]['pseudolager'] = 0;
|
|
$data[$i]['anzahl_lager'] = 0;
|
|
} elseif ($data[$i]['pseudolager'] > 0) {
|
|
$data[$i]['anzahl_lager'] = $data[$i]['pseudolager'];
|
|
}
|
|
if ($data[$i]['anzahl_lager'] < 0) {
|
|
$data[$i]['anzahl_lager'] = 0;
|
|
}
|
|
$data[$i]['autolagerlampe'] = $tmp->GetAutolagerlampe();
|
|
if (method_exists($this->app->erp, 'GetArtikelShopEinstellung')) {
|
|
$data[$i]['autolagerlampe'] = $this->app->erp->GetArtikelShopEinstellung('autolagerlampe', $artikel, $shopexportarr);
|
|
}
|
|
if ($data[$i]['autolagerlampe'] != '1') {
|
|
$data[$i]['anzahl_lager'] = '';
|
|
$data[$i]['pseudolager'] = '';
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE `artikel_onlineshops`
|
|
SET `storage_cache` = NULL, `pseudostorage_cache` = NULL
|
|
WHERE `artikel` = %d AND `shop` = %d',
|
|
$artikel, $id
|
|
)
|
|
);
|
|
} else {
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
'UPDATE `artikel_onlineshops`
|
|
SET `storage_cache` = %d, `pseudostorage_cache` = %s
|
|
WHERE `artikel` = %d AND `shop` = %d',
|
|
$data[$i]['anzahl_lager'],
|
|
!isset($data[$i]['pseudolager']) || !is_numeric($data[$i]['pseudolager']) ? 'NULL' : $data[$i]['pseudolager'],
|
|
$artikel,
|
|
$id
|
|
)
|
|
);
|
|
}
|
|
|
|
$projekt = $shopexportarr['projekt']; // $this->app->DB->Select("SELECT projekt FROM shopexport WHERE id='$id' LIMIT 1");
|
|
if (!empty($shopexportarr['crosssellingartikeluebertragen']) && !empty($loadElements['cross_selling'])) {
|
|
//if($this->app->DB->Select("SELECT crosssellingartikeluebertragen FROM shopexport WHERE id = '$id' LIMIT 1")){
|
|
$data[$i]['crosssellingartikel'] = $this->app->DB->SelectArr("SELECT a.id, a.nummer, ak.bezeichnung as kategorie, a.name_de, a.name_en, ca.art, ca.gegenseitigzuweisen, af.nummer AS fremdnummer
|
|
FROM crossselling_artikel ca
|
|
JOIN artikel a ON ca.crosssellingartikel = a.id
|
|
LEFT JOIN artikelkategorien ak ON CONCAT(ak.id,'_kat') = a.typ
|
|
LEFT JOIN (SELECT af.id,af.nummer,af.artikel,af.shopid FROM artikelnummer_fremdnummern af JOIN (SELECT artikel, MAX(shopid) AS maxid FROM artikelnummer_fremdnummern WHERE aktiv=1 AND (shopid=0 OR shopid=2) GROUP BY artikel) x ON x.artikel = af.artikel AND af.shopid=x.maxid WHERE af.aktiv = 1) af ON af.artikel = a.id
|
|
WHERE ca.artikel='" . $tmp->GetId() . "' AND (ca.shop='$id' OR ca.shop='0')
|
|
GROUP BY ca.crosssellingartikel, ca.art");
|
|
|
|
if (empty($data[$i]['crosssellingartikel'])) {
|
|
$data[$i]['crosssellingartikel'] = [];
|
|
}
|
|
|
|
|
|
$sql = "SELECT a.id, a.nummer, ak.bezeichnung as kategorie, a.name_de, a.name_en, ca.art, ca.gegenseitigzuweisen, af.nummer AS fremdnummer
|
|
FROM crossselling_artikel ca
|
|
JOIN artikel a ON ca.artikel = a.id
|
|
LEFT JOIN artikelkategorien ak ON CONCAT(ak.id,'_kat') = a.typ
|
|
LEFT JOIN (SELECT af.id,af.nummer,af.artikel,af.shopid FROM artikelnummer_fremdnummern af JOIN (SELECT artikel, MAX(shopid) AS maxid FROM artikelnummer_fremdnummern WHERE aktiv=1 AND (shopid=0 OR shopid=2) GROUP BY artikel) x ON x.artikel = af.artikel AND af.shopid=x.maxid WHERE af.aktiv = 1) af ON af.artikel = a.id
|
|
LEFT JOIN (SELECT nummer,artikel FROM artikelnummer_fremdnummern WHERE shopid=0 OR shopid='$id' ORDER BY shopid DESC LIMIT 1 ) af2 ON af2.artikel = a.id
|
|
WHERE ca.crosssellingartikel='" . $tmp->GetId() . "' AND ca.gegenseitigzuweisen=1 AND (ca.shop='$id' OR ca.shop='0')
|
|
GROUP BY ca.artikel, ca.art";
|
|
|
|
$gegenseitigzugewiesen = $this->app->DB->SelectArr($sql);
|
|
|
|
if (!empty($gegenseitigzugewiesen)) {
|
|
foreach ($gegenseitigzugewiesen as $gegenseitigzugewiesenercrosssellingartikel) {
|
|
$data[$i]['crosssellingartikel'][] = $gegenseitigzugewiesenercrosssellingartikel;
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($loadElements['article_descriptions']) && $this->app->erp->ModulVorhanden('artikel_texte')) {
|
|
$sprachen = ['de', 'en'];
|
|
foreach ($sprachen as $sprache) {
|
|
$query = sprintf("SELECT * FROM artikel_texte WHERE shop=%d AND sprache='%s' AND artikel=%d AND aktiv=1 LIMIT 1",
|
|
$id, strtoupper($sprache), $artikel);
|
|
$ersetzeStandardbeschreibung = $this->app->DB->SelectRow($query);
|
|
if (!empty($ersetzeStandardbeschreibung)) {
|
|
$data[$i]['name_' . $sprache] = $ersetzeStandardbeschreibung['name'];
|
|
$data[$i]['beschreibung_' . $sprache] = $ersetzeStandardbeschreibung['beschreibung_online'];
|
|
$data[$i]['kurztext_' . $sprache] = $ersetzeStandardbeschreibung['kurztext'];
|
|
$data[$i]['metadescription_' . $sprache] = $ersetzeStandardbeschreibung['meta_description'];
|
|
$data[$i]['metakeywords_' . $sprache] = $ersetzeStandardbeschreibung['meta_keywords'];
|
|
$data[$i]['metatitle_' . $sprache] = $ersetzeStandardbeschreibung['meta_title'];
|
|
if ($sprache === 'de') {
|
|
$data[$i]['anabregs_text'] = $ersetzeStandardbeschreibung['beschreibung'];
|
|
} else {
|
|
$data[$i]['anabregs_text_en'] = $ersetzeStandardbeschreibung['beschreibung'];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!empty($loadElements['standard_price'])) {
|
|
|
|
$priceInformation = $this->app->DB->SelectArr("SELECT v.preis AS preis, v.waehrung
|
|
FROM `verkaufspreise` AS `v`
|
|
WHERE v.artikel = '{$artikel}' AND v.ab_menge = 1 AND v.geloescht = 0 AND v.art != 'Gruppe'
|
|
AND (v.objekt = 'Standard' OR v.objekt = '') AND (v.adresse = '0' OR v.adresse = '')
|
|
AND (v.gueltig_bis >= NOW() OR v.gueltig_bis = '0000-00-00')
|
|
ORDER BY v.preis DESC LIMIT 1");
|
|
|
|
if (!empty($priceInformation)) {
|
|
$priceInformation = reset($priceInformation);
|
|
$defaultPrice = $priceInformation['preis'];
|
|
$defaultCurrency = $priceInformation['waehrung'] ?: 'EUR';
|
|
if ($preisgruppe && method_exists($this->app->erp, 'GetVerkaufspreisGruppe')) {
|
|
$defaultCurrency = 'EUR'; //the follow up function imply EUR as the default currency
|
|
$defaultPrice = $this->app->erp->GetVerkaufspreisGruppe($artikel, 1, $preisgruppe);
|
|
}
|
|
$data[$i]['waehrung'] = $defaultCurrency;
|
|
$data[$i]['preis'] = $defaultPrice;
|
|
}
|
|
|
|
if (!empty($tmp->GetSteuersatz()) && $tmp->GetSteuersatz() != -1) {
|
|
$data[$i]['steuersatz'] = (float) $tmp->GetSteuersatz();
|
|
} elseif ($data[$i]['umsatzsteuer'] === 'ermaessigt') {
|
|
$data[$i]['steuersatz'] = (float) $this->app->erp->GetStandardSteuersatzErmaessigt($projekt);
|
|
} elseif ($data[$i]['umsatzsteuer'] === 'befreit') {
|
|
$data[$i]['steuersatz'] = 0;
|
|
} else {
|
|
$data[$i]['steuersatz'] = (float) $this->app->erp->GetStandardSteuersatzNormal($projekt);
|
|
}
|
|
|
|
$steuer = ($data[$i]['steuersatz'] + 100) / 100.0;
|
|
|
|
if (!empty($shopexportarr['staffelpreiseuebertragen']) && !empty($loadElements['bulk_prices'])) {
|
|
$preisgruppenzusatz = " AND v.art = 'Kunde' AND v.adresse = 0";
|
|
if (!empty($preisgruppe)) {
|
|
$preisgruppenzusatz = " AND v.gruppe = '$preisgruppe'";
|
|
}
|
|
$query = sprintf("SELECT v.adresse, g.name, g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung
|
|
FROM `verkaufspreise` AS `v`
|
|
LEFT JOIN `gruppen` AS `g` on v.gruppe = g.id
|
|
WHERE v.artikel = %d AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND v.adresse = 0 AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab)) %s
|
|
ORDER by g.id, v.ab_menge", $artikel, $preisgruppenzusatz);
|
|
$standardstaffelpreise = $this->app->DB->SelectArr($query);
|
|
$data[$i]['staffelpreise_standard'] = [];
|
|
if (!empty($standardstaffelpreise)) {
|
|
foreach ($standardstaffelpreise as $staffelpreis) {
|
|
$data[$i]['staffelpreise_standard'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR'
|
|
];
|
|
}
|
|
}
|
|
|
|
$query = sprintf("SELECT a.name AS `kundenname`, a.email, v.adresse, v.ab_menge, v.preis, v.waehrung
|
|
FROM `verkaufspreise` AS `v`
|
|
JOIN `adresse` AS `a` ON v.adresse = a.id AND v.art LIKE 'Kunde'
|
|
WHERE v.`artikel` = %d AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab))
|
|
ORDER by v.adresse, v.ab_menge", $artikel);
|
|
$staffelpreisekunden = $this->app->DB->SelectArr($query);
|
|
if (!empty($staffelpreisekunden)) {
|
|
foreach ($staffelpreisekunden as $staffelpreis) {
|
|
$data[$i]['staffelpreise_kunden'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR',
|
|
'email' => $staffelpreis['email'],
|
|
'kundenname' => $staffelpreis['kundenname']
|
|
];
|
|
}
|
|
}
|
|
|
|
$query = sprintf("SELECT g.name, g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung, sk.extgruppename
|
|
FROM `verkaufspreise` AS `v`
|
|
JOIN `gruppen` AS `g` on v.gruppe = g.id
|
|
JOIN `shopexport_kundengruppen` AS `sk` ON sk.gruppeid = v.gruppe
|
|
WHERE v.`artikel` = %d AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND v.art like 'Gruppe' AND v.gruppe <> '%s' AND sk.shopid = %d AND sk.aktiv = 1 AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab))
|
|
ORDER by g.id, v.ab_menge", $artikel, $preisgruppe, $id);
|
|
$staffelpreisegruppen = $this->app->DB->SelectArr($query);
|
|
if (!empty($staffelpreisegruppen)) {
|
|
foreach ($staffelpreisegruppen as $staffelpreis) {
|
|
$data[$i]['staffelpreise_gruppen'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR',
|
|
'kennziffer' => $staffelpreis['kennziffer'],
|
|
'gruppenname' => $staffelpreis['name'],
|
|
'gruppeextern' => $staffelpreis['extgruppename']
|
|
];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @deprecated 20.3
|
|
* Staffelpreise werden gesondert uebergeben statt in einem sammelarray
|
|
*/
|
|
$staffelpreise = $this->app->DB->SelectArr("
|
|
SELECT a.name AS kundenname, a.email, v.adresse, g.name,g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung, art.umsatzsteuer
|
|
FROM `verkaufspreise` AS v
|
|
INNER JOIN artikel art ON v.artikel = art.id
|
|
LEFT JOIN gruppen g on v.gruppe = g.id AND v.art like 'Gruppe'
|
|
LEFT JOIN adresse a ON v.adresse = a.id AND v.art LIKE 'Kunde'
|
|
WHERE v.`artikel` = '$artikel' AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab)) ORDER by g.id, ab_menge");
|
|
|
|
if (!empty($staffelpreise)) {
|
|
foreach ($staffelpreise as $k => $v) {
|
|
if (empty($v['adresse'])) {
|
|
$data[$i]['staffelpreise'][] = array('ab_menge' => $v['ab_menge'], 'preis' => $v['preis'], 'bruttopreis' => $v['preis'] * $steuer, 'waehrung' => ($v['waehrung'] ? $v['waehrung'] : 'EUR'));
|
|
if ($v['id']) {
|
|
$data[$i]['staffelpreise'][count($data[$i]['staffelpreise']) - 1]['gruppenkennziffer'] = $v['kennziffer'];
|
|
$data[$i]['staffelpreise'][count($data[$i]['staffelpreise']) - 1]['gruppenname'] = $v['name'];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/**
|
|
* @deprecated Ende
|
|
*/
|
|
}
|
|
$data[$i]['bruttopreis'] = $data[$i]['preis'] * $steuer;
|
|
}
|
|
$data[$i]['checksum'] = $tmp->GetChecksum();
|
|
if ($data[$i]['preis'] == '' && !empty($artikelexport) && !$nurlager) {
|
|
if ($lagerexport) {
|
|
$nurlager = true;
|
|
} else {
|
|
$this->app->erp->Systemlog(
|
|
'Shopexport bei Artikel ' . $data[$i]['nummer'] . ' ' . $data[$i]['name_de'] . ' fehlgeschlagen, da Verkaufspreis fehlt.'
|
|
);
|
|
$data[$i]['artikel'] = 'ignore';
|
|
}
|
|
}
|
|
|
|
$steuerermaessigt = ($this->app->erp->GetStandardSteuersatzErmaessigt($projekt) + 100) / 100.0;
|
|
$steuernormal = ($this->app->erp->GetStandardSteuersatzNormal($projekt) + 100) / 100.0;
|
|
$steuermapping = [
|
|
'befreit' => 1,
|
|
'ermaessigt' => $steuerermaessigt,
|
|
'normal' => $steuernormal
|
|
];
|
|
|
|
if (!empty($loadElements['variants']) && !empty($shopexportarr['variantenuebertragen']) && $this->app->erp->ModulVorhanden('matrixprodukt') && $tmp->GetMatrixprodukt()) {
|
|
$artfreifeld = '';
|
|
for ($_i = 1; $_i <= 40; $_i++) {
|
|
$artfreifeld .= sprintf(' art.freifeld%d AS `freifeld%d`, ', $_i, $_i);
|
|
}
|
|
$varianten = null;
|
|
|
|
$data[$i]['artikel_varianten'] = [];
|
|
$db = $this->app->Container->get('Database');
|
|
|
|
$offset = 0;
|
|
$eigenschaftind = 0;
|
|
|
|
$gruppenuebersetzung = [];
|
|
$gruppenwertuebersetzung = [];
|
|
|
|
$query = sprintf('SELECT meoa.name AS wert,meoa.name_ext AS wert_ext, mega.name AS gruppe, mega.name_ext AS gruppe_ext
|
|
FROM matrixprodukt_optionen_zu_artikel AS moza
|
|
JOIN matrixprodukt_eigenschaftenoptionen_artikel AS meoa ON moza.option_id = meoa.id
|
|
JOIN matrixprodukt_eigenschaftengruppen_artikel AS mega ON mega.id = meoa.gruppe
|
|
JOIN artikel art ON art.id = moza.artikel
|
|
WHERE art.variante_von=%d ANd art.geloescht=0 AND art.nummer <> "DEL" AND art.intern_gesperrt=0
|
|
GROUP BY mega.id, meoa.id
|
|
ORDER BY SUM(POW(10,1-mega.sort) * meoa.sort) ASC', $artikel);
|
|
foreach ($db->yieldAll($query) as $matrixdaten) {
|
|
$data[$i]['matrix_varianten']['gruppen'][$matrixdaten['gruppe']][$matrixdaten['wert']] = true;
|
|
|
|
if ($translationpossible && !empty($loadElements['translations'])) {
|
|
if (empty($gruppenuebersetzung[$matrixdaten['gruppe']])) {
|
|
$gruppennamen = $this->app->DB->SelectArr("SELECT
|
|
IF(name_external_from<>'',name_external_from,name_from) AS name_from,
|
|
IF(name_external_to<>'',name_external_to,name_to) AS name_to, language_to
|
|
FROM `matrix_article_translation`
|
|
WHERE name_from='" . $matrixdaten['gruppe'] . "' AND (project=0 OR project='$projekt')");
|
|
$gruppenuebersetzung[$matrixdaten['gruppe']] = true;
|
|
if (!empty($gruppennamen)) {
|
|
foreach ($gruppennamen as $gruppenname) {
|
|
$data[$i]['matrix_varianten']['texte']['gruppen'][$gruppenname['language_to']][$gruppenname['name_from']] = $gruppenname['name_to'];
|
|
}
|
|
}
|
|
}
|
|
if (empty($gruppenwertuebersetzung[$matrixdaten['wert']])) {
|
|
$gruppenwerte = $this->app->DB->SelectArr("SELECT
|
|
IF(maot.name_external_from<>'',maot.name_external_from,maot.name_from) AS `name_from`,
|
|
IF(maot.name_external_to<>'',maot.name_external_to,maot.name_to) AS `name_to`, maot.language_to
|
|
FROM `matrix_article_options_translation` AS `maot`
|
|
WHERE maot.name_from='" . $this->app->DB->real_escape_string($matrixdaten['wert']) . "'");
|
|
$gruppenwertuebersetzung[$matrixdaten['wert']] = true;
|
|
foreach ($gruppenwerte as $gruppenwert) {
|
|
$data[$i]['matrix_varianten']['texte']['werte'][$gruppenwert['language_to']][$gruppenwert['name_from']] = $gruppenwert['name_to'];
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
do {
|
|
unset($data[$i]['matrix_varianten']['artikel']);
|
|
unset($data[$i]['artikel_varianten']);
|
|
//if($this->app->DB->Select("SELECT variantenuebertragen FROM shopexport WHERE id = '$id' LIMIT 1")){
|
|
$varianten = "SELECT art.pseudolager AS `pseudolager`, art.nummer AS `nummer`, art.inaktiv AS `inaktiv`,
|
|
art.id AS `artikel`, art.gewicht AS `gewicht`, art.zolltarifnummer AS `zolltarifnummer`, art.name_en AS `name_en`,
|
|
$artfreifeld
|
|
art.pseudopreis AS `pseudopreis`, art.lieferzeitmanuell AS `lieferzeitmanuell`, art.altersfreigabe AS `altersfreigabe`,
|
|
IF(art.intern_gesperrt = 1,1,0) AS `gesperrt`, art.uebersicht_de AS `uebersicht_de`, art.uebersicht_en AS `uebersicht_en`,
|
|
IF(IFNULL(vp2.preis,0) > 0, vp2.preis, vp.preis) as `preis`, art.umsatzsteuer AS `umsatzsteuer`, art.ean AS `ean`,
|
|
art.name_de AS `name_de`, art.restmenge AS `restmenge`, art.steuersatz AS `steuersatz`
|
|
FROM artikel AS `art`
|
|
LEFT JOIN
|
|
( SELECT v.artikel,min(v.preis) as `preis`
|
|
FROM verkaufspreise AS `v`
|
|
WHERE (ifnull(v.gueltig_bis,'0000-00-00')='0000-00-00' OR v.gueltig_bis >= curdate() ) AND v.ab_menge <= 1
|
|
AND v.art = 'Kunde' AND v.adresse = 0
|
|
GROUP BY v.artikel ) AS `vp` ON vp.artikel = art.id
|
|
LEFT JOIN (SELECT v2.artikel,min(v2.preis) as `preis`
|
|
FROM verkaufspreise AS `v2`
|
|
WHERE (ifnull(v2.gueltig_bis,'0000-00-00')='0000-00-00' OR v2.gueltig_bis >= curdate() ) AND v2.ab_menge <= 1
|
|
AND v2.art = 'Gruppe' AND v2.gruppe = '$preisgruppe'
|
|
GROUP BY v2.artikel
|
|
) AS `vp2` ON vp2.artikel = art.id
|
|
JOIN `matrixprodukt_optionen_zu_artikel` AS `moza` ON moza.artikel = art.id
|
|
JOIN `matrixprodukt_eigenschaftenoptionen_artikel` AS `meoa` ON moza.option_id = meoa.id
|
|
JOIN `matrixprodukt_eigenschaftengruppen_artikel` AS `mega` ON meoa.gruppe = mega.id
|
|
WHERE art.variante_von = '$artikel' AND art.geloescht <> 1 AND art.nummer <> 'DEL'
|
|
GROUP BY art.id
|
|
ORDER BY SUM(POW(10,1-mega.sort) * meoa.sort) ASC
|
|
LIMIT 5000 OFFSET $offset";
|
|
$offset += 5000;
|
|
|
|
foreach ($db->yieldAll($varianten) as $eigenschaft) {
|
|
$eigenschaftind++;
|
|
$steuer = $steuermapping[$eigenschaft['umsatzsteuer']];
|
|
if (!empty($eigenschaft['steuersatz']) && $eigenschaft['steuersatz'] != -1) {
|
|
$steuer = ($eigenschaft['steuersatz'] + 100) / 100;
|
|
}
|
|
if (empty($steuer)) {
|
|
$steuer = $steuernormal;
|
|
}
|
|
$matrixPseudoStorage = $eigenschaft['pseudolager'];
|
|
$this->app->erp->RunHook('remote_send_article_list_pseudostorage', 3, $id, $eigenschaft['artikel'], $matrixPseudoStorage);
|
|
if (is_numeric($matrixPseudoStorage) && $matrixPseudoStorage < 0) {
|
|
$matrixPseudoStorage = 0;
|
|
}
|
|
$matrixStock = (float) $this->app->erp->ArtikelAnzahlVerkaufbar($eigenschaft['artikel'], 0, $projektlager, $id, $lagergrundlage);
|
|
if ($matrixStock < 0) {
|
|
$matrixStock = 0;
|
|
}
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][] = array('zolltarifnummer' => $eigenschaft['zolltarifnummer'], 'gewicht' => $eigenschaft['gewicht'],
|
|
'artikel' => $eigenschaft['artikel'], 'preis' => $eigenschaft['preis'], 'gesperrt' => $eigenschaft['gesperrt'],
|
|
'nummer' => $eigenschaft['nummer'], 'lieferzeitmanuell' => $eigenschaft['lieferzeitmanuell'],
|
|
'altersfreigabe' => $eigenschaft['altersfreigabe'], 'ean' => $eigenschaft['ean'],
|
|
'lag' => $matrixStock,
|
|
'pseudolager' => $matrixPseudoStorage, 'pseudopreis' => $eigenschaft['pseudopreis'],
|
|
'restmenge' => $eigenschaft['restmenge'], 'steuersatz' => ($steuer - 1) * 100, 'umsatzsteuer' => $eigenschaft['umsatzsteuer'],
|
|
'bruttopreis' => $eigenschaft['preis'] * $steuer, 'inaktiv' => $eigenschaft['inaktiv'],
|
|
'name_de' => $eigenschaft['name_de'], 'name_en' => $eigenschaft['name_en'],
|
|
'uebersicht_de' => $eigenschaft['uebersicht_de'], 'uebersicht_en' => $eigenschaft['uebersicht_en']);
|
|
if ($freifelder) {
|
|
foreach ($freifelder as $freifeld) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']]) - 1]['freifelder']['DE'][$freifeld['freifeld_shop']] = $this->app->DB->Select('SELECT ' . $freifeld['freifeld_wawi'] . ' FROM artikel WHERE id=' . $eigenschaft['artikel']);
|
|
}
|
|
|
|
//Freifeldübersetzungen
|
|
$freifelduebersetzungen = $this->app->DB->SelectArr("SELECT sf.freifeld_shop, af.sprache, af.nummer, af.wert FROM shopexport_freifelder sf JOIN artikel_freifelder af ON sf.freifeld_wawi = CONCAT('freifeld',af.nummer) WHERE sf.shop = '$id' AND af.artikel = '" . $eigenschaft['artikel'] . "' AND sf.aktiv = 1 AND sf.freifeld_wawi <> '' AND sf.freifeld_shop <> '' AND af.wert <> ''");
|
|
if (!empty($freifelduebersetzungen)) {
|
|
foreach ($freifelduebersetzungen as $ffukey => $ffuvalue) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']]) - 1]['freifelder'][$ffuvalue['sprache']][] = array('mapping' => $ffuvalue['freifeld_shop'], 'freifeldnummer' => $ffuvalue['nummer'], 'wert' => $ffuvalue['wert']);
|
|
}
|
|
}
|
|
}
|
|
|
|
if ($shopbilderuebertragen && !empty($loadElements['pictures'])) {
|
|
$dateien = $this->getImagesForArticle($eigenschaft['artikel']);
|
|
if (!empty($dateien)) {
|
|
foreach ($dateien as $datei) {
|
|
$filename = $this->app->erp->GetDateiName($datei['id']);
|
|
$path_info = pathinfo($filename);
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['datei'][] = base64_encode($this->app->erp->GetDatei($datei['id']));
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['filename'][] = $filename;
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['extension'][] = $path_info['extension'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['titel'][] = $datei['titel'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['beschreibung'][] = $datei['beschreibung'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['stichwort'][] = $datei['subjekt'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['id'][] = $datei['id'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['version'][] = $datei['version'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']['extid'][] = $this->GetShopexportMappingExt($id, 'datei', $datei['id']);
|
|
}
|
|
}
|
|
}
|
|
|
|
$standardstaffelpreise = null;
|
|
if (!empty($loadElements['standard_price'])) {
|
|
$preisgruppenzusatz = " AND v.art = 'Kunde' AND v.adresse = 0";
|
|
if (!empty($preisgruppe)) {
|
|
$preisgruppenzusatz = " AND v.gruppe = '$preisgruppe'";
|
|
}
|
|
$standardstaffelpreise = $this->app->DB->SelectArr("
|
|
SELECT v.adresse, g.name,g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung, art.umsatzsteuer
|
|
FROM `verkaufspreise` AS v
|
|
INNER JOIN artikel art ON v.artikel = art.id
|
|
LEFT JOIN gruppen g on v.gruppe = g.id
|
|
WHERE v.`artikel` = '" . $eigenschaft['artikel'] . "' AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND v.adresse=0 AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab)) $preisgruppenzusatz
|
|
ORDER by g.id, ab_menge");
|
|
}
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise_standard'] = [];
|
|
if (!empty($standardstaffelpreise)) {
|
|
foreach ($standardstaffelpreise as $staffelpreis) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise_standard'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR'
|
|
];
|
|
}
|
|
}
|
|
if (!empty($loadElements['bulk_prices'])) {
|
|
$staffelpreisekunden = $this->app->DB->SelectArr("
|
|
SELECT a.name AS kundenname, a.email, v.adresse, v.ab_menge, v.preis, v.waehrung, art.umsatzsteuer
|
|
FROM `verkaufspreise` AS v
|
|
INNER JOIN artikel art ON v.artikel = art.id
|
|
JOIN adresse a ON v.adresse = a.id AND v.art LIKE 'Kunde'
|
|
WHERE v.`artikel` = '" . $eigenschaft['artikel'] . "' AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab))
|
|
ORDER by v.adresse, ab_menge");
|
|
if (!empty($staffelpreisekunden)) {
|
|
foreach ($staffelpreisekunden as $staffelpreis) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise_kunden'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR',
|
|
'email' => $staffelpreis['email'],
|
|
'kundenname' => $staffelpreis['kundenname']
|
|
];
|
|
}
|
|
}
|
|
|
|
$staffelpreisegruppen = $this->app->DB->SelectArr("
|
|
SELECT g.name,g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung, art.umsatzsteuer,sk.extgruppename
|
|
FROM `verkaufspreise` AS v
|
|
INNER JOIN artikel art ON v.artikel = art.id
|
|
JOIN gruppen g on v.gruppe = g.id
|
|
JOIN shopexport_kundengruppen sk ON sk.gruppeid=v.gruppe
|
|
WHERE v.`artikel` = '" . $eigenschaft['artikel'] . "' AND v.geloescht = 0 AND (v.gueltig_bis = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND v.art like 'Gruppe' AND v.gruppe<>'$preisgruppe' AND sk.shopid='$id' AND sk.aktiv=1 AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab))
|
|
ORDER by g.id, ab_menge");
|
|
if (!empty($staffelpreisegruppen)) {
|
|
foreach ($staffelpreisegruppen as $staffelpreis) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise_gruppen'][] = [
|
|
'ab_menge' => $staffelpreis['ab_menge'],
|
|
'preis' => $staffelpreis['preis'],
|
|
'bruttopreis' => $staffelpreis['preis'] * $steuer,
|
|
'waehrung' => $staffelpreis['waehrung'] ?: 'EUR',
|
|
'kennziffer' => $staffelpreis['kennziffer'],
|
|
'gruppenname' => $staffelpreis['name'],
|
|
'gruppeextern' => $staffelpreis['extgruppename']
|
|
];
|
|
}
|
|
}
|
|
}
|
|
$staffelpreisema = null;
|
|
if (!empty($shopexportarr['crosssellingartikeluebertragen']) && !empty($loadElements['cross_selling'])) {
|
|
//if($this->app->DB->Select("SELECT crosssellingartikeluebertragen FROM shopexport WHERE id = '$id' LIMIT 1")){
|
|
$preisgruppenzusatz = '';
|
|
if (!empty($preisgruppe)) {
|
|
$preisgruppenzusatz = " AND v.gruppe = '$preisgruppe'";
|
|
}
|
|
$staffelpreisema = $this->app->DB->SelectArr("
|
|
SELECT g.name, g.kennziffer, v.ab_menge, v.preis, g.id, v.waehrung, v.id, v.adresse, v.art, sk.extgruppename
|
|
FROM `verkaufspreise` AS v
|
|
LEFT JOIN gruppen g on v.gruppe = g.id AND v.art like 'Gruppe'
|
|
LEFT JOIN shopexport_kundengruppen sk ON sk.gruppeid=v.gruppe
|
|
WHERE v.`artikel` = '" . $eigenschaft['artikel'] . "' AND v.geloescht = 0 AND (ifnull(v.gueltig_bis,'0000-00-00') = '0000-00-00' OR curdate() <= v.gueltig_bis OR isnull(v.gueltig_bis))
|
|
AND (v.gueltig_ab = '0000-00-00' OR curdate() >= v.gueltig_ab OR isnull(v.gueltig_ab)) $preisgruppenzusatz ORDER by g.id, ab_menge");
|
|
}
|
|
if (!empty($staffelpreisema)) {
|
|
foreach ($staffelpreisema as $k => $v) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][] = array('ab_menge' => $v['ab_menge'], 'preis' => $v['preis'], 'bruttopreis' => $v['preis'] * $steuer, 'waehrung' => ($v['waehrung'] ? $v['waehrung'] : 'EUR'));
|
|
if ($v['id']) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise']) - 1]['gruppenkennziffer'] = $v['kennziffer'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise']) - 1]['gruppenname'] = $v['name'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise']) - 1]['adresse'] = $v['adresse'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise']) - 1]['art'] = $v['art'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise'][count($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['staffelpreise']) - 1]['gruppeextern'] = $v['extgruppename'];
|
|
}
|
|
}
|
|
}
|
|
|
|
$articleVariant = $data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0];
|
|
$articleVariant['artikel'] = $eigenschaft['artikel'];
|
|
$data[$i]['artikel_varianten'][] = $articleVariant;
|
|
unset($data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][0]['Dateien']);
|
|
|
|
$query = sprintf('SELECT meoa.name AS wert,meoa.name_ext AS wert_ext, mega.name AS gruppe, mega.name_ext AS gruppe_ext
|
|
FROM matrixprodukt_optionen_zu_artikel AS moza
|
|
JOIN matrixprodukt_eigenschaftenoptionen_artikel AS meoa ON moza.option_id = meoa.id
|
|
JOIN matrixprodukt_eigenschaftengruppen_artikel AS mega ON mega.id = meoa.gruppe
|
|
WHERE moza.artikel=%d
|
|
ORDER BY mega.id, moza.id', $eigenschaft['artikel']);
|
|
$matrixdaten = $this->app->DB->SelectArr($query);
|
|
|
|
for ($iv = 0, $ivMax = (!empty($matrixdaten) ? count($matrixdaten) : 0); $iv < $ivMax; $iv++) {
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][$iv]['name'] = $matrixdaten[$iv]['gruppe'];
|
|
$data[$i]['matrix_varianten']['artikel'][$eigenschaft['artikel']][$iv]['values'] = $matrixdaten[$iv]['wert'];
|
|
}
|
|
}
|
|
|
|
if (empty($data)) {
|
|
continue;
|
|
}
|
|
} while (count($data[$i]['matrix_varianten']['artikel'] ?? [])>=5000);
|
|
|
|
// Bulk transfer (new 2024-06-28)
|
|
$result = null;
|
|
if (!empty($artikelexport) && !$nurlager) {
|
|
$result = $this->sendlist($id, $data, true);
|
|
}
|
|
if (!empty($lagerexport)) {
|
|
$result = $this->sendlistlager($id, $data);
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
if (!empty($loadElements['variants']) && $this->app->DB->Select("SELECT id FROM artikel WHERE variante_von = '$artikel' AND variante = 1 AND geloescht <> 1 AND nummer != 'DEL' LIMIT 1")) {
|
|
if ($this->app->DB->Select("SELECT id FROM artikel WHERE id = '$artikel' AND variante = 0 AND matrixprodukt=0 AND geloescht <> 1 AND nummer != 'DEL' LIMIT 1")) {
|
|
$data[$i]['artikel_varianten'] = [];
|
|
$data[$i]['variantevorhanden'] = 1;
|
|
$varianten = "SELECT * FROM artikel WHERE variante_von = '$artikel' AND variante = 1 AND geloescht <> 1 AND nummer != 'DEL'";
|
|
$db = $this->app->Container->get('Database');
|
|
foreach ($db->yieldAll($varianten) as $v) {
|
|
$steuer = $steuermapping[$v['umsatzsteuer']];
|
|
if ($v['steuersatz'] != -1 && !empty($v['steuersatz'])) {
|
|
$steuer = ($v['steuersatz'] + 100) / 100;
|
|
}
|
|
if (empty($steuer)) {
|
|
$steuer = $steuernormal;
|
|
}
|
|
$variantennettopreis = null;
|
|
if (!empty($loadElements['standard_price'])) {
|
|
if ($preisgruppe && method_exists($this->app->erp, 'GetVerkaufspreisGruppe')) {
|
|
$variantennettopreis = $this->app->erp->GetVerkaufspreisGruppe($v['id'], 1, $preisgruppe);
|
|
} else {
|
|
$variantennettopreis = $this->app->erp->GetVerkaufspreis($v['id'], 1, 0);
|
|
}
|
|
}
|
|
if (!empty($loadElements['translations']) && $this->app->erp->ModulVorhanden('artikel_texte')) {
|
|
$sprachen = ['de', 'en'];
|
|
foreach ($sprachen as $sprache) {
|
|
$query = sprintf("SELECT * FROM artikel_texte WHERE shop=%d AND sprache='%s' AND artikel=%d AND aktiv=1 LIMIT 1",
|
|
$id, strtoupper($sprache), $v['id']);
|
|
$ersetzeStandardbeschreibung = $this->app->DB->SelectRow($query);
|
|
if (!empty($ersetzeStandardbeschreibung)) {
|
|
$v['name_' . $sprache] = $ersetzeStandardbeschreibung['name'];
|
|
}
|
|
}
|
|
}
|
|
$this->app->erp->RunHook('remote_send_article_list_pseudostorage', 3, $id, $v['id'], $v['pseudolager']);
|
|
if (is_numeric($v['pseudolager']) && $v['pseudolager'] < 0) {
|
|
$v['pseudolager'] = 0;
|
|
}
|
|
$projectStockId = $this->app->DB->Select("SELECT `id` FROM `projekt` WHERE `id` = '{$projekt}' AND `projektlager` = 1 LIMIT 1");
|
|
$stock = (float) $this->app->erp->ArtikelAnzahlVerkaufbar(
|
|
$v['id'],
|
|
0,
|
|
$projectStockId,
|
|
$id,
|
|
$lagergrundlage
|
|
);
|
|
if ($stock < 0) {
|
|
$stock = 0;
|
|
}
|
|
$data[$i]['artikel_varianten'][] = array('nummer' => $v['nummer'], 'name_de' => $v['name_de'], 'name_en' => $v['name_en'], 'restmenge' => $v['restmenge'], 'gesperrt' => ($v['gesperrt'] == 1 || $v['intern_gesperrt'] == 1 ? 1 : 0),
|
|
'artikel' => $v['id'], 'zolltarifnummer' => $v['zolltarifnummer'], 'ean' => $v['ean'], 'gewicht' => $v['gewicht'], 'inaktiv' => $v['inaktiv'], 'uebersicht_de' => $v['uebersicht_de'],
|
|
'lag' => $stock,
|
|
'pseudolager' => $v['pseudolager'], 'pseudopreis' => $v['pseudopreis'], 'preis' => $variantennettopreis, 'bruttopreis' => $variantennettopreis * $steuer,
|
|
'artikelnummer_fremdnummern' => $this->app->DB->SelectArr("SELECT * FROM artikelnummer_fremdnummern WHERE artikel = '" . $v['id'] . "' AND nummer <> '' AND shopid = '$id' AND aktiv = '1'"),
|
|
'steuersatz' => ($steuer - 1) * 100);
|
|
if (!empty($data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['artikelnummer_fremdnummern'])) {
|
|
foreach ($data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['artikelnummer_fremdnummern'] as $fkey => $fval) {
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['artikelnummer_fremdnummern'][$fkey]['nummer'] = trim($fval['nummer']);
|
|
}
|
|
}
|
|
if ($eigenschaftenuebertragen && !empty($loadElements['properties'])) {
|
|
$varianteneigenschaften = $this->app->DB->SelectArr("SELECT e.name, ew.wert FROM artikeleigenschaften e INNER JOIN artikeleigenschaftenwerte ew ON e.id = ew.artikeleigenschaften
|
|
WHERE ew.artikel = '" . $v['id'] . "' AND e.name <> '' AND ew.wert <> '' AND e.geloescht <> 1 ORDER BY e.name");
|
|
if (!empty($varianteneigenschaften)) {
|
|
foreach ($varianteneigenschaften as $eigenschaft) {
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['eigenschaften'][] = array('name' => $eigenschaft['name'], 'values' => $eigenschaft['wert']);
|
|
}
|
|
}
|
|
$eigenschaftenuebersetzungen = $this->app->DB->SelectArr("SELECT language_from, language_to, property_from, property_to,property_value_from,property_value_to FROM article_property_translation WHERE article_id = '" . $v['id'] . "'");
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['eigenschaftenuebersetzungen'] = $eigenschaftenuebersetzungen;
|
|
}
|
|
|
|
if (!empty($freifelder) && !empty($loadElements['free_fields'])) {
|
|
foreach ($freifelder as $freifeld) {
|
|
if (method_exists($tmp, 'Get' . ucfirst($freifeld['freifeld_wawi']))) {
|
|
$_funktionsname = 'Get' . ucfirst($freifeld['freifeld_wawi']);
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['freifelder']['DE'][$freifeld['freifeld_shop']] = $v[$freifeld['freifeld_wawi']];
|
|
}
|
|
}
|
|
//Freifeldübersetzungen
|
|
$freifelduebersetzungen = $this->app->DB->SelectArr("SELECT sf.freifeld_shop, af.sprache, af.nummer, af.wert FROM shopexport_freifelder sf JOIN artikel_freifelder af ON sf.freifeld_wawi = CONCAT('freifeld',af.nummer) WHERE sf.shop = '$id' AND af.artikel = '" . $v['id'] . "' AND sf.aktiv = 1 AND sf.freifeld_wawi <> '' AND sf.freifeld_shop <> '' AND af.wert <> ''");
|
|
if (!empty($freifelduebersetzungen)) {
|
|
foreach ($freifelduebersetzungen as $ffukey => $ffuvalue) {
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['freifelder'][$ffuvalue['sprache']][] = array('mapping' => $ffuvalue['freifeld_shop'], 'freifeldnummer' => $ffuvalue['nummer'], 'wert' => $ffuvalue['wert']);
|
|
}
|
|
}
|
|
}
|
|
if ($shopbilderuebertragen && !empty($loadElements['pictures'])) {
|
|
$dateien = $this->getImagesForArticle($v['id']);
|
|
if (!empty($dateien)) {
|
|
foreach ($dateien as $datei) {
|
|
$filename = $this->app->erp->GetDateiName($datei['id']);
|
|
$path_info = pathinfo($filename);
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['datei'][] = base64_encode($this->app->erp->GetDatei($datei['id']));
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['filename'][] = $filename;
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['extension'][] = $path_info['extension'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['titel'][] = $datei['titel'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['beschreibung'][] = $datei['beschreibung'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['stichwort'][] = $datei['subjekt'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['id'][] = $datei['id'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['version'][] = $datei['version'];
|
|
$data[$i]['artikel_varianten'][count($data[$i]['artikel_varianten']) - 1]['Dateien']['extid'][] = $this->GetShopexportMappingExt($id, 'datei', $datei['id']);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
$data[$i]['variantevorhanden'] = 0;
|
|
}
|
|
|
|
if (empty($data)) {
|
|
continue;
|
|
}
|
|
}
|
|
|
|
// Bulk transfer (new 2024-06-28)
|
|
$result = null;
|
|
if (!empty($artikelexport) && !$nurlager) {
|
|
$result = $this->sendlist($id, $data, true);
|
|
}
|
|
if (!empty($lagerexport)) {
|
|
$result = $this->sendlistlager($id, $data);
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* @param int $articleId
|
|
* @return array|null
|
|
*/
|
|
protected function getImagesForArticle($articleId) {
|
|
$query = sprintf("SELECT d.id AS `id`, dv.id AS `vid`, d.titel, d.beschreibung, ds.subjekt, ds.sort, dv.version AS `version`
|
|
FROM `datei_stichwoerter` AS `ds`
|
|
INNER JOIN `datei` AS `d` ON ds.datei = d.id
|
|
INNER JOIN `datei_version` AS `dv` ON dv.datei = ds.datei
|
|
INNER JOIN (SELECT MAX(`version`) AS `version`, `datei` FROM `datei_version` GROUP BY `datei`) AS `dvm` ON dvm.datei = dv.datei AND dvm.version = dv.version
|
|
WHERE ds.parameter = %d AND ds.objekt like 'Artikel' AND ds.subjekt LIKE 'Shopbild' AND d.geloescht = 0
|
|
ORDER BY ds.sort", $articleId);
|
|
|
|
return $this->app->DB->SelectArr($query);
|
|
}
|
|
|
|
protected function sendlistlager(int $shop_id, array $data) {
|
|
$result = $this->RemoteCommand($shop_id, 'sendlistlager', $data);
|
|
return $result;
|
|
}
|
|
|
|
protected function sendlist(int $shop_id, array $data, $isLagerExported) {
|
|
|
|
// See description of return format in function RemoteSendArticleList()
|
|
$result = $this->RemoteCommand($shop_id, 'sendlist', $data);
|
|
|
|
if (!empty($result) && is_array($result)) {
|
|
foreach ($result['articles'] as $artikelid) {
|
|
/** @var Shopexport $objShopexport */
|
|
$objShopexport = $this->app->loadModule('shopexport');
|
|
$changedHash = $objShopexport->hasArticleHashChanged($artikelid, $shop_id);
|
|
$hash = $changedHash['hash'];
|
|
|
|
$checkAo = $this->app->DB->Select(
|
|
sprintf(
|
|
'SELECT id FROM artikel_onlineshops WHERE artikel = %d AND shop=%d LIMIT 1',
|
|
$artikelid, $shop_id
|
|
)
|
|
);
|
|
if (empty($checkAo)) {
|
|
$this->app->DB->Insert(
|
|
sprintf(
|
|
'INSERT INTO artikel_onlineshops (artikel, shop, aktiv, ausartikel)
|
|
VALUES (%d, %d, 1, 1) ',
|
|
$artikelid, $shop_id
|
|
)
|
|
);
|
|
}
|
|
$this->app->DB->Update(
|
|
sprintf(
|
|
"UPDATE artikel_onlineshops
|
|
SET last_article_transfer = NOW(), last_article_hash = '%s'
|
|
WHERE artikel = %d AND shop = %d",
|
|
$this->app->DB->real_escape_string($hash), $artikelid, $shop_id
|
|
)
|
|
);
|
|
}
|
|
}
|
|
|
|
if (!empty($result) && is_array($result)) {
|
|
foreach ($result['new'] as $artikelid => $fremdnummer) {
|
|
$artikelid = (int) $artikelid;
|
|
$artikelnummer = $this->app->DB->Select("SELECT nummer FROM artikel WHERE id = '$artikelid' LIMIT 1");
|
|
if ($artikelid > 0 && $artikelnummer != trim($fremdnummer) &&
|
|
($this->app->DB->Select("SELECT id FROM artikel WHERE id = '$artikelid' AND (shop = '$shop_id' OR shop2 = '$shop_id' OR shop3 = '$shop_id') LIMIT 1") ||
|
|
$this->app->DB->Select("SELECT id FROM artikel_onlineshops WHERE artikel = '$artikelid' AND aktiv = 1")
|
|
) && trim($fremdnummer) !== '') {
|
|
//Nur falls Artikel zum Shop passt und keine aktive Fremdnummer exisitert.
|
|
if (!$this->app->DB->Select("SELECT id FROM `artikelnummer_fremdnummern` WHERE artikel = '$artikelid' AND shopid = '$shop_id' AND nummer <> '' AND (aktiv = 1 OR nummer = '" . trim($this->app->DB->real_escape_string($fremdnummer)) . "') LIMIT 1 ")) {
|
|
$this->app->DB->Insert("INSERT INTO `artikelnummer_fremdnummern` (artikel, bezeichnung, nummer, shopid, bearbeiter, zeitstempel, aktiv)
|
|
VALUES ('$artikelid','Erstellt durch Artikelexport','" . trim($this->app->DB->real_escape_string($fremdnummer)) . "','$shop_id','" . ((isset($this->app->User) && method_exists($this->app->User, 'GetName')) ? $this->app->DB->real_escape_string($this->app->User->GetName()) : 'Cronjob') . "',now(),0)
|
|
");
|
|
}
|
|
}
|
|
}
|
|
if (isset($result['anzahl'])) {
|
|
$result['count'] = $result['anzahl'];
|
|
}//Altes Verhalten
|
|
}
|
|
|
|
if (!$isLagerExported) {
|
|
$this->sendlistlager($shop_id, $data);
|
|
}
|
|
return $result;
|
|
}
|
|
|
|
public function getDataToSendForUpdateOrder(int $shopId, int $orderId): ?OrderStatusUpdateRequest
|
|
{
|
|
$orderArr = $this->app->DB->SelectRow("SELECT `zahlungsweise`, `shopextid` FROM `auftrag` WHERE `id` = $orderId LIMIT 1");
|
|
if (empty($orderArr))
|
|
return null;
|
|
|
|
$data = new OrderStatusUpdateRequest();
|
|
$data->orderId = $orderId;
|
|
$data->shopOrderId = $orderArr['shopextid'];
|
|
|
|
$statusArr = $this->app->DB->SelectFirstCols("SELECT DISTINCT status FROM auftrag WHERE id = $orderId OR teillieferungvon = $orderId");
|
|
if (in_array('storniert', $statusArr))
|
|
$data->orderStatus = OrderStatus::Cancelled;
|
|
if (in_array('abgeschlossen', $statusArr))
|
|
$data->orderStatus = OrderStatus::Completed;
|
|
if (in_array('freigegeben', $statusArr))
|
|
$data->orderStatus = OrderStatus::InProgress;
|
|
if (in_array('angelegt', $statusArr))
|
|
$data->orderStatus = OrderStatus::Imported;
|
|
|
|
$sql = "
|
|
SELECT DISTINCT
|
|
v.id,
|
|
v.tracking,
|
|
v.tracking_link,
|
|
COALESCE(sv.versandart_ausgehend, sv.versandart_shop, v.versandart) versandart
|
|
FROM
|
|
auftrag a
|
|
LEFT JOIN lieferschein l ON
|
|
l.auftragid = a.id
|
|
LEFT JOIN lieferschein_position lp ON
|
|
lp.lieferschein = l.id
|
|
LEFT JOIN versandpaket_lieferschein_position vlp ON
|
|
vlp.lieferschein_position = lp.id
|
|
LEFT JOIN versandpakete v ON
|
|
vlp.versandpaket = v.id OR v.lieferschein_ohne_pos = l.id
|
|
LEFT JOIN shopexport_versandarten sv ON
|
|
sv.versandart_wawision = v.versandart AND sv.shop = $shopId
|
|
WHERE (a.id = $orderId OR a.teillieferungvon = $orderId) AND v.id IS NOT NULL
|
|
ORDER BY v.id";
|
|
|
|
$shipments = $this->app->DB->SelectArr($sql);
|
|
foreach ($shipments as $shipment) {
|
|
$item = new Shipment();
|
|
$item->id = $shipment['id'];
|
|
$item->trackingNumber = $shipment['tracking'];
|
|
$item->trackingUrl = $shipment['tracking_link'];
|
|
$item->shippingMethod = $shipment['versandart'];
|
|
$data->shipments[] = $item;
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $orderId
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteUpdateAuftrag($shopId, $orderId) {
|
|
$data = $this->getDataToSendForUpdateOrder((int)$shopId, (int)$orderId);
|
|
if($data?->orderStatus !== OrderStatus::Completed)
|
|
return;
|
|
|
|
$bearbeiter = 'Cronjob';
|
|
if (isset($this->app->User)) {
|
|
$bearbeiter = $this->app->DB->real_escape_string($this->app->User->GetName());
|
|
}
|
|
|
|
$response = $this->RemoteCommand($shopId, 'updateauftrag', $data);
|
|
if ($response instanceOf ShopConnectorResponseInterface && !$response->isSuccessful()) {
|
|
$query = sprintf('UPDATE `auftrag`
|
|
SET `shop_status_update_attempt` = `shop_status_update_attempt` + 1,
|
|
`shop_status_update_last_attempt_at` = NOW()
|
|
WHERE `id` = %d', $orderId);
|
|
$this->app->DB->Update($query);
|
|
|
|
$this->app->erp->AuftragProtokoll($orderId, 'Versandmeldung an Shop fehlgeschlagen', $bearbeiter);
|
|
|
|
$this->logger->error('Versandmeldung an Shop fehlgeschlagen',
|
|
[
|
|
'orderId' => $orderId,
|
|
'shopId' => $shopId,
|
|
'message' => $response->getMessage()
|
|
]
|
|
);
|
|
return;
|
|
}
|
|
|
|
$this->app->erp->AuftragProtokoll($orderId, 'Versandmeldung an Shop übertragen', $bearbeiter);
|
|
$this->app->DB->Update("UPDATE `auftrag` SET `shopextstatus` = 'abgeschlossen' WHERE `id` = $orderId LIMIT 1");
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param string $auftrag
|
|
*
|
|
* @param string $internet
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteDeleteAuftrag($shopId, $auftrag, $internet = '') {
|
|
$data['auftrag'] = $auftrag;
|
|
$data['internet'] = $internet;
|
|
$this->RemoteCommand($shopId, 'deleteauftrag', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $orderId
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteStorniereAuftrag($shopId, $orderId) {
|
|
$orderArr = $this->app->DB->SelectRow("SELECT shopextid, internet FROM auftrag WHERE id='$orderId' LIMIT 1");
|
|
if (empty($orderArr)) {
|
|
return;
|
|
}
|
|
$shopextid = $orderArr['shopextid'];
|
|
$internet = $orderArr['internet'];
|
|
$data['auftrag'] = $shopextid;
|
|
$data['internet'] = $internet;
|
|
|
|
$this->app->DB->Insert("
|
|
INSERT INTO auftrag_protokoll (auftrag, zeit, bearbeiter, grund)
|
|
VALUES ($orderId,now(),'" . (isset($this->app->User) ? $this->app->DB->real_escape_string($this->app->User->GetName()) : 'Cronjob') . "',
|
|
'Stonierung an Shop übertragen')"
|
|
);
|
|
$this->RemoteCommand($shopId, 'storniereauftrag', $data);
|
|
$shopextstatus = 'storniert';
|
|
$this->app->DB->Update("UPDATE auftrag SET shopextstatus='$shopextstatus' WHERE id='$orderId' LIMIT 1");
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $fileId
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteDeleteFile($shopId, $fileId) {
|
|
$inhalt = $this->app->erp->GetDatei($fileId);
|
|
$fileArr = $this->app->DB->SelectRow("SELECT titel,beschreibung FROM datei WHERE id='$fileId' LIMIT 1");
|
|
$titel = $fileArr['titel'];
|
|
$beschreibung = $fileArr['beschreibung'];
|
|
|
|
$data['datei'] = $fileId;
|
|
//$data['checksum'] = md5($inhalt);
|
|
$data['checksum'] = md5($inhalt . $titel . $beschreibung);
|
|
return $this->RemoteCommand($shopId, 'deletefile', $data);
|
|
}
|
|
|
|
/**
|
|
* @param int $articleId
|
|
* @param int $shopId
|
|
*/
|
|
public function RemoteUpdateFilesArtikel($articleId, $shopId) {
|
|
$files = $this->app->DB->SelectArr("SELECT DISTINCT ds.datei
|
|
FROM datei_stichwoerter ds, datei d, artikel a
|
|
WHERE d.id=ds.datei AND (ds.subjekt='Shopbild' OR ds.subjekt='Gruppenbild') AND ((ds.objekt='Artikel' AND
|
|
ds.parameter=a.id) OR (ds.objekt='Kampangen' AND ds.parameter='$shopId')) AND
|
|
d.firma='" . $this->app->User->GetFirma() . "' AND a.shop='$shopId' AND a.id='$articleId'"
|
|
);
|
|
|
|
$tmp = $this->app->remote->RemoteGetFileListArticle($shopId, $articleId);
|
|
if (!empty($tmp)) {
|
|
foreach ($tmp as $row) {
|
|
$checkarray[$row['datei']] = $row['checksum'];
|
|
}
|
|
}
|
|
|
|
if (!empty($files)) {
|
|
foreach ($files as $file) {
|
|
$fid = $file['datei'];
|
|
$geloescht = $this->app->DB->Select("SELECT geloescht FROM datei WHERE id='$fid' LIMIT 1");
|
|
if ($geloescht) {
|
|
$this->app->remote->RemoteDeleteFile($shopId, $fid);
|
|
$checkarray[$fid] = 'delete';
|
|
} else {
|
|
$md5 = !empty($checkarray[$fid]) ? (String) $checkarray[$fid] : '';
|
|
$md5file = md5($this->app->erp->GetDatei($fid));
|
|
if ($md5 !== $md5file) {
|
|
$this->app->remote->RemoteSendFile($shopId, $fid);
|
|
$this->app->remote->RemoteAddFileSubject($shopId, $fid);
|
|
$checkarray[$fid] = 'update';
|
|
}
|
|
}
|
|
$checkarray[$fid] = 'mark';
|
|
}
|
|
}
|
|
if (!empty($checkarray)) {
|
|
foreach ($checkarray as $key => $value) {
|
|
if ($checkarray[$key] !== 'mark' && $checkarray[$key] !== 'delete' && $checkarray[$key] !== 'update') {
|
|
$this->app->remote->RemoteDeleteFile($shopId, $key);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $fileId
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendFile($shopId, $fileId) {
|
|
// sende stichwoerter
|
|
$fileArr = $this->app->DB->SelectRow("SELECT geloescht, titel, beschreibung FROM datei WHERE id='$fileId' LIMIT 1");
|
|
if (empty($fileArr)) {
|
|
return '';
|
|
}
|
|
$geloescht = $fileArr['geloescht'];
|
|
$titel = $fileArr['titel'];
|
|
$beschreibung = $fileArr['beschreibung'];
|
|
|
|
$inhalt = $this->app->erp->GetDatei($fileId);
|
|
$data['datei'] = $fileId;
|
|
$data['titel'] = $titel;
|
|
$data['beschreibung'] = $beschreibung;
|
|
$data['inhalt'] = base64_encode($inhalt);
|
|
$data['checksum'] = md5($inhalt . $titel . $beschreibung);
|
|
if (!$geloescht) {
|
|
return $this->RemoteCommand($shopId, 'sendfile', $data);
|
|
}
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param int $fileId
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteAddFileSubject($shopId, $fileId) {
|
|
// sende stichwoerter
|
|
$fileList = $this->app->DB->SelectArr("SELECT subjekt, parameter
|
|
FROM datei_stichwoerter
|
|
WHERE (objekt='Artikel' OR objekt='Kampangen') AND datei='$fileId'"
|
|
);
|
|
if (empty($fileList)) {
|
|
return;
|
|
}
|
|
|
|
foreach ($fileList as $fileRow) {
|
|
$geloescht = $this->app->DB->Select("SELECT geloescht FROM datei WHERE id='$fileId' LIMIT 1");
|
|
$stichwort['subjekt'] = $fileRow['subjekt'];
|
|
$stichwort['artikel'] = $fileRow['parameter'];
|
|
$stichwort['datei'] = $fileId;
|
|
if (!$geloescht) {
|
|
$this->RemoteCommand($shopId, 'addfilesubjekt', $stichwort);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param array $artikel
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteDeleteArticle($shopId, $artikel) {
|
|
return $this->RemoteCommand($shopId, 'deletearticle', $artikel);
|
|
}
|
|
|
|
/**
|
|
* @param int $shopId
|
|
* @param array $partner
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteSendPartner($shopId, $partner) {
|
|
return $this->RemoteCommand($shopId, 'partnerlist', $partner);
|
|
}
|
|
|
|
/**
|
|
* @param object $obj
|
|
* @param string $methodname
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getMethod($obj, $methodname) {
|
|
$methodname = trim((String) $methodname);
|
|
if ($methodname === '') {
|
|
return '';
|
|
}
|
|
if (!$obj) {
|
|
return '';
|
|
}
|
|
if (method_exists($obj, $methodname)) {
|
|
return $methodname;
|
|
}
|
|
$methods = get_class_methods($obj);
|
|
$classname = get_class($obj);
|
|
foreach ($methods as $v) {
|
|
if (strtolower($v) === 'import' . strtolower($methodname)) {
|
|
return $v;
|
|
}
|
|
if (strtolower($v) === strtolower($classname . $methodname)) {
|
|
return $v;
|
|
}
|
|
}
|
|
foreach ($methods as $v) {
|
|
if (strtolower($v) === strtolower($methodname)) {
|
|
return $v;
|
|
}
|
|
}
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param string $action
|
|
* @param string|array $data
|
|
*
|
|
* @return mixed
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteCommand($id, $action, $data = '') {
|
|
$challenge = '';
|
|
$shoptyp = $this->app->DB->Select("SELECT shoptyp FROM shopexport WHERE id='$id' LIMIT 1");
|
|
$modulename = trim($this->app->DB->Select("SELECT modulename FROM shopexport WHERE id='$id' LIMIT 1"), '.');
|
|
$isActionAuth = $action === 'auth';
|
|
$exception = null;
|
|
|
|
$this->logger->debug(
|
|
'RemoteCommand (Shop '.$id.") ".$action,
|
|
[
|
|
'shop' => $id,
|
|
'action' => $action,
|
|
'data' => $data
|
|
]
|
|
);
|
|
|
|
if ($shoptyp === 'custom') {
|
|
|
|
$error = null;
|
|
|
|
if ($modulename != '') {
|
|
|
|
$file = dirname(__DIR__) . '/plugins/external/shopimporter/' . $modulename;
|
|
$classa = explode('_', str_replace('_' . $id . '.php', '', $modulename));
|
|
foreach ($classa as $k => $v) {
|
|
$classa[$k] = ucfirst($v);
|
|
}
|
|
$class = implode('_', $classa);
|
|
if ($this->app->DB->Select("SELECT aktiv FROM shopexport WHERE id = '$id' LIMIT 1")) {
|
|
if (file_exists($file)) {
|
|
include_once($file);
|
|
if (class_exists($class)) {
|
|
$obj = new $class($this->app, true);
|
|
if ($obj) {
|
|
if (method_exists($obj, 'getKonfig')) {
|
|
$obj->getKonfig($id, $data);
|
|
}
|
|
$method = $this->getMethod($obj, $action);
|
|
if (method_exists($obj, $method)) {
|
|
$ret = $obj->$method();
|
|
$this->logger->debug('RemoteCommand result (Shop '.$id.') '.$modulename.' '.$action,
|
|
[
|
|
'shop' => $id,
|
|
'action' => $action,
|
|
'data' => $data,
|
|
'result' => $ret
|
|
]
|
|
);
|
|
if (!empty($this->app->stringcleaner)) {
|
|
$this->app->stringcleaner->XMLArray_clean($ret);
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Importer konnte nicht initialisiert werden';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Importer konnte nicht initialisiert werden';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Importer konnte nicht initialisiert werden';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Datei ' . $file . ' existiert nicht';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Schnittstelle nicht aktiv';
|
|
}
|
|
} else {
|
|
$error = 'Fehler: Kein Modul angegeben';
|
|
}
|
|
}
|
|
else if ($shoptyp === 'intern') {
|
|
if ($modulename != '') {
|
|
if ($this->app->erp->ModulVorhanden($modulename)) {
|
|
$obj = $this->app->erp->LoadModul($modulename);
|
|
if ($obj) {
|
|
if (method_exists($obj, 'getKonfig')) {
|
|
$obj->getKonfig($id, $data);
|
|
}
|
|
$method = 'Import' . $action;
|
|
if (method_exists($obj, $method)) {
|
|
try {
|
|
$ret = $obj->$method();
|
|
} catch (Exception $e) {
|
|
$exception = $e;
|
|
if ($isActionAuth) {
|
|
$error = 'Fehler Auth: ' . $e->getMessage();
|
|
} else {
|
|
$error = 'Fehler: ' . $e->getMessage();
|
|
}
|
|
}
|
|
$this->logger->debug('RemoteCommand result (Shop '.$id.') '.$modulename.' '.$action,
|
|
[
|
|
'shop' => $id,
|
|
'action' => $action,
|
|
'data' => $data,
|
|
'result' => $ret
|
|
]
|
|
);
|
|
if (!empty($this->app->stringcleaner)) {
|
|
$this->app->stringcleaner->XMLArray_clean($ret);
|
|
}
|
|
$this->parseReturn($ret, $id, $action);
|
|
} else {
|
|
$error = 'Fehler: Funktion nicht implementiert: ' . $method;
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Importer konnte nicht initialisiert werden';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Dieses Modul ist nicht verfügbar';
|
|
}
|
|
} elseif ($isActionAuth) {
|
|
$error = 'Fehler: Kein Modul vorhanden';
|
|
} else {
|
|
$error = 'Fehler: Kein Modul angegeben';
|
|
}
|
|
}
|
|
if ($error) {
|
|
$this->logger->error('RemoteCommand error (Shop '.$id.') '.$modulename.' '.$action,
|
|
[
|
|
'error' => $error,
|
|
'exception' => $exception
|
|
]
|
|
);
|
|
return($error);
|
|
}
|
|
|
|
return $ret;
|
|
|
|
// Dead code removed here 2024-09-13
|
|
}
|
|
|
|
/**
|
|
* @param mixed $ret
|
|
* @param int $id
|
|
* @param string $action
|
|
*/
|
|
public function parseReturn($ret, $id, $action) {
|
|
if ($action === 'getarticlelist') {
|
|
if (empty($ret)) {
|
|
return;
|
|
}
|
|
$anz = 0;
|
|
if (empty($ret['errors'])) {
|
|
foreach ($ret as $v) {
|
|
$anz++;
|
|
$this->app->DB->Insert("INSERT INTO shopexport_getarticles (shop, nummer) VALUES ('$id', '" . $this->app->DB->real_escape_string($v) . "')");
|
|
}
|
|
if (!$this->app->DB->Select("SELECT id FROM `prozessstarter` WHERE aktiv = 1 AND parameter = 'getarticles' LIMIT 1")) {
|
|
$this->app->DB->Update("UPDATE `prozessstarter` SET aktiv = 1 WHERE parameter = 'getarticles' LIMIT 1");
|
|
}
|
|
$this->app->DB->Update("UPDATE `prozessstarter` SET letzteausfuerhung = DATE_SUB(now(), INTERVAL periode MINUTE) WHERE aktiv = 1 AND parameter = 'getarticles' AND mutex = 0 LIMIT 1");
|
|
}
|
|
$this->app->erp->SetKonfigurationValue('artikelimportanzahl_' . $id, $anz);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param int $id
|
|
* @param string $action
|
|
* @param string|array $data
|
|
*
|
|
* @return mixed|string
|
|
* @throws Exception
|
|
*/
|
|
public function RemoteCommandAES($id, $action, $data = '') {
|
|
$challenge = '';
|
|
$shopexport = $this->app->DB->SelectRow("SELECT * FROM shopexport WHERE id='$id' LIMIT 1");
|
|
if (!empty($shopexport)) {
|
|
if ($shopexport['shoptyp'] === 'intern' || $shopexport['shoptyp'] === 'custom') {
|
|
return '';
|
|
}
|
|
$token = $shopexport['token'];
|
|
$url = $shopexport['url'];
|
|
$z = $shopexport['passwort'];
|
|
if ($z === '' || $token === '' || $url === '') {
|
|
throw new Exception('Der ImportKey/ImportToken/ImportUrl ist leer');
|
|
}
|
|
}
|
|
$tmp = parse_url($url);
|
|
|
|
$aes = new AES($z);
|
|
$token = base64_encode($aes->encrypt(serialize($token)));
|
|
|
|
$client = new HttpClient($tmp['host']);
|
|
$geturl = $tmp['path'] . 'index.php?module=import&action=' . $action . '&challenge=' . $challenge;
|
|
|
|
$post_data['token'] = $token;
|
|
$post_data['data'] = base64_encode($aes->encrypt(serialize($data)));
|
|
|
|
if (!$client->post($geturl, $post_data)) {
|
|
$this->logger->error('An error occurred',
|
|
[
|
|
'error' => $client->getError()
|
|
]
|
|
);
|
|
|
|
throw new Exception('An error occurred: ' . $client->getError());
|
|
}
|
|
return unserialize($aes->decrypt(base64_decode($client->getContent())));
|
|
}
|
|
}
|
|
|