app->DB->Select("SELECT devicekey FROM firmendaten WHERE devicekey!='' LIMIT 1"); $tmpdevices = $this->app->DB->SelectPairs("SELECT bezeichnung, adapterboxseriennummer FROM drucker WHERE adapterboxseriennummer!='' AND aktiv='1' AND (anbindung='adapterbox' OR anbindung='spooler')"); $tmpdevices2 = $this->app->DB->SelectFirstCols("SELECT bezeichnung, seriennummer as adapterboxseriennummer FROM adapterbox WHERE seriennummer!=''"); $tmpdevices = array_unique(array_merge($tmpdevices, $tmpdevices2)); $col1 = ''; $col2 = ''; foreach($tmpdevices as $device) { $authkeys[$device] = $this->generateHash($validPass, $device); $col1 .= sprintf(" IF( adapterboxseriennummer = '%s', '%s',", $this->app->DB->real_escape_string($device), $this->app->DB->real_escape_string($authkeys[$device]) ); $col2 .= sprintf(" IF( seriennummer = '%s', '%s',", $this->app->DB->real_escape_string($device), $this->app->DB->real_escape_string($authkeys[$device]) ); } $col1 .= "''".str_repeat(')', count($tmpdevices)); $col2 .= "''".str_repeat(')', count($tmpdevices)); $heading = ['Typ','Bezeichnung','Seriennummer','AuthKey','']; $width = ['10%', '20%', '20%', '20%', '1%']; $findcols = [ 't.typ','t.bezeichnung','t.adapterboxseriennummer','t.auth','t.id' ]; $sql = "SELECT SQL_CALC_FOUND_ROWS t.id,t.typ,t.bezeichnung, t.adapterboxseriennummer, t.auth,t.id FROM (( SELECT 'Adpaterbox' as Typ, bezeichnung, adapterboxseriennummer, $col1 AS auth,id FROM drucker WHERE adapterboxseriennummer!='' AND aktiv='1' AND (anbindung='adapterbox' OR anbindung='spooler') ) UNION ALL ( SELECT 'Drucker' as Typ, bezeichnung, seriennummer as adapterboxseriennummer, $col2 AS auth,id FROM adapterbox WHERE seriennummer!='' )) AS t "; break; case 'adapterbox_request_logs': $validPass = $this->app->DB->Select("SELECT devicekey FROM firmendaten WHERE devicekey!='' LIMIT 1"); $passes = $this->app->DB->SelectFirstCols('SELECT DISTINCT validpass FROM adapterbox_request_log WHERE validpass != \'\''); $allPasses = []; if(!empty($validPass)) { $allPasses[] = $validPass; } $allPasses = array_unique(array_merge($allPasses, $passes)); $devices = $this->app->DB->SelectFirstCols('SELECT DISTINCT device FROM adapterbox_request_log WHERE device != \'\''); $tmpdevices = $this->app->DB->SelectFirstCols("SELECT adapterboxseriennummer FROM drucker WHERE adapterboxseriennummer!='' AND aktiv='1' AND (anbindung='adapterbox' OR anbindung='spooler')"); $tmpdevices2 = $this->app->DB->SelectFirstCols("SELECT seriennummer as adapterboxseriennummer FROM adapterbox WHERE seriennummer!=''"); $tmpdevices = array_unique(array_merge($tmpdevices, $tmpdevices2)); $alldevices = array_unique(array_merge($tmpdevices, $devices)); $authkeys = []; $countKeys = 0; $colAuthNeeded = ' IF( arl.success OR arl.auth = \'\' AND arl.digets <> \'\', arl.auth,'; foreach($alldevices as $device) { foreach($allPasses as $pass) { $authkeys[$device][$pass] = $this->generateHash($pass, $device); $colAuthNeeded .= sprintf(" IF( arl.device = '%s' AND arl.validpass = '%s', '%s',", $this->app->DB->real_escape_string($device), $this->app->DB->real_escape_string($pass), $this->app->DB->real_escape_string($authkeys[$device][$pass]) ); $countKeys++; } } /*foreach($authkeys as $device => $authArr) { foreach($authArr as $pass ) }*/ $colAuthNeeded .= "''".str_repeat(')', $countKeys + 1); $heading = ['Datum','IP','Device','Auth gesendet','Auth benötigt','Digets','Status','color','Menü']; $width = ['10%', '10%','10%', '20%', '20%', '20%', '10%', '1%']; $findcols = [ 'arl.created_at','arl.ip','arl.device','arl.auth',$colAuthNeeded,'arl.digets', "IF(arl.success=1,'OK','Fehler')",'arl.success', 'arl.id' ]; $searchsql = ['arl.ip', 'arl.device','arl.auth']; $datecols = [0]; $where = ''; $menu = ''; $trcol = 7; $sql = "SELECT SQL_CALC_FOUND_ROWS arl.id, DATE_FORMAT(arl.created_at, '%d.%m.%Y %H:%i:%s'),arl.ip, arl.device, arl.auth, $colAuthNeeded, arl.digets, IF(arl.success=1,'OK','Fehler'), IF(arl.success=1,'#D2EC9D','#F1B19F'), arl.id FROM adapterbox_request_log AS arl"; $defaultorder = 1; $defaultorderdesc = 1; break; case 'adapterbox_list': $allowed['adapterbox'] = array('list'); // START EXTRA checkboxen // ENDE EXTRA checkboxen // headings $heading = array('Bezeichnung', 'Seriennummer', 'Verwenden als','Letzte IP','Status','Menü'); $width = array('40%', '35%','15%','15%', '5%'); $findcols = array('a.bezeichnung', 'a.seriennummer','a.verwendenals','a.tmpip','a.letzteverbindung', 'a.id'); $searchsql = array('a.bezeichnung', 'a.seriennummer','a.verwendenals','a.tmpip', 'a.id'); $defaultorder = 1; // sortiert nach dem oeffnen nach spalte 2 $defaultorderdesc = 0; // 0 = auftsteigend , 1 = absteigen (eventuell notfalls pruefen) $menu = '
' . '' . "app->Conf->WFconf['defaulttheme']}/images/edit.svg\" border=\"0\">" . " " ."" . "app->Conf->WFconf['defaulttheme']}/images/download.svg\" border=\"0\">". " "."" . "app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\">" . ' 
'; // SQL statement $sql = "SELECT SQL_CALC_FOUND_ROWS a.id, if(a.bezeichnung='','Ohne Bezeichnung',a.bezeichnung) as bezeichnung, a.seriennummer, if(a.verwendenals='' || a.verwendenals='etikettendrucker','Etikettendrucker',if(a.verwendenals='waage','Waage',if(a.verwendenals='kamera','Kamera',if(a.verwendenals='metratecrfid','RFID-Leser',if(a.verwendenals='bondrucker','Bondrucker',a.verwendenals))))),a.tmpip,if(TIME_TO_SEC(TIMEDIFF(NOW(),a.letzteverbindung)) > 10 OR a.letzteverbindung IS NULL,'disconnected','connected'),a.id FROM adapterbox a "; $count = 'SELECT COUNT(id) FROM adapterbox'; break; case 'adapterbox_jobs': $allowed['adapterbox'] = array('jobs'); $heading = array('Sender', 'Empfänger', 'art', 'Zeit', 'Menü'); $width = array('20%', '20%', '20%', '20%', '10%'); $findcols = array('d.deviceidsource', 'd.deviceiddest', 'd.art', 'd.zeitstempel', 'd.id'); $searchsql = array('d.deviceidsource', 'd.deviceiddest', 'd.art', 'd.zeitstempel'); $menu = '
' . "" . "app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\">" . ' 
'; // SQL statement $sql = 'SELECT SQL_CALC_FOUND_ROWS d.id, d.deviceidsource, d.deviceiddest, d.art, d.zeitstempel, d.id FROM device_jobs d '; $where = '';//d.firma='" . $this->app->User->GetFirma() . "'"; $count = 'SELECT COUNT(d.id) FROM device_jobs AS d'; break; case 'adapterbox_log': $allowed['adapterbox'] = array('list'); $heading = array('Zeit', 'IP', 'Seriennummer', 'Meldung', 'Menü'); $width = array('15%', '15%', '15%', '40%', '10%'); $findcols = array('a.datum', 'a.ip', 'a.seriennummer', 'a.meldung', 'a.id'); $searchsql = array("DATE_FORMAT(a.datum,'%d.%m.%Y %H:%i:%s')", 'a.ip', 'a.meldung', 'a.seriennummer'); $defaultorder = 5; $defaultorderdesc = 1; $menu = '
' . "" . "app->Conf->WFconf['defaulttheme']}/images/delete.svg\" border=\"0\">" . ' 
'; // SQL statement $sql = "SELECT SQL_CALC_FOUND_ROWS a.id, DATE_FORMAT(a.datum,'%d.%m.%Y %H:%i:%s'), a.ip, a.seriennummer, a.meldung, a.id FROM adapterbox_log a"; $count = 'SELECT COUNT(a.id) FROM adapterbox_log a'; break; } $erg = []; foreach($erlaubtevars as $k => $v) { if(isset($$v)) { $erg[$v] = $$v; } } return $erg; } /** * Adapterbox constructor. * * @param Application $app * @param bool $intern */ public function __construct($app, $intern = false) { //parent::GenAdapterbox($app); $this->app=$app; if($intern) { return; } $this->app->ActionHandlerInit($this); $this->app->ActionHandler("create","AdapterboxCreate"); $this->app->ActionHandler("edit","AdapterboxEdit"); $this->app->ActionHandler("delete","AdapterboxDelete"); $this->app->ActionHandler("deletelog","AdapterboxDeleteLog"); $this->app->ActionHandler("list","AdapterboxList"); $this->app->ActionHandler("log","AdapterboxLog"); $this->app->ActionHandler("jobs","AdapterboxJobs"); $this->app->ActionHandler("schritt2","AdapterboxSchritt2"); $this->app->ActionHandler("download","AdapterboxDownload"); $this->app->ActionHandler("endgeraet","AdapterboxEndgeraet"); $this->app->ActionHandler("testdruck","AdapterboxTestdruck"); $this->app->ActionHandler("testbild","AdapterboxTestbild"); $this->app->ActionHandler("deletejob","AdapterboxDeletejob"); $this->app->ActionHandler("deletejobs","AdapterboxDeletejobs"); $this->app->ActionHandler("demo","AdapterboxDemo"); $this->app->ActionHandler("log","AdapterboxLogs"); $this->app->ActionHandlerListen($app); } public function AdapterboxLogs() { $this->AdapterboxMenu(); $this->app->YUI->TableSearch('TAB1','adapterbox_devicekeys','show','','',basename(__FILE__),__CLASS__); $this->app->YUI->TableSearch('TAB1','adapterbox_request_logs','show','','',basename(__FILE__),__CLASS__); $this->app->Tpl->Parse('PAGE', 'tabview.tpl'); } public function AdapterboxSchritt2() { $id = $this->app->Secure->GetGET('id'); $this->AdapterboxMenuSchritte(); $this->app->Tpl->Add('MESSAGE',"
Konfiguration Übertragen.
Anschließend weiter mit Schritt 3.
"); $this->app->Tpl->Set('ID',$id); $this->app->Tpl->Parse('PAGE','adapterbox_schritt2.tpl'); } public function AdapterboxEndgeraet() { $id = $this->app->Secure->GetGET('id'); $submit = $this->app->Secure->GetPOST('submit'); $seriennummer = $this->app->Secure->GetPOST('seriennummer'); $bezeichnung = $this->app->Secure->GetPOST('bezeichnung'); $verwendenals = $this->app->Secure->GetPOST('verwendenals'); $model = $this->app->Secure->GetPOST('model'); $baudrate = $this->app->Secure->GetPOST('baudrate'); $this->AdapterboxMenuSchritte(); if($submit) { $this->app->DB->Update("UPDATE adapterbox SET seriennummer='$seriennummer',verwendenals='$verwendenals',bezeichnung='$bezeichnung',model='$model',baudrate='$baudrate' WHERE id='$id' LIMIT 1"); $iddrucker = $this->app->DB->Select("SELECT id FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' AND art=2 LIMIT 1"); $idseriennummer = $this->app->DB->Select("SELECT COUNT(id) FROM adapterbox WHERE seriennummer='$seriennummer' AND seriennummer!='' LIMIT 1"); //$this->app->Tpl->Set(MESSAGE,"
Die Einstellung wurde gespeichert!
"); if($idseriennummer>=2) { $this->app->Tpl->Set('MESSAGE','
Achtung, es gibt bereits eine Adapterboxen mit der Seriennummer $seriennummer.
'); } if($verwendenals=='' || $verwendenals==='etikettendrucker') { if($iddrucker<=0) { // pruefe ob es namen schon gibt $checkname = $this->app->DB->Select("SELECT id FROM drucker WHERE name LIKE '$bezeichnung' LIMIT 1"); if($checkname <= 0 && $bezeichnung!='' && $seriennummer!='' && $idseriennummer<2) { //drucker anlegen $this->app->DB->Insert("INSERT INTO drucker (id,name,art,adapterboxseriennummer,aktiv,anbindung,firma) VALUES ('','$bezeichnung','2','$seriennummer',1,'adapterbox',1)"); $iddrucker = $this->app->DB->GetInsertID(); $this->app->DB->Update("UPDATE adapterbox SET bezeichnung='$bezeichnung' WHERE id='$id' LIMIT 1"); } else { if($checkname > 0) $this->app->Tpl->Set('MESSAGE',"
Es gibt bereits einen Drucker mit dem gleichen Namen! Bitte wählen Sie einen anderen Namen.
"); else $this->app->Tpl->Set('MESSAGE',"
Bitte füllen Sie alle Felder aus!
"); } } else { if($idseriennummer<2) { $this->app->DB->Update("UPDATE drucker SET name='$bezeichnung' WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' LIMIT 1"); $this->app->DB->Update("UPDATE adapterbox SET bezeichnung='$bezeichnung' WHERE id='$id' LIMIT 1"); } } $standarddrucker = $this->app->erp->Firmendaten('standardetikettendrucker'); $checkstandarddrucker = $this->app->DB->Select("SELECT id FROM drucker WHERE id='$standarddrucker' LIMIT 1"); if($standarddrucker <= 0 || $checkstandarddrucker <=0) { $this->app->erp->FirmendatenSet('standardetikettendrucker',$iddrucker); } $standarddrucker = $this->app->erp->Firmendaten('etikettendrucker_wareneingang'); $checkstandarddrucker = $this->app->DB->Select("SELECT id FROM drucker WHERE id='$standarddrucker' LIMIT 1"); if($standarddrucker <= 0 || $checkstandarddrucker <=0) { $this->app->erp->FirmendatenSet('etikettendrucker_wareneingang',$iddrucker); } } // pruefe ob es einen standard etikettendrucker gibt wenn nicht lege ihn an } $verwendenals = $this->app->DB->Select("SELECT verwendenals FROM adapterbox WHERE id='$id' LIMIT 1"); $baudrate = $this->app->DB->Select("SELECT baudrate FROM adapterbox WHERE id='$id' LIMIT 1"); $model = $this->app->DB->Select("SELECT model FROM adapterbox WHERE id='$id' LIMIT 1"); if($idseriennummer<2) { $seriennummer = $this->app->DB->Select("SELECT seriennummer FROM adapterbox WHERE id='$id' LIMIT 1"); } else { $seriennummer=''; } $this->app->Tpl->Add('MESSAGE',"
Druckerbezeichnung frei vergeben und Seriennummer der Adapterbox eintragen. Dann einmal Speichern drücken und auf den Reiter \"Schritt 4 - Demo\" wechseln. Bzw. auf die Übersicht gehen und prüfen ob die Adapterbox vom Status auf \"connected\" wechselt.
"); $iddrucker = $this->app->DB->Select("SELECT id FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' AND art=2 LIMIT 1"); if($iddrucker > 0 && ($verwendenals=='' || $verwendenals==='etikettendrucker')) { $name_drucker = $this->app->DB->Select("SELECT name FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND art=2 LIMIT 1"); //$this->app->Tpl->Add(MESSAGE,"
Nach dem Anstecken kann es ca. 1-2 Minuten dauern bis die ersten Testetiketten aus dem Drucker kommen.
"); $this->app->Tpl->Add('MESSAGE',"
Einen Testdruck (kann das erste Mal einige Sekunden dauern) durchführen oder das Etikettenformat (Menüpunkt Drucker) einstellen.
"); } else { $name_drucker = $this->app->DB->Select("SELECT bezeichnung FROM adapterbox WHERE id='$id' LIMIT 1"); } $options = ''; $tmp = array('marel'=>'Marel','pce'=>'PCE','sartorius'=>'Sartorius'); foreach($tmp as $key=>$value) { if($key==$model){ $options .= "'; } else{ $options .= "'; } } $this->app->Tpl->Set('MODEL',$options); $options = ""; $tmp = array('1'=>'4800','2'=>'9600'); foreach($tmp as $key=>$value) { if($key==$baudrate){ $options .= "'; } else{ $options .= "'; } } $this->app->Tpl->Set('BAUDRATE',$options); $options = ''; $tmp = array('etikettendrucker'=>'Etikettendrucker','waage'=>'Waage','kamera'=>'Kamera','bondrucker'=>'Bondrucker','display'=>'POS Display','metratecrfid'=>'RFID-Leser','rksvlight'=>'RKSV Light Smartcard'); foreach($tmp as $key=>$value) { if($key==$verwendenals){ $options .= "'; } else{ $options .= "'; } } $this->app->Tpl->Set('VERWENDENALS',$options); $this->app->Tpl->Set('SERIENNUMMER',$seriennummer); $this->app->Tpl->Set('BEZEICHNUNG',$name_drucker); $this->app->Tpl->Set('ID',$id); $this->app->Tpl->Parse('PAGE','adapterbox_endgeraet.tpl'); } public function AdapterboxDownload() { $id = $this->app->Secure->GetGET('id'); $tmp = $this->app->DB->SelectArr("SELECT * FROM adapterbox WHERE id='$id' LIMIT 1"); $url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']; $url_parts = parse_url($url); if (strpos($_SERVER['HTTP_X_FORWARDED_PROTO'], 'https') !== false) $_SERVER['HTTPS']='on'; if(isset($_SERVER['HTTPS'])) { if ($_SERVER['HTTPS'] == 'on') { $secure_connection = true; $url_parts['scheme'] = 'https'; } } if($url_parts['hostname']=='') { if($url_parts['port']!=''){ $url_parts['hostname'] = $url_parts['host'] . ':' . $url_parts['port']; } else{ $url_parts['hostname'] = $url_parts['host']; } } $url_parts['path'] = str_replace('index.php','',$url_parts['path']); $constructed_url = $url_parts['scheme'] . '://' . $url_parts['hostname'] . rtrim($url_parts['path'],'/'); $devicekey = $this->app->erp->Firmendaten('devicekey'); header('Content-type: text/plain'); header('Content-Disposition: attachment; filename=wawision.php'); echo ''; exit; } public function AdapterboxCreate() { $this->app->DB->Insert('INSERT INTO adapterbox (id) VALUES (NULL)'); $id = $this->app->DB->GetInsertID(); header('Location: index.php?module=adapterbox&action=edit&id='.$id); exit; } /** * @return bool */ public function isLoggingActive() { if($this->logging !== null) { return (bool)$this->logging; } $loggingActive = (string)$this->app->erp->GetKonfiguration('adapterbox_logging_active'); if($loggingActive === '') { $this->app->erp->SetKonfigurationValue('adapterbox_logging_active', '0'); $this->logging = false; return false; } $this->logging = (bool)$loggingActive; return $this->logging; } public function AdapterboxList() { $this->AdapterboxMenu(); $isLoggingActive = $this->isLoggingActive(); if($isLoggingActive) { $this->app->Tpl->Set('LOGGINGACTIVE', 'checked'); } $this->app->YUI->AutoSaveKonfiguration('logginActive', 'adapterbox_logging_active'); $devicekey = $this->app->erp->Firmendaten('devicekey'); if($devicekey=='') { $this->app->Tpl->Set('MESSAGE','
Aktuell ist kein API Schlüssel hinterlegt! Für die Adapterboxen benötigen Sie diesen! aktivieren
'); } $deviceenable = $this->app->erp->Firmendaten('deviceenable'); if($deviceenable!='1') { $this->app->Tpl->Add('MESSAGE','
Aktuell ist die API nicht aktiviert! Bitte aktivieren Sie diese! aktivieren
'); } $this->app->YUI->TableSearch('TAB1','adapterbox_list', 'show','','',basename(__FILE__), __CLASS__); $this->app->Tpl->Parse('PAGE','adapterbox_overview.tpl'); } public function AdapterboxDelete() { $id = $this->app->Secure->GetGET('id'); if(is_numeric($id)) { $this->app->DB->Delete("DELETE FROM adapterbox WHERE id='$id'"); } //$this->AdapterboxList(); header('Location: index.php?module=adapterbox&action=list'); exit; } public function AdapterboxMenuSchritte() { $id = $this->app->Secure->GetGET('id'); $data = $this->app->DB->SelectRow("SELECT * FROM adapterbox WHERE id='$id' LIMIT 1"); if(!empty($data)){ $this->app->Tpl->Set('KURZUEBERSCHRIFT1', $data['verwendenals']); $this->app->Tpl->Add('KURZUEBERSCHRIFT2', 'SN: ' . $data['seriennummer']); } $this->app->erp->MenuEintrag("index.php?module=adapterbox&action=edit&id=$id",'Schritt 1 - Netzwerkkonfiguration'); $this->app->erp->MenuEintrag("index.php?module=adapterbox&action=schritt2&id=$id",'Schritt 2 - Konfiguration übertragen'); $this->app->erp->MenuEintrag("index.php?module=adapterbox&action=endgeraet&id=$id",'Schritt 3 - Endgerät einstellen'); $this->app->erp->MenuEintrag("index.php?module=adapterbox&action=demo&id=$id",'Schritt 4 - Demo'); // $this->app->erp->MenuEintrag("index.php?module=adapterbox&action=list","Zurück zur Übersicht"); } public function AdapterboxDemo() { $id = $this->app->Secure->GetGET('id'); $this->AdapterboxMenuSchritte(); $data = $this->app->DB->SelectArr("SELECT * FROM adapterbox WHERE id='$id' LIMIT 1"); $data = reset($data); switch($data['verwendenals']) { case 'waage': $gewicht = $this->app->erp->GetAdapterboxAPIWaage($data['seriennummer']); if($gewicht!=''){ $gewicht="Ergebnis:

"; } $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:

$gewicht"); break; case 'rksvlight': $result = $this->app->erp->GetAdapterboxAPIRKSVlight($data['seriennummer'],"-getcardnumber -reader 0"); if($result!=''){ $result="Ergebnis:

"; } $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:

$result"); break; case 'kamera': $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:
"); break; case 'etikettendrucker': $seriennummer = $data['seriennummer']; $druckercode = $this->app->DB->Select("SELECT id FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' AND art=2 LIMIT 1"); $this->app->erp->EtikettenDrucker("etikettendrucker_einfach",1,"","",array('bezeichnung1'=>'Xentral','bezeichnung2'=>'www.xentral.com'),"",$druckercode); $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:
"); break; case 'display': $seriennummer = $data['seriennummer']; $this->app->erp->GetAdapterboxAPIDisplay($seriennummer,array('Xentral POS','www.xentral.com')); $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:
"); break; case 'bondrucker': $seriennummer = $data['seriennummer']; $druckercode = $this->app->DB->Select("SELECT id FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' AND art=2 LIMIT 1"); $printer = new phpprint(); $printer->newline(); $printer->set_font(phpprint::FONT_A); $printer->set_justification(phpprint::JUSTIFY_CENTER); $printer->enlargePrint(true); $printer->text("Xentral Store\n"); $printer->newline(); $printer->enlargePrint(); $printer->text("Xentral ERP Software GmbH\n"); $printer->text("Fuggerstrasse 11\n"); $printer->text("86150 Augsburg\n"); $printer->text("Tel: 0821/26841041\n"); $printer->text("www.wawision.de\n"); $printer->newline(); $printer->set_justification(phpprint::JUSTIFY_CENTER); $printer->feed(1); $beleg = rand(111111,999999); $printer->qrCode(md5('123456789012345678901234567890'),phpprint::QR_ECLEVEL_L,6); //$printer->generateBarcode($beleg, phpprint::BARCODE_CODE39, 80); $printer->cut(); $printer->pulse(); $bon = base64_encode($printer->str); $this->app->erp->GetAdapterboxAPIBondrucker($seriennummer,$bon); $this->app->Tpl->Set('TAB1',"
Zum Testen bitte klicken:
"); break; } $this->app->Tpl->Parse('PAGE','tabview.tpl'); } public function AdapterboxMenu() { $id = $this->app->Secure->GetGET('id'); //$this->app->Tpl->Add(KURZUEBERSCHRIFT,"Adapterbox"); $this->app->erp->MenuEintrag('index.php?module=adapterbox&action=list','Übersicht'); $this->app->erp->MenuEintrag('index.php?module=adapterbox&action=jobs','Device Jobs'); $this->app->erp->MenuEintrag('index.php?module=adapterbox&action=log','Logs'); //$this->app->erp->MenuEintrag("index.php?module=adapterbox&action=log","Log"); $this->app->erp->MenuEintrag('index.php?module=adapterbox&action=create','Neu'); if($this->app->Secure->GetGET('action')==='list'){ $this->app->erp->MenuEintrag('index.php?module=einstellungen&action=list', 'Zurück zur Übersicht'); } else{ $this->app->erp->MenuEintrag('index.php?module=adapterbox&action=list', 'Zurück zur Übersicht'); } } public function AdapterboxDeletejobs() { $msg = $this->app->erp->base64_url_encode('
Die Jobs wurden gelöscht!
'); $this->app->DB->Delete('DELETE FROM device_jobs'); header('Location: index.php?module=adapterbox&action=jobs&msg='.$msg); exit; } public function AdapterboxDeletejob() { $id = (int)$this->app->Secure->GetGET('id'); $msg = $this->app->erp->base64_url_encode('
Der Job wurde gelöscht!
'); if($id > 0){ $this->app->DB->Delete("DELETE FROM device_jobs WHERE id='$id'"); } header("Location: index.php?module=adapterbox&action=jobs&msg=$msg"); exit; } public function AdapterboxJobs() { $this->AdapterboxMenu(); $this->app->YUI->TableSearch('TAB1','adapterbox_jobs', 'show','','',basename(__FILE__), __CLASS__); $this->app->Tpl->Add('TAB1',"
"); $this->app->Tpl->Parse('PAGE','tabview.tpl'); } public function AdapterboxEdit() { $this->AdapterboxMenuSchritte(); $id = $this->app->Secure->GetGET('id'); $this->app->Tpl->Add('MESSAGE',"
Bitte richten Sie die Netzwerkverbindung an der Adapterbox ein.
Anschließend weiter mit Schritt 2.
"); parent::AdapterboxEdit(); } public function AdapterboxLog() { $this->AdapterboxMenu(); $this->app->DB->Delete("DELETE FROM `adapterbox_log` WHERE id < SELECT MIN(id) FROM `adapterbox_log` ORDER BY id DESC LIMIT 0,100"); $this->app->YUI->TableSearch('TAB1','adapterbox_log', 'show','','',basename(__FILE__), __CLASS__); $this->app->Tpl->Parse('PAGE','tabview.tpl'); } public function AdapterboxDeleteLog() { $id = $this->app->Secure->GetGET('id'); $this->app->DB->Delete("DELETE FROM adapterbox_log WHERE id='$id' LIMIT 1"); $msg = $this->app->erp->base64_url_encode('
Der Logeintrag wurde gelöscht!
'); header("Location: index.php?module=adapterbox&action=log&msg=$msg"); exit; } public function AdapterboxTestbild() { $id = $this->app->Secure->GetGET('id'); $seriennummer = $this->app->DB->Select("SELECT seriennummer FROM adapterbox WHERE id='$id' LIMIT 1"); //$image = $this->app->erp->GetAdapterboxAPIImage($seriennummer,"480","360"); $image = $this->app->erp->GetAdapterboxAPIImage($seriennummer,'800','600'); //$image = $this->app->erp->GetAdapterboxAPIImage("999999999","960","720"); header('Content-Type: image/jpeg'); header('Content-Length: ' .strlen($image) ); echo ($image); exit; } public function AdapterboxTestdruck() { $id = $this->app->Secure->GetGET('id'); $seriennummer = $this->app->DB->Select("SELECT seriennummer FROM adapterbox WHERE id='$id' LIMIT 1"); $druckercode = $this->app->DB->Select("SELECT id FROM drucker WHERE adapterboxseriennummer='$seriennummer' AND adapterboxseriennummer!='' AND art=2 LIMIT 1"); $this->app->erp->EtikettenDrucker('etikettendrucker_einfach',1,'','',array('bezeichnung1'=>'Xentral','bezeichnung2'=>'www.xentral.biz'),'',$druckercode); header('Location: index.php?module=adapterbox&action=endgeraet&id='.$id); exit; } }