Skip to content
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Withings Daten einlesen

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.1k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.1k

Withings Daten einlesen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
126 Beiträge 27 Kommentatoren 32.7k Aufrufe 19 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • MaufloM Mauflo

    @bnz99 Ja, ich hätte großes Interesse daran - bis jetzt scheitere ich kläglich am Authorisierungsprozess via Javascript. Obwohl ich mir viel lieber einen eigenen Script schreiben würde, der meine Daten ausliest und die in die Datenpunkte überträgt. Ich weiß nämlich immer noch nicht was in der withings.cmd stehen muß und wo ich die ablegen muss, damit der Autorisierungsprozess funktioniert. Braucht man dafür einen Webserver? Hab ich nämlich nicht!

    S Offline
    S Offline
    stoffel67
    schrieb am zuletzt editiert von
    #101

    @Mauflo ja den braucht man, ich dachte, dass das oben deutlich rauskommt,...
    man braucht einen Webserver, der min. ein "OK" an withings zurückgibt

    Mein Adapter: JUNG/GIRA eNet-Adapter

    1 Antwort Letzte Antwort
    0
    • B Offline
      B Offline
      bnz99
      schrieb am zuletzt editiert von bnz99
      #102
      1. Zunächst brauchen wir einen iobroker app key.

      Ich habe einen iobroker pro account. Wenn man sich dort einloggt findet man unter APP-KEYS den URL-Anteil, den ich ausgeblendet habe. Wenn der noch nicht existiert, muss man den dort mit "App Key erzeugen" anlegen. Es geht wahrscheinlich auch mit einem iobroker.net app key, habe ich aber nicht getestet.

      1. Wir brauchen einen IFTTT key. Den gibt es bei ifttt.com, wenn man auf https://ifttt.com/maker_webhooks/ geht und auf documentation klickt. Da steht dann "Your key is:".

      2. Dann erzeugen wir ein ifttt applet. Bei ifttt.com create->if withings body scale new measurement then webhook:

      85f39a12-00d0-4e90-ab1a-ae62b186c905-image.png

      Der JSON Anteil hier noch mal zum kopieren:

      { "iftttType":"withingsBodyScale", "weightKg":{{WeightKg}}, "leanMassKg":{{LeanMassKg}}, "fatMassKg":{{FatMassKg}}, "fatPercent":{{FatPercent}},"measuredAt":" {{MeasuredAt}}" }
      

      Die URL setzt sich aus dem ifttt Anteil von iobroker.pro/iobroker.net zusammen + den appkey Anteil.

      1. Als nächstes müssen wir iftt im iobroker Cloud Adapter konfigurieren. Wenn der noch nicht installiert ist, muss der installiert werden. Wenn man nun die cloud.0 Instanz konfiguriert, muss der App Key eingetragen sein aus der iobroker.pro oder iobroker.net Konfiguration. Im Tab Services und IFTTT muss der IFTTT Key eingetragen werden. Der Rest kann so bleiben.

      2. Wir kriegen jetzt den json payload von Withings in iobroker reingepusht. Er liegt im Objektbaum unter cloud.0/services/ifttt. Da wird immer nur der jeweils aktuell übermittelte json string reinkopiert. Wenn wir vom Blutdruckmessgerät auch Daten kriegen (Vorgehen ist analog zu dem hier), kommt das hier auch reinkopiert. D.h. es bleibt hier auch nicht daurhaft als "Withings Wert" stehen. Jetzt muss der JSON payload zerlegt und sortiert abgelegt werden. Dafür können wir ein Blockly Skript anlegen. Mein Skript, welches auch das Blutdruckmessgerät unterstützt sieht so aus:

      61435317-3320-434d-9a9d-c1fa7ca41014-image.png

      1. Der im Skript referenzierte Code ist der hier:
      var moment = require('moment');
      require("moment/min/locales.min");
      moment.locale('en');
      
      var dateTime = moment(dateString,"MMMM DD, YYYY at hh:ssp", "Europe/Berlin");
      
      return dateTime.toDate();
      

      Damit das funktioniert, muss im Javascript Adapter "moment" als zusätzliches npm Modul eingetragen werden. Der Datumscode funktioniert aber scheinbar noch nicht ganz korrekt. Der String sieht aktuell etwas kaputt aus bei mir. Ich hatte aber noch keine Zeit mir das anzusehen.

      Ich hoffe das hilft soweit!

      MaufloM X 3 Antworten Letzte Antwort
      0
      • B bnz99
        1. Zunächst brauchen wir einen iobroker app key.

        Ich habe einen iobroker pro account. Wenn man sich dort einloggt findet man unter APP-KEYS den URL-Anteil, den ich ausgeblendet habe. Wenn der noch nicht existiert, muss man den dort mit "App Key erzeugen" anlegen. Es geht wahrscheinlich auch mit einem iobroker.net app key, habe ich aber nicht getestet.

        1. Wir brauchen einen IFTTT key. Den gibt es bei ifttt.com, wenn man auf https://ifttt.com/maker_webhooks/ geht und auf documentation klickt. Da steht dann "Your key is:".

        2. Dann erzeugen wir ein ifttt applet. Bei ifttt.com create->if withings body scale new measurement then webhook:

        85f39a12-00d0-4e90-ab1a-ae62b186c905-image.png

        Der JSON Anteil hier noch mal zum kopieren:

        { "iftttType":"withingsBodyScale", "weightKg":{{WeightKg}}, "leanMassKg":{{LeanMassKg}}, "fatMassKg":{{FatMassKg}}, "fatPercent":{{FatPercent}},"measuredAt":" {{MeasuredAt}}" }
        

        Die URL setzt sich aus dem ifttt Anteil von iobroker.pro/iobroker.net zusammen + den appkey Anteil.

        1. Als nächstes müssen wir iftt im iobroker Cloud Adapter konfigurieren. Wenn der noch nicht installiert ist, muss der installiert werden. Wenn man nun die cloud.0 Instanz konfiguriert, muss der App Key eingetragen sein aus der iobroker.pro oder iobroker.net Konfiguration. Im Tab Services und IFTTT muss der IFTTT Key eingetragen werden. Der Rest kann so bleiben.

        2. Wir kriegen jetzt den json payload von Withings in iobroker reingepusht. Er liegt im Objektbaum unter cloud.0/services/ifttt. Da wird immer nur der jeweils aktuell übermittelte json string reinkopiert. Wenn wir vom Blutdruckmessgerät auch Daten kriegen (Vorgehen ist analog zu dem hier), kommt das hier auch reinkopiert. D.h. es bleibt hier auch nicht daurhaft als "Withings Wert" stehen. Jetzt muss der JSON payload zerlegt und sortiert abgelegt werden. Dafür können wir ein Blockly Skript anlegen. Mein Skript, welches auch das Blutdruckmessgerät unterstützt sieht so aus:

        61435317-3320-434d-9a9d-c1fa7ca41014-image.png

        1. Der im Skript referenzierte Code ist der hier:
        var moment = require('moment');
        require("moment/min/locales.min");
        moment.locale('en');
        
        var dateTime = moment(dateString,"MMMM DD, YYYY at hh:ssp", "Europe/Berlin");
        
        return dateTime.toDate();
        

        Damit das funktioniert, muss im Javascript Adapter "moment" als zusätzliches npm Modul eingetragen werden. Der Datumscode funktioniert aber scheinbar noch nicht ganz korrekt. Der String sieht aktuell etwas kaputt aus bei mir. Ich hatte aber noch keine Zeit mir das anzusehen.

        Ich hoffe das hilft soweit!

        MaufloM Offline
        MaufloM Offline
        Mauflo
        schrieb am zuletzt editiert von
        #103

        @bnz99 Herzlichen Dank! Das klingt sehr vielversprechend. Ich werde das am WE mal versuchen. Ich habe einen .net Account. Außerdem habe ich ein Nokia Home System, eine HR Uhr und eine Body Cardio Waage. Daher werde ich eine Menge Daten auseinanderzuklauben haben. Außerdem möchte ich die Daten noch in eine SQL Datenbank eintragen lassen, damit ich sie später im VIS wiederverwenden kann. Weiters möchte ich gerne die Daten dazu verwenden, dass Alexa bei bestimmten Werten entsprechende Ansagen macht. Wird also ein größeres Projekt. 😉 Daher möchte ich mich für Deine Unterstützung herzlich bedanken. Sollte ich entsprechende Lösungen programmiert haben, werde ich das hier auch veröffentlichen, damit andere User von unseren Erfahrungen profitieren können! LG und nochmals Danke!

        RaspberryPi 4 4 GB - Raspbian light Buster - ARMv7 Processor rev 3 (v7l) - Node.js v12.18.0 - NPM 6.14.4 - Aktive Instanzen 18 (admin, alexa2, backitup, broadlink2, ham-wemo, harmony, history, hs100, hue, info, iot, javascript, radar2, scenes, tr-064, web [2x], wifilight) all latest and updated

        B 1 Antwort Letzte Antwort
        0
        • MaufloM Mauflo

          @bnz99 Herzlichen Dank! Das klingt sehr vielversprechend. Ich werde das am WE mal versuchen. Ich habe einen .net Account. Außerdem habe ich ein Nokia Home System, eine HR Uhr und eine Body Cardio Waage. Daher werde ich eine Menge Daten auseinanderzuklauben haben. Außerdem möchte ich die Daten noch in eine SQL Datenbank eintragen lassen, damit ich sie später im VIS wiederverwenden kann. Weiters möchte ich gerne die Daten dazu verwenden, dass Alexa bei bestimmten Werten entsprechende Ansagen macht. Wird also ein größeres Projekt. 😉 Daher möchte ich mich für Deine Unterstützung herzlich bedanken. Sollte ich entsprechende Lösungen programmiert haben, werde ich das hier auch veröffentlichen, damit andere User von unseren Erfahrungen profitieren können! LG und nochmals Danke!

          B Offline
          B Offline
          bnz99
          schrieb am zuletzt editiert von bnz99
          #104

          Hm...sehe gerade, dass in dem Javascriptteil noch der Test-Timestamp drin ist. Der muss entsprechend durch den Übergabeparameter ersetzt werden. Sonst steht da immer dasselbe drin.

          Ansonsten für die Datenbankspeicherung muss halt nur der SQL Adapter oder sonstiges installiert werden und entsprechend im Wert angehakt werden.

          Edit: in der Tat, habe eben mal in der DB nachgesehen, meine geparsten Zeitstempel waren alle dieselben 😉 Habe den Post oben korrigiert. Ich glaube der geparste Zeitwert ist aber ohnehin überflüssig. Sobald sich der Wert ändert, bekommt der Eintrag vom SQL Adapter ohnehin einen Zeitstempel bei der Speicherung. Der mag zwar in der Theorie etwas abweichen, aber eine Abweichung der Messwerte um ein paar Minuten bis der IFTTT Aufruf erfolgt, dürfte denke ich mal bei Gewicht oder Blutdruck die wenigsten interessieren.

          1 Antwort Letzte Antwort
          1
          • S Offline
            S Offline
            stoffel67
            schrieb am zuletzt editiert von
            #105

            @bnz99 aber den "authentication code" brauchst du doch auch, und ich vermute als "redirect" gibst du dann die IFTTT URL an?

            Mein Adapter: JUNG/GIRA eNet-Adapter

            B 1 Antwort Letzte Antwort
            0
            • S stoffel67

              @bnz99 aber den "authentication code" brauchst du doch auch, und ich vermute als "redirect" gibst du dann die IFTTT URL an?

              B Offline
              B Offline
              bnz99
              schrieb am zuletzt editiert von
              #106

              @stoffel67 Ich bin mir gerade nicht sicher, welchen Authentication Code Du meinst.

              Falls Du die OAuth Token von Withings selbst meinst und mit der Frage auf die vorher im Thread selbstgebauten Lösungen mithilfe des Withings Developer Accounts verweist: die Lösung unterscheidet sich grundsätzlich von der selbstgebauten. Wenn ich mich richtig erinnere, authentisiert man IFTTT bei Withings bei erstmaligen Anlegen des Withings "this" Triggers. Das Token zu Deinem Withings Account hält dann IFTTT. IFTTT ist dann der Mittelmann, der mitlesen kann und für das Weiterleiten verantwortlich ist. Muss man halt selbst wissen inwieweit man das gut findet oder nicht. Man tauscht geringere Komplexität gegen seine Daten (an IFTTT).

              Ansonsten braucht man keinen Authentication Code.

              1 Antwort Letzte Antwort
              0
              • B bnz99
                1. Zunächst brauchen wir einen iobroker app key.

                Ich habe einen iobroker pro account. Wenn man sich dort einloggt findet man unter APP-KEYS den URL-Anteil, den ich ausgeblendet habe. Wenn der noch nicht existiert, muss man den dort mit "App Key erzeugen" anlegen. Es geht wahrscheinlich auch mit einem iobroker.net app key, habe ich aber nicht getestet.

                1. Wir brauchen einen IFTTT key. Den gibt es bei ifttt.com, wenn man auf https://ifttt.com/maker_webhooks/ geht und auf documentation klickt. Da steht dann "Your key is:".

                2. Dann erzeugen wir ein ifttt applet. Bei ifttt.com create->if withings body scale new measurement then webhook:

                85f39a12-00d0-4e90-ab1a-ae62b186c905-image.png

                Der JSON Anteil hier noch mal zum kopieren:

                { "iftttType":"withingsBodyScale", "weightKg":{{WeightKg}}, "leanMassKg":{{LeanMassKg}}, "fatMassKg":{{FatMassKg}}, "fatPercent":{{FatPercent}},"measuredAt":" {{MeasuredAt}}" }
                

                Die URL setzt sich aus dem ifttt Anteil von iobroker.pro/iobroker.net zusammen + den appkey Anteil.

                1. Als nächstes müssen wir iftt im iobroker Cloud Adapter konfigurieren. Wenn der noch nicht installiert ist, muss der installiert werden. Wenn man nun die cloud.0 Instanz konfiguriert, muss der App Key eingetragen sein aus der iobroker.pro oder iobroker.net Konfiguration. Im Tab Services und IFTTT muss der IFTTT Key eingetragen werden. Der Rest kann so bleiben.

                2. Wir kriegen jetzt den json payload von Withings in iobroker reingepusht. Er liegt im Objektbaum unter cloud.0/services/ifttt. Da wird immer nur der jeweils aktuell übermittelte json string reinkopiert. Wenn wir vom Blutdruckmessgerät auch Daten kriegen (Vorgehen ist analog zu dem hier), kommt das hier auch reinkopiert. D.h. es bleibt hier auch nicht daurhaft als "Withings Wert" stehen. Jetzt muss der JSON payload zerlegt und sortiert abgelegt werden. Dafür können wir ein Blockly Skript anlegen. Mein Skript, welches auch das Blutdruckmessgerät unterstützt sieht so aus:

                61435317-3320-434d-9a9d-c1fa7ca41014-image.png

                1. Der im Skript referenzierte Code ist der hier:
                var moment = require('moment');
                require("moment/min/locales.min");
                moment.locale('en');
                
                var dateTime = moment(dateString,"MMMM DD, YYYY at hh:ssp", "Europe/Berlin");
                
                return dateTime.toDate();
                

                Damit das funktioniert, muss im Javascript Adapter "moment" als zusätzliches npm Modul eingetragen werden. Der Datumscode funktioniert aber scheinbar noch nicht ganz korrekt. Der String sieht aktuell etwas kaputt aus bei mir. Ich hatte aber noch keine Zeit mir das anzusehen.

                Ich hoffe das hilft soweit!

                X Offline
                X Offline
                Xanon
                schrieb am zuletzt editiert von
                #107

                Hallo @bnz99,
                vielen Dank für dein Workaround.

                Könntest du dein Skript hier vielleicht einmal als export zur Verfügung stellen?

                Das wäre super nett!!!

                1 Antwort Letzte Antwort
                1
                • B bnz99
                  1. Zunächst brauchen wir einen iobroker app key.

                  Ich habe einen iobroker pro account. Wenn man sich dort einloggt findet man unter APP-KEYS den URL-Anteil, den ich ausgeblendet habe. Wenn der noch nicht existiert, muss man den dort mit "App Key erzeugen" anlegen. Es geht wahrscheinlich auch mit einem iobroker.net app key, habe ich aber nicht getestet.

                  1. Wir brauchen einen IFTTT key. Den gibt es bei ifttt.com, wenn man auf https://ifttt.com/maker_webhooks/ geht und auf documentation klickt. Da steht dann "Your key is:".

                  2. Dann erzeugen wir ein ifttt applet. Bei ifttt.com create->if withings body scale new measurement then webhook:

                  85f39a12-00d0-4e90-ab1a-ae62b186c905-image.png

                  Der JSON Anteil hier noch mal zum kopieren:

                  { "iftttType":"withingsBodyScale", "weightKg":{{WeightKg}}, "leanMassKg":{{LeanMassKg}}, "fatMassKg":{{FatMassKg}}, "fatPercent":{{FatPercent}},"measuredAt":" {{MeasuredAt}}" }
                  

                  Die URL setzt sich aus dem ifttt Anteil von iobroker.pro/iobroker.net zusammen + den appkey Anteil.

                  1. Als nächstes müssen wir iftt im iobroker Cloud Adapter konfigurieren. Wenn der noch nicht installiert ist, muss der installiert werden. Wenn man nun die cloud.0 Instanz konfiguriert, muss der App Key eingetragen sein aus der iobroker.pro oder iobroker.net Konfiguration. Im Tab Services und IFTTT muss der IFTTT Key eingetragen werden. Der Rest kann so bleiben.

                  2. Wir kriegen jetzt den json payload von Withings in iobroker reingepusht. Er liegt im Objektbaum unter cloud.0/services/ifttt. Da wird immer nur der jeweils aktuell übermittelte json string reinkopiert. Wenn wir vom Blutdruckmessgerät auch Daten kriegen (Vorgehen ist analog zu dem hier), kommt das hier auch reinkopiert. D.h. es bleibt hier auch nicht daurhaft als "Withings Wert" stehen. Jetzt muss der JSON payload zerlegt und sortiert abgelegt werden. Dafür können wir ein Blockly Skript anlegen. Mein Skript, welches auch das Blutdruckmessgerät unterstützt sieht so aus:

                  61435317-3320-434d-9a9d-c1fa7ca41014-image.png

                  1. Der im Skript referenzierte Code ist der hier:
                  var moment = require('moment');
                  require("moment/min/locales.min");
                  moment.locale('en');
                  
                  var dateTime = moment(dateString,"MMMM DD, YYYY at hh:ssp", "Europe/Berlin");
                  
                  return dateTime.toDate();
                  

                  Damit das funktioniert, muss im Javascript Adapter "moment" als zusätzliches npm Modul eingetragen werden. Der Datumscode funktioniert aber scheinbar noch nicht ganz korrekt. Der String sieht aktuell etwas kaputt aus bei mir. Ich hatte aber noch keine Zeit mir das anzusehen.

                  Ich hoffe das hilft soweit!

                  X Offline
                  X Offline
                  Xanon
                  schrieb am zuletzt editiert von Xanon
                  #108

                  @bnz99
                  Ich habe jetzt alles per IFTTT konfiguriert (so wie beschrieben)

                  Bekomme auch Daten rein und die Objekte werden auch beschrieben.
                  Allerdings bekomme ich die Daten erst nach ca. einer Stunde und das nächste mal nach 15 min. und dann auch gar nicht.

                  Wird IFTTT nur alle x-mal pro stunde ausgeführt?
                  Ist das bei Euch auch so?
                  Kann man dagegen etwas machen oder habe ich da etwas falsch gemacht?

                  Danke und Gruß
                  Xanon

                  1 Antwort Letzte Antwort
                  0
                  • N Offline
                    N Offline
                    numeric
                    schrieb am zuletzt editiert von
                    #109

                    Hallo in die Runde.

                    Hier scheint sich länger nichts mehr getan zu haben 🙂
                    Ich habe mich mal quer durch alle Einträge gelesen, da mich das Thema auch brennend interessiert.
                    Ich überlege nämlich mir ein Blutdruckmessgerät, eine Waage und die Schlafmatte von Withings zu kaufen. Die Daten würde ich gerne über die API in einer eigenen APP anzeigen lassen. Die APP würde ich gerne mithilfe von Flutter (Programmiersprache: DART) programmieren. Da ich nun teilweise unterschiedliche Foreneinträge gelesen habe von "es klappt ganz okay" bis hin zu "es klappt überhaupt nicht" wollte ich mir mal eure Erfahrungswerte in dieser Thematik einholen. Ist mein Vorhaben realistisch oder gibt es eventuell Probleme seitens von Withings? Hat jemand eventuell genau diesen Datenabgriff schon hergestellt und kann mir hilfreiche Tipps oder bekannte Probleme nennen (soweit ich weiß wurde Withings zwischenzeitlich von Nokia aufgekauft und ist mittlerweile wieder als eigenes Unternehmen tätig)?

                    Ich wäre über jede noch so kleine Anregung dankbar und wünsche schon einmal einen schönen Tag!

                    lobomauL 1 Antwort Letzte Antwort
                    0
                    • N numeric

                      Hallo in die Runde.

                      Hier scheint sich länger nichts mehr getan zu haben 🙂
                      Ich habe mich mal quer durch alle Einträge gelesen, da mich das Thema auch brennend interessiert.
                      Ich überlege nämlich mir ein Blutdruckmessgerät, eine Waage und die Schlafmatte von Withings zu kaufen. Die Daten würde ich gerne über die API in einer eigenen APP anzeigen lassen. Die APP würde ich gerne mithilfe von Flutter (Programmiersprache: DART) programmieren. Da ich nun teilweise unterschiedliche Foreneinträge gelesen habe von "es klappt ganz okay" bis hin zu "es klappt überhaupt nicht" wollte ich mir mal eure Erfahrungswerte in dieser Thematik einholen. Ist mein Vorhaben realistisch oder gibt es eventuell Probleme seitens von Withings? Hat jemand eventuell genau diesen Datenabgriff schon hergestellt und kann mir hilfreiche Tipps oder bekannte Probleme nennen (soweit ich weiß wurde Withings zwischenzeitlich von Nokia aufgekauft und ist mittlerweile wieder als eigenes Unternehmen tätig)?

                      Ich wäre über jede noch so kleine Anregung dankbar und wünsche schon einmal einen schönen Tag!

                      lobomauL Offline
                      lobomauL Offline
                      lobomau
                      schrieb am zuletzt editiert von lobomau
                      #110

                      @numeric ich hatte es bis März 2021 über ifttt erfolgreich laufen. Dann wollte ifttt, dass man eine Pro-Version kauft. Seitdem habe ich es nicht in Gebrauch.
                      Müsste man mal schauen ob der andere Weg noch funktioniert.

                      Edit.: hier ist viel beschrieben:
                      https://developer.withings.com/oauth2/#section/Glossary
                      Nur leider nicht in einer Sprache, die verstehe.

                      Hierüber habe ich mich nun angemeldet und habe nun:

                      • CLIENT-ID
                      • CONSUMER-GEHEIMNIS

                      Irgendwoher muss man jetzt noch diese Daten herbekommen:

                      • oauth_access_token
                      • oauth_access_token_secret

                      https://account.withings.com/partner/dashboard_oauth2

                      Host: NUC8i3 mit Proxmox:

                      • ioBroker CT Debian 13, npm 10.9.3, nodejs 22.20.0
                      • Slave: Pi4
                      N 1 Antwort Letzte Antwort
                      0
                      • lobomauL lobomau

                        @numeric ich hatte es bis März 2021 über ifttt erfolgreich laufen. Dann wollte ifttt, dass man eine Pro-Version kauft. Seitdem habe ich es nicht in Gebrauch.
                        Müsste man mal schauen ob der andere Weg noch funktioniert.

                        Edit.: hier ist viel beschrieben:
                        https://developer.withings.com/oauth2/#section/Glossary
                        Nur leider nicht in einer Sprache, die verstehe.

                        Hierüber habe ich mich nun angemeldet und habe nun:

                        • CLIENT-ID
                        • CONSUMER-GEHEIMNIS

                        Irgendwoher muss man jetzt noch diese Daten herbekommen:

                        • oauth_access_token
                        • oauth_access_token_secret

                        https://account.withings.com/partner/dashboard_oauth2

                        N Offline
                        N Offline
                        numeric
                        schrieb am zuletzt editiert von
                        #111

                        @lobomau Danke für die schnelle Antwort. Das hört sich ja schon mal gut an, dass es technisch möglich ist (bzw. war 😉 )

                        Sorry für die Nachfrage aber ich bin Maschinenbauer und kein Programmierer und daher noch nicht ganz so in der Materie 🙂

                        Du hast Dir also einen Developer Account erstellt und dann die gemessenen Daten über ifttt mit deiner APP/deinem Server/deiner Cloud verbunden und dir da die Werte anzeigen lassen richtig? Hast du einen eigenen ifttt Code geschrieben oder gibt es vorgefertigte Codes für Withings?

                        Ich habe mal eine Beispielskizze angehangen wie ich mir das bei mir ungefähr vorstelle:

                        MicrosoftTeams-image.png

                        Ich führe also eine Messung durch und lasse die Daten über WLAN/Bluetooth an den "Withings" Server schicken. Von dort aus möchte ich die gemessenen Werte von meiner eigenen APP ("Unsere APP") ablesen lassen und visuell darstellen. Dann werden die Daten weitergeschickt an "Unser Server" bei dem alle Daten hinterlegt werden sollen. Die Daten sollen hier zentral gespeichert werden, da ich in Zukunft eventuell noch weitere Devices wie eine Smart-Watch (von einem anderen Hersteller) zu meinem System hinzufügen möchte.

                        Daher ist meine Frage, ob ich ifttt überhaupt brauche wenn ich zunächst einmal nur die Daten in meiner APP darstellen möchte?

                        lobomauL 1 Antwort Letzte Antwort
                        0
                        • N numeric

                          @lobomau Danke für die schnelle Antwort. Das hört sich ja schon mal gut an, dass es technisch möglich ist (bzw. war 😉 )

                          Sorry für die Nachfrage aber ich bin Maschinenbauer und kein Programmierer und daher noch nicht ganz so in der Materie 🙂

                          Du hast Dir also einen Developer Account erstellt und dann die gemessenen Daten über ifttt mit deiner APP/deinem Server/deiner Cloud verbunden und dir da die Werte anzeigen lassen richtig? Hast du einen eigenen ifttt Code geschrieben oder gibt es vorgefertigte Codes für Withings?

                          Ich habe mal eine Beispielskizze angehangen wie ich mir das bei mir ungefähr vorstelle:

                          MicrosoftTeams-image.png

                          Ich führe also eine Messung durch und lasse die Daten über WLAN/Bluetooth an den "Withings" Server schicken. Von dort aus möchte ich die gemessenen Werte von meiner eigenen APP ("Unsere APP") ablesen lassen und visuell darstellen. Dann werden die Daten weitergeschickt an "Unser Server" bei dem alle Daten hinterlegt werden sollen. Die Daten sollen hier zentral gespeichert werden, da ich in Zukunft eventuell noch weitere Devices wie eine Smart-Watch (von einem anderen Hersteller) zu meinem System hinzufügen möchte.

                          Daher ist meine Frage, ob ich ifttt überhaupt brauche wenn ich zunächst einmal nur die Daten in meiner APP darstellen möchte?

                          lobomauL Offline
                          lobomauL Offline
                          lobomau
                          schrieb am zuletzt editiert von
                          #112

                          @numeric ich habe das gleiche Problem, bin auch nur Maschinenbauer 🐶
                          IFTTT wäre eine Alternative zu dem anderen Weg. War sehr einfach einzustellen. Bei dem anderen komme ich nicht weiter... bzw. da müsste man sich lange einlesen...
                          Wenn man das Prinzip kennt, ist es nicht so schwierig, nehme ich an.

                          Host: NUC8i3 mit Proxmox:

                          • ioBroker CT Debian 13, npm 10.9.3, nodejs 22.20.0
                          • Slave: Pi4
                          1 Antwort Letzte Antwort
                          0
                          • N Offline
                            N Offline
                            numeric
                            schrieb am zuletzt editiert von
                            #113

                            Okay das hört sich zunächst einmal so an als ob es theoretisch ohne ifttt klappen würde.

                            Gibt es denn jemanden, der es möglicherweise schon ohne ifttt umgesetzt hat? (In den früheren Beiträgen sind leider viele tote Links, wo Nokia noch seine Finger mit im Spiel hatte)
                            Da die Messgeräte nun auch nicht ganz billig sind, wollte ich mich lieber erst einmal hier erkundigen, ob mein Vorhaben überhaupt Sinn macht oder ob ihr mir davon abratet.

                            1 Antwort Letzte Antwort
                            0
                            • S stoffel67

                              @Kaiman55
                              das steht doch alles hier:
                              (http://developer.withings.com/oauth2/#tag/OAuth-2.0)
                              zunächst: (OAuth 2.0 - Get your authentication code )
                              hier übergibst du u.a. deine client-id und eine "repsonse URL ( Bsp. bei mir: http://<mein-server>.ddns.net/cgi-bin/withings.cmd), dabei wird ein Browserfenster geöffnet (interaktiv) bei dem du deinen account auswählst und dann
                              der Nutzung der App zustimmst, direkt darauf wird die o.a. URL aufgerufen und der "code" und der "state"-string zurückgegeben.
                              diesen "code" dann in den nächsten Aufruf (Get your access token)rein, um den Access_token und den refresh_token zu bekommen, mit diesen kannst du dann die Daten abrufen.
                              Diese Aktion ist nur einmalig notwendig.
                              Achtung:

                              1. code ist nur 30 sec. gültig
                              2. Access_token ist nur 3h gültig, (dafür gibt's dann den refresh_token)
                              N Offline
                              N Offline
                              numeric
                              schrieb am zuletzt editiert von numeric
                              #114

                              @stoffel67 said in Withings Daten einlesen:

                              @Kaiman55
                              das steht doch alles hier:
                              (http://developer.withings.com/oauth2/#tag/OAuth-2.0)
                              zunächst: (OAuth 2.0 - Get your authentication code )
                              hier übergibst du u.a. deine client-id und eine "repsonse URL ( Bsp. bei mir: http://<mein-server>.ddns.net/cgi-bin/withings.cmd), dabei wird ein Browserfenster geöffnet (interaktiv) bei dem du deinen account auswählst und dann
                              der Nutzung der App zustimmst, direkt darauf wird die o.a. URL aufgerufen und der "code" und der "state"-string zurückgegeben.
                              diesen "code" dann in den nächsten Aufruf (Get your access token)rein, um den Access_token und den refresh_token zu bekommen, mit diesen kannst du dann die Daten abrufen.
                              Diese Aktion ist nur einmalig notwendig.
                              Achtung:

                              1. code ist nur 30 sec. gültig
                              2. Access_token ist nur 3h gültig, (dafür gibt's dann den refresh_token)

                              Hallo nochmal. Genau an diesem Punkt hänge ich leider auch gerade. Ich würde gerne mithilfe des Programms "postman" (https://www.postman.com/) meinen Access Token generieren und die API testen.

                              Ich habe die Client-ID und das Consumer-Geheimnis erhalten und als Callback-URI die Adresse von meinem Postman angegeben (siehe Bild):
                              2.JPG

                              Anschließend habe ich den folgenden Beispiel-Link genutzt und meine client-id und die callback URI übergeben:

                              http://account.withings.com/oauth2_user/authorize2?response_type=code&client_id=XXXXX&state=a_random_value&scope=user.info,user.metrics,user.activity&redirect_uri=XXXX&mode=demo

                              Daraufhin öffnete sich ein Browserfenster bei dem die Demo ausgewählt war und bei dem ich der Nutzung der App zustimmen konnte. Die Authentication ist damit complete und in der aufgerufenen URL ist der "Code" und der "state" angegeben. (siehe nachfolgendes Bild):
                              4.JPG

                              Nun hänge ich leider an dem letzten Schritt, indem ich einen Access Token und einen Refresh Token bekommen will.
                              Da ich leider kein Programmierer bin und nur mühsam Schritt für Schritt vorankomme wollte ich erstmal fragen ob ich soweit alles richtig gemacht habe und meine Umsetzung in Postman (Zur Testung der API) überhaupt möglich ist oder ob man da schon einen eigenen Server für braucht?

                              Meine Postman Maske sieht nun folgendermaßen aus:
                              5.JPG

                              Leider weiß ich nicht genau was ich für "Auth URL" und für "Access Token URL" eintragen muss um einen neuen Access Token zu bekommen. Für Scope habe ich "user.info,user.metrics,user.activity" eingesetzt und für State "a_random_value".

                              Ich wäre um jede Hilfe sehr dankbar, da ich langsam echt verzweifle. Und dabei bin ich ja noch ganz am Anfang...

                              S 1 Antwort Letzte Antwort
                              0
                              • N numeric

                                @stoffel67 said in Withings Daten einlesen:

                                @Kaiman55
                                das steht doch alles hier:
                                (http://developer.withings.com/oauth2/#tag/OAuth-2.0)
                                zunächst: (OAuth 2.0 - Get your authentication code )
                                hier übergibst du u.a. deine client-id und eine "repsonse URL ( Bsp. bei mir: http://<mein-server>.ddns.net/cgi-bin/withings.cmd), dabei wird ein Browserfenster geöffnet (interaktiv) bei dem du deinen account auswählst und dann
                                der Nutzung der App zustimmst, direkt darauf wird die o.a. URL aufgerufen und der "code" und der "state"-string zurückgegeben.
                                diesen "code" dann in den nächsten Aufruf (Get your access token)rein, um den Access_token und den refresh_token zu bekommen, mit diesen kannst du dann die Daten abrufen.
                                Diese Aktion ist nur einmalig notwendig.
                                Achtung:

                                1. code ist nur 30 sec. gültig
                                2. Access_token ist nur 3h gültig, (dafür gibt's dann den refresh_token)

                                Hallo nochmal. Genau an diesem Punkt hänge ich leider auch gerade. Ich würde gerne mithilfe des Programms "postman" (https://www.postman.com/) meinen Access Token generieren und die API testen.

                                Ich habe die Client-ID und das Consumer-Geheimnis erhalten und als Callback-URI die Adresse von meinem Postman angegeben (siehe Bild):
                                2.JPG

                                Anschließend habe ich den folgenden Beispiel-Link genutzt und meine client-id und die callback URI übergeben:

                                http://account.withings.com/oauth2_user/authorize2?response_type=code&client_id=XXXXX&state=a_random_value&scope=user.info,user.metrics,user.activity&redirect_uri=XXXX&mode=demo

                                Daraufhin öffnete sich ein Browserfenster bei dem die Demo ausgewählt war und bei dem ich der Nutzung der App zustimmen konnte. Die Authentication ist damit complete und in der aufgerufenen URL ist der "Code" und der "state" angegeben. (siehe nachfolgendes Bild):
                                4.JPG

                                Nun hänge ich leider an dem letzten Schritt, indem ich einen Access Token und einen Refresh Token bekommen will.
                                Da ich leider kein Programmierer bin und nur mühsam Schritt für Schritt vorankomme wollte ich erstmal fragen ob ich soweit alles richtig gemacht habe und meine Umsetzung in Postman (Zur Testung der API) überhaupt möglich ist oder ob man da schon einen eigenen Server für braucht?

                                Meine Postman Maske sieht nun folgendermaßen aus:
                                5.JPG

                                Leider weiß ich nicht genau was ich für "Auth URL" und für "Access Token URL" eintragen muss um einen neuen Access Token zu bekommen. Für Scope habe ich "user.info,user.metrics,user.activity" eingesetzt und für State "a_random_value".

                                Ich wäre um jede Hilfe sehr dankbar, da ich langsam echt verzweifle. Und dabei bin ich ja noch ganz am Anfang...

                                S Offline
                                S Offline
                                spandex21
                                schrieb am zuletzt editiert von
                                #115

                                @numeric

                                Ja du kannst die API problemlos testen und dir den Access Token auch ausgeben lassen. Ich habe dies beispielsweise mit reqbin durchgeführt und auch sämtliche Daten erhalten.

                                Viele Grüße

                                1 Antwort Letzte Antwort
                                0
                                • S Offline
                                  S Offline
                                  spandex21
                                  schrieb am zuletzt editiert von
                                  #116

                                  Hallo ich hätte selbst noch eine Frage.

                                  Ich habe mir vor kurzem die Withings Waage Body + zugelegt und möchte die Daten zentral sammeln und zur Verfügung stellen. Jetzt habe ich weiter oben gelesen, dass man einen eigenen Webserver hierfür benötigt und wollte mal fragen, was da die günstigste Methode wäre? Oder ist es unumgänglich sich beispielsweise einen Cloud-Server zuzulegen, für den man monatlich bezahlen muss?

                                  Viele Grüße

                                  1 Antwort Letzte Antwort
                                  0
                                  • S Offline
                                    S Offline
                                    Stadtschloss
                                    schrieb am zuletzt editiert von
                                    #117

                                    Hallo 🙂 gibt es eine Möglichkeit die Schlafdaten auszulesen?

                                    T 1 Antwort Letzte Antwort
                                    0
                                    • S Stadtschloss

                                      Hallo 🙂 gibt es eine Möglichkeit die Schlafdaten auszulesen?

                                      T Offline
                                      T Offline
                                      tombox
                                      schrieb am zuletzt editiert von tombox
                                      #118

                                      Hat jemand ein Account mit Geräten drin dann kann ich schnell ein Adapter schreiben.
                                      Ist nur die Fragen ob über die App oder Apps mehr Daten kommen als über die API kann man über die App was steuern

                                      O 1 Antwort Letzte Antwort
                                      1
                                      • T tombox

                                        Hat jemand ein Account mit Geräten drin dann kann ich schnell ein Adapter schreiben.
                                        Ist nur die Fragen ob über die App oder Apps mehr Daten kommen als über die API kann man über die App was steuern

                                        O Online
                                        O Online
                                        Oli
                                        schrieb am zuletzt editiert von
                                        #119

                                        @tombox

                                        das wäre super Cool, bin momentan nur leider unterwegs, und keine Daten dabei

                                        Gruß
                                        Oliver

                                        T 1 Antwort Letzte Antwort
                                        0
                                        • O Oli

                                          @tombox

                                          das wäre super Cool, bin momentan nur leider unterwegs, und keine Daten dabei

                                          T Offline
                                          T Offline
                                          tombox
                                          schrieb am zuletzt editiert von
                                          #120

                                          @oli Ich habe mal blind ein Adapter geschrieben ist aber nicht mit Geräten getestet
                                          https://forum.iobroker.net/topic/51104/test-withings-v0-0-x

                                          O StuebiS 2 Antworten Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          749

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe