Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Vorlage] Sony Bravia TV ab 2013

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Sony Bravia TV ab 2013

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

      Coole Sache.

      Das Auslesen meines Fernsehers klappt schon mal.

      Nur die Lautstärke wir am Fernseher als geändert angezeigt, ändert sich aber nicht. Das liegt vermutlich an der angeschlossenen Soundbar von Sonos.

      1 Reply Last reply Reply Quote 0
      • L
        Lucky last edited by

        > Leider läuft das Script bei mir nicht. Nach dem Start kommen im Log diese Fehlermeldungen:

        Speichere das Skript bitte nicht unter Common, sondern in einer extra Gruppe, z.b. "Sony_Bravia" starte dann den Javaskript Adapter neu und versuch es nochmal !

        Was für ein Bravia Modell hast du ?

        > Nur die Lautstärke wir am Fernseher als geändert angezeigt, ändert sich aber nicht. Das liegt vermutlich an der angeschlossenen Soundbar von Sonos.

        ja das ist bei mir auch so, die TV Lautstärker hat nur auswirkungen auf den TV eigenen Lautsprecher, und wirkt nicht auf CEC Geräte !

        Über CEC Steuerung ist in der API auch nicht viel vorhanden 😐

        1 Reply Last reply Reply Quote 0
        • L
          Linedancer last edited by

          Danke für die Rückmeldung.

          Mein Bravia ist ein KDL-55EX505

          Ich habe unter "common" eine Gruppe "Bravia _TV" angelegt in der das Script liegt. Der Neustart des Adapters hat leider an den Fehlermeldungen nix geändert.

          Schade auch.

          Über den upnp Adapter kann ich mit dem Bravia reden, allerdings nur Lautstärke nd Mute.

          1 Reply Last reply Reply Quote 0
          • L
            Lucky last edited by

            speichere bitte nicht unter Common ! lege direkt eine neue Gruppe an !
            2611_sony_skript.jpg

            1 Reply Last reply Reply Quote 0
            • L
              Linedancer last edited by

              Hat leider auch nix geholfen. Immer noch die gleichen Fehler im Log 😞

              1 Reply Last reply Reply Quote 0
              • M
                Mighty last edited by

                Hallo,

                habe auch den 805 und versuche, das Script zum Laufen zu bekommen.

                Wo trage ich die IP ein? Ist das so korrekt?

                createState('javascript.0.Sony_Bravia_VAR.System.IP_Adresse','192.168.2.248',{type: "string", role: "IP Adresse"});

                Original war das so:

                createState('javascript.0.Sony_Bravia_VAR.System.IP_Adresse',{type: "string", role: "IP Adresse"});

                Danke & Grüße Mighty

                1 Reply Last reply Reply Quote 0
                • T
                  tesso last edited by

                  Hallo,

                  ich habe das Skript bei mir im Einsatz. Das Ausschalten des Fernsehers geht über das Setzen der Datenpunktes "Power" auf false. (Kann gerade nicht nachsehen, ob er wirklich so heißt)

                  Kann ich den Fernseher darüber auch wieder einschalten? Das will mir nicht gelingen. Muß ich evtl. am Fernsher noch etwas einstellen?

                  Gibt es vielleicht schon eine neuere Version des Skriptes?

                  1 Reply Last reply Reply Quote 0
                  • M
                    Mighty last edited by

                    @tesso:

                    Hallo,

                    ich habe das Skript bei mir im Einsatz. Das Ausschalten des Fernsehers geht über das Setzen der Datenpunktes "Power" auf false. (Kann gerade nicht nachsehen, ob er wirklich so heißt)

                    Kann ich den Fernseher darüber auch wieder einschalten? Das will mir nicht gelingen. Muß ich evtl. am Fernsher noch etwas einstellen?

                    Gibt es vielleicht schon eine neuere Version des Skriptes? `

                    Hi tesso,

                    wo hast du denn die IP eingetragen und welche Infos muss man dem Skript noch geben? Bekomme es garnicht erst zum Starten. 😞

                    Grüße Mighty

                    1 Reply Last reply Reply Quote 0
                    • T
                      tesso last edited by

                      Ich habe mich einfach an die Vorgehensweise aus dem ersten Post gehalten.

                      Die IP habe ich im Datenpunkt für die IP eingetragen. Ich komme leider im Moment nicht auf mein System (bin unterwegs). Evtl. kann ich nachher nachschauen.

                      1 Reply Last reply Reply Quote 0
                      • M
                        Mighty last edited by

                        Wäre super, wenn du da nochmal nachschauen könntest.

                        Datenpunkt?

                        Grüße Mighty

                        1 Reply Last reply Reply Quote 0
                        • T
                          tesso last edited by

                          System - IP Adresse

                          Nicht zu verfehlen

                          1 Reply Last reply Reply Quote 0
                          • M
                            Mighty last edited by

                            @tesso:

                            System - IP Adresse

                            Nicht zu verfehlen `

                            Ok. Danke. Wo finde ich den Benutzernamen?

                            Habe folgendes eingetragen:

                            createState('javascript.0.Sony_Bravia_VAR.Authorization.User','Mighty',{type: "string", role: "User"});
                            //System
                            createState('javascript.0.Sony_Bravia_VAR.System.IP_Adresse','192.168.2.248',{type: "string", role: "IP Adresse"});
                            

                            Bekomme folgende Fehlermeldungen:

                            5:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: Anfrage{"id":40,"method":"actRegister","params":[{"clientid":"","nickname":""},[{"clientid":"","value":"yes","nickname":"","function":"WOL"}]],"version":"1.0"}
                            15:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: Anfrage{"id":40,"method":"actRegister","params":[{"clientid":"","nickname":""},[{"clientid":"","value":"yes","nickname":"","function":"WOL"}]],"version":"1.0"}
                            15:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: Anfrage{"id":40,"method":"actRegister","params":[{"clientid":"","nickname":""},[{"clientid":"","value":"yes","nickname":"","function":"WOL"}]],"version":"1.0"}
                            15:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: registered 25 subscriptions and 0 schedules
                            15:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: registered 25 subscriptions and 0 schedules
                            15:59:30.270	[info]	javascript.0 script.js.Sony_Bravia.Main: registered 25 subscriptions and 0 schedules
                            15:59:32.543	[info]	javascript.0 script.js.Sony_Bravia.Main: Error: getaddrinfo ENOTFOUND null null:80
                            15:59:32.543	[info]	javascript.0 script.js.Sony_Bravia.Main: Error: getaddrinfo ENOTFOUND null null:80
                            15:59:32.543	[info]	javascript.0 script.js.Sony_Bravia.Main: Error: getaddrinfo ENOTFOUND null null:80
                            

                            Hat jemand eine Idee, was hier falsch läuft?

                            Grüße Mighty

                            1 Reply Last reply Reply Quote 0
                            • T
                              tesso last edited by

                              Der Username ist etwas irreführend. gemeint ist der "Vorsinstallierte Schlüssel" den du ihm Fernseher einstellen musst.

                              1 Reply Last reply Reply Quote 0
                              • M
                                Mighty last edited by

                                So, jetzt läuft es. Ich hatte die Daten direkt unter 'Skripte' im Code eingetragen. War aber falsch.

                                Man muss unter Objekte ->

                                javascript.0.Sony_Bravia_VAR.System und .Authorization seine Daten eintragen. Dann klappt's.

                                Wie man an was kommt, ist hier beschrieben:

                                https://github.com/alanreid/bravia

                                Danke & Grüße Mighty

                                ps jetzt fehlt nur noch der MR400 der Telekom für EntertainTV.

                                1 Reply Last reply Reply Quote 0
                                • L
                                  Lucky last edited by

                                  Moin Moin,

                                  ich habe mal wider etwas an dem Skript gearbeitet

                                  1.Durch einen Update Intervall werden die States jetzt auch Aktualisiert wenn mit der Fernbedienung bedient wurde

                                  2. Verbesserungen und Fehler behoben

                                  hier die neue Version

                                  ! ```
                                  `createState('javascript.0.Sony_Bravia_VAR.Authorization.PIN_Anfordern', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Authorization.Cookie', 'init',{type: "string", role: "Cookie",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.Authorization.PIN', 0,{type: "number", role: "PIN"});
                                  createState('javascript.0.Sony_Bravia_VAR.Authorization.Status', false,{type: "boolean", role: "Erfolgreich",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.Authorization.User','',{type: "string", role: "User"});
                                  //System
                                  createState('javascript.0.Sony_Bravia_VAR.System.IP_Adresse',{type: "string", role: "IP Adresse"});
                                  createState('javascript.0.Sony_Bravia_VAR.System.MAC_Adresse',{type: "string", role: "MAC Adresse",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Generation',{type: "string", role: "Generation",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Language',{type: "string", role: "Language",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Model',{type: "string", role: "Model",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Name',{type: "string", role: "Name",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Product',{type: "string", role: "Product",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Serial',{type: "string", role: "Serial",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.System.Update', 0,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Power', false,{type: "boolean", role: "Power"});
                                  //Control
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Play', false,{type:"boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Stop', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Pause', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Skip_Plus', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Skip_Minus', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Page_Next', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Control.Page_Previous', false,{type: "boolean", role: "button"});
                                  //Input
                                  createState('javascript.0.Sony_Bravia_VAR.Input.InputsStatus', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.ActivInput', false,{type: "string", role: "ActivInput"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.HDMI1', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.HDMI2', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.HDMI3', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.HDMI4', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.SetTV', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.AV1', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.AV2', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Input.BildschirmSpiegeln', false,{type: "boolean", role: "button"});
                                  //TV
                                  createState('javascript.0.Sony_Bravia_VAR.TV.Channel', 0,{type: "number", role: "Channel"});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.ProgrammTitel',{type: "string", role: "ProgrammTitel",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.Länge',{type: "number", role: "Länge (Minuten)",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.Startzeit',{type: "string", role: "Startzeit",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.SenderLesen', false,{type: "boolean", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.ChannelList',0,{type: "number", role: "Channel List",states:"0:none"});
                                  createState('javascript.0.Sony_Bravia_VAR.TV.SenderName',{type: "string", role: "Sendername",write:false});
                                  //Audio
                                  createState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume', 0,{type: "number", role: " SpeakerVolume"});
                                  createState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume_UP', 0,{type: "number", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume_DOWN', 0,{type: "number", role: "button"});
                                  createState('javascript.0.Sony_Bravia_VAR.Audio.HeadphoneVolume', 0,{type: "number", role: " HeadphoneVolume",write:false});
                                  createState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerMute', false,{type: "boolean", role: "SpeakerMute"});
                                  ! var request = require('request');
                                  ! var MySonyTV = {
                                  ip:'',
                                  mac:'',
                                  pin:0,
                                  auth:'',
                                  body:{},
                                  channel:{},
                                  sony:{id:1,method:'',params:[],version:'1.0'},

                                  system: {       getColorKeysLayout:function (val) {return MySonyTV.Send(1,'system','getColorKeysLayout',val)},
                                                  getCurrentTime:function (val) {return MySonyTV.Send(2,'system','getCurrentTime',val)},
                                                  getDateTimeFormat:function (val) {return MySonyTV.Send(3,'system','getDateTimeFormat',val)},
                                                  getInterfaceInformation:function (val) {return MySonyTV.Send(4,'system','getInterfaceInformation',val)},
                                                  getMethodTypes:function (val) {return MySonyTV.Send(5,'system','getMethodTypes',val)},
                                                  getPostalCode:function (val) {return MySonyTV.Send(6,'system','getPostalCode',val)},
                                                  getPowerSavingMode:function (val) {return MySonyTV.Send(7,'system','getPowerSavingMode',val)},
                                                  getPowerStatus:function (val) {return MySonyTV.Send(8,'system','getPowerStatus',val)},
                                                  getRemoteControllerInfo:function (val) {return MySonyTV.Send(9,'system','getRemoteControllerInfo',val)},
                                                  getSystemInformation:function (val) {return MySonyTV.Send(10,'system','getSystemInformation',val)},
                                                  getSystemSupportedFunction:function (val) {return MySonyTV.Send(11,'system','getSystemSupportedFunction',val)},
                                                  getVersions:function (val) {return MySonyTV.Send(12,'system','getVersions',val)},
                                                  getWolMode:function (val) {return MySonyTV.Send(13,'system','getWolMode',val)},
                                                  requestToNotifyDeviceStatus:function (val) {return MySonyTV.Send(14,'system','requestToNotifyDeviceStatus',val)},
                                  
                                                  setCurrentTime:function (val) {return MySonyTV.Send(15,'system','setCurrentTime',val)},
                                                  setLEDIndicatorStatus:function (val) {return MySonyTV.Send(16,'system','setLEDIndicatorStatus',val)},
                                                  setLanguage:function (val) {return MySonyTV.Send(17,'system','setLanguage',val)},
                                                  setPostalCode:function (val) {return MySonyTV.Send(18,'system','setPostalCode',val)},
                                                  setPowerSavingMode:function (val) {return MySonyTV.Send(19,'system','setPowerSavingMode',val)},
                                                  setPowerStatus:function (val) {return MySonyTV.Send(20,'system','setPowerStatus',val)},
                                                  setWolMode:function (val) {return MySonyTV.Send(21,'system','setWolMode',val)},
                                  },
                                  
                                  avContent:{     deleteContent:function (val) {return MySonyTV.Send(22,'avContent','deleteContent',val)},
                                                  getContentCount:function (val) {return MySonyTV.Send(23,'avContent','getContentCount',val)},
                                                  getContentList:function (val) {return MySonyTV.Send(24,'avContent','getContentList',val)},
                                                  getCurrentExternalInputsStatus:function (val) {return MySonyTV.Send(25,'avContent','getCurrentExternalInputsStatus',val)},
                                                  getMethodTypes:function (val) {return MySonyTV.Send(26,'avContent','getMethodTypes',val)},
                                                  getParentalRatingSettings:function (val) {return MySonyTV.Send(27,'avContent','getParentalRatingSettings',val)},
                                                  getPlayingContentInfo:function (val) {return MySonyTV.Send(28,'avContent','getPlayingContentInfo',val)},
                                                  getSchemeList:function (val) {return MySonyTV.Send(29,'avContent','getSchemeList',val)},
                                                  getSourceList:function (val) {return MySonyTV.Send(30,'avContent','getSourceList',val)},
                                                  getVersions:function (val) {return MySonyTV.Send(31,'avContent','getVersions',val)},
                                  
                                                  setDeleteProtection:function (val) {return MySonyTV.Send(32,'avContent','setDeleteProtection',val)},
                                                  setPlayContent:function (val) {return MySonyTV.Send(33,'avContent','setPlayContent',val)},
                                                  setPlayTvContent:function (val) {return MySonyTV.Send(34,'avContent','setPlayTvContent',val)},
                                  },
                                  
                                  audio:{         getMethodTypes:function (val) {return MySonyTV.Send(35,'audio','getMethodTypes',val)},
                                                  getVersions:function (val) {return MySonyTV.Send(36,'audio','getVersions',val)},
                                                  getVolumeInformation:function (val) {return MySonyTV.Send(37,'audio','getVolumeInformation',val)},
                                                  setAudioMute:function (val) {return MySonyTV.Send(38,'audio','setAudioMute',val)},
                                                  setAudioVolume:function (val) {return MySonyTV.Send(39,'audio','setAudioVolume',val)},
                                  },
                                  
                                  accessControl:{ actRegister:function (val) {return MySonyTV.Send(40,'accessControl','actRegister',val)},
                                                  getMethodTypes:function (val) {return MySonyTV.Send(41,'accessControl','getMethodTypes',val)},
                                                  getVersions:function (val) {return MySonyTV.Send(42,'accessControl','getVersions',val)},
                                  }, 
                                  
                                  IRCC:         { setIRCC:function (val) {return MySonyTV.Send(255,'IRCC','setIRCC',val)},
                                  
                                  },
                                  
                                  Send: 	function(id,service,method,params) {
                                  
                                      this.sony.method=method;
                                      this.sony.params=params;
                                      this.sony.id=id;
                                      this.ip=getState('javascript.0.Sony_Bravia_VAR.System.IP_Adresse').val;
                                  

                                  ! var j = request.jar();
                                  var cookie = request.cookie(this.auth);
                                  var FormData;

                                      if(service!='IRCC'){FormData=JSON.stringify(this.sony)}
                                      else{FormData='<ircccode>'+params+'</ircccode>';
                                          console.log('IRCC');
                                      }
                                  

                                  //##############################################################################
                                  // Configure the request
                                  var options = {
                                  url: 'http://'+this.ip+'/sony/'+service,
                                  jar: true,
                                  method: 'POST',
                                  headers: {'Authorization':'Basic '+ Buffer.from(':'+this.pin).toString('base64')},
                                  form:FormData
                                  };

                                  ! console.log('Anfrage'+options.form);
                                  ! j.setCookie(cookie,options.url);
                                  ! // Start the request
                                  request(options, function (error, response, body) {
                                  ! if(!error){ // && response.statusCode == 200

                                              //-------------------------------------------------------------------------------
                                  
                                              if ("undefined" !== typeof body&&service!='IRCC'){
                                  
                                                           console.log('Body '+body);  
                                  
                                                          this.body=JSON.parse(body);
                                  
                                                          if ("undefined" !== typeof this.body.error){
                                                              if(this.body.error[1]=='not power-on'){
                                                                  setState('javascript.0.Sony_Bravia_VAR.Power',val=false,akt=true);
                                  
                                                                  setTimeout(MySonyTV.system.getPowerStatus,10000,[]);  //neu (20.07.17)
                                                              }
                                                              else if(this.body.error[1]=='Unauthorized'){
                                                              setState('javascript.0.Sony_Bravia_VAR.Authorization.Status',val=false,akt=true);
                                                              setState('javascript.0.Sony_Bravia_VAR.Authorization.PIN',val=0,akt=false);
                                                              console.warn('##############################Unauthorized##############################');
                                  
                                                                this.auth='';
                                                                setState('javascript.0.Sony_Bravia_VAR.Authorization.Cookie',val= this.auth);  
                                                              }
                                  
                                                              else if(this.body.error[1]=="not register any more"){
                                                              setState('javascript.0.Sony_Bravia_VAR.Authorization.Status',val=false,akt=true);
                                                              }
                                  
                                                              console.log(this.body.error[1]);
                                                          }    
                                                          else {
                                  
                                                                  if ("undefined" !== typeof this.body.auth_url){  //tritt ein wenn keinCookie vorhanden oder abgelaufen/falsch ist
                                                                      setState('javascript.0.Sony_Bravia_VAR.Authorization.Status',val=false,akt=true);
                                                                      console.log('Sony TV Authorization abgelaufen ! ');
                                                                      //Authorization();  //kann probleme machen, endlosschleife
                                  
                                                                  }
                                  
                                                                  if ("undefined" !== typeof  this.body.id){
                                                                  switch(this.body.id){
                                  
                                                                      case 40://actRegister
                                                                          //cookie string zerlegen, krücke, aber gehr ;-) ---------------------------------
                                                                           if ("undefined" !== typeof response.headers['set-cookie']){    //wenn objekt definiert ist
                                                                              var C=JSON.stringify(response.headers['set-cookie']).split(';');
                                                                              C=C[0].split('"');
                                                                              this.auth=C[1];
                                                                              setState('javascript.0.Sony_Bravia_VAR.Authorization.Cookie',val=this.auth,akt=true);
                                                                              }//end if
                                  
                                                                          if ("undefined" !== typeof this.body.result){ //positive Antwort auf ActRegister
                                                                              if (this.body.result.length===0){
                                                                                  setState('javascript.0.Sony_Bravia_VAR.Authorization.Status',val=true,akt=true);
                                                                                  setState('javascript.0.Sony_Bravia_VAR.Authorization.PIN',val=0,akt=true);
                                                                                  update();
                                                                              }
                                  
                                                                          } 
                                                                          break;
                                  
                                                                      case 8://getPowerStatus
                                                                      if(this.body.result[0].status=='active'){
                                  
                                                                          setState('javascript.0.Sony_Bravia_VAR.Power',val=true,akt=true)
                                  
                                                                          if(getState('javascript.0.Sony_Bravia_VAR.Authorization.Status').val===true){
                                                                                  if ("undefined" == typeof Intervall){
                                  
                                                                                       Intervall=setInterval(updateStatus,5000);
                                                                                  }
                                                                                   else if (Intervall._idleTimeout<0){Intervall=setInterval(updateStatus,5000)};
                                  
                                                                              }
                                  
                                                                      }
                                                                      else if(this.body.result[0].status=='standby'){
                                                                          setState('javascript.0.Sony_Bravia_VAR.Power',val=false,akt=true)
                                  
                                                                          setTimeout(MySonyTV.system.getPowerStatus,10000,[]);  //neu (20.07.17)
                                  
                                                                           if ("undefined" !== typeof Intervall && Intervall._idleTimeout>0 ){
                                                                               clearInterval(Intervall)
                                                                           }
                                  
                                                                      }
                                                                          break;
                                  
                                                                      case 10://getSystemInformation
                                                                      this.mac=this.body.result[0].macAddr;
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.MAC_Adresse',val=this.body.result[0].macAddr,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Generation',val=this.body.result[0].generation,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Language',val=this.body.result[0].language,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Model',val=this.body.result[0].model,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Name',val=this.body.result[0].name,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Product',val=this.body.result[0].product,akt=true);
                                                                      setState('javascript.0.Sony_Bravia_VAR.System.Serial',val=this.body.result[0].serial,akt=true);
                                                                          break;
                                  
                                                                      case 37://getVolumeInformation
                                                                          setState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume',val=this.body.result[0][0].volume,akt=true);
                                                                          setState('javascript.0.Sony_Bravia_VAR.Audio.HeadphoneVolume',val=this.body.result[0][1].volume,akt=true);
                                                                          setState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerMute',val=this.body.result[0][0].mute,akt=true);
                                                                          break;
                                  
                                                                      case 24://getContentList'
                                                                          //var channels=this.body.result[0];
                                                                          MySonyTV.channel=this.body.result[0];
                                                                          var StateString='';
                                                                           for(var i = 0; i < 20; i++) { //MySonyTV.channel.length geht nicht da mehr als 50 Sender
                                                                               StateString=StateString+i.toString()+':'+MySonyTV.channel[i].title+';';
                                                                               //StateString=StateString+i.toString()+':'+channels[i].title+';';
                                                                           }
                                                                           var obj = getObject('javascript.0.Sony_Bravia_VAR.TV.ChannelList');
                                                                                      obj.common.states = StateString;
                                                                                      setObject('javascript.0.Sony_Bravia_VAR.TV.ChannelList', obj);
                                                                          break;
                                  
                                                                      case 28://getPlayingContentInfo':
                                                                          if ("undefined" !== typeof this.body.result[0].source){
                                                                              setState('javascript.0.Sony_Bravia_VAR.Input.ActivInput',this.body.result[0].source,akt=true);
                                                                              if (this.body.result[0].source=='extInput:hdmi'&&this.body.result[0].title=='HDMI 1'){setState('javascript.0.Sony_Bravia_VAR.Input.HDMI1',true,akt=true)}
                                                                              else if (this.body.result[0].source=='extInput:hdmi'&&this.body.result[0].title=='HDMI 2'){setState('javascript.0.Sony_Bravia_VAR.Input.HDMI2',true,akt=true)}
                                                                              else if (this.body.result[0].source=='extInput:hdmi'&&this.body.result[0].title=='HDMI 3'){setState('javascript.0.Sony_Bravia_VAR.Input.HDMI3',true,akt=true)}
                                                                              else if (this.body.result[0].source=='extInput:hdmi'&&this.body.result[0].title=='HDMI 4'){setState('javascript.0.Sony_Bravia_VAR.Input.HDMI4',true,akt=true)}
                                                                              else if (this.body.result[0].source=='tv:dvbc'){setState('javascript.0.Sony_Bravia_VAR.Input.SetTV',true,akt=true)};
                                  
                                                                          };
                                                                          if ("undefined" !== typeof this.body.result[0].programTitle){setState('javascript.0.Sony_Bravia_VAR.TV.ProgrammTitel',val=this.body.result[0].programTitle,akt=true)}; 
                                                                          if ("undefined" !== typeof this.body.result[0].durationSec){setState('javascript.0.Sony_Bravia_VAR.TV.Länge',val=parseFloat(this.body.result[0].durationSec)/60,akt=true)};
                                                                          if ("undefined" !== typeof this.body.result[0].startDateTime){setState('javascript.0.Sony_Bravia_VAR.TV.Startzeit',val=this.body.result[0].startDateTime,akt=true)};
                                                                          if ("undefined" !== typeof this.body.result[0].title){setState('javascript.0.Sony_Bravia_VAR.TV.SenderName',val=this.body.result[0].title,akt=true)};
                                                                          if ("undefined" !== typeof this.body.result[0].uri){
                                                                              if ("undefined" !== typeof MySonyTV.channel[0]){
                                                                                  for(var i=0; i < MySonyTV.channel.length; i++){
                                                                                      if(MySonyTV.channel[i].uri==this.body.result[0].uri){
                                                                                         setState('javascript.0.Sony_Bravia_VAR.TV.ChannelList',val=i,akt=true)
                                                                                         setState('javascript.0.Sony_Bravia_VAR.TV.Channel',val=i,akt=true)
                                                                                         break;
                                                                                      }
                                  
                                                                                  }
                                  
                                                                              }    
                                  
                                                                          };
                                  
                                                                          break;
                                  
                                                                          default:
                                                                          break;
                                                                  }// end of Switch
                                  
                                                          }// if id undefined  
                                                      }// end else
                                  
                                              } // end if undefined
                                  

                                  }//end if !error

                                  else{
                                  console.log(error) //oder ETIMEDOUT
                                  if(error.code=='EHOSTUNREACH'||"ETIMEDOUT"){

                                   setState('javascript.0.Sony_Bravia_VAR.Power',false,akt=true)
                                  
                                   if ("undefined" !== typeof Intervall){clearInterval(Intervall)}
                                  
                                   setTimeout(MySonyTV.system.getPowerStatus,10000,[]);
                                  
                                   console.log('##############################TV AUS ODER NICHT ERREICHBAR ##############################')
                                  

                                  }

                                  !
                                  !
                                  }
                                  ! }) ; // end of Request

                                      return;
                                  

                                  } // end of Function Send
                                  }; // end of Object MySonyTV
                                  //##############################################################################

                                  ! Authorization() // Initiale abfrage bei Skript Start !!

                                  ! function update(){
                                  MySonyTV.avContent.getContentList([{source:"tv:dvbc",target:"",type:"",cnt:50,stIdx:""}]);
                                  MySonyTV.system.getSystemInformation([]);
                                  MySonyTV.system.getPowerStatus([]);
                                  MySonyTV.avContent.getPlayingContentInfo([])
                                  MySonyTV.avContent.getCurrentExternalInputsStatus([]);
                                  MySonyTV.audio.getVolumeInformation([])
                                  }//end update
                                  ! function updateStatus (){
                                  console.log('######################################################### UPDATE TV STATUS ###########################################################')
                                  MySonyTV.system.getPowerStatus([]);
                                  MySonyTV.avContent.getPlayingContentInfo([])
                                  //MySonyTV.avContent.getCurrentExternalInputsStatus([]);
                                  MySonyTV.audio.getVolumeInformation([])
                                  ! }
                                  ! function Authorization(){
                                  var user =getState('javascript.0.Sony_Bravia_VAR.Authorization.User').val
                                  data= [{clientid:user,nickname:user},[{clientid:user,value:'yes',nickname:user,function:'WOL'}]];
                                  MySonyTV.accessControl.actRegister(data);
                                  }
                                  ! var data;
                                  ! on({id:'javascript.0.Sony_Bravia_VAR.Authorization.Status',change:'any'}, function (obj){

                                   if (obj.state.val===true){
                                       if(getState('javascript.0.Sony_Bravia_VAR.Power').val===true){
                                               if ("undefined" == typeof Intervall){Intervall=setInterval(updateStatus,5000)};
                                          }        
                                      }
                                  else{
                                      if ("undefined" !== typeof Intervall){clearInterval(Intervall)}
                                  }
                                  

                                  });

                                  ! on({id:'javascript.0.Sony_Bravia_VAR.System.IP_Adresse',change:"any"}, function (obj){
                                  MySonyTV.ip=obj.state.val
                                  MySonyTV.system.getSystemInformation([]);

                                  }) ;

                                  ! on({id:'javascript.0.Sony_Bravia_VAR.Authorization.PIN_Anfordern',val:true}, function (obj){
                                  if(getState('javascript.0.Sony_Bravia_VAR.Authorization.User').val.length>=1){
                                  Authorization()
                                  }
                                  }) ;

                                  on('javascript.0.Sony_Bravia_VAR.Authorization.PIN', function (obj){
                                  if (!obj.state.ack) {
                                  MySonyTV.pin=obj.state.val;
                                  Authorization()
                                  }

                                  });

                                  on({id:'javascript.0.Sony_Bravia_VAR.Input.InputsStatus',val:true}, function (obj){
                                  MySonyTV.avContent.getCurrentExternalInputsStatus([]);
                                  //MySonyTV.avContent.getPlayingContentInfo([]);
                                  //MySonyTV.avContent.getSchemeList([]);
                                  //MySonyTV.avContent.getSourceList([{scheme:'tv'}]);
                                  //MySonyTV.system.getRemoteControllerInfo([])
                                  //MySonyTV.audio.getMethodTypes(['1.0']);

                                  });

                                  on({id:'javascript.0.Sony_Bravia_VAR.Input.HDMI1',val:true}, function (obj){
                                          if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:hdmi?port=1'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                          }
                                  

                                  });

                                  on({id:'javascript.0.Sony_Bravia_VAR.Input.HDMI2',val:true}, function (obj){
                                          if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:hdmi?port=2'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                          }
                                  

                                  });

                                  on({id:'javascript.0.Sony_Bravia_VAR.Input.HDMI3',val:true}, function (obj){
                                          if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:hdmi?port=3'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                          }
                                  

                                  });

                                    on({id:'javascript.0.Sony_Bravia_VAR.Input.HDMI4',val:true}, function (obj){
                                            if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:hdmi?port=4'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                            }
                                  

                                  });

                                    on({id:'javascript.0.Sony_Bravia_VAR.Input.SetTV',val:true}, function (obj){ 
                                            if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'tv:'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                            }
                                  

                                  });

                                    on({id:'javascript.0.Sony_Bravia_VAR.Input.AV1',val:true}, function (obj){
                                            if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:scart?port=1'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                            }
                                  

                                  });

                                      on({id:'javascript.0.Sony_Bravia_VAR.Input.AV2',val:true}, function (obj){
                                            if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:composite?port=1'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                            }
                                  

                                  });

                                        on({id:'javascript.0.Sony_Bravia_VAR.BildschirmSpiegeln',val:true}, function (obj){
                                            if (!obj.state.ack) { 
                                  if (obj.state.val===true){
                                      MySonyTV.avContent.setPlayContent([{uri:'extInput:widi?port=1'}]);
                                      MySonyTV.avContent.getPlayingContentInfo([]);
                                  }
                                            }
                                  

                                  });

                                    on({id: 'javascript.0.Sony_Bravia_VAR.TV.SenderLesen', val: true}, function (obj){
                                      MySonyTV.avContent.getContentList([{source:"tv:dvbc",target:"",type:"",cnt:50,stIdx:""}])
                                       MySonyTV.avContent.getPlayingContentInfo([]);
                                  

                                  });

                                    on(  'javascript.0.Sony_Bravia_VAR.TV.ChannelList', function (obj){
                                         if (!obj.state.ack) {
                                                 if ("undefined" !== typeof MySonyTV.channel[0]){
                                  
                                                       MySonyTV.avContent.setPlayContent([{uri:MySonyTV.channel[obj.state.val].uri}])
                                                       MySonyTV.avContent.getPlayingContentInfo([]);
                                                       }
                                                       else {
                                                           MySonyTV.avContent.getContentList([{source:"tv:dvbc",target:"",type:"",cnt:50,stIdx:""}])
                                                           //setState('javascript.0.Sony_Bravia_VAR.TV.ChannelList',val=obj.oldState.val,akt=false)
                                                  }
                                         }
                                    })
                                  

                                  !
                                  on('javascript.0.Sony_Bravia_VAR.TV.Channel', function (obj){
                                  if (!obj.state.ack) {
                                  if(obj.state.val>=1){
                                  //console.log (typeof MySonyTV.channel[0])
                                  if ("undefined" !== typeof MySonyTV.channel[0]){

                                                       MySonyTV.avContent.setPlayContent([{uri:MySonyTV.channel[obj.state.val-1].uri}]);
                                                       MySonyTV.avContent.getPlayingContentInfo([]);
                                                       }
                                                       else {
                                                           MySonyTV.avContent.getContentList([{source:"tv:dvbc",target:"",type:"",cnt:50,stIdx:""}])
                                                       }
                                               }
                                        }     
                                  

                                  });

                                   on('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume', function (obj){
                                        if (!obj.state.ack) { 
                                       MySonyTV.audio.setAudioVolume([{target:"speaker",volume:obj.state.val.toString()}])
                                       MySonyTV.audio.getVolumeInformation([])
                                        }
                                  

                                  });

                                   on('javascript.0.Sony_Bravia_VAR.Audio.SpeakerMute', function (obj){
                                       MySonyTV.audio.setAudioMute([{status:obj.state.val}])
                                       MySonyTV.audio.getVolumeInformation([])
                                  

                                  }); //

                                   on({id:'javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume_UP',val:true}, function (obj){
                                        if (!obj.state.ack) { 
                                             var vol=getState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume').val
                                             if(vol<100){
                                                 vol++
                                                 MySonyTV.audio.setAudioVolume([{target:"speaker",volume:vol.toString()}])
                                             }
                                       MySonyTV.audio.getVolumeInformation([])
                                        }
                                  

                                  });

                                  on({id:'javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume_DOWN',val:true}, function (obj){
                                  if (!obj.state.ack) {
                                  var vol=getState('javascript.0.Sony_Bravia_VAR.Audio.SpeakerVolume').val
                                  if(vol>0){
                                  vol--
                                  MySonyTV.audio.setAudioVolume([{target:"speaker",volume:vol.toString()}])
                                  }
                                  MySonyTV.audio.getVolumeInformation([])
                                  }
                                  });

                                  on('javascript.0.Sony_Bravia_VAR.Power', function (obj){
                                  if (!obj.state.ack) {
                                  if (obj.state.val===false){
                                  MySonyTV.system.setPowerStatus([{status:false}])
                                  //if ("undefined" !== typeof Intervall){clearInterval(Intervall)}
                                  }
                                  else{
                                  var wol = require('wake_on_lan');
                                  wol.wake(getState('javascript.0.Sony_Bravia_VAR.System.MAC_Adresse').val, function(error) {
                                  if(!error){
                                  //setState('javascript.0.Sony_Bravia_VAR.Power',true,akt=true)
                                  console.log('############################## TV WIRD EINGESCHALTET ##############################')

                                                                                 setTimeout(MySonyTV.system.getPowerStatus,5000,[]);  //5s nach WOL Packet Powerstatus abfragen (20.07.17)
                                                                             }
                                                                             else{console.error('Fehler beim Einschalten(WOL)')}
                                                                         });       
                                                        }
                                   }
                                   else{}
                                  

                                  ! });

                                  on( {id:'javascript.0.Sony_Bravia_VAR.System.Update',val:true}, function (obj){
                                  update()

                                  ! });

                                  on( {id:'javascript.0.Sony_Bravia_VAR.Control.Play',val:true}, function (obj){
                                     MySonyTV.IRCC.setIRCC('AAAAAgAAAJcAAAAaAw==')
                                  

                                  ! });

                                     on( {id:'javascript.0.Sony_Bravia_VAR.Control.Stop',val:true}, function (obj){
                                     MySonyTV.IRCC.setIRCC('AAAAAgAAAJcAAAAYAw==')
                                  

                                  ! });
                                  ! on( {id:'javascript.0.Sony_Bravia_VAR.Control.Pause',val:true}, function (obj){
                                  MySonyTV.IRCC.setIRCC('AAAAAgAAAJcAAAAZAw==')
                                  ! });` [/i][/i][/i]

                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    Mighty last edited by

                                    Hallo,

                                    bekomme folgende Fehlermeldung:

                                    host.loxberry 2017-09-21 21:14:22.240 error instance system.adapter.javascript.0 terminated with code 0 (OK)

                                    javascript.0 2017-09-21 21:14:22.208 info terminating

                                    javascript.0 2017-09-21 21:14:22.181 error at emitNone (events.js:91:20)

                                    javascript.0 2017-09-21 21:14:22.181 error at IncomingMessage.g (events.js:292:16)

                                    javascript.0 2017-09-21 21:14:22.181 error at IncomingMessage. (/opt/iobroker/node_modules/request/request.js:1085:12)

                                    javascript.0 2017-09-21 21:14:22.181 error at Request.emit (events.js:188:7)

                                    javascript.0 2017-09-21 21:14:22.181 error at emitOne (events.js:96:13)

                                    javascript.0 2017-09-21 21:14:22.181 error at Request. (/opt/iobroker/node_modules/request/request.js:1163:10)

                                    javascript.0 2017-09-21 21:14:22.181 error at Request.emit (events.js:191:7)

                                    javascript.0 2017-09-21 21:14:22.181 error at emitTwo (events.js:106:13)

                                    javascript.0 2017-09-21 21:14:22.181 error at Request.self.callback (/opt/iobroker/node_modules/request/request.js:186:22)

                                    javascript.0 2017-09-21 21:14:22.181 error at Request._callback (script.js.Sony_Bravia.Main:270:110)

                                    javascript.0 2017-09-21 21:14:22.181 error TypeError: Cannot read property 'title' of undefined

                                    javascript.0 2017-09-21 21:14:22.180 error uncaught exception: Cannot read property 'title' of undefined

                                    javascript.0 2017-09-21 21:14:22.159 info script.js.Sony_Bravia.Main: Body {"id":24,"result":[[]]}

                                    Kommentiere ich die Zeile 270 aus, geht es. Ich habe ja absolut keine Ahnung, aber kann es daran liegen, dass ich keine Kanäle habe? Benutze den Fernseher nur als Bildschirm.

                                    Grüße Mighty

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

                                    Support us

                                    ioBroker
                                    Community Adapters
                                    Donate

                                    800
                                    Online

                                    31.7k
                                    Users

                                    79.8k
                                    Topics

                                    1.3m
                                    Posts

                                    4
                                    18
                                    4455
                                    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