NAME
Pithub - Github v3 API
VERSION
version 0.01001
SYNOPSIS
use Pithub;
use Data::Dumper;
$result = Pithub->new->repos->get( user => 'plu', repo => 'Pithub' );
print Dumper $result->content;
$result = Pithub->new( user => 'plu' )->repos->get( repo => 'Pithub' );
print Dumper $result->content;
$result = Pithub->new( user => 'plu', repo => 'Pithub' )->repos->get;
print Dumper $result->content;
$result = Pithub::Repos->new->get( user => 'plu', repo => 'Pithub' );
print Dumper $result->content;
$result = Pithub::Repos->new( user => 'plu' )->get( repo => 'Pithub' );
print Dumper $result->content;
$result = Pithub::Repos->new( user => 'plu', repo => 'Pithub' )->get;
print Dumper $result->content;
WARNING
Pithub as well as the Github v3 API are still under development. So there might be things broken on both sides. Besides that it's possible that the API will change. This applies to Pithub itself as well as the Github v3 API.
MODULES
There are different ways of using Pithub library. You can either use the main module Pithub
to get access to all other modules like Pithub::Repos for example, or you can use Pithub::Repos directly. In the synopsis above, all the calls are equivalent. Here's an overview over all modules and how to get access to them:
-
See also: http://developer.github.com/v3/gists/
$gists = Pithub->new->gists; $gists = Pithub::Gists->new;
-
See also: http://developer.github.com/v3/gists/comments/
$comments = Pithub->new->gists->comments; $comments = Pithub::Gists->new->comments; $comments = Pithub::Gists::Comments->new;
-
-
See also: http://developer.github.com/v3/git/
$git_data = Pithub->new->git_data; $git_data = Pithub::GitData->new;
-
See also: http://developer.github.com/v3/git/blobs/
$blobs = Pithub->new->git_data->blobs; $blobs = Pithub::GitData->new->blobs; $blobs = Pithub::GitData::Blobs->new;
-
See also: http://developer.github.com/v3/git/commits/
$commits = Pithub->new->git_data->commits; $commits = Pithub::GitData->new->commits; $commits = Pithub::GitData::Commits->new;
-
See also: http://developer.github.com/v3/git/refs/
$references = Pithub->new->git_data->references; $references = Pithub::GitData->new->references; $references = Pithub::GitData::References->new;
-
See also: http://developer.github.com/v3/git/tags/
$tags = Pithub->new->git_data->tags; $tags = Pithub::GitData->new->tags; $tags = Pithub::GitData::Tags->new;
-
See also: http://developer.github.com/v3/git/trees/
$trees = Pithub->new->git_data->trees; $trees = Pithub::GitData->new->trees; $trees = Pithub::GitData::Trees->new;
-
-
See also: http://developer.github.com/v3/issues/
$issues = Pithub->new->issues; $issues = Pithub::Issues->new;
-
See also: http://developer.github.com/v3/issues/comments/
$comments = Pithub->new->issues->comments; $comments = Pithub::Issues->new->comments; $comments = Pithub::Issues::Comments->new;
-
See also: http://developer.github.com/v3/issues/events/
$events = Pithub->new->issues->events; $events = Pithub::Issues->new->events; $events = Pithub::Issues::Events->new;
-
See also: http://developer.github.com/v3/issues/labels/
$labels = Pithub->new->issues->labels; $labels = Pithub::Issues->new->labels; $labels = Pithub::Issues::Labels->new;
-
See also: http://developer.github.com/v3/issues/milestones/
$milestones = Pithub->new->issues->milestones; $milestones = Pithub::Issues->new->milestones; $milestones = Pithub::Issues::Milestones->new;
-
-
See also: http://developer.github.com/v3/orgs/
$orgs = Pithub->new->orgs; $orgs = Pithub::Orgs->new;
-
See also: http://developer.github.com/v3/orgs/members/
$members = Pithub->new->orgs->members; $members = Pithub::Orgs->new->members; $members = Pithub::Orgs::Members->new;
-
See also: http://developer.github.com/v3/orgs/teams/
$teams = Pithub->new->orgs->teams; $teams = Pithub::Orgs->new->teams; $teams = Pithub::Orgs::Teams->new;
-
-
See also: http://developer.github.com/v3/pulls/
$pull_requests = Pithub->new->pull_requests; $pull_requests = Pithub::PullRequests->new;
Pithub::PullRequests::Comments
See also: http://developer.github.com/v3/pulls/comments/
$comments = Pithub->new->pull_requests->comments; $comments = Pithub::PullRequests->new->comments; $comments = Pithub::PullRequests::Comments->new;
-
See also: http://developer.github.com/v3/repos/
$repos = Pithub->new->repos; $repos = Pithub::Repos->new;
-
See also: http://developer.github.com/v3/repos/collaborators/
$collaborators = Pithub->new->repos->collaborators; $collaborators = Pithub::Repos->new->collaborators; $collaborators = Pithub::Repos::Collaborators->new;
-
See also: http://developer.github.com/v3/repos/commits/
$commits = Pithub->new->repos->commits; $commits = Pithub::Repos->new->commits; $commits = Pithub::Repos::Commits->new;
-
See also: http://developer.github.com/v3/repos/downloads/
$downloads = Pithub->new->repos->downloads; $downloads = Pithub::Repos->new->downloads; $downloads = Pithub::Repos::Downloads->new;
-
See also: http://developer.github.com/v3/repos/forks/
$forks = Pithub->new->repos->forks; $forks = Pithub::Repos->new->forks; $forks = Pithub::Repos::Forks->new;
-
See also: http://developer.github.com/v3/repos/keys/
$keys = Pithub->new->repos->keys; $keys = Pithub::Repos->new->keys; $keys = Pithub::Repos::Keys->new;
-
See also: http://developer.github.com/v3/repos/watching/
$watching = Pithub->new->repos->watching; $watching = Pithub::Repos->new->watching; $watching = Pithub::Repos::Watching->new;
-
-
See also: http://developer.github.com/v3/users/
$users = Pithub->new->users; $users = Pithub::Users->new;
-
See also: http://developer.github.com/v3/users/emails/
$emails = Pithub->new->users->emails; $emails = Pithub::Users->new->emails; $emails = Pithub::Users::Emails->new;
-
See also: http://developer.github.com/v3/users/followers/
$followers = Pithub->new->users->followers; $followers = Pithub::Users->new->followers; $followers = Pithub::Users::Followers->new;
-
See also: http://developer.github.com/v3/users/keys/
$keys = Pithub->new->users->keys; $keys = Pithub::Users->new->keys; $keys = Pithub::Users::Keys->new;
-
Besides that there are other modules involved. Every method call which maps directly to a Github API call returns a Pithub::Result object. This contains everything interesting about the response (Pithub::Response) returned from the API call as well as the request (Pithub::Request). Even the Pithub::Base module might be interesting because this one provides the "request" in Pithub::Base method, which is used by all other modules. In case Github adds a new API call which is not supported yet by Pithub the "request" in Pithub::Base method can be used directly.
AUTHOR
Johannes Plunien <plu@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Johannes Plunien.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.