NEWS
[Vorlage] HP Drucker Füllstände (Javascript).
-
-
@jensus11 sagte in [Vorlage] HP Drucker Füllstände (Javascript).:
This XML file does not appear to have any style information associated with it. The document tree is shown below.
Ich habe Deine Datei gerade mal mit NodeRed und dem XML Parser bearbeitet sieht die Struktur gut aus:
Wie gesagt - mach mal den console.log Befehl in das Script um zu sehen, ob die Variable ausgelesen wird.
Ich gehe mal davon aus, dass Du die XML Datei aus dem Browser rauskopiert hast.
Hast Du denn überhaupt mal geprüft, ob Dein request im script funktioniert?
Denke mal die URL wirst Du angepasst haben.Mach doch mal hinter:
request(url, function (error, response, body) {
in die nächste Zeile ein
console.log('error: ' + error + '; response: ' + response);
-
die URL habe ich im Skript angepasst, kopiert und im Browser geöffnet, sowie dann den Inhalt hier gepostet.
Anbei mein Skript nochmal. Fehler oder sonst was erhalte ich im Log nicht.
/** * Read informations from HP Printers; * 2021-04-16 @ TheAlphaGhost; */ var url = 'http://10.1.50.104/DevMgmt/ConsumableConfigDyn.xml'; var request = require('request'); var parseString = require('xml2js').parseString; // Create datapoints; createState('Drucker.HP.M283fdw.Black.ConsumableFamilyName'); createState('Drucker.HP.M283fdw.Black.ConsumableLabelCode'); createState('Drucker.HP.M283fdw.Black.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M283fdw.Black.ProductNumber'); createState('Drucker.HP.M283fdw.Cyan.ConsumableFamilyName'); createState('Drucker.HP.M283fdw.Cyan.ConsumableLabelCode'); createState('Drucker.HP.M283fdw.Cyan.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M283fdw.Cyan.ProductNumber'); createState('Drucker.HP.M283fdw.Magenta.ConsumableFamilyName'); createState('Drucker.HP.M283fdw.Magenta.ConsumableLabelCode'); createState('Drucker.HP.M283fdw.Magenta.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M283fdw.Magenta.ProductNumber'); createState('Drucker.HP.M283fdw.Yellow.ConsumableFamilyName'); createState('Drucker.HP.M283fdw.Yellow.ConsumableLabelCode'); createState('Drucker.HP.M283fdw.Yellow.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M283fdw.Yellow.ProductNumber'); function GetData() { request(url, function (error, response, body) { console.log('error: ' + error + '; response: ' + response); var xml, result; parseString(body, function (err, result) { xml = JSON.stringify(result); var json = JSON.parse(xml); for (var i in json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo']) { let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i]; let ConsumableFamilyName = node['dd:ConsumableFamilyName']; let ConsumableLabelCode = node['dd:ConsumableLabelCode']; let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining']; console.log(ConsumablePercentageLevelRemaining); let ProductNumber = node['dd:ProductNumber']; var ColorDataPoint = ""; switch (String(ConsumableLabelCode)) { case "K": ColorDataPoint = "Black"; break; case "C": ColorDataPoint = "Cyan"; break; case "M": ColorDataPoint = "Magenta"; break; case "Y": ColorDataPoint = "Yellow"; break; case "CMYK": continue; break; default: continue; log("[ERROR] ColorDataPoint not found for " + ConsumableLabelCode + "!"); }; setState('javascript.0.Drucker.HP.M283fdw.' + ColorDataPoint + '.ConsumableFamilyName', ConsumableFamilyName); setState('javascript.0.Drucker.HP.M283fdw.' + ColorDataPoint + '.ConsumableLabelCode', ConsumableLabelCode); setState('javascript.0.Drucker.HP.M283fdw.' + ColorDataPoint + '.ConsumablePercentageLevelRemaining', ConsumablePercentageLevelRemaining); setState('javascript.0.Drucker.HP.M283fdw.' + ColorDataPoint + '.ProductNumber', ProductNumber); }; }); }); }; schedule("42 23 * * *", function () { GetData(); });
-
@jensus11 Nachdem Du nun die beiden console.log Befehle eingebaut hast, solltest Du doch nun was im Log sehen. Eine Info zu den Konsolen ausgaben.
Kannst Du das mal in CodeTags posten.
-
das ist das einzige was da steht.
javascript.0 2021-07-04 13:46:25.373 info script.js.Visualisierung.HP_Druckerfüllstand: registered 0 subscriptions and 1 schedule javascript.0 2021-07-04 13:46:25.318 info Start javascript script.js.Visualisierung.HP_Druckerfüllstand javascript.0 2021-07-04 13:46:25.305 info Stop script script.js.Visualisierung.HP_Druckerfüllstand
-
fehlt da was?
-
@jensus11 Aus meiner Sicht da die Module die in dem Script requestet wurden ja drin sind.
Was mir spanisch vorkommt, ist der Schedule - als ob er nur abends ausgeführt wird.
Gibt doch mal in Deinem Script
*/15 * * * *
beim Scheduler ein und warte mal 15 Minuten ob das Script dann ausgeführt wird.
-
@jensus11
nimm mal das schedule raus und Ruf nur die Funktion auf -
@latzi wie sieht das dann aus? der meckert dann wegen Klammern und so.
-
@mickym sagte in [Vorlage] HP Drucker Füllstände (Javascript).:
Was mir spanisch vorkommt, ist der Schedule - als ob er nur abends ausgeführt wird.
Beim Starten müsste es ja trotzdem ausgeführt werden oder?
-
@jensus11 sagte in [Vorlage] HP Drucker Füllstände (Javascript).:
@mickym sagte in [Vorlage] HP Drucker Füllstände (Javascript).:
Was mir spanisch vorkommt, ist der Schedule - als ob er nur abends ausgeführt wird.
Beim Starten müsste es ja trotzdem ausgeführt werden oder?
Nun er sagt ja den Scheduler ist gestartet und wenn ich das richtig interpretiere, wird es genau 1 mal täglich um 23:42 ausgeführt.
-
jensus11
nur
GetData();
Rest auskommentieren -
2021-07-04 14:15:00.130 - info: javascript.0 (28334) script.js.Visualisierung.HP_Druckerfüllstand: ['70'] 2021-07-04 14:15:00.133 - info: javascript.0 (28334) script.js.Visualisierung.HP_Druckerfüllstand: ['70'] 2021-07-04 14:15:00.133 - info: javascript.0 (28334) script.js.Visualisierung.HP_Druckerfüllstand: ['70'] 2021-07-04 14:15:00.133 - info: javascript.0 (28334) script.js.Visualisierung.HP_Druckerfüllstand: ['60']
Es lag an diesem Scheduler, hätte ich nicht gedacht.
Da der Drucker ja nicht immer an ist, weiss ich nicht genau wie ich die Abfrage einstellen sollte.
Wäre es möglich das zum Drucker immer ein ping alle 30min gesendet wird und wenn der erreichbar ist wird das Script gestartet?
-
Mach das halt wie ich gesagt habe:
*/30 * * * *
damit sollte er dann alle 30 Minuten abfragen.
-
so werde ich es erstmal machen. Danke für die Unterstützung
-
@christian-4 Vielen Dank für Dein tolles Script. Ich habe es mal mal schnell für Farbpatronen erweitert.
Funktioniert mit meinem HP ENVY Pro 6400 einwandfrei./** * Read informations from HP Printers; * 2021-04-16 @ TheAlphaGhost; */ var url = 'http://HP983B82.fritz.box/DevMgmt/ConsumableConfigDyn.xml'; var request = require('request'); var parseString = require('xml2js').parseString; // Create datapoints; createState('Drucker.HP.983B82.Black.ConsumableFamilyName'); createState('Drucker.HP.983B82.Black.ConsumableLabelCode'); createState('Drucker.HP.983B82.Black.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Black.ProductNumber'); createState('Drucker.HP.983B82.Cyan.ConsumableFamilyName'); createState('Drucker.HP.983B82.Cyan.ConsumableLabelCode'); createState('Drucker.HP.983B82.Cyan.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Cyan.ProductNumber'); createState('Drucker.HP.983B82.Magenta.ConsumableFamilyName'); createState('Drucker.HP.983B82.Magenta.ConsumableLabelCode'); createState('Drucker.HP.983B82.Magenta.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Magenta.ProductNumber'); createState('Drucker.HP.983B82.Yellow.ConsumableFamilyName'); createState('Drucker.HP.983B82.Yellow.ConsumableLabelCode'); createState('Drucker.HP.983B82.Yellow.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Yellow.ProductNumber'); createState('Drucker.HP.983B82.CMY.ConsumableFamilyName'); createState('Drucker.HP.983B82.CMY.ConsumableLabelCode'); createState('Drucker.HP.983B82.CMY.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.CMY.ProductNumber'); function GetData() { request(url, function (error, response, body) { var xml, result; parseString(body, function (err, result) { xml = JSON.stringify(result); var json = JSON.parse(xml); for (var i in json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo']) { let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i]; let ConsumableFamilyName = node['dd:ConsumableFamilyName']; let ConsumableLabelCode = node['dd:ConsumableLabelCode']; let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining']; let ProductNumber = node['dd:ProductNumber']; var ColorDataPoint = ""; log("[Test] ConsumableLabelCode " + String(ConsumableLabelCode) + " -> ConsumablePercentageLevelRemaining" + ConsumablePercentageLevelRemaining) ; switch (String(ConsumableLabelCode)) { case "K": ColorDataPoint = "Black"; break; case "C": ColorDataPoint = "Cyan"; break; case "M": ColorDataPoint = "Magenta"; break; case "Y": ColorDataPoint = "Yellow"; break; case "CMY": ColorDataPoint = "CMY"; break; case "CMYK": continue; break; default: continue; log("[ERROR] ColorDataPoint not found for " + ConsumableLabelCode + "!"); }; setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumableFamilyName', ConsumableFamilyName); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumableLabelCode', ConsumableLabelCode); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumablePercentageLevelRemaining', ConsumablePercentageLevelRemaining); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ProductNumber', ProductNumber); }; }); }); }; schedule("42 23 * * *", function () { GetData(); });
-
@Christian-4
Habe dein Skript 1:1 kopiert und nur IP & Druckernamen angepasst./** * Read informations from HP Printers; * 2021-04-16 @ TheAlphaGhost; */ var url = 'http://192.168.1.118/DevMgmt/ConsumableConfigDyn.xml'; var request = require('request'); var parseString = require('xml2js').parseString; // Create datapoints; createState('Drucker.HP.M277dw.Black.ConsumableFamilyName'); createState('Drucker.HP.M277dw.Black.ConsumableLabelCode'); createState('Drucker.HP.M277dw.Black.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M277dw.Black.ProductNumber'); createState('Drucker.HP.M277dw.Cyan.ConsumableFamilyName'); createState('Drucker.HP.M277dw.Cyan.ConsumableLabelCode'); createState('Drucker.HP.M277dw.Cyan.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M277dw.Cyan.ProductNumber'); createState('Drucker.HP.M277dw.Magenta.ConsumableFamilyName'); createState('Drucker.HP.M277dw.Magenta.ConsumableLabelCode'); createState('Drucker.HP.M277dw.Magenta.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M277dw.Magenta.ProductNumber'); createState('Drucker.HP.M277dw.Yellow.ConsumableFamilyName'); createState('Drucker.HP.M277dw.Yellow.ConsumableLabelCode'); createState('Drucker.HP.M277dw.Yellow.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.M277dw.Yellow.ProductNumber'); function GetData() { request(url, function (error, response, body) { var xml, result; parseString(body, function (err, result) { xml = JSON.stringify(result); var json = JSON.parse(xml); for (var i in json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo']) { let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i]; let ConsumableFamilyName = node['dd:ConsumableFamilyName']; let ConsumableLabelCode = node['dd:ConsumableLabelCode']; let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining']; let ProductNumber = node['dd:ProductNumber']; var ColorDataPoint = ""; switch (String(ConsumableLabelCode)) { case "K": ColorDataPoint = "Black"; break; case "C": ColorDataPoint = "Cyan"; break; case "M": ColorDataPoint = "Magenta"; break; case "Y": ColorDataPoint = "Yellow"; break; case "CMYK": continue; break; default: continue; log("[ERROR] ColorDataPoint not found for " + ConsumableLabelCode + "!"); }; log(ConsumablePercentageLevelRemaining); setState('javascript.0.Drucker.HP.M277dw.' + ColorDataPoint + '.ConsumableFamilyName', ConsumableFamilyName); setState('javascript.0.Drucker.HP.M277dw.' + ColorDataPoint + '.ConsumableLabelCode', ConsumableLabelCode); setState('javascript.0.Drucker.HP.M277dw.' + ColorDataPoint + '.ConsumablePercentageLevelRemaining', ConsumablePercentageLevelRemaining); setState('javascript.0.Drucker.HP.M277dw.' + ColorDataPoint + '.ProductNumber', ProductNumber); }; }); }); }; schedule('*/1 * * * *', function () { GetData(); });
Allerdings steht bei mir in den DP´s die Werte in eckigen Klammern und Hochkomma. So funktioniert meine Anzeige natürlich nicht. Kann mir einer auf die Sprünge helfen. Das XML sieht ok aus.
</dd:ConsumableStateAvailableActions> <dd:ConsumableLowThreshold>5</dd:ConsumableLowThreshold> <dd:ConsumablePercentageLevelRemaining>70</dd:ConsumablePercentageLevelRemaining> <dd:ConsumableReplaceabilityType>userReplaceable</dd:ConsumableReplaceabilityType> <dd:ConsumableSelectibilityNumber>201A</dd:ConsumableSelectibilityNumber> <dd:ConsumableTypeEnum>toner</dd:ConsumableTypeEnum>
-
@dolomiti Okay, dann entfernen wir diese Zeichen einfach:
/** * Read informations from HP Printers; * 2021-04-16 @ TheAlphaGhost; */ var url = 'http://HP983B82.fritz.box/DevMgmt/ConsumableConfigDyn.xml'; var request = require('request'); var parseString = require('xml2js').parseString; // Create datapoints; createState('Drucker.HP.983B82.Black.ConsumableFamilyName'); createState('Drucker.HP.983B82.Black.ConsumableLabelCode'); createState('Drucker.HP.983B82.Black.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Black.ProductNumber'); createState('Drucker.HP.983B82.Cyan.ConsumableFamilyName'); createState('Drucker.HP.983B82.Cyan.ConsumableLabelCode'); createState('Drucker.HP.983B82.Cyan.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Cyan.ProductNumber'); createState('Drucker.HP.983B82.Magenta.ConsumableFamilyName'); createState('Drucker.HP.983B82.Magenta.ConsumableLabelCode'); createState('Drucker.HP.983B82.Magenta.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Magenta.ProductNumber'); createState('Drucker.HP.983B82.Yellow.ConsumableFamilyName'); createState('Drucker.HP.983B82.Yellow.ConsumableLabelCode'); createState('Drucker.HP.983B82.Yellow.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.Yellow.ProductNumber'); createState('Drucker.HP.983B82.CMY.ConsumableFamilyName'); createState('Drucker.HP.983B82.CMY.ConsumableLabelCode'); createState('Drucker.HP.983B82.CMY.ConsumablePercentageLevelRemaining'); createState('Drucker.HP.983B82.CMY.ProductNumber'); function GetData() { request(url, function (error, response, body) { var xml, result; parseString(body, function (err, result) { xml = JSON.stringify(result); var json = JSON.parse(xml); for (var i in json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo']) { let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i]; let ConsumableFamilyName = node['dd:ConsumableFamilyName'] let ConsumableLabelCode = node['dd:ConsumableLabelCode']; let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining']; let ProductNumber = node['dd:ProductNumber']; var ColorDataPoint = ""; switch (String(ConsumableLabelCode)) { case "K": ColorDataPoint = "Black"; break; case "C": ColorDataPoint = "Cyan"; break; case "M": ColorDataPoint = "Magenta"; break; case "Y": ColorDataPoint = "Yellow"; break; case "CMY": ColorDataPoint = "CMY"; break; case "CMYK": continue; break; default: continue; log("[ERROR] ColorDataPoint not found for " + ConsumableLabelCode + "!"); }; ConsumableFamilyName = String(ConsumableFamilyName).replace((/[^*a-zA-Z0-9]/g), ""); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumableFamilyName', String(ConsumableFamilyName).replace((/[^*a-zA-Z0-9]/g), "")); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumableLabelCode', String(ConsumableLabelCode).replace((/[^*a-zA-Z0-9]/g), "")); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ConsumablePercentageLevelRemaining', String(ConsumablePercentageLevelRemaining).replace((/[^*a-zA-Z0-9]/g), "")); setState('javascript.0.Drucker.HP.983B82.' + ColorDataPoint + '.ProductNumber', String(ProductNumber).replace((/[^*a-zA-Z0-9]/g), "")); }; }); }); }; schedule("42 23 * * *", function () { GetData(); })
-
@dolomiti Eine andere Möglichkeit ist übrigens das SNMP Modul. Die entsprechenden OIDs sind bei meinem Drucker:
Farbe: .1.3.6.1.2.1.43.11.1.1.9.1.1
S/W :.1.3.6.1.2.1.43.11.1.1.9.1.2Ich glaube der Status soll auch nicht mehr in javascript.0 sondern in 0_userdata. Aber diese kleine Änderung schaffst Du selber
-
@dolomiti Ich habe das Script jetzt noch mal etwas (für mich) optimiert. In Userdata "umgezogen". Als Drucker reicht es jetzt den FQDN oben zu ändern und ich habe die Stati ohne Funktion entfernt:
/** * Read informations from HP Printers; * 2021-04-16 @ TheAlphaGhost; */ var printername = 'HP983B82.fritz.box'; var url = 'http://' + printername + '/DevMgmt/ConsumableConfigDyn.xml'; var datapointname = printername.split('.')[0]; var request = require('request'); var parseString = require('xml2js').parseString; // Create datapoints; createState('0_userdata.0.Drucker.' + datapointname + '.Black.ConsumableLabelCode'); createState('0_userdata.0.Drucker.' + datapointname + '.Black.ConsumablePercentageLevelRemaining'); createState('0_userdata.0.Drucker.' + datapointname + '.CMY.ConsumableLabelCode'); createState('0_userdata.0.Drucker.' + datapointname + '.CMY.ConsumablePercentageLevelRemaining'); function GetData() { request(url, function (error, response, body) { var xml, result; parseString(body, function (err, result) { xml = JSON.stringify(result); var json = JSON.parse(xml); for (var i in json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo']) { let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i]; let ConsumableFamilyName = node['dd:ConsumableFamilyName'] let ConsumableLabelCode = node['dd:ConsumableLabelCode']; let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining']; let ProductNumber = node['dd:ProductNumber']; var ColorDataPoint = ""; switch (String(ConsumableLabelCode)) { case "K": ColorDataPoint = "Black"; break; case "CMY": ColorDataPoint = "CMY"; break; default: continue; log("[ERROR] ColorDataPoint not found for " + ConsumableLabelCode + "!"); }; setState('0_userdata.0.Drucker.' + datapointname + '.' + ColorDataPoint + '.ConsumableLabelCode', String(ConsumableLabelCode).replace((/[^*a-zA-Z0-9]/g), "")); setState('0_userdata.0.Drucker.' + datapointname + '.' + ColorDataPoint + '.ConsumablePercentageLevelRemaining', String(ConsumablePercentageLevelRemaining).replace((/[^*a-zA-Z0-9]/g), "")); }; }); }); }; schedule("42 23 * * *", function () { GetData(); })