Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Vorlage] todoist.com To-Do-Listen Script für VIS

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] todoist.com To-Do-Listen Script für VIS

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

      Seit heute folgender Fehler..

      Unexpected token < in JSON at position 0

      Ich hab gelesen, dass es diesen Fehler schonmal gab und durch die Anpassung zweier Zeilen gefixt wurde... Bei mir ist das Script allerdings auf dem neusten Stand. Hat sonst noch jemand dieses Problem?

      Viele Grüße
      BJ

      haselchen 1 Reply Last reply Reply Quote 0
      • haselchen
        haselchen Most Active @Blackjack3000 last edited by haselchen

        @Blackjack3000
        @intruder7

        Ja, ich auch. Genau der gleiche Fehler, damals war es eine URL Anpassung .
        Vielleicht könnte derjenige, der damals geholfen hat, nochmal aushelfen.

        I sigi234 2 Replies Last reply Reply Quote 0
        • I
          intruder7 @haselchen last edited by

          @haselchen
          @Blackjack3000
          bei mir keine Probleme

          1 Reply Last reply Reply Quote 0
          • sigi234
            sigi234 Forum Testing Most Active @haselchen last edited by

            @haselchen

            https://forum.iobroker.net/topic/28021/html-table-für-vis-oder-iqontrol-js-und-blockly/54

            haselchen 1 Reply Last reply Reply Quote 0
            • haselchen
              haselchen Most Active @sigi234 last edited by

              @sigi234

              Hab ich schon sehen . Danke.
              Bin aber Old School. Wenn was funktioniert,
              dann änder ich nichts, sondern versuche zu "reparieren".
              By the way, Todoist geht wieder.
              Der Token Fehler kam nen halben Tag und war dann wieder weg.

              1 Reply Last reply Reply Quote 0
              • tobetobe
                tobetobe @tempestas last edited by

                @tempestas
                @haselchen

                Hallo,
                ein interessanter Beitrag. Nun wurde ja die Unterstützung von Alexa in ioBroker eingestellt.

                Ich selbst arbeite zurzeit an einer Offline-Variante zur Sprachsteuerung namens Rhasspy. Das funktioniert soweit sehr gut und ich habe auch bereits eine Einkaufsliste über den Bring!-Adapter integriert.

                Hierzu übergebe ich aus einem MQTT-Intent einfach den Wert (zB den Einkaufsgegenstand) an die Adresse der jeweiligen Einkaufsliste im Bring!-Adapter. Eine einfache Geschichte also.

                Es fehlt mir momentan nur noch eine ToDo-Liste. ToDoist hatte ich mir angeschaut und finde ich interessant. Für ToDoist gibt es jedoch meines Wissens keinen Adapter. Von daher würde ich eure Skripts und die VIS-Lösung bei mir gern einbauen.

                Deshalb meine Fragen:

                • Habt ihr euch schon mit einer Ersatzlösung für Alexa auseinandergesetzt?
                • Könnten die Skripte ggf. einfach an die von mir geschilderte Vorgehensweise angepasst werden?

                Wäre schön, wenn ihr euch hierzu kurz melden könntet. Herzlichen Dank schonmal.

                haselchen 1 Reply Last reply Reply Quote 0
                • haselchen
                  haselchen Most Active @tobetobe last edited by

                  @tobetobe

                  Ich habe das oder die Skripte auch nur übernommen.
                  Wie was wo funktioniert kann ich Dir leider mangels Wissen nicht beantworten.
                  In Verbindung mit Alexa und Handy und VIS läuft es perfekt.
                  Hab die Anleitung 1-2 Seiten vorher gepostet.

                  tobetobe 1 Reply Last reply Reply Quote 0
                  • tobetobe
                    tobetobe @haselchen last edited by

                    @haselchen
                    Guten Morgen,
                    vielen Dank für deine Antwort. Kein Problem, wenn du dich mit Javascript nicht so auskennst. Vielleicht könntest du mir jedoch noch etwas zur Funktionalität aus Anwendersicht sagen, bzw. mir kurz bestätigen, ob ich das Ganze richtig oder falsch verstehe.

                    Ich habe natürlich selbst versucht, mich in die Skripte einzulesen. Außer, dass im Namen bzw. in den Pfaden der Name Alexa auftaucht, kann ich jedoch nichts Alexa-spezifisches finden. Das meiste scheint mir ioBroker-intern zu sein oder mit Telegram zu tun zu haben oder mit der Ankopplung an ToDoist über den API-Token.

                    Soweit mein Verständnis von den Skripten.

                    Funktional verstehe ich das Ganze also so, dass Einträge in die ToDo- oder in die Einkaufslisten entweder über die App auf dem Handy oder über VIS erzeugt werden. Wenn das über VIS passiert, gibt es noch eine Message per Telegram (vermutlich an andere Mitglieder im Haushalt).
                    Das Ganze dann auch als Sprachkommando noch über Alexa ausführen zu können, scheint mir nur eine weitere Option zu sein, deren Funktionalität aber in ioBroker anders sichergestellt wird und vermutlich nichts mit diesen Skripten zu tun hat.

                    Passt das so, oder liege ich daneben?

                    Viele Grüße

                    haselchen 1 Reply Last reply Reply Quote 0
                    • haselchen
                      haselchen Most Active @tobetobe last edited by

                      @tobetobe

                      Ich antworte mal schnell zwischen Tür und Angel.
                      Also in der Todoist App oder auf der Website musst du in deinem Account eine Verbindung zu Alexa herstellen.
                      In der Alexa App dann den Todoist Skill aktivieren.
                      So entsteht über den Api Token die Verbindung.

                      tobetobe 1 Reply Last reply Reply Quote 0
                      • tobetobe
                        tobetobe @haselchen last edited by

                        @haselchen

                        Hallo, vielen Dank soweit. Meine Frage ging allerdings in eine andere Richtung, da ich ja keine Alexa. Ich möchte ToDoist einfach nur an ioBroker anbinden.

                        @tempestas

                        Bitte sei so gut, und greife meine Fragen auf. Ich denke, mit ein paar einfachen Hinweisen komme ich schon weiter. Vielen Dank.

                        Grüße
                        Thomas

                        haselchen 1 Reply Last reply Reply Quote 0
                        • haselchen
                          haselchen Most Active @tobetobe last edited by haselchen

                          @tobetobe

                          Das Du Dich an @tempestas richtest ist, denke ich, genau richtig.
                          Zu Deiner Fragestellung.
                          Wie Du das weiter oben erklärt hast, ist das schon richtig.
                          Da ich programmiertechnisch nicht bewandert bin würde ich vorschlagen, dass Du Dich nebenbei auch auf der Website von Todoist umsiehst.
                          Du müsstest Dir da nen kostenlosen Account einrichten und ich meine, dass in dem Account ne Menge Einstellmöglichkeiten bezüglich 3rd PartyApps und API vorhanden sind.

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

                            Hallo! Habt ihr hier immer noch das Ziel, dies in einen Adapter umzuwandeln, oder ist das aktuell nicht geplant? Gerade was das Thema VIS betrifft könnte man hier sicher noch ein schönes Widget dazugestalten. Und ich glaube, mit den Skripten gibt es immer wieder viele Anwender, die sich hier schwer tun.

                            1 Reply Last reply Reply Quote 0
                            • F
                              flubb last edited by

                              Hallo zusammen,

                              ich weiß dass es mittlerweile einen Adapter gibt, jedoch war für mich das Skript bisher vollkommen ausreichend, nur leider funktioniert es aktuell wohl nicht mehr.
                              Habe die URL bereits auf die REST-API v2 umgestellt, trotzdem bekomme ich auf die Request-Funktion nur ein "Forbidden" als Antwort. Kann hier jemand sagen was ich falsch mache?

                                  var APIprojectsURL = "https://api.todoist.com/rest/v2/projects?token=" + APItoken;
                                  var request = require("request");
                              
                                  request(APIprojectsURL, function (error, response, body){
                                      log(body);
                                  });
                              
                              info	javascript.0 (13563) script.js.Todoist.TodoListe: Forbidden
                              

                              Wenn ich die URL einfach im Browser eingebe, erhalte ich das gewünschte JSON als Antwort. Die URL scheint mir also korrekt...

                              DANKE

                              J 1 Reply Last reply Reply Quote 0
                              • J
                                JayDee @flubb last edited by

                                @flubb
                                hey.
                                same here 😞 .

                                Hat jmd. einen Tipp?

                                Danke! 😉

                                S 1 Reply Last reply Reply Quote 0
                                • S
                                  Streit187 @JayDee last edited by

                                  @jaydee @flubb

                                  Die derzeit richtigen URL´s lauten:
                                  var APIprojectsURL = "https://api.todoist.com/rest/v2/projects?token=" + APItoken;
                                  var APItaskURL = "https://api.todoist.com/rest/v2/tasks?token=" + APItoken;

                                  Weiter braucht es inzwischen einen Header zur Authentifizierung. Dazu unter den Variablen einfügen:

                                      const options = {
                                    headers: {
                                      'Authorization': 'Bearer ' + APItoken
                                    }
                                  }
                                  

                                  und dann bei den beiden "request" Zeilen:

                                  request(APIprojectsURL, options, function (error, response, body) {
                                  

                                  und

                                  request(APItaskURL, options, function (error, response, body) {
                                  
                                  1 Reply Last reply Reply Quote 0
                                  • B
                                    Beowolf last edited by

                                    Ich habe mal versucht das Skrip auf "httpget" umzuschreiben.

                                    Ich hoffe das es so richtig ist - es funktioniert bei mir.

                                    //  Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
                                    //  Scriptversion: v0.2
                                    //  Ergänzungen tempestas, Stand 17.3.2018
                                    //  https://forum.iobroker.net/viewtopic.php?f=21&t=12563
                                    //  https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
                                    //  umgeschrieben/geändert "request" durch "https.get"  10.06.2024
                                     
                                    //Erforderliche Angaben:
                                    var APItoken = "xxxx"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                    var debug = false;
                                    var force = true;
                                     
                                    //Weitere Parameter ggf. anpassen:
                                    var instanz = 'javascript.0';  instanz = instanz + '.';     // Instanz fuer die Datenpunkte definieren
                                    var pfad =   'Todoist.';                    // Pfad definieren
                                    // var regexTrigger = /^javascript\.0\.Einkaufsliste\.Items\..*$/;   // Trigger analog der manuellen Einkaufsliste, brauchst du nicht, deaktiviert
                                     
                                    schedule("*/1 * * * *", checkTODOIST);  // Abfragezeit: alle 6 Minuten
                                    
                                    const https = require('https');
                                    
                                    const options = {
                                      headers: {
                                        'Authorization': 'Bearer ' + APItoken
                                      }
                                    }
                                    
                                    // *********************************************************
                                    // Scriptbeginn - Ab hier nichts mehr ändern!
                                    // *********************************************************
                                    
                                    function checkTODOIST() {
                                        
                                        var APIprojectsURL = "https://api.todoist.com/rest/v2/projects";
                                        var APItaskURL = "https://api.todoist.com/rest/v2/tasks";
                                        var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                                        var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                                    
                                        https.get(APIprojectsURL, options, (response) => {
                                            let body = '';
                                            
                                            response.on('data', (chunk) => {
                                                body += chunk;
                                            });
                                    
                                            response.on('end', () => {
                                                try {
                                                    var projects_json = JSON.parse(body);
                                                    for (let k = 0; k < projects_json.length; k++) {
                                                        var projects = parseInt(projects_json[k].id);
                                                        var projects_name = projects_json[k].name;
                                                        ToDoListen[ToDoListen.length] = projects;
                                                        ToDoListen_names[ToDoListen_names.length] = projects_name;
                                                        createState(instanz + pfad + ToDoListen_names[k], {def: 'false', type: 'string', role: 'html', name: ToDoListen_names[k] + ' HTML String'});
                                                        if (debug) log("Datenpunkt " + ToDoListen_names[k] + " erstellt.", "info");
                                                        createState(instanz + pfad + ToDoListen_names[k] + '.TaskID', {def: 'false', type: 'string', role: 'string', name: ToDoListen_names[k] + ' Task IDs'});
                                                        if (debug) log("Datenpunkt " + ToDoListen_names[k] + '.TaskID' + " erstellt.", "info");            
                                                    }
                                                } catch (err) {
                                                    log(err.message);
                                                }
                                            });
                                        }).on('error', (err) => {
                                            log(err.message);
                                        });
                                        
                                        setTimeout(function() {
                                            https.get(APItaskURL, options, (response) => {
                                                let body = '';
                                    
                                                response.on('data', (chunk) => {
                                                    body += chunk;
                                                });
                                    
                                                response.on('end', () => {
                                                    try {
                                                        var tasks = JSON.parse(body);
                                                        for (let j = 0; j < ToDoListen.length; j++) {
                                                            var HTMLcontent = "";
                                                            var HTMLtaskid = "";
                                                            for (let i = 0; i < tasks.length; i++) {
                                                                var content = 'leer';
                                                                if (tasks[i].content) content = tasks[i].content;
                                                                content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                                                                var taskurl = tasks[i].url;
                                                                var taskid = 'leer';
                                                                if (tasks[i].id) taskid = tasks[i].id;
                                                                var id = tasks[i].project_id;
                                                                if (id == ToDoListen[j]) {
                                                                    if (debug) log("[" + content + "] in " + ToDoListen_names[j] + " gefunden", "info");
                                                                    HTMLcontent = HTMLcontent + content + "<br>";
                                                                    if (debug) log("[" + taskid + "] in " + ToDoListen_names[j] + " gefunden", "info");
                                                                    HTMLtaskid = HTMLtaskid + taskid + "<br>";
                                                                }
                                                            }
                                                            setState(instanz + pfad + ToDoListen_names[j], HTMLcontent);
                                                            setState(instanz + pfad + ToDoListen_names[j] + '.TaskID', HTMLtaskid);
                                                        }
                                                    } catch (err) {
                                                        log(err.message);
                                                    }
                                                });
                                            }).on('error', (err) => {
                                                log(err.message);
                                            });
                                        }, 2000);
                                    }
                                    

                                    Grüße

                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      Beowolf last edited by

                                      Hallo zusammen,

                                      ich habe das Skript vom Beitrag über diesem am laufen.

                                      Dazu habe ich eine Frage.

                                      Hier

                                      ordner1.jpg

                                      erscheinen Werte in der "Ordnerzeile". Ist das so richtig?
                                      Das habe ich bei keinem anderen Ordner so gesehen.

                                      Hier so wie das Skript ist.

                                      skript1.jpg

                                      Grüße

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

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      945
                                      Online

                                      31.7k
                                      Users

                                      79.7k
                                      Topics

                                      1.3m
                                      Posts

                                      28
                                      130
                                      18299
                                      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