2017 © Pedro Peláez

library fitbit

Fork of popthestack/fitbit with new APIs



Fork of popthestack/fitbit with new APIs

  • Wednesday, October 14, 2015
  • by huitiemesens
  • Repository
  • 2 Watchers
  • 1 Stars
  • 199 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 103 Forks
  • 0 Open issues
  • 1 Versions
  • 1 % Grown



Basic wrapper for the OAuth-based FitBit REST API. See dev.fitbit.com for details on their OAuth implementation., (*1)

Both this library and the Fitbit API are in beta., (*2)

This library does not require the PHP OAuth extension. It should work on any server with PHP >= 5.3., (*3)


This package is installable with composer: "huitiemesens/fitbit": "dev-master", (*4)


You need a consumer key and secret. You can obtain them by registering an application at http://dev.fitbit.com., (*5)

Simple, but full OAuth workflow example:, (*6)

$factory = new \Fitbit\ApiGatewayFactory;
$factory->setCredentials($consumer_key, $consumer_secret);

$adapter = new \OAuth\Common\Storage\Session();

$auth_gateway = $factory->getAuthenticationGateway();

if (isset($_GET['oauth_token']) && isset($_GET['oauth_verifier'])) {
    $auth_gateway->authenticateUser($_GET['oauth_token'], $_GET['oauth_verifier']);
} elseif (isset($_GET['connect'])) {

if ($auth_gateway->isAuthorized()) {
    $user_gateway = $factory->getUserGateway();
    $user_profile = $user_gateway->getProfile();
    echo '

    echo '
'; } else { echo 'Not connected.'; }

If you want to retrieve the OAuth token and secret from the session to store elsewhere (e.g. a database):, (*7)

$storage = $factory->getStorageAdapter();
$token   = $storage->retrieveAccessToken('FitBit');

// Save these somewhere:
$oauth_token  = $token->getRequestToken();
$oauth_secret = $token->getRequestTokenSecret();

Here's how to use your OAuth token and secret without the Session storage adapter. It's a little cumbersome, but it works. If I ever have time for it, I'd like to replace the current OAuth library with something that doesn't enforce so much... stuff., (*8)

$token = new \OAuth\OAuth1\Token\StdOAuth1Token();

$adapter = new \OAuth\Common\Storage\Memory();
$adapter->storeAccessToken('FitBit', $token);


$user_gateway = $factory->getUserGateway();
$food_gateway = $factory->getFoodGateway();

$user_profile = $user_gateway->getProfile();
$user_devices = $user_gateway->getDevices();
$foods        = $food_gateway->searchFoods('banana split');

echo '

echo '


  • By default, all requests assume you want data for the authorized user (viewer). There are, however, several endpoints you can use to access the data of other Fitbit users, given that you have permission to access their data. This is accomplished by setting the Fitbit User ID with the setUserID method available on ApiGatewayFactory and the Endpoint Gateways (e.g. UserGateway, FoodGateway).
  • Subscriptions: this library has some basic methods to add/delete subscriptions, but it's your responsibility to track the list and maintain server endpoints to receive notifications from Fitbit, as well as register them at http://dev.fitbit.com. See Subscriptions API for more information., (*9)

    New API

  • getWeight in BodyGateway : Allow to get all weight log over a period, a range date or on a specific date. check on https://wiki.fitbit.com/display/API/API-Get-Body-Weight for more information, (*10)

The Versions

14/10 2015


9999999-dev https://github.com/huitiemesens/fitbitphp

Fork of popthestack/fitbit with new APIs

  Sources   Download


The Requires