sportlog / garmin-connect
Authenticate to Garmin Connect and query data.
Installs: 9
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/sportlog/garmin-connect
Requires
- php: >=8.2
- psr/log: ^3.0
Requires (Dev)
- phpstan/phpstan: ^1.10
- phpunit/phpunit: ^9.6
README
A PHP (>= PHP 8.2 with OAuth PECL) library to connect to the Garmin API. This is a port of garth.
Install via Composer
You can install sportlog/garmin-connect using Composer.
$ composer require sportlog/garmin-connect
Main functions
GarminConnect
- GarminConnect::login(...): Login to garmin connect API. If MFA is enabled, you need a subsequent call to GarminConnect::resumeLogin(...).
- GarminConnect::resumeLogin(...): In case MFA is enabled, you must resume login by providing the received MFA-code.
- GarminConnect::connectApi(...): Try to connect with previously fetched token. This refreshes an invalid token, if possible. If false is returned, a call to GarminConnect::login(...) is required. This function is a convenient function to not require passing the password all the time in case a valid token exists.
GarminConnectApi
- GarminConnectApi::runQuery(...): Run query against Garmin connect Api. You can use the factories for getting predefined queries or pass a custom query.
The tokens are saved to the filesystem in folder "./storage" of the current directory. However you can provide your own implementation of TokenStorageInterface, if you want to save the tokens to database, for instance.
How to use
<?php require 'vendor/autoload.php'; use Sportlog\GarminConnect\ConnectStatus; use Sportlog\GarminConnect\GarminConnect; use Sportlog\GarminConnect\FileTokenStorage; use Sportlog\GarminConnect\Queries\GarminConnectQueryFactory; // You need to supply the Garmin user name. // This example uses the built in FileTokenStorage. You must ensure that the directory // exists and is writable for your webserver user. However You can provide your own // implementation of TokenStorageInterface and/or a PSR-3 Logger for debugging. $tokenStorage = new FileTokenStorage(join(DIRECTORY_SEPARATOR, [getcwd(), '.garminconnect'])); $garminConnect = new GarminConnect("<user>", $tokenStorage); // call login with pwd $connectResult = $garminConnect->login("<pwd>"); // Check status if ($connectResult->status === ConnectStatus::Connected) { // MFA is not enabled, you're done. $connectApi = $connectResult->connectApi; // Query some data $response = $connectApi->runQuery(GarminConnectQueryFactory::searchActivities()); // Get the response result $data = $response->toJson(); } if ($connectResult->status === ConnectStatus::MultiFactorAuthorizationRequired) { // MFA is enabled, show login form (incomplete example): echo '<form method="post" action="mfa"> <input type="text" name="mfa" placeholder="MFA code" autofocus /> <input type="hidden" name="csrf" value="' . $result->csrfToken . '" /> <button type="submit">Login</button> </form>'; }
In case of MFA after form submission (mfa.php):
<?php require 'vendor/autoload.php'; use Sportlog\GarminConnect\ConnectStatus; use Sportlog\GarminConnect\GarminConnect; use Sportlog\GarminConnect\Queries\GarminConnectQueryFactory; $mfaCode = $_REQUEST['mfa']; $csrfToken = $_REQUEST['csrf']; // resume login with MFA code and CSRF-token from pevious login() call $connectApi = $garminConnect->resumeLogin($mfaCode, $csrfToken); // Query some data $response = $connectApi->runQuery(GarminConnectQueryFactory::searchActivities()); // Get the response result $data = $response->toJson();