stoufa06 / php-garmin-connect-api
PHP library to connect and use garmin wellness api
Installs: 11 434
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 6
Forks: 10
Open Issues: 3
Requires
- league/oauth1-client: 1.8
Requires (Dev)
- vlucas/phpdotenv: ^4.2
This package is auto-updated.
Last update: 2024-04-13 05:36:43 UTC
README
Description
PHP library to connect and use garmin wellness api
Installtion
composer require stoufa06/php-garmin-connect-api
Example
Please take a look at examples folder
Usage
Get authorization link
use Stoufa\GarminApi\GarminApi; try { $config = array( 'identifier' => getenv('GARMIN_KEY'), 'secret' => getenv('GARMIN_SECRET'), 'callback_uri' => getenv('GARMIN_CALLBACK_URI') ); $server = new GarminApi($config); // Retreive temporary credentials from server $temporaryCredentials = $server->getTemporaryCredentials(); // Save temporary crendentials in session to use later to retreive authorization token $_SESSION['temporaryCredentials'] = $temporaryCredentials; // Get authorization link $link = $server->getAuthorizationUrl($temporaryCredentials); } catch (\Throwable $th) { // catch your exception here }
Get token credentials
After the user connects his garmin account successfully it will redirect to callback_uri. "oauth_token" and "oauth_verifier" should be available in $_GET.
try { $config = array( 'identifier' => getenv('GARMIN_KEY'), 'secret' => getenv('GARMIN_SECRET'), 'callback_uri' => getenv('GARMIN_CALLBACK_URI') ); $server = new GarminApi($config); // Retrieve the temporary credentials we saved before $temporaryCredentials = $_SESSION['temporaryCredentials']; // We will now retrieve token credentials from the server. $tokenCredentials = $server->getTokenCredentials($temporaryCredentials, $_GET['oauth_token'], $_GET['oauth_verifier']); } catch (\Throwable $th) { // catch your exception here }
Get Garmin user id
$userId = $server->getUserUid($tokenCredentials);
Backfill activities
When you connect garmin account and get token credentials first time, you won't be able to get previous activities because garmin does not give you activities older than your token credentials. Instead you need to use backfill method to fullfull your token with previous activities (no more than one month).
// backfill activities for last 7 days ago $params = [ 'summaryStartTimeInSeconds' => strtotime("-7 days", time()), 'summaryEndTimeInSeconds' => time() ]; $server->backfillActivitySummary($tokenCredentials, $params);
Deregistration
$server->deleteUserAccessToken($tokenCredentials);
Avalaible methods (for the moment)
Get summary activities
$params = [ 'uploadStartTimeInSeconds' => 1598814036, // time in seconds utc 'uploadEndTimeInSeconds' => 1598900435 // time in seconds utc ]; // Activity summaries $server->getActivitySummary($tokenCredentials, $params); // Manually activity summaries $server->getManuallyActivitySummary($tokenCredentials, $params); // Activity details summaries $server->getActivityDetailsSummary($tokenCredentials, $params);
Backfill activities
// For backfill params can be with upload start time $params = [ 'uploadStartTimeInSeconds' => 1598814036, // time in seconds utc 'uploadEndTimeInSeconds' => 1598900435 // time in seconds utc ]; // or with summary start time $params = [ 'summaryStartTimeInSeconds' => 1598814036, // time in seconds utc 'summaryEndTimeInSeconds' => 1598900435 // time in seconds utc ]; // Backfill activity summaries $server->backfillActivitySummary($tokenCredentials, $params); // Backfill daily activity summaries $server->backfillDailySummary($tokenCredentials, $params); // Backfill epoch summaries $server->backfillEpochSummary($tokenCredentials, $params); // Backfill activity details summaries $server->backfillActivityDetailsSummary($tokenCredentials, $params); // Backfill sleep summaries $server->backfillSleepSummary($tokenCredentials, $params); // Backfill body composition summaries $server->backfillBodyCompositionSummary($tokenCredentials, $params); // Backfill stress details summaries $server->backfillStressDetailsSummary($tokenCredentials, $params); // Backfill user metrics summaries $server->backfillUserMetricsSummary($tokenCredentials, $params); // Backfill pulse ox summaries $server->backfillPulseOxSummary($tokenCredentials, $params); // Backfill respiration summaries $server->backfillRespirationSummary($tokenCredentials, $params);