NEWS
[Vorlage] HP Drucker Füllstände (Javascript).
-
@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(); })
-
@clown007 Steilvorlage
Wenn schon SNMP dann aber auch das volle Programm...
1.3.6.1.2.1.43.11.1.1.9.1.1 Farbe 1 (gibt die Anzahl Seiten an die mit der Farbe 1 noch gedruckt werden können)
1.3.6.1.2.1.43.11.1.1.9.1.2 Farbe 2
1.3.6.1.2.1.43.11.1.1.9.1.3 Farbe 3
1.3.6.1.2.1.43.11.1.1.9.1.4 Farbe 4
1.3.6.1.2.1.43.11.1.1.6.1.1 Name Farbe 1 (z.B. Black)
1.3.6.1.2.1.43.11.1.1.6.1.2 Name Farbe 2
1.3.6.1.2.1.43.11.1.1.6.1.3 Name Farbe 3
1.3.6.1.2.1.43.11.1.1.6.1.4 Name Farbe 4
1.3.6.1.2.1.43.11.1.1.8.1.1 Kapazität F1 (Wie viele Seiten können max gedruckt werden)
1.3.6.1.2.1.43.11.1.1.8.1.2 Kapazität F2
1.3.6.1.2.1.43.11.1.1.8.1.3 Kapazität F3
1.3.6.1.2.1.43.11.1.1.8.1.4 Kapazität F4 -
@clown007
Danke für die Anpassung. Ich hatte mir das auch schon überlegt. Meiner Meinung nach konvertiert xml2js nicht richtig.
Im ersten Beispiel wird der Text angezeigt wie erwartet.var parseString = require('xml2js').parseString; var xml = "<aaaa>Ein Text</aaaa>" parseString(xml, function (err, result) { log(result); });
Ergebnis bei mir:
{'aaaa':'Ein Text'}
Ab der zweiten Ebene kommen die eckigen Klammern hinzu
var parseString = require('xml2js').parseString; var xml = "<aaaa><bbbb>Ein Text</bbbb></aaaa>" parseString(xml, function (err, result) { log(result); });
Ergebnis
{'aaaa':{'bbbb':['Ein Text']}}
Bei einem Onlinekonverter wie z.B. hier ist das Ergebnis wie erwartet.
{ "aaaa": { "bbbb": "Ein Text" }, }
Ist dein geparstes Ergebnis auch mit eckigen Klammern? Ich dachte schon, es liegt an meiner ioBroker-Installation mit einer alten oder falschen xml2js, aber in einem neuen Proxmox-Container mit ganz frischem ioBroker ist das Ergebnis das gleiche. Anscheinend macht er bei mir ein Array aus dem einzelnen Wert.
Mit deiner Version läuft es jetzt jedenfalls, aber ich würde das Problem gerne verstehen und nachvollziehen können. -
@amg_666 ... Die OIDs für für Farbe 1-4 sind identisch und gibt mir den % Wert (90)
Name Farbe 1 gibt es bei mir nicht, Farbe 2 ist dann black, Farbe 3 und Farbe 4 gibt es wieder nicht.1.3.6.1.2.1.43.11.1.1.8.1.1 Kapazität F2 ist bei mir 100?
Kapazität 1,3,4 gibt es bei mir nicht.Damit bleibt es bei mir bei den o.g. OIDs
-
@dolomiti sagte in [Vorlage] HP Drucker Füllstände (Javascript).:
xml2js
Ich gebe zu, dass ich es mir einfach gemacht habe, und darüber nicht weiter nachgedacht habe. Eventuell hilft Dir das weiter?
https://www.npmjs.com/package/xml2js -
@clown007 Hab meinen Post korrigiert, da waren copy&paste Fehler drin
Die OID habe ich aus meinem snmp Adapter rauskopiert, damit lese ich meinen Drucker aus, es ist ein Samsung C48x und die Samsung haben normalerweise gleiche OID wie HP, in den Objekten sieht das dann so aus:
Die Werte bei Kapazität z.B. 1000 oder 1500 sagen aus wieviele Kapazität die Farbkartusche hat (wieviele Seiten er in der Farbe drucken kann).
"Name Farbe 1 gibt es bei mir nicht, Farbe 2 ist dann black, Farbe 3 und Farbe 4 gibt es wieder nicht."
Hast du einen Schwarzweiß-Drucker? Dann hast du natürlich nur 1* Farbe und 1* Kapazität -
@amg_666 Ich habe einen Farbdrucker mit einer SW und einer Farbpatrone. Kapazität gibt es aber anscheinend bei HP nicht, nur die Füllstände in %.