MagicMirror Forum
    • Recent
    • Tags
    • Unsolved
    • Solved
    • MagicMirror² Repository
    • Documentation
    • 3rd-Party-Modules
    • Donate
    • Discord
    • Register
    • Login
    A New Chapter for MagicMirror: The Community Takes the Lead
    Read the statement by Michael Teeuw here.

    Fitbit

    Scheduled Pinned Locked Moved Troubleshooting
    129 Posts 42 Posters 200.8k Views 37 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • H Offline
      Hellangel1987 @olliewarren411
      last edited by

      @olliewarren411

      i set it all on that page. exeption was my location. but all other options are set.

      1 Reply Last reply Reply Quote 0
      • H Offline
        Hellangel1987 @olliewarren411
        last edited by

        @olliewarren411

        works! i sued your code. Delete the token. set it up new - start it with sudo npm start in MagicMirror directory. -> WORKS!

        I think i missunterstand the fibit API page where you have some buttons tu push and autorize the app (i think i pushed them in the wrong way)…

        You sayed something about your token.ini -> can you explain what exactly you have to to every day? i think about an cronjob for that - good chance to solve that together!

        And another option is the weight of my fitbit ARIA, these data are also available - how can we bind them into the app ?

        O 1 Reply Last reply Reply Quote 0
        • O Offline
          olliewarren411 @Hellangel1987
          last edited by

          @Hellangel1987
          Glad to hear you got it working.

          I’m just trying to get the module to refresh more often. Not sure how to go about it.

          You probably could get your weight data in too, you’d need to contact the creator of the module for that.

          K 1 Reply Last reply Reply Quote 0
          • K Offline
            kckndrgn @olliewarren411
            last edited by

            @olliewarren411 said in Fitbit:

            Yes, you can change the refresh interval. In the script MMM-fitbit.js you’ll see

            start: function() {
            		Log.info('Starting module: ' + this.name);
            		this.sendSocketNotification('SET CREDS',this.config.credentials)
            		this.sendSocketNotification('GET DATA', 'intial');
            		
            		this.fadeSpeed = 500;
            		
            		// Schedule update interval.
            		var self = this;
            		setInterval(function() {
            			self.updateData();
            		}, 60*60*1000);
            },
            

            change the 60 x 60 x 1000 to an interval of your choosing. Just be careful to to refresh too often as you’ll get emails from FB telling you that you are pulling too much data. I think (and I’d have to check tonight) that I have mine set to 15 x 60 x 1000.

            O 1 Reply Last reply Reply Quote 0
            • O Offline
              olliewarren411 @kckndrgn
              last edited by

              @kckndrgn

              Thanks! works perfect. I’ve copied your set up so it refreshes the data every 15 mins.

              1 Reply Last reply Reply Quote 0
              • P Offline
                plumcraft
                last edited by

                I was getting invalid redirect_uri during the setup process. (sudo python setupAccess.py)

                But now It’s working for me, great module !

                1 Reply Last reply Reply Quote 0
                • K Offline
                  kckndrgn
                  last edited by

                  Anyway to get around having to run the setupAccess.py everyday/every other day to keep the tokens fresh?
                  Since I have to stop the MM from running, run the script to get new token, start MM again, it gets kind of annoying. I also run my Pi w/o keyboard/mouse so when I need to refresh the tokens I have to connect them.
                  I thought about adding a cron job to stop the MM, run the script and start MM, thoughts? Since the script leaves a browser window open, can the cron job kill it or is there a way to have the python script close the window when done?

                  TIA

                  H 1 Reply Last reply Reply Quote 0
                  • H Offline
                    Hellangel1987 @kckndrgn
                    last edited by

                    @kckndrgn

                    dont know exactly but im also interested in your cronjob solution, can you inform us about your steps ? im tired getting every day that setupaccess working :(

                    K 1 Reply Last reply Reply Quote 0
                    • K Offline
                      kckndrgn @Hellangel1987
                      last edited by

                      @Hellangel1987 said in Fitbit:

                      @kckndrgn

                      dont know exactly but im also interested in your cronjob solution, can you inform us about your steps ? im tired getting every day that setupaccess working :(

                      I haven’t done it, yet, just thinking about it since it was mentioned. I think I’ve narrowed down the issue though:

                      {"message": {"401": {"errors": [{"message": "Access token expired: eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiI0NU5QMzUiLCJhdWQiOiIyMjdRVjkiLCJpc3MiOiJGaXRiaXQiLCJ0eXAiOiJhY2Nlc3NfdG9rZW4iLCJzY29wZXMiOiJ3aHIgd3BybyB3bnV0IHdzbGUgd3dlaSB3c29jIHdhY3Qgd3NldCB3bG9jIiwiZXhwIjoxNDcxNzAxNjYzLCJpYXQiOjE0NzE2NzI4NjN9.VvLWtyYYvVShgrWC4UOVMXfdv0uiy7Nic-WDj7RMiKA. Visit https://dev.fitbit.com/docs/oauth2 for more information on the Fitbit Web API authorization process.", "errorType": "expired_token"}], "success": false}}, "type": "error"}
                      {"message": "Getting a new access token", "type": "status"}
                      {"message": "Error getting new access token", "type": "error"}
                      {"message": {"400": {"errors": [{"message": "Refresh token invalid: 4292cf037821b9441122e432bdd92a238fac61028dfbd6be982d2e6b73474c32. Visit https://dev.fitbit.com/docs/oauth2 for more information on the Fitbit Web API authorization process.", "errorType": "invalid_grant"}], "success": false}}, "type": "error"}
                      

                      First got an “expired” token notice, then the process tries to get a new token (possibly using the “refresh” token, I’m not sure at this point). But refresh tokens are valid for one use only, so it’s like the updated token is getting updated in the token.ini file.

                      1 Reply Last reply Reply Quote 0
                      • P Offline
                        plumcraft
                        last edited by

                        Also interested with the cron mechanism, the module could execute the setupAccess process once a day and trigger a reload on the gui ?

                        I’m using vnc to connect remotely on the RPI since i don’t have mouse/keyboards connected.

                        1 Reply Last reply Reply Quote 0
                        • K Offline
                          kckndrgn
                          last edited by

                          3 days of syncing without an issue. Not sure what changed, I did pull the latest dev code for MM but made no changes to the fitbit module.
                          (of course now that I’ve said this, it will error out during the day :) )

                          1 Reply Last reply Reply Quote 0
                          • K Offline
                            kckndrgn
                            last edited by

                            Had my first issues in a while last night. The problem was that my router lost internet connection and when it was restored the tokens were expired. I ran the setupAccess.py and got new tokens.
                            Seems that there should be a better way to reset the module on restart, like if the tokens are expired, the go get new ones.

                            1 Reply Last reply Reply Quote 0
                            • VendittelliV Offline
                              Vendittelli Module Developer
                              last edited by

                              The python that accesses the fitbit API is currently having that functionality added, I’m doing some work at the moment to help with install issues and once the work on python-fitbit is complete I’ll update again.

                              1 Reply Last reply Reply Quote 0
                              • C Offline
                                chengstark
                                last edited by paviro

                                results: [{"message":"Writing credentials to credentials.ini","type":"status"},{"message":"Writing id: 227Z5P and secret: 55b8d28e28533664a52c6ec6a25b51f0","type":"status"},{"message":"Credentials write successful","type":"status"}]
                                nop
                                Whoops! There was an uncaught exception...
                                { Error: process exited with code 1
                                    at terminateIfNeeded (/home/pi/MagicMirror/modules/node_modules/python-shell/index.js:100:23)
                                    at ChildProcess.<anonymous> (/home/pi/MagicMirror/modules/node_modules/python-shell/index.js:88:9)
                                    at emitTwo (events.js:106:13)
                                    at ChildProcess.emit (events.js:191:7)
                                    at Process.ChildProcess._handle.onexit (internal/child_process.js:215:12)
                                  executable: 'python',
                                  options: null,
                                  script: 'modules/MMM-fitbit/python/getData.py',
                                  args: null,
                                  exitCode: 1 }
                                MagicMirror will not quit, but it might be a good idea to check why this happened. Maybe no internet connection?
                                If you think this really is an issue, please open an issue on GitHub: https://github.com/MichMich/MagicMirror/issues
                                

                                i noticed that my mirror stopped getting data updates. it works yesterday but not today, can you help me identify where went wrong?


                                Note from admin: Please use Markdown on code snippets for easier reading!

                                K 1 Reply Last reply Reply Quote 0
                                • K Offline
                                  kckndrgn @chengstark
                                  last edited by

                                  @chengstark,
                                  Possibly the internet connection was lost during a refresh, this will cause the tokens to get out of date.
                                  I stop MM, re-run the “setupAccess.py” script using credentials from the file, then re-start MM and all is fine, until the next time I have an internet hiccup.

                                  C 1 Reply Last reply Reply Quote 0
                                  • C Offline
                                    chengstark @kckndrgn
                                    last edited by

                                    @kckndrgn thanks, will try

                                    1 Reply Last reply Reply Quote 0
                                    • VendittelliV Offline
                                      Vendittelli Module Developer
                                      last edited by

                                      I have released a fix for the .ini files problem in the latest version on GitHub. You’ll need to delete your tokens.ini and credentials.ini files and remake them (as well as performing a git pull) for the fix to be effective.

                                      1 Reply Last reply Reply Quote 1
                                      • D Offline
                                        darrene
                                        last edited by

                                        For some reason, I’m getting calories displayed, but nothing else. @Vendittelli, does the module have any additional debugging or logging that I can turn on to look through? - I’m not getting any issues in dev mode or in the terminal - it seems that’s the only data I get. When I look in the dev console, I see:

                                        writing steps (data/goal): 0/10000
                                        Writing floors (data/goal): 0/10
                                        writing calories out (data/goal): 1664/2930
                                        writing distance (data/goal) 0/5
                                        writing activeminutes (data/goal): 0/30
                                        writing sleep (data/goal): 0/480

                                        When I clear down my tokens.ini and re-run the setupaccess.py, I can see the scope information for the token results includes u’social’, u’settings’, u’profile’, u’sleep’, u’activity’, u’heartrate’, u’weight’, u’nutrition’, u’location’
                                        if that’s helpful…
                                        As a slight aside: @olliewarren411, would you mind sharing your ‘vertical-layout’ css? I’m still trying to get my head around cascading style sheets!

                                        VendittelliV 1 Reply Last reply Reply Quote 0
                                        • VendittelliV Offline
                                          Vendittelli Module Developer @darrene
                                          last edited by

                                          @darrene That is weird. The module is pretty unadvanced so I don’t have proper debugging, unfortunately. The scope looks correct, are you sure you have synced your Fitbit today? It would explain why calories are displayed as they are calculated automatically so you don’t need to sync them.

                                          D 1 Reply Last reply Reply Quote 0
                                          • D Offline
                                            darrene @Vendittelli
                                            last edited by

                                            Thanks for the quick reply @Vendittelli - that could be the answer. I didn’r realise the calories were calculated like that - as you say, it’d certainly explain it.

                                            I’ll have a look into it. If it comes to it, I’ll recreate the app - I seem to remember there are a list of tick boxes for the fitibit attributes and on the pi browser, it was really difficult to tell whether or not they were ticked!

                                            1 Reply Last reply Reply Quote 0

                                            Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                            Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                            With your input, this post could be even better 💗

                                            Register Login
                                            • 1
                                            • 2
                                            • 3
                                            • 4
                                            • 5
                                            • 6
                                            • 7
                                            • 3 / 7
                                            • First post
                                              Last post
                                            Enjoying MagicMirror? Please consider a donation!
                                            MagicMirror created by Michael Teeuw.
                                            Forum managed by Sam, technical setup by Karsten.
                                            This forum is using NodeBB as its core | Contributors
                                            Contact | Privacy Policy