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.