NAME WebService::HealthGraph - A thin wrapper around the Runkeeper (Health Graph) API VERSION version 0.000003 SYNOPSIS my $runkeeper = WebService::HealthGraph->new( debug => 1, token => 'foo', ); my $user = $runkeeper->user; use Data::Printer; p $user->content; # Fetch a weight feed use DateTime (); use URI::FromHash qw( uri ); my $cutoff = DateTime->now->subtract( days => 7 ); my $uri = uri( path => '/weight', query => { noEarlierThan => $cutoff->ymd }, ); my $feed = $runkeeper->get($uri, { feed => 1 }); p $feed->content; DESCRIPTION BETA BETA BETA. The interface is subject to change. This is a very thin wrapper around the Runkeeper (Health Graph) API. At this point it assumes that you already have an OAuth token to connect with. You can use Mojolicious::Plugin::Web::Auth::Site::Runkeeper to create a token. If that doesn't suit you, patches to add OAuth token retrieval to this module will be happily accepted. CONSTRUCTOR ARGUMENTS base_url The URL of the API. Defaults to <https://api.runkeeper.com>. This is settable in case you'd need this for mocking. debug( $bool ) Turns on debugging via LWP::ConsoleLogger. Off by default. token OAuth token. Optional, but you'll need to to get any URLs. ua A user agent object of the LWP::UserAgent family. If you provide your own, be sure you set the correct default headers required for authentication. url_map Returns a map of keys to URLs, as provided by the "user" endpoint. Runkeeper wants you to use these URLs rather than constructing your own. url_for Gives you the corresponding url for any key which exists in "url_map" my $friends = $runkeeper->get( $runkeeper->url_for('team'), { feed => 1 } ); user The WebService::HealthGraph::Response object for the "user" endpoint. user_id The id of the user as provided by the "user" endpoint. METHODS get( $url, $optional_args ) This module will try to do the right thing with the minimum amount of information: my $weight_response = $runkeeper->get( 'weight', { feed => 1 } ); if ( $weight_response->success ) { ... } Optionally, you can provide your own Accept (or other) headers: my $record_response = $runkeeper->get( 'records', { headers => { Accept => 'application/vnd.com.runkeeper.Records+json' } ); Returns a WebService::HealthGraph::Response object. CAVEATS Most response content will contain a "HashRef", but the "records" endpoint returns a response with an "ArrayRef" in the content. AUTHOR Olaf Alders <olaf@wundercounter.com> COPYRIGHT AND LICENSE This software is copyright (c) 2016 by Olaf Alders. This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.