Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. IoBroker und Stau- / Verkehrsinformationen

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    IoBroker und Stau- / Verkehrsinformationen

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

      Hallo,
      habe auch den Roadtraffic Adapter installiert und funktioniert echt super,
      ABER bei mir läuft jeden Tag der API Key von here.com aus.

      Ich lege einen an, alles funktioniert und am nächsten Tag funktioniert der Adapter nicht mehr, weil der API Key bei Here.com auf "Expired" steht:

      507bc914-bf70-4911-9154-19a90b8e14c9-image.png

      Hat jemand eine Idee, warum der Api Key bei mir nur immer einen Tag gültig ist?

      So kann ich immer nur 24 Stunden den Roadtraffic Adapter nutzen und danach holt er keine Routen mehr:

      a3d20769-5d78-4e0c-8896-a65da03a1137-image.png

      _--------------------------------------------------------------------------------------------------------

      EDIT

      Falls den Fehler noch wer hat, es war meine Schuld.
      Ich habe vergessen meine Email zu verifizieren, dadurch läuft der API Key nach 60 Minuten ab.

      1 Reply Last reply Reply Quote 0
      • T
        Tirador @BuZZy last edited by

        @BuZZy said in IoBroker und Stau- / Verkehrsinformationen:

        @nousefor82 die Sache mit Google und deren "Preismodell" hat mich auch genervt..

        Habe daher den roadtraffic Adapter auf Here.com umgeschrieben.
        https://github.com/BuZZy1337/ioBroker.roadtraffic
        Arbeitet über here.com und fragt aktuellen Fahrzeiten ab.

        👍 Wow. Vielen Dank für deine tolle Arbeit. Der Adapter funktioniert auf Anhieb! 🙂

        K 1 Reply Last reply Reply Quote 0
        • K
          Kuddel @Tirador last edited by

          Hallo zusammen,

          ich habe den Adapter auch gerade installiert.

          Kann man bei der Eingabe von Start und Ziel die Strecke irgendwie beeinflussen ?

          1 Reply Last reply Reply Quote 0
          • G
            gutgut30 last edited by

            Hat es eigentlich irgendwer geschafft sich einfach nur die Karte einzubinden wie auf Jeepers Screenshot? Ich bekomme es einfach nicht hin eine valide URL zu generieren für das iFrame Widget.

            Stephan Schleich 1 Reply Last reply Reply Quote 0
            • Stephan Schleich
              Stephan Schleich @gutgut30 last edited by

              Nutzt das Script oder den Adapter noch wer?
              Der Adapter funktioniert bei mir nämlich nicht, vllt kann kurz jemand Rückmeldung geben

              H 1 Reply Last reply Reply Quote 0
              • H
                hohmannc @Stephan Schleich last edited by

                @stephan-schleich also bei mir ist der adapter Gelb und läuft nicht.

                1 Reply Last reply Reply Quote 0
                • M
                  marsmännchen last edited by

                  Ja, schaut schlecht aus:

                  Error from Here: undefined undefined
                  

                  Ich versuch es mal mit Git-Issue
                  MfG

                  1 Reply Last reply Reply Quote 0
                  • G
                    gutgut30 last edited by gutgut30

                    Mir hat das Script hier sehr geholfen. Daher man den request inzwischen anders ausführen soll (Deprecrated Meldung) habe ich es auf Axios abgepasst.

                    Zudem noch 2x VIA Wegepunkt und das Script zieht die Daten nur wenn ich anwesend bin. Das spart Aufrufe. Zudem erzeuge ich noch einen extra Datenpunkt mit dem aktuellen Zeitstempel um zu sehen wie alt der aktuelle Wert ist.

                    Falls jemand auch auf Axios umstellen will, hier das Script:

                    // Beschreibung der API: https://developers.google.com/maps/documentation/directions/intro?hl=de#traffic-model
                    // API-Key: https://console.developers.google.com/apis/dashboard?project=iobroker-privat&duration=PT1H
                    // Infos : http://forum.iobroker.net/viewtopic.php?f=8&t=4019&p=38235#p38226
                    
                    const axios = require('axios');
                    
                    var ldebug = true; // lokale Debugausgabe des Skripts true/false
                    
                    var pfad = "0_userdata.0.xxxxx."; // der Pfad zu den Datenpunkten. Letzten Punkt nicht löschen
                    
                    var stauStufe1AbMinuten = 5;
                    var stauStufe2AbMinuten = 8;
                    var stauStufe3AbMinuten = 12;
                    
                    // Standardzeit in Minuten je Route
                    var standardMinuten0 = 33;
                    
                    var origin = "11.1111111,2.2222222"; // Start
                    var via1 = "11.1111111,2.2222222"; // Zwischenpunt1
                    var via2 = "11.1111111,2.2222222"; // Zwischenpunt2
                    var destination = "11.1111111,2.2222222"; //  Ziel
                    
                    var apikey = "DEINAPIKEY";
                    
                    var myJson = {};
                    
                    var idUrl = pfad + "skript.url";
                    var idJson = pfad + "skript.ergebnis_json";
                    var idStatus = pfad + "skript.status";
                    var idTimestamp = pfad + "skript.timestamp";
                    var idMinuten_0 = pfad + "Minuten_0";
                    var idMinuten_0_durchschnitt = pfad + "Minuten_0_Durchschnitt";
                    var idMinuten_0_delta = pfad + "Minuten_0_Deltazeit";
                    var idRoute_0 = pfad + "Route_0"; // Routenbezeichnung von Google Maps
                    var idStau_0 = pfad + "Stau_0"; // boolean
                    var idStaustufe_0 = pfad + "Staustufe_0"; // Wert von (0-3)
                    var idAnzahlWaypoints = pfad + "Anzahl_Wegpunkte_0"; // Anzahl der Wegpunkte der aktuellen Route
                    
                    function createAllStates() {
                    
                        createState(idMinuten_0, 0, {
                            name: 'Route 0 Minuten aktuell zum Ziel',
                            desc: 'Route 0 Minuten aktuell zum Ziel',
                            type: 'number',
                            role: 'value',
                            unit: 'min'
                        });
                    
                        createState(idMinuten_0_durchschnitt, 0, {
                            name: 'Route 0 Minuten im Durchschnitt zum Ziel',
                            desc: 'Route 0 Minuten im Durchschnitt zum Ziel',
                            type: 'number',
                            role: 'value',
                            unit: 'min'
                        });
                    
                        createState(idMinuten_0_delta, 0, {
                            name: 'Route 0 Minuten Delta gegenüber dem Durchschnitt',
                            desc: 'Route 0 Minuten Delta gegenüber dem Durchschnitt',
                            type: 'number',
                            role: 'value',
                            unit: 'min'
                        });
                    
                        createState(idRoute_0, "init", {
                            name: 'Bezeichnung der Route 0',
                            desc: 'Bezeichnung der Route 0 von Google Maps',
                            type: 'string',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idStau_0, false, {
                            name: 'Stau auf Route 0 (boolean)',
                            desc: 'Stau auf Route 0 (boolean)',
                            type: 'boolean',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idStaustufe_0, 0, {
                            name: 'Staustufe auf Route 0 (0-3)',
                            desc: 'Staustufe (0 kein Stau bis 3 starker Stau) auf Route 0',
                            type: 'number',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idAnzahlWaypoints, 0, {
                            name: 'Aktuelle Anzahl der Wegpunkte für die Route',
                            desc: 'Aktuelle Anzahl der Wegpunkte für die Route',
                            type: 'number',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idUrl, "", {
                            name: 'url der Abfrage zur Google',
                            desc: 'url der Abfrage zur Google',
                            type: 'string',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idJson, "", {
                            name: 'Ergebnis der Abfrage von Google',
                            desc: 'Ergebnis der Abfrage von Google (json)',
                            type: 'string',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idStatus, "", {
                            name: 'Status der Abfrage zur Google',
                            desc: 'Status der Abfrage zur Google',
                            type: 'string',
                            role: 'value',
                            unit: ''
                        });
                    
                        createState(idTimestamp, "", {
                            name: 'Letze Aktualisierung',
                            desc: 'Letze Aktualisierung',
                            type: 'string',
                            role: 'value',
                            unit: ''
                        });
                    }
                    
                    function readJson(url, callback) {
                        axios.get(url)
                            .then(response => {
                                if (response.status === 200) {
                                    var json = response.data;
                                    callback(null, json);
                                } else {
                                    var error = "Fehler beim Auslesen des JSON. Statuscode: " + response.status;
                                    callback(error, null);
                                }
                            })
                            .catch(error => {
                                var error = "Fehler bei der Abfrage von: " + url + ". Fehler: " + error.message;
                                callback(error, null);
                            });
                    }
                    
                    var url = 'https://maps.googleapis.com/maps/api/directions/json'
                        + '?origin=' + origin
                        + '&waypoints=via:' + via1
                        + '&waypoints=via:' + via2
                        + '&destination=' + destination
                        + '&departure_time=now'
                        // + '&sensor=false'
                        // + '&alternatives=true'
                        + '&mode=driving' // driving = default
                        + '&language=de-DE'
                        + '&key=' + apikey;
                    
                    function main() {
                        if (ldebug) log("url: " + url);
                        setState(idUrl, url);
                    
                        readJson(url, function (err, json) {
                            if (!err) {
                                myJson = json;
                                if (ldebug) log("json:" + JSON.stringify(myJson));
                                setState(idJson, JSON.stringify(myJson));
                    
                                if (myJson.status == "OK") {
                                    log("Anzahl Wegepunkte: " + myJson.routes[0].legs[0].steps.length);
                    
                                    var minuten0 = Math.ceil(myJson.routes[0].legs[0].duration_in_traffic.value / 60);
                                    var minuten0_durchschnitt = Math.ceil(myJson.routes[0].legs[0].duration.value / 60);
                                    var stau0 = false;
                                    var staustufe0 = 0;
                                    var delta = minuten0 - minuten0_durchschnitt;
                    
                                    if (delta >= stauStufe1AbMinuten) { stau0 = true; staustufe0 = 1 }
                                    if (delta >= stauStufe2AbMinuten) { staustufe0 = 2 }
                                    if (delta >= stauStufe3AbMinuten) { staustufe0 = 3 }
                    
                                    setState(idMinuten_0, minuten0); // aktuelle Dauer der Route
                                    setState(idMinuten_0_durchschnitt, minuten0_durchschnitt); // durchschnittliche Dauer der Route
                                    setState(idMinuten_0_delta, delta); // Delta Aktuell im Vergleich zum Durchschnitt
                                    setState(idRoute_0, myJson.routes[0].summary); // Bezeichnung Route als Text
                                    setState(idStau_0, stau0); // Boolean
                                    setState(idStaustufe_0, staustufe0);
                                    setState(idAnzahlWaypoints, myJson.routes[0].legs[0].steps.length);
                                } else {
                                    log("Kein gültiger Status Google Maps: " + myJson.status);
                                    setState(idStatus, myJson.status);
                                }
                            } else {
                                log("Fehler beim Auslesen des JSON. Keine Daten erhalten.", "warn");
                                myJson = {};
                            }
                        });
                    
                        var timestampnow =  Date.now()
                            // Setze den aktuellen Zeitstempel
                            setState(idTimestamp, timestampnow);
                        
                    }
                    
                    // ACHTUNG !!!! Individuelle Anpassung ruhr70
                    // verkleinert den Abfrageintervall an einem Arbeitstag im Zeitraum vor dem Losfahren
                    // globale Funktionen notwendig:
                    // arbeitstag()
                    // urlaubstag()
                    // isTimeInRange()
                    //if (isTimeInRange('05:00:00', '06:00:00')) {
                    // if (arbeitstag() && !urlaubstag()) {
                    // setTimeout(main,90*1000); // alle 90 Sekunden, 1.5 Minuten abfragen
                    // }
                    //}
                    
                    // Abfrage nur aktualisieren wenn jemand anwesend ist
                    if (anwesend()) {
                        schedule("*/10 * * * *", function () { // alle 10 Minuten die Werte abfragen
                            main();
                        });
                    }
                    
                    createAllStates();
                    
                    // Beim Skriptstart die Werte abfragen
                    setTimeout(main, 1000);
                    
                    
                    N 1 Reply Last reply Reply Quote 0
                    • N
                      newbie0815 @gutgut30 last edited by

                      @gutgut30 Hallo, vielen Dank für das Script. Der Adapter läuft bei mir nicht mehr - man muss wohl eine neue APi erzeugen, aber man muss auch für einen Free Account Zahlungsdaten usw. angeben. Ich würde gerne Dein Script benutzen, bin mir aber nicht sicher was ich genau machen muss. Kannst Du mir etwas auf die Sprünge helfen ? Danke.

                      N 1 Reply Last reply Reply Quote 0
                      • N
                        newbie0815 @newbie0815 last edited by

                        @newbie0815 Hi, ich habe Chatgpt bemüht und es läuft. Danke

                        G 1 Reply Last reply Reply Quote 0
                        • G
                          gutgut30 @newbie0815 last edited by

                          @newbie0815 ich kann dir morgen mal das aktuelle Script posten. Der Trigger funktioniert im hier geposteten so nämlich nicht wirklich sinnvoll und kann dir flott die kostenlosen API Aufrufe verbrauchen.

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

                          Support us

                          ioBroker
                          Community Adapters
                          Donate
                          FAQ Cloud / IOT
                          HowTo: Node.js-Update
                          HowTo: Backup/Restore
                          Downloads
                          BLOG

                          895
                          Online

                          31.9k
                          Users

                          80.1k
                          Topics

                          1.3m
                          Posts

                          48
                          119
                          27688
                          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