Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] ps4-waker/ NPM Modul von Github installieren/ (TV via HDMI CEC einschalten)

    NEWS

    • Amazon Alexa - ioBroker Skill läuft aus ?

    • Monatsrückblick – September 2025

    • Neues Video "KI im Smart Home" - ioBroker plus n8n

    [gelöst] ps4-waker/ NPM Modul von Github installieren/ (TV via HDMI CEC einschalten)

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 last edited by

      @zuldero:

      auch im javascript adpter habe ich "ps4-waker" eingetragen `
      Funktioniert es nicht im Skript ?

      1 Reply Last reply Reply Quote 0
      • Z
        zuldero last edited by

        wie meinst du dass? ich habe eben kein skript. dieses möchte ich ja eben von git downloaden. oder hab ich da was falsch verstanden?

        Gesendet von meinem ONEPLUS A5000 mit Tapatalk

        1 Reply Last reply Reply Quote 0
        • paul53
          paul53 last edited by

          Das ist ein NPM-Modul, dessen Funktionalität Du in einem Skript verwenden kannst. Laut Doku:

          const {Device} = require('ps4-waker');
          
          var ps4 = new Device();
          ps4.turnOn().then(() => ps4.close());
          

          @readme:

          Most methods on the Device object return a Promise and can be used with async/await. The Device will automatically attempt to maintain an active connection to your device until you explicitly close() it or call turnOff(). This will let you issue subsequent commands like .startTitle() or .sendKeys() without seeing the annoying "A companion app has connected/disconnected" messages all the time. `

          1 Reply Last reply Reply Quote 0
          • Z
            zuldero last edited by

            achso jetzt verstehe ich was ein modul ist und macht xD. danke. werde mich jetzt dann noch einarbeiten in demfall (jetzt muss ich wohl endlich mit javascript anfangen, ist ja nichts für blockli oder) ich will jetzt nicht jede kleinigkeit hir fragen. sollte ich nicht weiter kommen melde ich mich 🙂

            Gesendet von meinem ONEPLUS A5000 mit Tapatalk

            1 Reply Last reply Reply Quote 0
            • Stabilostick
              Stabilostick last edited by Stabilostick

              Hi,

              ich habe das Modul ps4-waker einfach in die Konfiguration des javascript-Adapters aufgenommen:

              7446_2018-07-06_20_45_17-instances_-_iobroker.png

              Dieser hat sich anschließend neu gestartet und im ioBroker-Log war das Folgende zu sehen:

              [...]
              018-07-06 20:39:51.745 - info: javascript.0 starting. Version 3.6.4 in C:/dev/iobroker/node_modules/iobroker.javascript, node: v8.11.1
              2018-07-06 20:39:51.749 - info: javascript.0 npm install ps4-waker --production --prefix "C:\dev\iobroker\node_modules\iobroker.javascript" (System call)
              2018-07-06 20:39:54.722 - info: javascript.0 C:\dev\iobroker\node_modules\iobroker.javascript\ps4-waker -> C:\dev\iobroker\node_modules\iobroker.javascript\node_modules\ps4-waker\bin\cmd.js
              2018-07-06 20:39:54.731 - info: javascript.0 + ps4-waker@1.4.3
              added 4 packages from 7 contributors in 1.133s
              2018-07-06 20:39:54.748 - info: javascript.0 requesting all states
              2018-07-06 20:39:54.749 - info: javascript.0 requesting all objects
              [...]
              

              Der javascript-Adapter hat also das ps4-waker-Modul installiert.

              Anschließend ein kleines Testscript im javascript-Adapter:

              const {Device} = require('ps4-waker');
              
              var ps4 = new Device();
              ps4.getDeviceStatus().then((result) => {
                  console.log(JSON.stringify(result, null, 2));
                  ps4.close()}
              );
              

              Das ergibt dann:

              21:14:24.554	[info]	javascript.0 Start javascript script.js.Entwicklung.ps4
              21:14:24.554	[info]	javascript.0 script.js.Entwicklung.ps4: registered 0 subscriptions and 0 schedules
              21:14:24.555	[info]	javascript.0 script.js.Entwicklung.ps4: { "type": "device", "statusLine": "200 Ok", "statusCode": "200", "status": "Ok", "host-id": "00Dxxxxxxx", "host-type": "PS4", "host-name": "PS4", "host-request-port": "997", "device-discovery-protocol-version": "00020020", "system-version": "04550011", "address": "192.168.179.67", "port": "997" }
              21:14:27.263	[info]	javascript.0 Stop script script.js.Entwicklung.ps4
              

              Der javascript-Adapter hat das ps4-waker Modul nach

              [...]/iobroker/node_modules/iobroker.javascript/node_modules/ps4-waker
              

              installiert.

              Dort kann dann mit node ./bin/cmd.js search das gleiche gemacht werden. Der Aufruf von node ./bin/cmd.js müsste zur Credentialseingabe (wenn die PS4 an ist) führen. Das braucht man auch für den obigen API-Aufruf.

              1 Reply Last reply Reply Quote 0
              • Dutchman
                Dutchman Developer Most Active Administrators last edited by

                Dein Log sieht in Ordnung aus, wo liegt jetzt das Problem ?

                Sent from my iPhone using Tapatalk

                1 Reply Last reply Reply Quote 0
                • Z
                  zuldero last edited by

                  das problem lag nur an meiner unwissenheit. danke leute. ich dacht es wird direkt ein snkript erstellt.

                  Gesendet von meinem ONEPLUS A5000 mit Tapatalk

                  1 Reply Last reply Reply Quote 0
                  • Z
                    zuldero last edited by

                    und da bin ich schon wieder

                    wenn die ps aus ist habe ich mit dem code

                    ! const {Device} = require('ps4-waker');
                    ! var ps4 = new Device();
                    ! ps4.getDeviceStatus().then((result) => {
                    ! console.log(JSON.stringify(result, null, 2));
                    ! ps4.close()}
                    ! ); den selben log wie du

                    @Stabilostick:

                    21:14:24.554 [info] javascript.0 Start javascript script.js.Entwicklung.ps4

                    21:14:24.554 [info] javascript.0 script.js.Entwicklung.ps4: registered 0 subscriptions and 0 schedules

                    21:14:24.555 [info] javascript.0 script.js.Entwicklung.ps4: { "type": "device", "statusLine": "200 Ok", "statusCode": "200", "status": "Ok", "host-id": "00D9D1AC3901", "host-type": "PS4", "host-name": "PS4", "host-request-port": "997", "device-discovery-protocol-version": "00020020", "system-version": "04550011", "address": "192.168.179.67", "port": "997" }

                    21:14:27.263 [info] javascript.0 Stop script script.js.Entwicklung.ps4 `
                    wenn die ps an ist, bekomme ich folgenden log:

                    ! javascript.0 2018-07-07 19:37:07.228 info }
                    ! javascript.0 2018-07-07 19:37:07.228 info "port": "997"
                    ! javascript.0 2018-07-07 19:37:07.228 info "address": "192.168.0.16",
                    ! javascript.0 2018-07-07 19:37:07.228 info "system-version": "05550021",
                    ! javascript.0 2018-07-07 19:37:07.228 info "device-discovery-protocol-version": "00020020",
                    ! javascript.0 2018-07-07 19:37:07.228 info "host-request-port": "997",
                    ! javascript.0 2018-07-07 19:37:07.228 info "host-name": "PS4-774",
                    ! javascript.0 2018-07-07 19:37:07.228 info "host-type": "PS4",
                    ! javascript.0 2018-07-07 19:37:07.228 info "host-id": "709E29B77E00",
                    ! javascript.0 2018-07-07 19:37:07.228 info "status": "Ok",
                    ! javascript.0 2018-07-07 19:37:07.228 info "statusCode": "200",
                    ! javascript.0 2018-07-07 19:37:07.228 info "statusLine": "200 Ok",
                    ! javascript.0 2018-07-07 19:37:07.228 info "type": "device",
                    ! javascript.0 2018-07-07 19:37:07.228 info script.js.Skripte.PS4.GET: {
                    ! javascript.0 2018-07-07 19:37:07.219 info script.js.Skripte.PS4.GET: registered 0 subscriptions and 0 schedules
                    soweit so gut.

                    um die ps mit dem befehlen

                    ! exec("ps4-waker standby")
                    ! exec("ps4-waker")
                    zu steuern muss ich sie ja noch "registrieren" also den credentials command im terminal ausführen (sagt ja auch der log in der untersten zeile, oder?).

                    Im terminal bekomme ich aber immer die Rückmeldung

                    ! Device must be awake for initial registration. Please turn it on manually and try again.
                    und dabei spielt es keine rolle ob die ps an oder aus ist.

                    was mache ich falsch? oder bin ich total auf dem holz weg?

                    1 Reply Last reply Reply Quote 0
                    • Stabilostick
                      Stabilostick last edited by Stabilostick

                      Bei mir unter Windows:

                      cd C:\dev\iobroker\node_modules\iobroker.javascript\node_modules\ps4-waker\bin
                      

                      Dort dann

                      node cmd.js --help
                      

                      bringt die Befehlsliste. Dann

                      node cmd.js
                      

                      bringt "Could not detect any matching PS4 device", wenn die PS4 aus ist.

                      node cmd.js search
                      

                      bringt

                      {
                        "type": "device",
                        "statusLine": "200 Ok",
                        "statusCode": "200",
                        "status": "Ok",
                        "host-id": "00Dxxxxxxxxx",
                        "host-type": "PS4",
                        "host-name": "PS4",
                        "host-request-port": "997",
                        "device-discovery-protocol-version": "00020020",
                        "system-version": "0xxxxx011",
                        "address": "192.168.xxxx"
                      }
                      

                      Anschließendes

                      node cmd.js
                      

                      bringt dann

                      Go to 'Settings -> PlayStation(R) App Connection Settings -> Add Device on your PS4 to obtain the PIN code.
                      

                      oder

                      WAKEUP sent to device... 192.168xxxx
                      Logging in..
                      
                      1 Reply Last reply Reply Quote 1
                      • Z
                        zuldero last edited by

                        node cmd.js search sagt mir das die ps4 im standby ist, jedoch ist an. alle weiteren commands sagen mir: Device must be awake for initial registration. Please turn it on manually and try again.
                        7535_unbenannt.png

                        1 Reply Last reply Reply Quote 0
                        • Stabilostick
                          Stabilostick last edited by

                          War bei mir auch so. Ich habe es nach dem Search noch mal gemacht und dann ging es. Da weiß ich leider auch nicht mehr weiter.

                          1 Reply Last reply Reply Quote 0
                          • Stabilostick
                            Stabilostick last edited by

                            Schon mal die Device-Info im Screenschon genauer angesehen? Das ist keine PS4. Das ist der PS4-Waker! Schau die mal meinen Datenblock oben an.

                            1 Reply Last reply Reply Quote 0
                            • Z
                              zuldero last edited by

                              genau das ist ja mein problem. wieso findet er keine ps. er muss die ps ja finden um si mit dem code zu verbinden. worin könnte der fehler liegen?

                              1 Reply Last reply Reply Quote 0
                              • Stabilostick
                                Stabilostick last edited by

                                <ironie on="">Du hast eine relabelte China-PS3?</ironie>

                                1 Reply Last reply Reply Quote 0
                                • Stabilostick
                                  Stabilostick last edited by

                                  "ps4-waker can't see the PS4"

                                  This can have a several possible causes:

                                  *The machine you're running on has multiple network adapters

                                  The system will just "pick" one in this case, and it might not be the one you need. Use the –bind command line option to specify the address of the appropriate adapter. This must be the same adapter that your phone can see (at least for the first run, when getting credentials from the mobile app) as well as the one that can see your PS4.

                                  *Your network is dropping UDP packets

                                  The app needs to be able to send and receive on port 987 and 997 to discover and wake the PS4, and for your phone to discover it in the initial credentials step. Make sure your router is letting these ports through.

                                  Also as part of discovery, ps4-waker listens by default on a random UDP port. If it is having trouble locating the PS4, and you're sure you've bound to the correct adapter using --bind, you may need to pick a port to listen on with --bind-port, and open that up on your router, as well.

                                  *You have multiple PS4s on your network

                                  By default, ps4-waker commands act on the first one they see. To search for every device on your network, add a -t <milliseconds>timeout flag to your command and it will keep waiting. You may also use -d to specify the IP address of a specific machine. Check out the "Device Selection" section of the command help, either here or by running ps4-waker -?.</milliseconds>

                                  1 Reply Last reply Reply Quote 0
                                  • Z
                                    zuldero last edited by

                                    auch hier bekomme ich einen fehler

                                    ! /usr/lib/node_modules/ps4-waker/bin$ node cmd.js –bind -b 192.168.0.16
                                    ! events.js:160
                                    ! throw er; // Unhandled 'error' event
                                    ! ^
                                    ! Error: bind EADDRNOTAVAIL 192.168.0.16
                                    ! at Object.exports._errnoException (util.js:1020:11)
                                    ! at exports._exceptionWithHostPort (util.js:1043:20)
                                    ! at _handle.lookup (dgram.js:219:18)
                                    ! at _combinedTickCallback (internal/process/next_tick.js:83:11)
                                    ! at process._tickCallback (internal/process/next_tick.js:104:9)
                                    ! at Module.runMain (module.js:613:11)
                                    ! at run (bootstrap_node.js:394:7)
                                    ! at startup (bootstrap_node.js:160:9)
                                    ! at bootstrap_node.js:507:3
                                    sorry für meine anfänger getue 😞

                                    was bedeutet dieser strich:| (–bind | -b <ip>)

                                    ist meine eingabe überhaupt richtig (node cmd.js --bind -b 192.168.0.16) (ip der ps4) oder leigt es ev. daran dass ich den iobroker auf nem raspi hab der auf dem 8081 port läuft? ich verstehe das so, dass die ps4 auf den 987 997 ports läuft. und da die app sich verbinden kann sollte sich der ps4-waker auch verbinden können oder?</ip>

                                    1 Reply Last reply Reply Quote 0
                                    • Stabilostick
                                      Stabilostick last edited by Stabilostick

                                      Entweder --bind ODER -b eingeben. Nicht gleichzeitig. 😄

                                      1 Reply Last reply Reply Quote 0
                                      • Z
                                        zuldero last edited by

                                        achso xD so simpel ein trennstrich. an sowas denke ich nicht facepalm

                                        aber trotzdem ich bekomme die selbe fehrlermeldeung.

                                        also so ist schon richtig oder:

                                        /usr/lib/node_modules/ps4-waker/bin$ node cmd.js -b 192.168.0.16

                                        1 Reply Last reply Reply Quote 0
                                        • Stabilostick
                                          Stabilostick last edited by

                                          You may also use -d to specify the IP address of a specific machine.

                                          Du machst -b. Das ist das binden an ein lokales Netzwerkinterface. Mach -d

                                          1 Reply Last reply Reply Quote 0
                                          • Z
                                            zuldero last edited by

                                            Haleluja es klappt 🙂 Danke tausendfach für deine hilfe xD heute hab ich mal wieder einiges gelernt.

                                            sollte irgendwann später jemand das hier lesen, und nach machen wollen. mit der ps second screen app sich autenfizieren hat bei mir nicht funktioniert. ich musste: node cmd.js –pin xxxxxxxx (der pincode muss ohne lehrzeichen eingetippt werden) eintippen.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            835
                                            Online

                                            32.3k
                                            Users

                                            81.1k
                                            Topics

                                            1.3m
                                            Posts

                                            blockly javascript
                                            9
                                            37
                                            7555
                                            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