定制 sportlog/garmin-connect 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

sportlog/garmin-connect

最新稳定版本:v0.9.1

Composer 安装命令:

composer require sportlog/garmin-connect

包简介

Authenticate to Garmin Connect and query data.

README 文档

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();

统计信息

  • 总下载量: 9
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-11-22