Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] HP Drucker Füllstände (Javascript).

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Vorlage] HP Drucker Füllstände (Javascript).

    This topic has been deleted. Only users with topic management privileges can see it.
    • mickym
      mickym Most Active @jensus11 last edited by mickym

      @jensus11
      Hast Du den Code gelesen, werden denn die Datenpunkte angelegt im iobroker, die mit createState erzeugt wurden?
      ==> Ich gehe mal davon aus, da Du nur schreibst das keine Werte angezeigt werden
      Du sagst das keine Werte geliefert werden?
      ==> Stimmt nicht, denn unter Deiner XML Datei kann man die Werte ja sehen (wie gesagt pack es bitte in Code-Tags)

      Ich bedien mich mal hier von @Glasfaser mit der tollen Illustration. 🙂

      Code-Tags.gif

      Ansonsten musst Du halt zu Debug-Zwecken mal ins Log schreiben.

      In der Schleife nach:

      let node = json['ccdyn:ConsumableConfigDyn']['ccdyn:ConsumableInfo'][i];
      

      könntest Du ja mal prüfen, ob das NodeObjekt sauber ausgelesen wird.

      also nach der Zeile

      let ConsumablePercentageLevelRemaining = node['dd:ConsumablePercentageLevelRemaining'];
      

      ein

      console.log(ConsumablePercentageLevelRemaining);
      

      Dann natürlich im LOG schauen, ob die Werte dort geschrieben werden.

      dann weisst Du

      1. die Daten kommen an und werden sauber ausgeslesen
      2. ggf. nur ein Problem mit dem Schreiben der Daten aber wo
      J 1 Reply Last reply Reply Quote 0
      • J
        jensus11 @mickym last edited by jensus11

        @mickym
        ja den Code habe ich gelesen und die Datenpunkte werden angelegt nur hallt nicht ausgefüllt. Steht halt überall NULL.

        This XML file does not appear to have any style information associated with it. The document tree is shown below.
        <!--
         THIS DATA SUBJECT TO DISCLAIMER(S) INCLUDED WITH THE PRODUCT OF ORIGIN. 
        -->
        <ccdyn:ConsumableConfigDyn xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:dd="http://www.hp.com/schemas/imaging/con/dictionaries/1.0/" xmlns:ccdyn="http://www.hp.com/schemas/imaging/con/ledm/consumableconfigdyn/2007/11/19" xsi:schemaLocation="http://www.hp.com/schemas/imaging/con/dictionaries/1.0/ dd/DataDictionaryMasterLEDM.xsd http://www.hp.com/schemas/imaging/con/ledm/consumableconfigdyn/2007/11/19 ConsumableConfigDyn.xsd">
        <dd:Version>
        <dd:Revision>SVN-IPG-LEDM.1103</dd:Revision>
        </dd:Version>
        <ccdyn:ProductConsumableInfo>
        <dd:NumOfUserReplaceableConsumables>4</dd:NumOfUserReplaceableConsumables>
        <dd:NumOfNonUserReplaceableConsumables>0</dd:NumOfNonUserReplaceableConsumables>
        <ccdyn:AtVeryLowSettings>
        <ccdyn:ConsumableSetting>
        <dd:ConsumableLabelCode>K</dd:ConsumableLabelCode>
        <dd:ConsumableStateAction>continue</dd:ConsumableStateAction>
        </ccdyn:ConsumableSetting>
        <ccdyn:ConsumableSetting>
        <dd:ConsumableLabelCode>CMY</dd:ConsumableLabelCode>
        <dd:ConsumableStateAction>continue</dd:ConsumableStateAction>
        </ccdyn:ConsumableSetting>
        </ccdyn:AtVeryLowSettings>
        <dd:StoreUsageData>disabled</dd:StoreUsageData>
        <ccdyn:GenuineHPSuppliesOnly>disabled</ccdyn:GenuineHPSuppliesOnly>
        </ccdyn:ProductConsumableInfo>
        <ccdyn:ConsumableInfo>
        <dd:Capacity>
        <dd:MaxCapacity>13</dd:MaxCapacity>
        <dd:Unit>100ImpressionsAt5PercentCoverage</dd:Unit>
        </dd:Capacity>
        <dd:CartridgeModelInformation>6600</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0087</dd:CartridgeModelLife>
        <dd:ConsumableFamilyName>Black toner supply</dd:ConsumableFamilyName>
        <dd:ConsumableLabelCode>K</dd:ConsumableLabelCode>
        <dd:ConsumableLastUsedDate>2021-07-03</dd:ConsumableLastUsedDate>
        <dd:ConsumableLifeState>
        <dd:ConsumableState>ok</dd:ConsumableState>
        <dd:MeasuredQuantityState>ok</dd:MeasuredQuantityState>
        <dd:Brand>HP</dd:Brand>
        </dd:ConsumableLifeState>
        <dd:ConsumableLowThreshold>10</dd:ConsumableLowThreshold>
        <dd:ConsumablePercentageLevelRemaining>70</dd:ConsumablePercentageLevelRemaining>
        <dd:ConsumableReplaceabilityType>userReplaceable</dd:ConsumableReplaceabilityType>
        <dd:ConsumableSelectibilityNumber>207A</dd:ConsumableSelectibilityNumber>
        <dd:ConsumableStation>0</dd:ConsumableStation>
        <dd:ConsumableTypeEnum>toner</dd:ConsumableTypeEnum>
        <dd:Installation>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Installation>
        <dd:Manufacturer>
        <dd:Name>HP</dd:Name>
        <dd:Date>2020-09-10</dd:Date>
        </dd:Manufacturer>
        <dd:ProductNumber>W2210A</dd:ProductNumber>
        <dd:SerialNumber>xxxxxxxxx</dd:SerialNumber>
        <dd:ConsumableManufacturingSignature>
        xxxxxxxdced8fe40921648037091df898be8592631e0cc685fa5ca01fb1390d50ee82105c127837acadd887c3b18bd8a14099dc991d668c43400bd3d2effaca896f6d0bf41dbe24d78afbe15ef5054f9d96d7180fa6792fbff830d0bcd785c89a821c8fe7e00a2cad4975a48c1fa7f51041ec34e874cf8097a4780127507c626b2f90fdd1284893c1b12b2409918ee266b8d067d49444cdabdac3a2d61b0f6d3c43cae7035567f99513063e69e0529673fca1df088722f2cdd64
        </dd:ConsumableManufacturingSignature>
        <dd:ConsumableEstimatedPages>
        <dd:ValueInt>1350</dd:ValueInt>
        <dd:PageYieldUnits>ISOPages</dd:PageYieldUnits>
        </dd:ConsumableEstimatedPages>
        <ccdyn:DataCollectionValid>false</ccdyn:DataCollectionValid>
        <ccdyn:PreviousCartridgeData>
        <dd:CartridgeModelInformation>0000</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0000</dd:CartridgeModelLife>
        <dd:ProductNumber/>
        <dd:Manufacturer>
        <dd:Name/>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Manufacturer>
        <dd:SerialNumber>0</dd:SerialNumber>
        <ccdyn:MonoColorRegardlessOfSize>0</ccdyn:MonoColorRegardlessOfSize>
        <ccdyn:EngineTonerRemaining>0</ccdyn:EngineTonerRemaining>
        <ccdyn:DrumLife>0</ccdyn:DrumLife>
        <ccdyn:DeveloperLife>0</ccdyn:DeveloperLife>
        <ccdyn:DeveloperWearLife>0</ccdyn:DeveloperWearLife>
        <ccdyn:EngineTonerRemainingLevelVeryLow>0</ccdyn:EngineTonerRemainingLevelVeryLow>
        <ccdyn:DrumLifeAtVeryLow>0</ccdyn:DrumLifeAtVeryLow>
        <ccdyn:DeveloperLifeAtVeryLow>0</ccdyn:DeveloperLifeAtVeryLow>
        <ccdyn:DeveloperWearLifeAtVeryLow>0</ccdyn:DeveloperWearLifeAtVeryLow>
        <ccdyn:PageCountLetterAreaConvertedAtVeryLow>0</ccdyn:PageCountLetterAreaConvertedAtVeryLow>
        </ccdyn:PreviousCartridgeData>
        </ccdyn:ConsumableInfo>
        <ccdyn:ConsumableInfo>
        <dd:Capacity>
        <dd:MaxCapacity>7</dd:MaxCapacity>
        <dd:Unit>100ImpressionsAt5PercentCoverage</dd:Unit>
        </dd:Capacity>
        <dd:CartridgeModelInformation>6603</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0046</dd:CartridgeModelLife>
        <dd:ConsumableFamilyName>Cyan toner supply</dd:ConsumableFamilyName>
        <dd:ConsumableLabelCode>C</dd:ConsumableLabelCode>
        <dd:ConsumableLastUsedDate>2021-07-03</dd:ConsumableLastUsedDate>
        <dd:ConsumableLifeState>
        <dd:ConsumableState>ok</dd:ConsumableState>
        <dd:MeasuredQuantityState>ok</dd:MeasuredQuantityState>
        <dd:Brand>HP</dd:Brand>
        </dd:ConsumableLifeState>
        <dd:ConsumableLowThreshold>10</dd:ConsumableLowThreshold>
        <dd:ConsumablePercentageLevelRemaining>70</dd:ConsumablePercentageLevelRemaining>
        <dd:ConsumableReplaceabilityType>userReplaceable</dd:ConsumableReplaceabilityType>
        <dd:ConsumableSelectibilityNumber>207A</dd:ConsumableSelectibilityNumber>
        <dd:ConsumableStation>3</dd:ConsumableStation>
        <dd:ConsumableTypeEnum>toner</dd:ConsumableTypeEnum>
        <dd:Installation>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Installation>
        <dd:Manufacturer>
        <dd:Name>HP</dd:Name>
        <dd:Date>2020-09-14</dd:Date>
        </dd:Manufacturer>
        <dd:ProductNumber>W2211A</dd:ProductNumber>
        <dd:SerialNumber>xxxxxxxxx</dd:SerialNumber>
        <dd:ConsumableManufacturingSignature>
        xxxxxxxxxbc2994cbe32689d404d448ef561500d3bd46c62f3d7ce273918abcbc8d56abff56ad514b00ab9ed4b0e938b23e400505f2556c9960eeabc77f4c1c325b4ffc5c1161ca78ac6783957c628b5482a78bdede1f3c58559d952d908430099b078097cc0d6f9e832a400a1295cec7c233bf7d6cac5bde1cbe0d6fe5be010f05756e6852b736f2b12eafba3c0f23cad5ce1a04d784f89801ba5bcd74add3b602ef370250b8cffe3db34feb1e81ec9fd75f997d72d88e7355aed665a7ee
        </dd:ConsumableManufacturingSignature>
        <dd:ConsumableEstimatedPages>
        <dd:ValueInt>700</dd:ValueInt>
        <dd:PageYieldUnits>ISOPages</dd:PageYieldUnits>
        </dd:ConsumableEstimatedPages>
        <ccdyn:DataCollectionValid>false</ccdyn:DataCollectionValid>
        <ccdyn:PreviousCartridgeData>
        <dd:CartridgeModelInformation>0000</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0000</dd:CartridgeModelLife>
        <dd:ProductNumber/>
        <dd:Manufacturer>
        <dd:Name/>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Manufacturer>
        <dd:SerialNumber>0</dd:SerialNumber>
        <ccdyn:MonoColorRegardlessOfSize>0</ccdyn:MonoColorRegardlessOfSize>
        <ccdyn:EngineTonerRemaining>0</ccdyn:EngineTonerRemaining>
        <ccdyn:DrumLife>0</ccdyn:DrumLife>
        <ccdyn:DeveloperLife>0</ccdyn:DeveloperLife>
        <ccdyn:DeveloperWearLife>0</ccdyn:DeveloperWearLife>
        <ccdyn:EngineTonerRemainingLevelVeryLow>0</ccdyn:EngineTonerRemainingLevelVeryLow>
        <ccdyn:DrumLifeAtVeryLow>0</ccdyn:DrumLifeAtVeryLow>
        <ccdyn:DeveloperLifeAtVeryLow>0</ccdyn:DeveloperLifeAtVeryLow>
        <ccdyn:DeveloperWearLifeAtVeryLow>0</ccdyn:DeveloperWearLifeAtVeryLow>
        <ccdyn:PageCountLetterAreaConvertedAtVeryLow>0</ccdyn:PageCountLetterAreaConvertedAtVeryLow>
        </ccdyn:PreviousCartridgeData>
        </ccdyn:ConsumableInfo>
        <ccdyn:ConsumableInfo>
        <dd:Capacity>
        <dd:MaxCapacity>7</dd:MaxCapacity>
        <dd:Unit>100ImpressionsAt5PercentCoverage</dd:Unit>
        </dd:Capacity>
        <dd:CartridgeModelInformation>6602</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0046</dd:CartridgeModelLife>
        <dd:ConsumableFamilyName>Magenta toner supply</dd:ConsumableFamilyName>
        <dd:ConsumableLabelCode>M</dd:ConsumableLabelCode>
        <dd:ConsumableLastUsedDate>2021-07-03</dd:ConsumableLastUsedDate>
        <dd:ConsumableLifeState>
        <dd:ConsumableState>ok</dd:ConsumableState>
        <dd:MeasuredQuantityState>ok</dd:MeasuredQuantityState>
        <dd:Brand>HP</dd:Brand>
        </dd:ConsumableLifeState>
        <dd:ConsumableLowThreshold>10</dd:ConsumableLowThreshold>
        <dd:ConsumablePercentageLevelRemaining>70</dd:ConsumablePercentageLevelRemaining>
        <dd:ConsumableReplaceabilityType>userReplaceable</dd:ConsumableReplaceabilityType>
        <dd:ConsumableSelectibilityNumber>207A</dd:ConsumableSelectibilityNumber>
        <dd:ConsumableStation>2</dd:ConsumableStation>
        <dd:ConsumableTypeEnum>toner</dd:ConsumableTypeEnum>
        <dd:Installation>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Installation>
        <dd:Manufacturer>
        <dd:Name>HP</dd:Name>
        <dd:Date>2020-09-13</dd:Date>
        </dd:Manufacturer>
        <dd:ProductNumber>W2213A</dd:ProductNumber>
        <dd:SerialNumber>xxxxxxxxx</dd:SerialNumber>
        <dd:ConsumableManufacturingSignature>
        xxxxxxxxxcc51a6eb16aa8a4446107dbc62a7c835c273d4fea88c8c4d2f926fe7973e5fa0917d4481856296c4bcf753cb20b3aa839664dbddb824f37e6ad051c5c6e71dbc86411b53f0f5040c0fc30259230323969a3133452ffd2ba38afd29d1f7949a6160e2f8eaa998235a6f95084feebede2dd98af10d4b9d95168b545c4172bcc57e2b77d634395d52fec261254130911227e36ad6d4322301176d588f330fb612ecca88d852f5e291eede135162e76df70e14c69648c0b2c6331e45
        </dd:ConsumableManufacturingSignature>
        <dd:ConsumableEstimatedPages>
        <dd:ValueInt>700</dd:ValueInt>
        <dd:PageYieldUnits>ISOPages</dd:PageYieldUnits>
        </dd:ConsumableEstimatedPages>
        <ccdyn:DataCollectionValid>false</ccdyn:DataCollectionValid>
        <ccdyn:PreviousCartridgeData>
        <dd:CartridgeModelInformation>0000</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0000</dd:CartridgeModelLife>
        <dd:ProductNumber/>
        <dd:Manufacturer>
        <dd:Name/>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Manufacturer>
        <dd:SerialNumber>0</dd:SerialNumber>
        <ccdyn:MonoColorRegardlessOfSize>0</ccdyn:MonoColorRegardlessOfSize>
        <ccdyn:EngineTonerRemaining>0</ccdyn:EngineTonerRemaining>
        <ccdyn:DrumLife>0</ccdyn:DrumLife>
        <ccdyn:DeveloperLife>0</ccdyn:DeveloperLife>
        <ccdyn:DeveloperWearLife>0</ccdyn:DeveloperWearLife>
        <ccdyn:EngineTonerRemainingLevelVeryLow>0</ccdyn:EngineTonerRemainingLevelVeryLow>
        <ccdyn:DrumLifeAtVeryLow>0</ccdyn:DrumLifeAtVeryLow>
        <ccdyn:DeveloperLifeAtVeryLow>0</ccdyn:DeveloperLifeAtVeryLow>
        <ccdyn:DeveloperWearLifeAtVeryLow>0</ccdyn:DeveloperWearLifeAtVeryLow>
        <ccdyn:PageCountLetterAreaConvertedAtVeryLow>0</ccdyn:PageCountLetterAreaConvertedAtVeryLow>
        </ccdyn:PreviousCartridgeData>
        </ccdyn:ConsumableInfo>
        <ccdyn:ConsumableInfo>
        <dd:Capacity>
        <dd:MaxCapacity>7</dd:MaxCapacity>
        <dd:Unit>100ImpressionsAt5PercentCoverage</dd:Unit>
        </dd:Capacity>
        <dd:CartridgeModelInformation>6601</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0046</dd:CartridgeModelLife>
        <dd:ConsumableFamilyName>Yellow toner supply</dd:ConsumableFamilyName>
        <dd:ConsumableLabelCode>Y</dd:ConsumableLabelCode>
        <dd:ConsumableLastUsedDate>2021-07-03</dd:ConsumableLastUsedDate>
        <dd:ConsumableLifeState>
        <dd:ConsumableState>ok</dd:ConsumableState>
        <dd:MeasuredQuantityState>ok</dd:MeasuredQuantityState>
        <dd:Brand>HP</dd:Brand>
        </dd:ConsumableLifeState>
        <dd:ConsumableLowThreshold>10</dd:ConsumableLowThreshold>
        <dd:ConsumablePercentageLevelRemaining>60</dd:ConsumablePercentageLevelRemaining>
        <dd:ConsumableReplaceabilityType>userReplaceable</dd:ConsumableReplaceabilityType>
        <dd:ConsumableSelectibilityNumber>207A</dd:ConsumableSelectibilityNumber>
        <dd:ConsumableStation>1</dd:ConsumableStation>
        <dd:ConsumableTypeEnum>toner</dd:ConsumableTypeEnum>
        <dd:Installation>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Installation>
        <dd:Manufacturer>
        <dd:Name>HP</dd:Name>
        <dd:Date>2020-09-12</dd:Date>
        </dd:Manufacturer>
        <dd:ProductNumber>W2212A</dd:ProductNumber>
        <dd:SerialNumber>xxxxxxxxx</dd:SerialNumber>
        <dd:ConsumableManufacturingSignature>
        xxxxxxxxx4878c48c0f92b3aeca01af66a0258308eccc50ad3af56d588b5e037a9f63ce79cee6ac1f03a913ce2614e0005261637dbe8d714a0f1919314842410f45591656b2d8fecc3480a1be0a3224cfc811bddbc1a36cf7954129203a002e6fd45de72f256279555f50648886fe0a5f5f57046a33c5ddbf89ad03ce8ba0e652a55cf4a8639e518cbe9892293a41a7d6683caa969013b3c66dc57420f765a622fa97c70b6ffa82af56624db922353de534f1e504600c498c6befb340bf0133
        </dd:ConsumableManufacturingSignature>
        <dd:ConsumableEstimatedPages>
        <dd:ValueInt>700</dd:ValueInt>
        <dd:PageYieldUnits>ISOPages</dd:PageYieldUnits>
        </dd:ConsumableEstimatedPages>
        <ccdyn:DataCollectionValid>false</ccdyn:DataCollectionValid>
        <ccdyn:PreviousCartridgeData>
        <dd:CartridgeModelInformation>0000</dd:CartridgeModelInformation>
        <dd:CartridgeModelLife>0000</dd:CartridgeModelLife>
        <dd:ProductNumber/>
        <dd:Manufacturer>
        <dd:Name/>
        <dd:Date>1976-01-01</dd:Date>
        </dd:Manufacturer>
        <dd:SerialNumber>0</dd:SerialNumber>
        <ccdyn:MonoColorRegardlessOfSize>0</ccdyn:MonoColorRegardlessOfSize>
        <ccdyn:EngineTonerRemaining>0</ccdyn:EngineTonerRemaining>
        <ccdyn:DrumLife>0</ccdyn:DrumLife>
        <ccdyn:DeveloperLife>0</ccdyn:DeveloperLife>
        <ccdyn:DeveloperWearLife>0</ccdyn:DeveloperWearLife>
        <ccdyn:EngineTonerRemainingLevelVeryLow>0</ccdyn:EngineTonerRemainingLevelVeryLow>
        <ccdyn:DrumLifeAtVeryLow>0</ccdyn:DrumLifeAtVeryLow>
        <ccdyn:DeveloperLifeAtVeryLow>0</ccdyn:DeveloperLifeAtVeryLow>
        <ccdyn:DeveloperWearLifeAtVeryLow>0</ccdyn:DeveloperWearLifeAtVeryLow>
        <ccdyn:PageCountLetterAreaConvertedAtVeryLow>0</ccdyn:PageCountLetterAreaConvertedAtVeryLow>
        </ccdyn:PreviousCartridgeData>
        </ccdyn:ConsumableInfo>
        </ccdyn:ConsumableConfigDyn>
        
        mickym 1 Reply Last reply Reply Quote 0
        • J
          jensus11 last edited by

          Bildschirmfoto 2021-07-04 um 12.46.10.png

          1 Reply Last reply Reply Quote 0
          • mickym
            mickym Most Active @jensus11 last edited by mickym

            @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:

            a19246f3-d688-4279-9953-e73f1a6fab6e-image.png

            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);
            
            1 Reply Last reply Reply Quote 0
            • J
              jensus11 last edited by

              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();
              });
              
              
              mickym 1 Reply Last reply Reply Quote 0
              • mickym
                mickym Most Active @jensus11 last edited by mickym

                @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.

                J 1 Reply Last reply Reply Quote 0
                • J
                  jensus11 @mickym last edited by

                  @mickym

                  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
                  
                  Latzi 1 Reply Last reply Reply Quote 0
                  • J
                    jensus11 last edited by

                    Bildschirmfoto 2021-07-04 um 13.53.06.png

                    fehlt da was?

                    mickym 1 Reply Last reply Reply Quote 0
                    • mickym
                      mickym Most Active @jensus11 last edited by

                      @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.

                      J 1 Reply Last reply Reply Quote 0
                      • Latzi
                        Latzi @jensus11 last edited by

                        @jensus11
                        nimm mal das schedule raus und Ruf nur die Funktion auf

                        J 1 Reply Last reply Reply Quote 0
                        • J
                          jensus11 @Latzi last edited by

                          @latzi wie sieht das dann aus? der meckert dann wegen Klammern und so.

                          Latzi 1 Reply Last reply Reply Quote 0
                          • J
                            jensus11 @mickym last edited by

                            @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?

                            mickym 1 Reply Last reply Reply Quote 0
                            • mickym
                              mickym Most Active @jensus11 last edited by

                              @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.

                              1 Reply Last reply Reply Quote 0
                              • Latzi
                                Latzi @jensus11 last edited by

                                jensus11
                                nur
                                GetData();
                                Rest auskommentieren

                                1 Reply Last reply Reply Quote 0
                                • J
                                  jensus11 last edited by

                                  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?

                                  mickym 1 Reply Last reply Reply Quote 0
                                  • mickym
                                    mickym Most Active @jensus11 last edited by

                                    @jensus11

                                    Mach das halt wie ich gesagt habe:

                                    */30 * * * *
                                    

                                    damit sollte er dann alle 30 Minuten abfragen.

                                    1 Reply Last reply Reply Quote 0
                                    • J
                                      jensus11 last edited by

                                      so werde ich es erstmal machen. Danke für die Unterstützung

                                      1 Reply Last reply Reply Quote 0
                                      • C
                                        Clown007 @Christian 4 last edited by

                                        @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();
                                        });
                                         
                                        
                                        Dolomiti 1 Reply Last reply Reply Quote 0
                                        • Dolomiti
                                          Dolomiti @Clown007 last edited by Dolomiti

                                          @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.

                                          HP.png

                                          </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>
                                          
                                          C 3 Replies Last reply Reply Quote 0
                                          • C
                                            Clown007 @Dolomiti last edited by

                                            @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 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            451
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            9
                                            52
                                            3676
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo