# NAME WebService::Toggl - Interface to the toggl.com API # SYNOPSIS use WebService::Toggl; my $toggl = WebService::Toggl->new({api_key => $ENV{API_KEY}}); my $me = $toggl->me(); say "Me: " . $me->fullname . " <" . $me->email . ">:"; say "My Workspaces:"; for my $ws ($me->workspaces->all) { say " " . $ws->name . " (" . $ws->id . ")"; say " Projects:"; say " " . $_->name . " (" . $_->id . ") " for ($ws->projects->all); } # DESCRIPTION **NB: This is a new module, and the API is still under development. While I'm pretty happy with the current interface, expect the internals to be heavily refactored before v1.0. This version currently only supports read access to the API, but I plan to add write access in the near future.** [WebService::Toggl](https://metacpan.org/pod/WebService::Toggl) is a perl interface to the [Toggl](http://www.toggl.com) API, as described at [https://github.com/toggl/toggl\_api\_docs](https://github.com/toggl/toggl_api_docs). When a new `WebService::Toggl` object is created, it is associated with a particulars user's credentials via their API token. The API token can be found at the bottom of your 'My Profile' on Toggl. Any new objects created by the `WebService::Toggl` object will inherit its credentials. ## Laziness All `Webservice::Toggl::API::` and `WebService::Toggl::Report::` objects are created lazily. If you ask for a particular `::API::Workspace` object by id, no GET request against the Toggl API will be issued until you request an attribute that has not yet been set. E.g. my $workspace = $toggl->workspace(1234); say $workspace->id; # prints 1234, no GET yet issued say $workspace->name; # name is not yet set, will issue GET request ## Raw data Each `API::` and `Report::` object stores the raw response received from Toggl in an attribute called `raw`. If you want to force the object to fill itself in with data from the API, calling `$object->raw()` will do so. ## Set objects Each `API::` class has a corresponding class that represents a set of the objects. These set objects store the raw response query and will return a list of the objects it comprises via the `->all()` method. ## Additional queries You can make other requests against the Toggle API via the `api_{get,post,put,delete}()` methods provided by [WebService::Toggl::Role::Base](https://metacpan.org/pod/WebService::Toggl::Role::Base). For instance, if you had a [WebService::Toggl::API::Tag](https://metacpan.org/pod/WebService::Toggl::API::Tag) object that you wanted to delete, you could write: $tag->api_delete( $tag->my_url ); # METHODS ## API objects ### me() Returns the [WebService::Toggl::API::Me](https://metacpan.org/pod/WebService::Toggl::API::Me) object representing the authorized user. ### workspace($id) Returns the [WebService::Toggl::API::Workspace](https://metacpan.org/pod/WebService::Toggl::API::Workspace) object with the given id. ### workspace\_user( $id ) Returns the [WebService::Toggl::API::WorkspaceUser](https://metacpan.org/pod/WebService::Toggl::API::WorkspaceUser) object with the given id. ### client( $id ) Returns the [WebService::Toggl::API::Client](https://metacpan.org/pod/WebService::Toggl::API::Client) object with the given id. ### project( $id ) Returns the [WebService::Toggl::API::Project](https://metacpan.org/pod/WebService::Toggl::API::Project) object with the given id. ### project\_user( $id ) Returns the [WebService::Toggl::API::ProjectUser](https://metacpan.org/pod/WebService::Toggl::API::ProjectUser) object with the given id. ### tag( $id ) Returns the [WebService::Toggl::API::Tag](https://metacpan.org/pod/WebService::Toggl::API::Tag) object with the given id. ### task( $id ) Returns the [WebService::Toggl::API::Task](https://metacpan.org/pod/WebService::Toggl::API::Task) object with the given id. ### time\_entry( $id ) Returns the [WebService::Toggl::API::TimeEntry](https://metacpan.org/pod/WebService::Toggl::API::TimeEntry) object with the given id. ### user( $id ) Returns the [WebService::Toggl::API::User](https://metacpan.org/pod/WebService::Toggl::API::User) object with the given id. ## Reports ### details( $args ) Returns the [WebService::Toggl::Report::Details](https://metacpan.org/pod/WebService::Toggl::Report::Details) object with the given arguments. ### summary( $args ) Returns the [WebService::Toggl::Report::Summary](https://metacpan.org/pod/WebService::Toggl::Report::Summary) object with the given arguments. ### weekly( $args ) Returns the [WebService::Toggl::Report::Weekly](https://metacpan.org/pod/WebService::Toggl::Report::Weekly) object with the given arguments. # LICENSE Copyright (C) Fitz Elliott. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. # AUTHOR Fitz Elliott <felliott@fiskur.org>