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.
    • E
      eXTreMe last edited by

      Wenn man Alexa mit Todoist verknüpft hat dann wird bei „setze auf todo liste“ das element in die Liste „Eingang“ bzw „Inbox“ gepackt. Sagt man Alexa „setze auf die Einkaufsliste“ dann erstellt todoist eine neue Liste namens Alexa-Einkaufsliste und erstellt dort die Elenente.

      Das Script erstellt für alle Listen jeweils einen Datenpunkt mit dem Listeninhalt.

      Den Schedule des Scripts kann man aber auch problemlos auf ein 1 Minuten Intervall umstellen.

      Todoist selbst braucht auch ca eine Minute um sich mit Alexa zu synchronisieren. Kann also manchmal auch 2 Minuten dauern bis die Liste in VIS aktualisiert ist wenn der abfragezyklus in dem moment etwas ungünstig liegt.

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

        @eXTreMe:

        Wenn man Alexa mit Todoist verknüpft hat dann wird bei „setze auf todo liste“ das element in die Liste „Eingang“ bzw „Inbox“ gepackt. Sagt man Alexa „setze auf die Einkaufsliste“ dann erstellt todoist eine neue Liste namens Alexa-Einkaufsliste und erstellt dort die Elenente.

        Das Script erstellt für alle Listen jeweils einen Datenpunkt mit dem Listeninhalt.

        Den Schedule des Scripts kann man aber auch problemlos auf ein 1 Minuten Intervall umstellen.

        Todoist selbst braucht auch ca eine Minute um sich mit Alexa zu synchronisieren. Kann also manchmal auch 2 Minuten dauern bis die Kiste in VIS aktualisiert ist wenn der abfragezyklus in dem moment etwas ungünstig liegt. `
        Wenn man IFFFT service benutzt, dann kann man darüber ioBroker triggern und ioBroker wird die Liste ziemlich sofort updaten.

        Es währe cool so ein Video zu haben:

        Alexa setzte auf Einkaufsliste blabla =>

        und dann erscheint sofort das auf vis. 🙂

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

          ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

          Zum einen müssten Dopplungen ausgeschlossen werden.

          Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

          Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann

          1 Reply Last reply Reply Quote 0
          • E
            eXTreMe last edited by

            @tempestas:

            ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

            Zum einen müssten Dopplungen ausgeschlossen werden.

            Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

            Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann `
            gibt eine REST API, man kann über cURL http POST befehle auch löschen.

            Bin erst totaler Neuling auf dem Gebiet, habe bisher nur GET befehle zum auslesen der tasks verwendet, weiß auch garnicht ob oder wie POST befehle mit javascript gehen, geschweige denn was überhaupt cURL genau ist und wie es funktioniert, bin mich noch am einlesen.

            Hier der Link zur API Doku: https://developer.todoist.com/rest/v8/#delete-a-task

            Wenn du da schlauer bist als ich und das script erweitern möchtest oder eine andere lösung für dein problem hast: nur zu!

            Ich lösche meine Events mit der todoist App auf meinem smartphone. Das script sollte einfach nur eine zusätzliche Darstellung auf VIS ermöglichen.

            Vielleicht kann man über IFTTT Webhooks auch etwas realisieren, Bluefox hatte das ja oben mal in den raum geworfen.

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

              @tempestas:

              ich überlege gerade, wie ich das Ding mit meiner existierenden Liste verknüpfen kann.

              Zum einen müssten Dopplungen ausgeschlossen werden.

              Dann ist die Frage, wie ich todoist Listen von Extern löschen bzw leeren kann - nur per Sprache?

              Hinzufügen ist auf die Art sehr angenehm, löschen finde ich dagegen anstrengend. Insbesondere, wenn ich z.B. 10 Sachen auf der Liste hatte, aber nur 8 gekauft habe. Dann müsste ich wahrscheinlich via Sprachbefehl 8 Sachen einzeln löschen, oder? Habe mir todoist bis heute noch nicht angesehen und suche gerade, ob man quasi von extern auch Dinge löschen kann `
              Sollte damit möglich sein.

              https://developer.todoist.com/sync/v7/

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

                @eXTreMe:

                habe bisher nur GET befehle zum auslesen der tasks verwendet `
                Wie denn? da braucht man doch auth key?

                1 Reply Last reply Reply Quote 0
                • E
                  eXTreMe last edited by

                  @Bluefox:

                  @eXTreMe:

                  habe bisher nur GET befehle zum auslesen der tasks verwendet Wie denn? da braucht man doch auth key?
                  Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

                  Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

                  Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

                  Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

                  hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview

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

                    Hi,

                    nur, damit wir uns da nicht missverstehen: das war keine Kritik und auch kein "mach mal mehr". Ich könnte das gar nicht, was du da gebastelt hast.

                    Als BWLer bin ich schon froh, das ich das, was du da gebastelst hast nachvollziehen und "lesen" kann.

                    War mehr meine Gedankensammlung zum Thema "was hätte ich gerne noch". Ich schaue mir die Sachen mal an

                    1 Reply Last reply Reply Quote 0
                    • E
                      eXTreMe last edited by

                      @tempestas:

                      Hi,

                      nur, damit wir uns da nicht missverstehen: das war keine Kritik und auch kein "mach mal mehr". Ich könnte das gar nicht, was du da gebastelt hast.

                      Als BWLer bin ich schon froh, das ich das, was du da gebastelst hast nachvollziehen und "lesen" kann.

                      War mehr meine Gedankensammlung zum Thema "was hätte ich gerne noch". Ich schaue mir die Sachen mal an `
                      Keine Angst, habe ich nicht so aufgefasst 🙂

                      Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben.

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

                        @eXTreMe:

                        @Bluefox:

                        @eXTreMe:

                        habe bisher nur GET befehle zum auslesen der tasks verwendet Wie denn? da braucht man doch auth key?
                        Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

                        Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

                        Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

                        Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

                        hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview `

                        Die Frage mag total blöd sein, aber ich stelle sie trotzdem:

                        wie kommst du aus dieser Doku von diesem Beispiel:

                        
                            Get tasks
                        
                        $ curl -X GET \
                          https://beta.todoist.com/API/v8/tasks \
                          -H "Authorization: Bearer $token”
                        
                        [
                            {
                                "id": 123,
                                "project_id": 234,
                                "content": "Inbox",
                                "comment_count": 10,
                                "order": 1,
                                "indent": 1,
                                "priority": 1,
                                "url": "https://todoist.com/showTask?id=123"
                            },
                            ...
                        ]
                        
                        

                        auf das hier:

                            request( https://beta.todoist.com/API/v8/tasks?token="+APItoken;;  , function (error, response, body) { ..... )
                        ````?
                        1 Reply Last reply Reply Quote 0
                        • Bluefox
                          Bluefox last edited by

                          @eXTreMe:

                          Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben. `
                          :!: :!: :!:

                          Push mal auf github, dann kann ich auch vielleicht helfen.

                          1 Reply Last reply Reply Quote 0
                          • E
                            eXTreMe last edited by

                            @Bluefox:

                            @eXTreMe:

                            Ich arbeite auch gerade daran das Script in einen Adapter umzuwandeln, so werden es sicher mehr Leute nutzen und wenn darunter der ein oder andere pfiffige Programmierer ist, dann wird es evt auch eher Funktionserweiterungen geben. `
                            :!: :!: :!:

                            Push mal auf github, dann kann ich auch vielleicht helfen. `
                            Hab es auf github hochgeladen, bekomme den Adapter aber nicht zum laufen. Habe im ioBroker Entwickler Forum einen Beitrag eröffnet.

                            Wäre super wenn du mal drüberschauen könntest.

                            viewtopic.php?f=24&t=12583

                            1 Reply Last reply Reply Quote 0
                            • E
                              eXTreMe last edited by

                              @tempestas:

                              @eXTreMe:

                              @Bluefox:

                              Wie denn? da braucht man doch auth key? `
                              Den API Key kann man unter todoist.com in den Profileinstellungen unter dem Menüpunkt Integration auslesen (wie oben schon beschrieben). Jeder Useraccount hat einen API Key.

                              Und habe damit dann die JSONs für meine Listen und Tasks ausgelesen

                              Listen: https://beta.todoist.com/API/v8/project … XXXXXXXXXX

                              Tasks: https://beta.todoist.com/API/v8/tasks?token=XXXXXXXXXX

                              hier die REST API Doku aus der ich die infos habe: https://developer.todoist.com/rest/v8/#overview `

                              Die Frage mag total blöd sein, aber ich stelle sie trotzdem:

                              wie kommst du aus dieser Doku von diesem Beispiel:

                              
                                  Get tasks
                              
                              $ curl -X GET \
                                https://beta.todoist.com/API/v8/tasks \
                                -H "Authorization: Bearer $token”
                              
                              [
                                  {
                                      "id": 123,
                                      "project_id": 234,
                                      "content": "Inbox",
                                      "comment_count": 10,
                                      "order": 1,
                                      "indent": 1,
                                      "priority": 1,
                                      "url": "https://todoist.com/showTask?id=123"
                                  },
                                  ...
                              ]
                              
                              

                              auf das hier:

                                  request( https://beta.todoist.com/API/v8/tasks?token="+APItoken;;  , function (error, response, body) { ..... )
                              ````? `  
                              

                              Ist eigentlich einfach:

                              $ curl -X GET \
                                https://beta.todoist.com/API/v8/tasks \
                                -H "Authorization: Bearer $token”
                              

                              Da steht die http-GET URL die du brauchst: https://beta.todoist.com/API/v8/tasks

                              und das Attribut welches benötigt wird: $token

                              Zusammengesetzt sieht das dann so aus: https://beta.todoist.com/API/v8/tasks?token=XXXX

                              Das kannst du mal im Browser eingeben mit deinem Token am Ende, dann sollte soetwas wie oben im Beispiel angegeben rauskommen (ggf. brauchst du noch ein Browser Addon wie "json view" damit es halbwegs schön angezeigt wird):

                                  {
                                      "id": 123,
                                      "project_id": 234,
                                      "content": "Inbox",
                                      "comment_count": 10,
                                      "order": 1,
                                      "indent": 1,
                                      "priority": 1,
                                      "url": "https://todoist.com/showTask?id=123"
                                  },
                              

                              mit dem rest von meinem javascript lese ich quasi die einzelnen Elemente aus dem json aus, packe sie in Variablen und verarbeite sie dann zu einem HTML Code für VIS.

                              Ich hab mir das auch nur aus anderen Scripten oder Javascript Online-Dokumentationen zusammengesucht und zusammengebastelt. Wirklich 100% verstanden habe ich das selber auch noch nicht im Detail, da ich nie systematisch bei Null angefangen habe Javascript zu lernen.

                              Du kannst den Code aus meinem Script quasi für alle möglichen http GET API anfragen (also nur daten auslesen, nicht ändern!) ganz einfach umschreiben wenn du selber etwas realisieren möchtest.

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

                                Hallo exTreme,

                                ich habe dein Skript etwas abgewandelt, damit man nun zumindest via eines Buttons in VIS die GESAMTE Liste löschen kann. Habs gerade getestet, funktioniert.

                                In deinem Skript habe ich eine zusätzliche Funktion eingebaut und ein createState, um die IDs der Tasks mit in die jeweilige Liste zu schreiben. Das ist dann fürs Löschen benötigt. Außerden, aber das ist reine Optik, habe ich die Link Funktion rausgenommen, mir reicht ein einfacher HTML Zeilenumbruch.

                                Hier das leicht ergänzte Skript:

                                ! ```
                                `//Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
                                //Scriptversion: v0.1
                                //https://forum.iobroker.net/viewtopic.php?f=21&t=12563
                                // https://forum.iobroker.net/viewtopic.php?f=21&p=133205#p133205
                                ! //Erforderliche Angaben:
                                var APItoken = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                ! //Weitere Parameter ggf. anpassen:
                                var instanz = 'javascript.0'; instanz = instanz + '.'; // Instanz fuer die Datenpunkte definieren
                                var pfad = 'Todoist.'; // Pfad definieren
                                schedule("*/1 * * * *", function () { // Abfragezeit: alle 1 Min
                                ! // Scriptbeginn - Ab hier nichts mehr ändern!
                                var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                                var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                                var request = require("request");
                                var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                                var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt

                                request(APIprojectsURL, function (error, response, body) {
                                    var projects_json = JSON.parse(body);
                                    for (k = 0; k < projects_json.length; k++) {
                                        var projects = parseInt(projects_json[k].id);
                                        var projects_name = JSON.stringify(projects_json[k].name);
                                        projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                        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'});
                                        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'});   // NEU EINGEFÜGT TEMPESTAS
                                        log("Datenpunkt "+ToDoListen_names[k]+'.TaskID'+" erstellt.", "info");            
                                    }
                                
                                });
                                setTimeout(function() {
                                    request(APItaskURL, function (error, response, body) {
                                        var json = JSON.parse(body);
                                        for (j = 0; j < ToDoListen.length; j++) {
                                            var HTMLstring = "";
                                            setState(instanz + pfad + ToDoListen_names[j], "leer");
                                            for (i = 0; i < json.length; i++) {
                                                var Liste = parseInt(json[i].project_id);
                                                var content = JSON.stringify(json[i].content);
                                                content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                                                var taskurl = JSON.stringify(json[i].url);
                                                taskurl = taskurl.replace(/\"/g, "");
                                                if (Liste == ToDoListen[j])
                                                {
                                                    log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                    HTMLstring = HTMLstring+content+"
                                

                                "; // mit Link: HTMLstring = HTMLstring+"* "+content+"";
                                setState(instanz + pfad + ToDoListen_names[j], HTMLstring); // "<>"+HTMLstring+"

                                ! ");
                                }
                                }
                                }

                                     });
                                }, 5000);
                                
                                    setTimeout(function() {                                                 // NEU EINGEFÜGT TEMPESTAS: legt IDs der einzelnen Tasks in Unterordnern an 
                                    request(APItaskURL, function (error, response, body) {
                                
                                        var json = JSON.parse(body);
                                
                                        for (j = 0; j < ToDoListen.length; j++) {
                                
                                            var HTMLstring = "";
                                
                                            setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                                            for (i = 0; i < json.length; i++) {
                                                var Liste = parseInt(json[i].project_id);
                                                var taskid = JSON.stringify(json[i].id);
                                                if (Liste == ToDoListen[j])
                                                {
                                                    log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                    HTMLstring = HTMLstring+taskid+"
                                

                                ";
                                setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring);
                                }
                                }
                                }

                                     });
                                }, 6000);
                                

                                });`

                                ! und mit diesem Skript kann man dann die Tasks (bzw Einkäufe) löschen. Hier im Beispiel reagiert es noch nicht auf einen VIS Button, aber einen Trigger einzubauen ist ja nun das Einfachste. Den könnte man dann über ioBroker auch via Alexa ansprechen.
                                ! >! [spoiler]`[code]
                                //Erforderliche Angaben:
                                var APItoken = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                var idEinkaufsliste = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID"; // hier den Pfad zur Einkaufsliste anlegen, die bei Betätigung gelöscht werden soll
                                ! // Scriptbeginn - ab hier nichts mehr ändern
                                ! var request = require("request");
                                !
                                function deleteTask(){
                                ! var idListArray =[];
                                var idList;

                                idList = getState(idEinkaufsliste).val;			
                                log(idList);
                                idListArray = idList.split("
                                

                                ");
                                idListArray.pop(); // aufgrund meiner uneleganten Änderungen steht als letztes immer "
                                " in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den Array ums letzte Element

                                log("idList Array ist " +idListArray);
                                log("idList Array Länge ist "+idListArray.length);
                                
                                for (i = 0; i< idListArray.length; i++){
                                
                                    log("Durchgang "+i);
                                
                                    var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListArray[i]+"?token="+APItoken;
                                    log("Delete URL ist "+deleteURL);
                                
                                    request({
                                        uri: deleteURL,
                                        method: "DELETE",
                                        timeout: 5000,
                                        }, 
                                            function(error, response, body) {
                                            console.log(body);
                                        });    
                                    }
                                

                                }

                                ! // Bei Start zum Testen
                                ! deleteTask();
                                ! // Bei Start zum Testen --> Später durch VIS Trigger ersetzen (könnte dann auch über Alexa gesteuert werden)
                                ! deleteTask();` [/i][/code][/spoiler][/i][/i][/i][/i][/i]

                                1 Reply Last reply Reply Quote 0
                                • E
                                  eXTreMe last edited by

                                  @tempestas:

                                  Hallo exTreme,

                                  ich habe dein Skript etwas abgewandelt, damit man nun zumindest via eines Buttons in VIS die GESAMTE Liste löschen kann. Habs gerade getestet, funktioniert. `

                                  Coole Sache!

                                  Habs probiert und es funktioniert super!

                                  Ich wusste nicht, dass es das hier gibt:

                                  method: "DELETE",
                                  

                                  Werde mich damit nochmal befassen., denn damit ergeben sich noch viele neue Möglichkeiten!

                                  Vielen Dank dafür!

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

                                    Habs gemacht wie du: googlen und ausprobieren 😉

                                    hier habe ich meine Infos gezogen:

                                    https://www.sitepoint.com/making-http-r … n-node-js/

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

                                      ich habe hier irgendwie Fehler im Log bei meinem abgewandeltem Skript. Da scheint was noch nicht zu stimmen:

                                      javascript.1	2018-03-15 14:59:06.204	error	at IncomingMessage.g (events.js:292:16)
                                      javascript.1	2018-03-15 14:59:06.204	error	at IncomingMessage. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1085:12)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Request.emit (events.js:188:7)
                                      javascript.1	2018-03-15 14:59:06.204	error	at emitOne (events.js:96:13)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Request. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1163:10)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Request.emit (events.js:191:7)
                                      javascript.1	2018-03-15 14:59:06.204	error	at emitTwo (events.js:106:13)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Request.self.callback (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:186:22)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Request._callback (script.js.common.Einkauf.todoist_alexa_listen2:38:29)
                                      javascript.1	2018-03-15 14:59:06.204	error	at Object.parse (native)
                                      javascript.1	2018-03-15 14:59:06.204	error	SyntaxError: Unexpected token I in JSON at position 0
                                      javascript.1	2018-03-15 14:59:06.203	error	uncaught exception: Unexpected token I in JSON at position 0
                                      

                                      Zeile 38 begeinnt bei mir das Task abholen. Denke, das hängt sich auf, weil nach dem Löschen keine Tasks mehr enthalten sind?

                                      Nachtrag: habe es mal ne ganze Weile beobachtet. Das kommt irgendwie nicht immer, obwohl ich nichts weiter geändert habe? Also auch bei Projekten ohne Tasks kommt nicht immer der Fehler. Nun bin ich planlos.

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

                                        Ich sheitere daran, die Create Task Erklärung aus der API in mein Javascript zu "übersetzen". IRgendwie fehlt mir da der Zugang, und google hat noch nicht wirklich geholfen. Kann mir jemand den entscheidenen Tipp geben? Wie füge ich einen Task hinzu?

                                        wie "übersetze" ich

                                        $ curl "https://beta.todoist.com/API/v8/tasks" \
                                            -X POST \
                                            --data '{"content": "Appointment with Maria", "due_string": "tomorrow at 12:00", "due_lang": "en", "priority": 4}' \
                                            -H "Content-Type: application/json" \
                                            -H "X-Request-Id: $(uuidgen)" \
                                            -H "Authorization: Bearer $token"
                                        
                                        {
                                            "comment_count": 0,
                                            "completed": false,
                                            "content": "Appointment with Maria",
                                            "due": {
                                                "date": "2016-09-01",
                                                "datetime": "2016-09-01T11:00:00Z",
                                                "string": "2017-07-01 12:00",
                                                "timezone": "Europe/Lisbon"
                                            },
                                            "id": 123,
                                            "order": 20,
                                            "priority": 4,
                                            "project_id": 234,
                                            "url": "https://todoist.com/showTask?id=123"
                                        }
                                        
                                        

                                        in mein Javascript? Beim löschen habe ich es ja hinbekommen, aber etwas hinzufügen, da scheitere ich.

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

                                          Also die Fehlermeldungen kommen leider weiter.

                                          Es bezieht sich aber augenscheinlich auf den Bereich, den ich NICHT geändert habe.

                                          ! ````
                                          host.iobrokerNUC 2018-03-16 07:55:01.368 error instance system.adapter.javascript.1 terminated with code 0 (OK)
                                          Caught 2018-03-16 07:55:01.368 error by controller[0]: at IncomingMessage.g (events.js:292:16)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at IncomingMessage. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1085:12)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at Request.emit (events.js:188:7)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at emitOne (events.js:96:13)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at Request. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1163:10)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at Request.emit (events.js:191:7)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at emitTwo (events.js:106:13)
                                          Caught 2018-03-16 07:55:01.367 error by controller[0]: at Request.self.callback (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:186:22)
                                          Caught 2018-03-16 07:55:01.366 error by controller[0]: at Request._callback (script.js.common.Einkauf.todoist_alexa_listen2:23:34)
                                          Caught 2018-03-16 07:55:01.366 error by controller[0]: at Object.parse (native)
                                          Caught 2018-03-16 07:55:01.364 error by controller[0]: SyntaxError: Unexpected token I in JSON at position 0
                                          javascript.1 2018-03-16 07:55:01.187 error at IncomingMessage.g (events.js:292:16)
                                          javascript.1 2018-03-16 07:55:01.187 error at IncomingMessage. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1085:12)
                                          javascript.1 2018-03-16 07:55:01.187 error at Request.emit (events.js:188:7)
                                          javascript.1 2018-03-16 07:55:01.187 error at emitOne (events.js:96:13)
                                          javascript.1 2018-03-16 07:55:01.187 error at Request. (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:1163:10)
                                          javascript.1 2018-03-16 07:55:01.187 error at Request.emit (events.js:191:7)
                                          javascript.1 2018-03-16 07:55:01.187 error at emitTwo (events.js:106:13)
                                          javascript.1 2018-03-16 07:55:01.187 error at Request.self.callback (/opt/iobroker/node_modules/iobroker.javascript/node_modules/request/request.js:186:22)
                                          javascript.1 2018-03-16 07:55:01.187 error at Request._callback (script.js.common.Einkauf.todoist_alexa_listen2:23:34)
                                          javascript.1 2018-03-16 07:55:01.187 error at Object.parse (native)
                                          javascript.1 2018-03-16 07:55:01.187 error SyntaxError: Unexpected token I in JSON at position 0
                                          javascript.1 2018-03-16 07:55:01.171 error uncaught exception: Unexpected token I in JSON at position 0

                                          
                                          Seltsamerweise kommt dieser Fehler auch nicht dauernd, obwohl der Schedule auf 1 Minute eingestellt ist sondern eben hier um 7:55h und davor um 6:59h? Jemand ne Idee?
                                          
                                          Nachtrag: entgegen meiner gestrigen Vermutung kommt der Fehler offenbar auch, wenn die Liste befüllt ist.
                                          
                                          Abseits vom Fehler: das hinzufügen von Extern (ohne Alexa) scheitert glaube ich i.W. am uniquie identifier, der benötigt wird. Was das nun wieder ist (außer dem rein vom Namen her offensichtlichem) und wie ich damit umgehe muss ich noch versuchen zu finden und zu verstehen
                                          1 Reply Last reply Reply Quote 0
                                          • T
                                            tempestas last edited by

                                            Guten morgen zusammen,

                                            ich habe das Thema weiter bearbeitet. Herausgekommen ist jetzt, dass ich die Zusammenführung meiner "manuellen" (d.h. am Tablet zu bedienenden) Liste und der todoist Alexa Liste soweit fertig habe, dass ich via Alexa Einkäufe hinzufügen kann und via Eingabe am Tablet auch. Diese Eingaben werden dann auch auf der TODOIST Liste berücksichtigt. Es funktioniert sowohl das hinzufügen als auch das löschen einzelner Dinge.

                                            Was noch fehlt ist jetzt die Rückkopplung in die andere Richtung, also ich füge etwas via Alexa hinzu und es wird entsprechend auf dem Tablet markiert (es soll ja nicht nur in die Liste gehen sondern der jeweilige Button muss auch true gehen). Dabei stellt sich mir neben der generellen Herausforderung aber noch das Problem, dass ich aktuell fürchte ich einen Zirkel schaffen würde, denn todoist lauscht jetzt auf Änderungen am Tablet. Wenn also das Tablet nun auf Änderungen bei Todoist lauscht, dann triggert sich beides gegenseitig. Dazu muss ich mir noch Gedanken machen.

                                            Aus Übersichtlichkeitsgründen habe ich derzeit drei Skripte.

                                            Skript 1 ist mein "manuelles Skript", visualisiert sieht das so aus:

                                            ! ![](</s><URL url=)<link_text text="download/file.php?id=22640&mode=view">https://forum.iobroker.net/download/file.php?id=22640&mode=view</link_text>" /> ~~das Skript:

                                            ! ```
                                            `// Einkaufsliste
                                            //
                                            // Idee und Basis: dna909
                                            //
                                            // http://forum.iobroker.net/viewtopic.php?f=21&t=8766
                                            //
                                            // abgewandelt: tempestas, Datum 6.11.2017
                                            //
                                            // status: v 1.0 - stable
                                            // status: v 1.1 - regex trigger über state verzögert, da sonst bei erstmaligem Ausführen ständig getriggert wird und damit Warnungen im LOG stehen;
                                            // - state für VIS Kategorienumschaltung eingefügt; Fehler bei PurchList.length korrigiert, die -1 entfernt.
                                            ! // SKRIPTEINSTELLUNGEN
                                            ! var debug = false;
                                            var force = true;
                                            var path = "javascript.0.Einkaufsliste."; // Pfad für generelle Variablen und States
                                            var pathItems = "javascript.0.Einkaufsliste.Items."; // Pfad für die zu kaufenden Gegenstände
                                            !
                                            ! // ############################
                                            // ########## STATES ##########
                                            // ############################
                                            ! createState(path +'regex', false, force, {
                                            name: "Liste",
                                            type: 'boolean',
                                            role: 'state',
                                            });
                                            ! createState(path +'Liste', "", force, { // String, in dem die Einkaufsliste gespeichert wird
                                            name: "Liste",
                                            type: 'string',
                                            role: 'string',
                                            });
                                            ! createState(path +'clearBtn', false, force, { // löschen Button, damit man nicht alles manuell abwählen muss
                                            name: 'Clear Liste',
                                            desc: 'Löscht die Liste',
                                            type: 'boolean',
                                            role: 'state',
                                            unit: ''
                                            });
                                            ! createState(path +'telegramBtn', false, force, { // sendet die Liste via Telegram
                                            name: 'Send Telegram',
                                            desc: 'Sendet Telegram Einkaufsliste',
                                            type: 'boolean',
                                            role: 'state',
                                            unit: ''
                                            });
                                            ! createState(path +'visCategory',0, force, { // für die verschiedenen Kategorien
                                            name: 'VIS Einkaufsliste',
                                            type: 'number',
                                            min: '0',
                                            max: '20',
                                            states: '0:Obst;1:Gemüse;2:Wurst/Fleisch; 3:Käse/Milchprodukte; 4: Brot/Getreide; 5: Saucen/Gewürze; 6: Getränke; 7: Drogerie 1; 8: Drogerie 2',
                                            desc: 'Einkaufskategorien'
                                            });
                                            ! createState(path +'visBtn', false, force, { // trigger für Anzeige der Gesamtliste in Vis
                                            name: 'Show Liste',
                                            desc: 'Zeigt die Gesamtliste in Vis',
                                            type: 'boolean',
                                            role: 'state',
                                            unit: ''
                                            });
                                            ! createState(path +'count',0, force, {
                                            name: 'VIS Einkaufsliste Anzahl Objekte',
                                            type: 'number',
                                            min: '0',
                                            max: '200',
                                            });
                                            ! // #########################################################
                                            // ARRAY MIT INHALT DER KAUFGEGENSTÄNDE
                                            // #########################################################
                                            ! var PurchList= [ "Ananas", "Apfel", "Aprikose_Pfirsich","Banane", "Birne", "Datteln", "Erdbeeren","Kirschen",
                                            "Kiwi", "Mandarine","Mango", "Melone", "Orange", "Waldbeeren", "Weintrauben", "Zitrone_Limette",

                                                                "Chilis", "Chinakohl", "Erbsen", "Gurke","Karotten", "Kartoffeln",  "Kohlrabi", "Kürbis", "Lauch", "Mais", "Paprika",
                                                                "Pilze", "Radieschen", "Tomaten", "Zucchini", "Zwiebeln", 
                                            
                                                                "Aufschnitt", "Geflügel", "Geschnetzeltes", "Hackfleisch", "Kabanossi", "Rind", "Schwein", "Wiener","Fischstäbchen", "Garnelen", 
                                            
                                                                "Bratfix", "Butter", "Creme-Fraiche", "Dips", "Eier", "Frischkaese", "Joghurt", "Kaese", "Kochsahne", "Kraeuterquark", "Milch",
                                                                "Mozzarella", "Quark", "Sauerrahm", "Schmelzkäse", 
                                            
                                                                "Brötchen", "Brot", "Couscous", "Haferflocken", "Kichererbsen", "Mehl", "Müsli", "Nudeln","Pizzateig", "Reis", "Sonnenblumenkerne", "Vollkornnudeln",
                                                                "Mandeln",
                                            
                                                                "Asiasauce", "Brühe","BBQ-Sauce", "Chili-Sauce", "Essig", "Ketchup", "Mayonaise", "Öl", "Paprikapulver", "Pesto", "Pfeffer", "Salz", "Tomatenmark", "Tomatensauce", "Senf", "Zucker", 
                                            
                                                                "Saft", "Tonicwater", "Cola", "Fanta", "Sprite", "Bier", "Bier-alkoholfrei","Alsterwasser", 
                                                                "Alsterwasser-alkoholfrei", "Weizenbier", "Sekt","Energydrink", "Wein", "Tee", "Kaffee", "Kaffee-entkoffiniert", 
                                            
                                                                "Alufolie", "Backpapier", "Biomüllbeutel","Klopapier", "Küchenrolle", "Deo", "Haargel", "Rasierklingen", "Rasierschaum", "Zahnbürste", "Zahnpasta","Duschgel", "Raumduft", "Shampoo",  "Seife",  "Schwamm", "Bürste", "Spüli", 
                                                                "Klarspüler", "Spülmaschinensalz", "Tabs","Badreiniger", "Glasreiniger","Fettlöser", "Bodenreiniger", "Ceranreiniger", "Weichspüler", "Waschmittel", "Fleckentferner"];
                                            

                                            !
                                            // ##################################################################
                                            // Variablen
                                            // ##################################################################
                                            ! var idRegex = path + 'regex';
                                            ! var idListe = path + 'Liste';
                                            ! var idClear = path + 'clearBtn';
                                            ! var idTelegram = path + 'telegramBtn';
                                            ! var idCount = path + 'count';
                                            ! var lengthListPurch=(PurchList.length); // Variablen für Auslesen wieviele Inhalte in den jeweiligen Arrays stehen

                                            var regexTrigger = /^javascript.0.Einkaufsliste.Items..*$/;

                                            ! var listeTotal = [];
                                            ! // ################################################################
                                            // ###### STATES FÜR DIE GEGENSTÄNDE IN OBJEKTEN ERZEUGEN #######
                                            // ################################################################
                                            ! function createItems(){
                                            var i = 0;
                                            for (i = 0; i < lengthListPurch; i++){
                                            createState(pathItems +PurchList[i], false, {
                                            name: 'Einkauf',
                                            desc: PurchList[i],
                                            type: 'boolean',
                                            role: 'state',
                                            unit: ''
                                            });

                                                /*
                                                createState(pathItems +(PurchList[i]) + ".Menge", 0, force, {           // hier könnte man Mengenangaben mit einbeziehen, brauche ich jedoch nicht.
                                                    name: 'Einkauf',
                                                    desc: PurchList[i],
                                                    type: 'number',
                                                    role: 'state',
                                                    unit: ''
                                                });
                                             */   
                                            
                                            }
                                            

                                            ! }
                                            ! // #############################################################
                                            // TRIGGER FÜR ERZEUGUNG, LÖSCHEN UND TELEGRAM
                                            // #############################################################
                                            ! on({ id:regexTrigger,
                                            change: 'ne'},
                                            function(data) { // regex trigger, löst immer aus sobald etwas an- oder abgewählt wird
                                            if(getState(idRegex).val === true) {
                                            purchlistCreate(); // if Bedingung, damit es nicht zu warnmeldungen kommt, wenn der regex trigger ausgeführt wird aber Objekte noch nicht angelegt sind
                                            count();
                                            }

                                            });

                                            ! on(idClear, function(obj){ // trigger fürs Löschen
                                            if(obj.state.val === true){
                                            clearPurch();
                                            }
                                            });
                                            ! on(idTelegram, function(obj){ // trigger für Telegram
                                            if(obj.state.val === true){
                                            sendTelegram();
                                            }
                                            });
                                            ! // #################################################################
                                            // FUNCTIONS
                                            // #################################################################
                                            ! ///// Einkaufsliste erzeugen //////////////////////////////////////////////////////////////////
                                            ! function purchlistCreate(){
                                            var i = 0;
                                            var item;

                                                listeTotal = [];
                                            
                                                for (i = 0; i < lengthListPurch; i++){
                                            
                                                    if(getState(pathItems +PurchList[i]).val === true) {
                                                    item = PurchList[i];
                                                    listeTotal.push(item);
                                                    if(debug) log(item + " zur Einkaufsliste hinzugefügt ");
                                                    }
                                                } 
                                            setState(idListe, listeTotal.join('
                                            

                                            ')); // Liste wird für VIS formatiert
                                            }

                                            ! function count(){
                                            var n = listeTotal.length;
                                            setState(idCount, n);
                                            }
                                            ! function clearPurch(){
                                            var i = 0;
                                            ! for (i = 0; i < lengthListPurch; i++){

                                                    if(getState(pathItems +PurchList[i]).val === true) {
                                                        setState(pathItems +PurchList[i], false);
                                                        setState(idListe, "");
                                                        setStateDelayed(idClear, false, 2000);
                                                    }
                                                }
                                            

                                            }

                                            ! function sendTelegram() {

                                                    var telegramtext = getState(idListe).val.replace(/
                                            

                                            /g , "\n"); // telegram Liste formatieren, entfernt den Zeilenumbruch für vis und ersettz mit Zeilenumbruch Telegram

                                                    sendTo('telegram.0', {                                          // Nachricht per Telegram senden
                                                    text: "Bitte mitbringen:\n\n" + telegramtext        
                                                    });
                                            
                                                    setStateDelayed(idTelegram, false, 2000);
                                            

                                            }

                                            ! // Bei Start
                                            ! createItems();
                                            setStateDelayed(idRegex, true, 30000); // nachdem alle states angelegt sind, kann der regex trigger genutzt werden; ! Das Auslesen von todoist habe ich etwas abgewandelt und auf einen Schedule (für die verbalen Änderungen via Alexa) und einen Trigger (für die Änderungen via Tablet) abgewandelt. ! Das Skript sieht nun so aus ! >! ~~[spoiler]~~[code]// Todoist Script zur Erstellung eines HTML Codes zur Einbindung in VIS mittels "basic - String (unescaped)" Widget
                                            // Scriptversion: v0.2
                                            // Ergänzungen tempestas: Task IDs mit ausgelesen und angelegt, trigger eingebaut, 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
                                            ! //Erforderliche Angaben:
                                            var APItoken = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                            var debug = false;
                                            ! //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
                                            ! schedule("
                                            /1 * * * *", checkTODOIST); // Abfragezeit: jede Minute
                                            ! // *********************************************************
                                            // Scriptbeginn - Ab hier nichts mehr ändern!
                                            // *********************************************************
                                            ! function checkTODOIST() {

                                            var APIprojectsURL = "https://beta.todoist.com/API/v8/projects?token="+APItoken;
                                            var APItaskURL = "https://beta.todoist.com/API/v8/tasks?token="+APItoken;
                                            var request = require("request");
                                            var ToDoListen = []; // wird mit IDs der TO-DO Listen befuellt
                                            var ToDoListen_names = []; // wird mit Namen der TO-DO Listen befuellt
                                            
                                            request(APIprojectsURL, function (error, response, body) {
                                                try{
                                                    var projects_json = JSON.parse(body);
                                                    for (k = 0; k < projects_json.length; k++) {
                                                        var projects = parseInt(projects_json[k].id);
                                                        var projects_name = JSON.stringify(projects_json[k].name);
                                                        projects_name = projects_name.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                        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)}
                                            });
                                            
                                            setTimeout(function() {
                                                try{
                                                    request(APItaskURL, function (error, response, body) {
                                                        var json = JSON.parse(body);
                                                        for (j = 0; j < ToDoListen.length; j++) {
                                                            var HTMLstring = "";
                                                            setState(instanz + pfad + ToDoListen_names[j], "leer");
                                                            for (i = 0; i < json.length; i++) {
                                                                var Liste = parseInt(json[i].project_id);
                                                                var content = JSON.stringify(json[i].content);
                                                                content = content.replace(/\"/g, ""); //entfernt die Anfuehrungszeichen aus dem quellstring
                                                                content = content[0].toUpperCase() + content.substring(1); // Macht den ersten Buchstaben des strings zu einem Grossbuchstaben
                                                                var taskurl = JSON.stringify(json[i].url);
                                                                taskurl = taskurl.replace(/\"/g, "");
                                                                if (Liste == ToDoListen[j])
                                                                {
                                                                    if(debug) log ("["+content+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                                    HTMLstring = HTMLstring+content+"
                                            

                                            "; // mit Link: HTMLstring = HTMLstring+"* "+content+"";
                                            setState(instanz + pfad + ToDoListen_names[j], HTMLstring); // "<>"+HTMLstring+"

                                            ! ");
                                            }
                                            }
                                            }
                                            });
                                            }
                                            catch(err) {log(err.message)}
                                            }, 1000);

                                                setTimeout(function() {                                                 // legt IDs der einzelnen Tasks in Unterordnern an
                                                request(APItaskURL, function (error, response, body) {
                                            
                                                    var json = JSON.parse(body);
                                            
                                                    for (j = 0; j < ToDoListen.length; j++) {
                                            
                                                        var HTMLstring = "";
                                            
                                                        setState(instanz + pfad + ToDoListen_names[j] +'.TaskID', "leer");
                                                        for (i = 0; i < json.length; i++) {
                                                            var Liste = parseInt(json[i].project_id);
                                                            var taskid = JSON.stringify(json[i].id);
                                                            if (Liste == ToDoListen[j])
                                                            {
                                                                if(debug) log ("["+taskid+"] in "+ToDoListen_names[j]+" gefunden", "info");
                                                                HTMLstring = HTMLstring+taskid+"
                                            

                                            "; // mit Link: HTMLstring = HTMLstring+"* "+content+"";
                                            setState(instanz + pfad + ToDoListen_names[j]+'.TaskID', HTMLstring); // "<>"+HTMLstring+"

                                            ! ");
                                            }
                                            }
                                            }

                                                 });
                                            }, 1000);
                                            

                                            }

                                            ! // ***********************************************
                                            // TRIGGER
                                            // ***********************************************
                                            ! on({ id:regexTrigger,
                                            change: 'ne'},
                                            function() { // regex trigger, löst immer aus sobald etwas in der manuellen Liste an- oder abgewählt wird
                                            ! checkTODOIST();
                                            }); ! Der Abgleich, sprich hinzufügen und löschen in der todoist Liste bei Änderungen am Tablet funktioniert dann mit dm dritten Skript: ! >! ~~[spoiler]~~[code]// SKRIPT FÜGT DER ALEXA EINKAUFSLISTE BEI TODOIST EINEN GEGENSTAND HINZU; WENN DIESER IN DER MANUELLEN EINKAUFSLISTE HINZUGEFÜGT WIRD BZW LÖSCHT
                                            ! var debug = true;
                                            ! var APItoken = "STRENG GEHEIM"; // API Token kann in den Todoist Settings auf der Webseite ausgelesen werden
                                            var idProject = nicht ganz so geheim, aber trotzdem; // Projekt-ID der Alexa-Einkaufsliste aus todoist
                                            var idEinkaufsIDS = "javascript.0.Todoist.Alexa-Einkaufsliste.TaskID"; // hier stehen die Task IDs
                                            var idEinkaufsItems = "javascript.0.Todoist.Alexa-Einkaufsliste"/Alexa-Einkaufsliste HTML String/;
                                            ! var regexTrigger = /^javascript.0.Einkaufsliste.Items..*$/; // Trigger analog der manuellen Einkaufsliste
                                            ! // **************************************************************
                                            // Scriptbeginn - Ab hier nichts mehr ändern!
                                            // **************************************************************
                                            ! var request = require("request");
                                            var uuid;
                                            var purchItem;
                                            ! // **************************************************************
                                            // uuid erstellen
                                            // **************************************************************
                                            ! function createUUID(){
                                            var dt = new Date().getTime();
                                            uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
                                            var r = (dt + Math.random()*16)%16 | 0;
                                            dt = Math.floor(dt/16);
                                            return (c=='x' ? r :(r&0x3|0x8)).toString(16);
                                            });
                                            return uuid;
                                            }
                                            ! // ********************************************************************
                                            // "Aufgabe" bzw Einkaufsgegenstand zur todoist Alexa Liste hinzufügen
                                            // ********************************************************************
                                            ! function addTask(){
                                            ! createUUID();
                                            log(uuid);
                                            ! var options = { method: 'POST',
                                            url: 'https://beta.todoist.com/API/v8/tasks',
                                            headers:
                                            { 'Cache-Control': 'no-cache',
                                            Authorization: 'Bearer ' +APItoken,
                                            'X-Request-Id': uuid,
                                            'Content-Type': 'application/json' },
                                            body:
                                            { content: purchItem,
                                            project_id: +idProject,
                                            },
                                            json: true };

                                                request(options, function (error, response, body) {
                                                  if (error) throw new Error(error);
                                            
                                                  if(debug) console.log(JSON.stringify(body));
                                                });
                                            

                                            }

                                            ! // ********************************************************************
                                            // "Aufgabe" bzw Einkaufsgegenstand von todoist entfernen
                                            // ********************************************************************
                                            ! function deleteTask(){
                                            ! // Array der IDs aufbereiten

                                            var idListIDsArray =[];
                                            var idListIDs;
                                            
                                            idListIDs = getState(idEinkaufsIDS).val;
                                            if(debug)log(idListIDs);
                                            idListIDsArray = idListIDs.split("
                                            

                                            ");
                                            idListIDsArray.pop(); // aufgrund meiner uneleganten Änderungen steht als letztes immer "
                                            " in der Liste. Damit würde ein Element zuviel ausgegeben werden (leer). Pop kürzt den array ums letzte Element

                                            ! // Array der Items aufbereiten
                                            ! var idListArray =[];
                                            var idList;

                                            idList = getState(idEinkaufsItems).val;
                                            if(debug)log(idList);
                                            idListArray = idList.split("
                                            

                                            ");
                                            idListArray.pop();

                                            ! // Bestimmen der ID Position im Array

                                            var arrayPosition = idListArray.indexOf(purchItem);
                                            
                                            // Den Gegenstand über die gefundene ID löschen
                                            

                                            ! var deleteURL = "https://beta.todoist.com/API/v8/tasks/"+idListIDsArray[arrayPosition]+"?token="+APItoken;
                                            if(debug) log("Delete URL ist "+deleteURL);

                                                request({
                                                    uri: deleteURL,
                                                    method: "DELETE",
                                                    timeout: 5000,
                                                    }, 
                                                        function(error, response, body) {
                                                        if(debug) console.log(body);
                                                    });    
                                            

                                            }

                                            ! // **************************************************************
                                            // Trigger und Wertübergabe
                                            // **************************************************************
                                            ! on({ id:regexTrigger, change: 'ne'}, // regex trigger, löst immer aus sobald etwas an- oder abgewählt wird
                                            function(data) {
                                            var temporary;
                                            temporary = data.id;
                                            purchItem = temporary.substring(33); // Pfad bis zum Item ist 33 Stellen lang

                                                        if(data.state.val) {                                // wenn das item auf der manuellen Liste hinzugefügt wurde (state ist true) dann...
                                                            if (debug) log("Es wird hinzugefügt: "+purchItem);
                                                            setTimeout(addTask, 500); }
                                                        else {                                              // sonst wenn wenn das item auf der manuellen Liste entfernt wurde dann...
                                                            if (debug) log("Es wird entfernt: "+purchItem);
                                                            setTimeout(deleteTask, 500); 
                                                        }    
                                                });
                                            

                                            ! [/code]`[/spoiler]
                                            ! Nun fehlen noch #Abgleiche beim Start und eben "verbal to manual" Angleichungen.
                                            ! Ich hoffe, der eine oder andere findet es vielleicht nützlich
                                            ! VG und schönes Wochenende[/i][/i][/i][/i][/i][/code][/spoiler][/i][/i][/i][/i][/i][/i][/i][/i]

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            691
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

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