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

                                  808
                                  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