hybridgroup-octokit 0.6.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +4 -0
- data/.gemtest +0 -0
- data/.gitignore +24 -0
- data/.rspec +3 -0
- data/.travis.yml +6 -0
- data/Gemfile +3 -0
- data/LICENSE +20 -0
- data/README.markdown +73 -0
- data/Rakefile +8 -0
- data/changelog.markdown +42 -0
- data/lib/faraday/response/raise_error.rb +33 -0
- data/lib/octokit/client/authentication.rb +23 -0
- data/lib/octokit/client/commits.rb +16 -0
- data/lib/octokit/client/connection.rb +34 -0
- data/lib/octokit/client/issues.rb +60 -0
- data/lib/octokit/client/network.rb +15 -0
- data/lib/octokit/client/objects.rb +33 -0
- data/lib/octokit/client/organizations.rb +90 -0
- data/lib/octokit/client/pulls.rb +25 -0
- data/lib/octokit/client/repositories.rb +138 -0
- data/lib/octokit/client/request.rb +41 -0
- data/lib/octokit/client/timelines.rb +22 -0
- data/lib/octokit/client/users.rb +75 -0
- data/lib/octokit/client.rb +40 -0
- data/lib/octokit/configuration.rb +61 -0
- data/lib/octokit/repository.rb +39 -0
- data/lib/octokit/version.rb +3 -0
- data/lib/octokit.rb +53 -0
- data/octokit.gemspec +33 -0
- data/spec/faraday/response_spec.rb +34 -0
- data/spec/fixtures/blob.json +1 -0
- data/spec/fixtures/blob_metadata.json +1 -0
- data/spec/fixtures/blobs.json +1 -0
- data/spec/fixtures/branches.json +1 -0
- data/spec/fixtures/collaborators.json +1 -0
- data/spec/fixtures/comment.json +1 -0
- data/spec/fixtures/comments.json +1 -0
- data/spec/fixtures/commit.json +1 -0
- data/spec/fixtures/commits.json +1 -0
- data/spec/fixtures/contributors.json +1 -0
- data/spec/fixtures/delete_token.json +1 -0
- data/spec/fixtures/emails.json +1 -0
- data/spec/fixtures/followers.json +1 -0
- data/spec/fixtures/following.json +1 -0
- data/spec/fixtures/issue.json +1 -0
- data/spec/fixtures/issues.json +1 -0
- data/spec/fixtures/labels.json +1 -0
- data/spec/fixtures/languages.json +1 -0
- data/spec/fixtures/network.json +1 -0
- data/spec/fixtures/network_data.json +1 -0
- data/spec/fixtures/network_meta.json +1 -0
- data/spec/fixtures/organization.json +1 -0
- data/spec/fixtures/organizations.json +1 -0
- data/spec/fixtures/public_keys.json +1 -0
- data/spec/fixtures/pull.json +1 -0
- data/spec/fixtures/pulls.json +1 -0
- data/spec/fixtures/raw.txt +7 -0
- data/spec/fixtures/repositories.json +1 -0
- data/spec/fixtures/repository.json +1 -0
- data/spec/fixtures/tags.json +1 -0
- data/spec/fixtures/team.json +1 -0
- data/spec/fixtures/teams.json +1 -0
- data/spec/fixtures/timeline.json +1237 -0
- data/spec/fixtures/tree.json +1 -0
- data/spec/fixtures/tree_metadata.json +1 -0
- data/spec/fixtures/user.json +1 -0
- data/spec/fixtures/users.json +1 -0
- data/spec/fixtures/watchers.json +1 -0
- data/spec/helper.rb +64 -0
- data/spec/octokit/client/commits_spec.rb +32 -0
- data/spec/octokit/client/issues_spec.rb +154 -0
- data/spec/octokit/client/network_spec.rb +32 -0
- data/spec/octokit/client/objects_spec.rb +81 -0
- data/spec/octokit/client/organizations_spec.rb +234 -0
- data/spec/octokit/client/pulls_spec.rb +44 -0
- data/spec/octokit/client/repositories_spec.rb +331 -0
- data/spec/octokit/client/timelines_spec.rb +42 -0
- data/spec/octokit/client/users_spec.rb +274 -0
- data/spec/octokit/client_spec.rb +12 -0
- data/spec/octokit_spec.rb +15 -0
- data/spec/repository_spec.rb +54 -0
- metadata +403 -0
data/.document
ADDED
data/.gemtest
ADDED
File without changes
|
data/.gitignore
ADDED
@@ -0,0 +1,24 @@
|
|
1
|
+
*.gem
|
2
|
+
*.rbc
|
3
|
+
*.swp
|
4
|
+
*.tmproj
|
5
|
+
*~
|
6
|
+
.DS_Store
|
7
|
+
.\#*
|
8
|
+
.bundle
|
9
|
+
.config
|
10
|
+
.yardoc
|
11
|
+
Gemfile.lock
|
12
|
+
InstalledFiles
|
13
|
+
\#*
|
14
|
+
_yardoc
|
15
|
+
coverage
|
16
|
+
doc/
|
17
|
+
lib/bundler/man
|
18
|
+
pkg
|
19
|
+
rdoc
|
20
|
+
spec/reports
|
21
|
+
test/tmp
|
22
|
+
test/version_tmp
|
23
|
+
tmp
|
24
|
+
tmtags
|
data/.rspec
ADDED
data/.travis.yml
ADDED
data/Gemfile
ADDED
data/LICENSE
ADDED
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright (c) 2011 Wynn Netherland, Adam Stacoviak, Erik Michaels-Ober
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.markdown
ADDED
@@ -0,0 +1,73 @@
|
|
1
|
+
Octokit
|
2
|
+
=======
|
3
|
+
Simple Ruby wrapper for the GitHub v2 API.
|
4
|
+
|
5
|
+
Installation
|
6
|
+
------------
|
7
|
+
gem install octokit
|
8
|
+
|
9
|
+
Continuous Integration
|
10
|
+
----------------------
|
11
|
+
[![Build Status](http://travis-ci.org/pengwynn/octokit.png)](http://travis-ci.org/pengwynn/octokit)
|
12
|
+
|
13
|
+
Some examples
|
14
|
+
-------------
|
15
|
+
|
16
|
+
### Show a user
|
17
|
+
|
18
|
+
Octokit.user('pengwynn')
|
19
|
+
=> <#Hashie::Mash blog="http://wynnnetherland.com" company="Orrka" created_at="2008/02/25 10:24:19 -0800" email="wynn.netherland@gmail.com" followers_count=21 following_count=55 id=865 location="Dallas, TX" login="pengwynn" name="Wynn Netherland" public_gist_count=4 public_repo_count=16>
|
20
|
+
|
21
|
+
### Show who a user follows
|
22
|
+
|
23
|
+
Octokit.following('pengwynn')
|
24
|
+
=> ["cglee", "bryansray", "rails", "zachinglis", "wycats", "obie", "mully", "squeejee", "jderrett", "Shopify", "ReinH", "technoweenie", "errfree", "defunkt", "joshsusser", "hashrocket", "newbamboo", "bigtiger", "github", "jamis", "jeresig", "thoughtbot", "therealadam", "jnunemaker", "seaofclouds", "choan", "llimllib", "kwhinnery", "marshall", "handcrafted", "adamstac", "jashkenas", "dan", "remy", "hayesdavis", "documentcloud", "imathis", "mdeiters", "njonsson", "asenchi", "mattsa", "marclove", "webiest", "brogers", "polomasta", "stephp", "mchelen", "piyush", "davidnorth", "rmetzler", "jferris", "madrobby", "zh", "erikvold", "desandro"]
|
25
|
+
|
26
|
+
Working with repositories
|
27
|
+
-------------------------
|
28
|
+
For convenience, methods that require a repo argument may be passed in any of the following forms
|
29
|
+
|
30
|
+
* "pengwynn/linked"
|
31
|
+
* {:username => 'pengwynn', :name => 'linkedin'}
|
32
|
+
* {:username => 'pengwynn', :repo => 'linkedin'}
|
33
|
+
* instance of Repository
|
34
|
+
|
35
|
+
### Show a repo
|
36
|
+
|
37
|
+
Octokit.repo("pengwynn/linkedin")
|
38
|
+
=> <#Hashie::Mash description="Ruby wrapper for the LinkedIn API" fork=false forks=1 homepage="http://bit.ly/ruby-linkedin" name="linkedin" open_issues=2 owner="pengwynn" private=false url="http://github.com/pengwynn/linkedin" watchers=36>
|
39
|
+
|
40
|
+
Authenticated requests
|
41
|
+
----------------------
|
42
|
+
Some methods require authentication so you'll need to pass a login and an api_token. You can find your GitHub API token on your [account page](https://github.com/account)
|
43
|
+
|
44
|
+
client = Octokit::Client.new(:login => 'pengwynn', :token => 'OU812')
|
45
|
+
client.follow!('adamstac')
|
46
|
+
|
47
|
+
Read the full [docs](http://rdoc.info/projects/pengwynn/octokit)
|
48
|
+
|
49
|
+
TODO
|
50
|
+
----
|
51
|
+
* Feed parsing
|
52
|
+
* More examples
|
53
|
+
|
54
|
+
Submitting a Pull Request
|
55
|
+
-------------------------
|
56
|
+
1. Fork the project.
|
57
|
+
2. Create a topic branch.
|
58
|
+
3. Implement your feature or bug fix.
|
59
|
+
4. Add documentation for your feature or bug fix.
|
60
|
+
5. Run <tt>bundle exec rake doc:yard</tt>. If your changes are not 100% documented, go back to step 4.
|
61
|
+
6. Add specs for your feature or bug fix.
|
62
|
+
7. Run <tt>bundle exec rake spec</tt>. If your changes are not 100% covered, go back to step 6.
|
63
|
+
8. Commit and push your changes.
|
64
|
+
9. Submit a pull request. Please do not include changes to the version or gemspec. (If you want to create your own version for some reason, please do so in a separate commit.)
|
65
|
+
|
66
|
+
Credits
|
67
|
+
-------
|
68
|
+
Octokit is inspired by [Octopi](http://github.com/fcoury/octopi) and aims to be a lightweight, less active-resourcey alternative.
|
69
|
+
|
70
|
+
Copyright
|
71
|
+
---------
|
72
|
+
Copyright (c) 2011 [Wynn Netherland](http://wynnnetherland.com), [Adam Stacoviak](http://adamstacoviak.com/), [Erik Michaels-Ober](https://github.com/sferik).
|
73
|
+
See [LICENSE](https://github.com/pengwynn/octokit/blob/master/LICENSE) for details.
|
data/Rakefile
ADDED
data/changelog.markdown
ADDED
@@ -0,0 +1,42 @@
|
|
1
|
+
# Changelog
|
2
|
+
## 0.5.0
|
3
|
+
* Rewrote all tests in rspec
|
4
|
+
* A handful of backwards-incompatible API changes
|
5
|
+
## 0.4.1
|
6
|
+
* Patch from [karlfreeman](http://github.com/karlfreeman) to fix user search
|
7
|
+
## 0.4.0
|
8
|
+
* Renamed to Ocotokit
|
9
|
+
* Switched to Faraday from HTTParty
|
10
|
+
## 0.3.0
|
11
|
+
* Added set_repo_info patch from [Scott Bronson](http://github.com/bronson)
|
12
|
+
## 0.2.4
|
13
|
+
* Rev'd HTTParty dependency, switched to Bundler
|
14
|
+
## 0.2.3
|
15
|
+
* Patch from [Sutto](http://github.com/Sutto) to use authentication with list repos if available
|
16
|
+
## 0.2.2
|
17
|
+
* Patch from [abrader](http://github.com/abrader) to add auth_params query to the blob, tree, and repo class methods
|
18
|
+
## 0.2.1
|
19
|
+
* Contributors API courtesy of @enricob
|
20
|
+
## 0.2.0
|
21
|
+
* Commits API courtesy of @enricob
|
22
|
+
|
23
|
+
## 0.1.4
|
24
|
+
|
25
|
+
* Preserved links array and content for events parsed from feeds
|
26
|
+
|
27
|
+
## 0.1.3
|
28
|
+
|
29
|
+
* Added Download event
|
30
|
+
|
31
|
+
## 0.1.2
|
32
|
+
|
33
|
+
* Added Delete event type
|
34
|
+
* Added Public event type
|
35
|
+
|
36
|
+
## 0.1.1
|
37
|
+
|
38
|
+
* Added Comment event type
|
39
|
+
|
40
|
+
## 0.0.1 Initial version
|
41
|
+
|
42
|
+
* GitHub v2 API complete
|
@@ -0,0 +1,33 @@
|
|
1
|
+
require 'faraday'
|
2
|
+
|
3
|
+
# @api private
|
4
|
+
module Faraday
|
5
|
+
class Response::RaiseError < Response::Middleware
|
6
|
+
def on_complete(response)
|
7
|
+
case response[:status].to_i
|
8
|
+
when 400
|
9
|
+
raise Octokit::BadRequest, error_message(response)
|
10
|
+
when 401
|
11
|
+
raise Octokit::Unauthorized, error_message(response)
|
12
|
+
when 403
|
13
|
+
raise Octokit::Forbidden, error_message(response)
|
14
|
+
when 404
|
15
|
+
raise Octokit::NotFound, error_message(response)
|
16
|
+
when 406
|
17
|
+
raise Octokit::NotAcceptable, error_message(response)
|
18
|
+
when 500
|
19
|
+
raise Octokit::InternalServerError, error_message(response)
|
20
|
+
when 501
|
21
|
+
raise Octokit::NotImplemented, error_message(response)
|
22
|
+
when 502
|
23
|
+
raise Octokit::BadGateway, error_message(response)
|
24
|
+
when 503
|
25
|
+
raise Octokit::ServiceUnavailable, error_message(response)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
def error_message(response)
|
30
|
+
"#{response[:method].to_s.upcase} #{response[:url].to_s}: #{response[:status]}#{(': ' + response[:body].inspect) if response[:body]}"
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Authentication
|
4
|
+
def authentication
|
5
|
+
if login && token
|
6
|
+
{:login => "#{login}/token", :password => token}
|
7
|
+
elsif login && password
|
8
|
+
{:login => login, :password => password}
|
9
|
+
else
|
10
|
+
{}
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
def authenticated?
|
15
|
+
!authentication.empty?
|
16
|
+
end
|
17
|
+
|
18
|
+
def oauthed?
|
19
|
+
!oauth_token.nil?
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,16 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Commits
|
4
|
+
|
5
|
+
def commits(repo, branch="master", options={})
|
6
|
+
get("commits/list/#{Repository.new(repo)}/#{branch}", options)['commits']
|
7
|
+
end
|
8
|
+
alias :list_commits :commits
|
9
|
+
|
10
|
+
def commit(repo, sha, options={})
|
11
|
+
get("commits/show/#{Repository.new(repo)}/#{sha}", options)['commits']
|
12
|
+
end
|
13
|
+
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
@@ -0,0 +1,34 @@
|
|
1
|
+
require 'faraday_middleware'
|
2
|
+
require 'faraday/response/raise_error'
|
3
|
+
|
4
|
+
module Octokit
|
5
|
+
class Client
|
6
|
+
# @private
|
7
|
+
module Connection
|
8
|
+
private
|
9
|
+
|
10
|
+
def connection(raw=false, authenticate=true)
|
11
|
+
options = {
|
12
|
+
:proxy => proxy,
|
13
|
+
:ssl => {:verify => false},
|
14
|
+
:url => endpoint,
|
15
|
+
}
|
16
|
+
|
17
|
+
options.merge!(:params => { :access_token => oauth_token }) if oauthed? && !authenticated?
|
18
|
+
|
19
|
+
Faraday::Connection.new(options) do |connection|
|
20
|
+
connection.use Faraday::Response::RaiseError
|
21
|
+
unless raw
|
22
|
+
connection.use Faraday::Response::Mashify
|
23
|
+
case format.to_s.downcase
|
24
|
+
when 'json' then connection.use Faraday::Response::ParseJson
|
25
|
+
when 'xml' then connection.use Faraday::Response::ParseXml
|
26
|
+
end
|
27
|
+
end
|
28
|
+
connection.basic_auth authentication[:login], authentication[:password] if authenticate and authenticated?
|
29
|
+
connection.adapter(adapter)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Issues
|
4
|
+
|
5
|
+
def search_issues(repo, search_term, state='open', options={})
|
6
|
+
get("issues/search/#{Repository.new(repo)}/#{state}/#{search_term}", options)['issues']
|
7
|
+
end
|
8
|
+
|
9
|
+
def issues(repo, state='open', options={})
|
10
|
+
get("issues/list/#{Repository.new(repo)}/#{state}", options)['issues']
|
11
|
+
end
|
12
|
+
alias :list_issues :issues
|
13
|
+
|
14
|
+
def issues_labeled(repo, label, options={})
|
15
|
+
get("issues/list/#{Repository.new(repo)}/label/#{label}", options)['issues']
|
16
|
+
end
|
17
|
+
|
18
|
+
def issue(repo, number, options={})
|
19
|
+
get("issues/show/#{Repository.new(repo)}/#{number}", options)['issue']
|
20
|
+
end
|
21
|
+
|
22
|
+
def issue_comments(repo, number, options={})
|
23
|
+
get("issues/comments/#{Repository.new(repo)}/#{number}", options)['comments']
|
24
|
+
end
|
25
|
+
|
26
|
+
def create_issue(repo, title, body, options={})
|
27
|
+
post("issues/open/#{Repository.new(repo)}", options.merge({:title => title, :body => body}))['issue']
|
28
|
+
end
|
29
|
+
alias :open_issue :create_issue
|
30
|
+
|
31
|
+
def close_issue(repo, number, options={})
|
32
|
+
post("issues/close/#{Repository.new(repo)}/#{number}", options)['issue']
|
33
|
+
end
|
34
|
+
|
35
|
+
def reopen_issue(repo, number, options={})
|
36
|
+
post("issues/reopen/#{Repository.new(repo)}/#{number}", options)['issue']
|
37
|
+
end
|
38
|
+
|
39
|
+
def update_issue(repo, number, title, body, options={})
|
40
|
+
post("issues/edit/#{Repository.new(repo)}/#{number}", options.merge({:title => title, :body => body}))['issue']
|
41
|
+
end
|
42
|
+
|
43
|
+
def labels(repo, options={})
|
44
|
+
get("issues/labels/#{Repository.new(repo)}", options)['labels']
|
45
|
+
end
|
46
|
+
|
47
|
+
def add_label(repo, label, number=nil, options={})
|
48
|
+
post(["issues/label/add/#{Repository.new(repo)}/#{label}", number].compact.join('/'), options)['labels']
|
49
|
+
end
|
50
|
+
|
51
|
+
def remove_label(repo, label, number=nil, options={})
|
52
|
+
post(["issues/label/remove/#{Repository.new(repo)}/#{label}", number].compact.join('/'), options)['labels']
|
53
|
+
end
|
54
|
+
|
55
|
+
def add_comment(repo, number, comment, options={})
|
56
|
+
post("issues/comment/#{Repository.new(repo)}/#{number}", options.merge({:comment => comment}))['comment']
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Network
|
4
|
+
|
5
|
+
def network_meta(repo, options={})
|
6
|
+
get("#{Repository.new(repo)}/network_meta", options, false, false)
|
7
|
+
end
|
8
|
+
|
9
|
+
def network_data(repo, options={})
|
10
|
+
get("#{Repository.new(repo)}/network_data_chunk", options, false, false)['commits']
|
11
|
+
end
|
12
|
+
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,33 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Objects
|
4
|
+
|
5
|
+
def tree(repo, tree_sha, options={})
|
6
|
+
get("tree/show/#{Repository.new(repo)}/#{tree_sha}", options)['tree']
|
7
|
+
end
|
8
|
+
|
9
|
+
def blob(repo, tree_sha, path, options={})
|
10
|
+
get("blob/show/#{Repository.new(repo)}/#{tree_sha}/#{path}", options)['blob']
|
11
|
+
end
|
12
|
+
|
13
|
+
def blobs(repo, tree_sha, options={})
|
14
|
+
get("blob/all/#{Repository.new(repo)}/#{tree_sha}", options)['blobs']
|
15
|
+
end
|
16
|
+
|
17
|
+
def blob_metadata(repo, tree_sha, options={})
|
18
|
+
get("blob/full/#{Repository.new(repo)}/#{tree_sha}", options)['blobs']
|
19
|
+
end
|
20
|
+
alias :blob_meta :blob_metadata
|
21
|
+
|
22
|
+
def tree_metadata(repo, tree_sha, options={})
|
23
|
+
get("tree/full/#{Repository.new(repo)}/#{tree_sha}", options)['tree']
|
24
|
+
end
|
25
|
+
alias :tree_meta :tree_metadata
|
26
|
+
|
27
|
+
def raw(repo, sha, options={})
|
28
|
+
get("blob/show/#{Repository.new(repo)}/#{sha}", options, true).body
|
29
|
+
end
|
30
|
+
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Organizations
|
4
|
+
|
5
|
+
def organization(org, options={})
|
6
|
+
get("organizations/#{org}", options)['organization']
|
7
|
+
end
|
8
|
+
alias :org :organization
|
9
|
+
|
10
|
+
def update_organization(org, values, options={})
|
11
|
+
put("organizations/#{org}", options.merge({:organization => values}))['organization']
|
12
|
+
end
|
13
|
+
alias :update_org :update_organization
|
14
|
+
|
15
|
+
def organizations(user=nil, options={})
|
16
|
+
if user
|
17
|
+
get("user/show/#{user}/organizations", options)
|
18
|
+
else
|
19
|
+
get("organizations", options)
|
20
|
+
end['organizations']
|
21
|
+
end
|
22
|
+
alias :list_organizations :organizations
|
23
|
+
alias :list_orgs :organizations
|
24
|
+
alias :orgs :organizations
|
25
|
+
|
26
|
+
def organization_repositories(org=nil, options={})
|
27
|
+
if org
|
28
|
+
get("organizations/#{org}/public_repositories", options)
|
29
|
+
else
|
30
|
+
get("organizations/repositories", options)
|
31
|
+
end['repositories']
|
32
|
+
end
|
33
|
+
alias :org_repositories :organization_repositories
|
34
|
+
alias :org_repos :organization_repositories
|
35
|
+
|
36
|
+
def organization_members(org, options={})
|
37
|
+
get("organizations/#{org}/public_members", options)['users']
|
38
|
+
end
|
39
|
+
alias :org_members :organization_members
|
40
|
+
|
41
|
+
def organization_teams(org, options={})
|
42
|
+
get("organizations/#{org}/teams", options)['teams']
|
43
|
+
end
|
44
|
+
alias :org_teams :organization_teams
|
45
|
+
|
46
|
+
def create_team(org, values, options={})
|
47
|
+
post("organizations/#{org}/teams", options.merge({:team => values}))['team']
|
48
|
+
end
|
49
|
+
|
50
|
+
def team(team_id, options={})
|
51
|
+
get("teams/#{team_id}", options)['team']
|
52
|
+
end
|
53
|
+
|
54
|
+
def update_team(team_id, values, options={})
|
55
|
+
put("teams/#{team_id}", options.merge({:team => values}))['team']
|
56
|
+
end
|
57
|
+
|
58
|
+
def delete_team(team_id, options={})
|
59
|
+
delete("teams/#{team_id}", options)['team']
|
60
|
+
end
|
61
|
+
|
62
|
+
def team_members(team_id, options={})
|
63
|
+
get("teams/#{team_id}/members", options)['users']
|
64
|
+
end
|
65
|
+
|
66
|
+
def add_team_member(team_id, user, options={})
|
67
|
+
post("teams/#{team_id}/members", options.merge({:name => user}))['user']
|
68
|
+
end
|
69
|
+
|
70
|
+
def remove_team_member(team_id, user, options={})
|
71
|
+
delete("teams/#{team_id}/members", options.merge({:name => user}))['user']
|
72
|
+
end
|
73
|
+
|
74
|
+
def team_repositories(team_id, options={})
|
75
|
+
get("teams/#{team_id}/repositories", options)['repositories']
|
76
|
+
end
|
77
|
+
alias :team_repos :team_repositories
|
78
|
+
|
79
|
+
def add_team_repository(team_id, repo, options={})
|
80
|
+
post("teams/#{team_id}/repositories", options.merge(:name => Repository.new(repo)))['repositories']
|
81
|
+
end
|
82
|
+
alias :add_team_repo :add_team_repository
|
83
|
+
|
84
|
+
def remove_team_repository(team_id, repo, options={})
|
85
|
+
delete("teams/#{team_id}/repositories", options.merge(:name => Repository.new(repo)))['repositories']
|
86
|
+
end
|
87
|
+
alias :remove_team_repo :remove_team_repository
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|
@@ -0,0 +1,25 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Pulls
|
4
|
+
def create_pull_request(repo, base, head, title, body, options={})
|
5
|
+
pull = {
|
6
|
+
:base => base,
|
7
|
+
:head => head,
|
8
|
+
:title => title,
|
9
|
+
:body => body,
|
10
|
+
}
|
11
|
+
post("pulls/#{Repository.new(repo)}", options.merge({:pull => pull}))['pulls']
|
12
|
+
end
|
13
|
+
|
14
|
+
def pull_requests(repo, state='open', options={})
|
15
|
+
get("pulls/#{Repository.new(repo)}/#{state}", options)['pulls']
|
16
|
+
end
|
17
|
+
alias :pulls :pull_requests
|
18
|
+
|
19
|
+
def pull_request(repo, number, options={})
|
20
|
+
get("pulls/#{Repository.new(repo)}/#{number}", options)['pull']
|
21
|
+
end
|
22
|
+
alias :pull :pull_request
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -0,0 +1,138 @@
|
|
1
|
+
module Octokit
|
2
|
+
class Client
|
3
|
+
module Repositories
|
4
|
+
|
5
|
+
def search_repositories(q, options={})
|
6
|
+
get("repos/search/#{q}", options)['repositories']
|
7
|
+
end
|
8
|
+
alias :search_repos :search_repositories
|
9
|
+
|
10
|
+
def repository(repo, options={})
|
11
|
+
get("repos/show/#{Repository.new(repo)}", options)['repository']
|
12
|
+
end
|
13
|
+
alias :repo :repository
|
14
|
+
|
15
|
+
def update_repository(repo, values, options={})
|
16
|
+
post("repos/show/#{Repository.new(repo)}", options.merge({:values => values}))['repository']
|
17
|
+
end
|
18
|
+
alias :update_repo :update_repository
|
19
|
+
|
20
|
+
def repositories(username=login, options={})
|
21
|
+
get(["repos/show", username].compact.join('/'), options)['repositories']
|
22
|
+
end
|
23
|
+
alias :list_repositories :repositories
|
24
|
+
alias :list_repos :repositories
|
25
|
+
alias :repos :repositories
|
26
|
+
|
27
|
+
def watch(repo, options={})
|
28
|
+
post("repos/watch/#{Repository.new(repo)}", options)['repository']
|
29
|
+
end
|
30
|
+
|
31
|
+
def unwatch(repo, options={})
|
32
|
+
post("repos/unwatch/#{Repository.new(repo)}", options)['repository']
|
33
|
+
end
|
34
|
+
|
35
|
+
def fork(repo, options={})
|
36
|
+
post("repos/fork/#{Repository.new(repo)}", options)['repository']
|
37
|
+
end
|
38
|
+
|
39
|
+
def create_repository(name, options={})
|
40
|
+
post("repos/create", options.merge(:name => name))['repository']
|
41
|
+
end
|
42
|
+
alias :create_repo :create_repository
|
43
|
+
alias :create :create_repository
|
44
|
+
|
45
|
+
def delete_repository(repo, options={})
|
46
|
+
response = post("repos/delete/#{Repository.new(repo)}", options)
|
47
|
+
if response.respond_to?(:delete_token)
|
48
|
+
response['delete_token']
|
49
|
+
else
|
50
|
+
response['repository']
|
51
|
+
end
|
52
|
+
end
|
53
|
+
alias :delete_repo :delete_repository
|
54
|
+
|
55
|
+
def delete_repository!(repo, options={})
|
56
|
+
response = post("repos/delete/#{Repository.new(repo)}", options)
|
57
|
+
post("repos/delete/#{Repository.new(repo)}", options.merge(:delete_token => response['delete_token']))['repository']
|
58
|
+
end
|
59
|
+
alias :delete_repo! :delete_repository!
|
60
|
+
|
61
|
+
def set_private(repo, options={})
|
62
|
+
post("repos/set/private/#{Repository.new(repo)}", options)['repository']
|
63
|
+
end
|
64
|
+
|
65
|
+
def set_public(repo, options={})
|
66
|
+
post("repos/set/public/#{Repository.new(repo)}", options)['repository']
|
67
|
+
end
|
68
|
+
|
69
|
+
def deploy_keys(repo, options={})
|
70
|
+
get("repos/keys/#{Repository.new(repo)}", options)['public_keys']
|
71
|
+
end
|
72
|
+
alias :list_deploy_keys :deploy_keys
|
73
|
+
|
74
|
+
def add_deploy_key(repo, title, key, options={})
|
75
|
+
post("repos/key/#{Repository.new(repo)}/add", options)['public_keys']
|
76
|
+
end
|
77
|
+
|
78
|
+
def remove_deploy_key(repo, id, options={})
|
79
|
+
post("repos/key/#{Repository.new(repo)}/remove", options.merge(:id => id))['public_keys']
|
80
|
+
end
|
81
|
+
|
82
|
+
def collaborators(repo, options={})
|
83
|
+
get("repos/show/#{Repository.new(repo)}/collaborators", options)['collaborators']
|
84
|
+
end
|
85
|
+
alias :collabs :collaborators
|
86
|
+
|
87
|
+
def add_collaborator(repo, collaborator, options={})
|
88
|
+
post("repos/collaborators/#{Repository.new(repo)}/add/#{collaborator}")['collaborators']
|
89
|
+
end
|
90
|
+
alias :add_collab :add_collaborator
|
91
|
+
|
92
|
+
def remove_collaborator(repo, collaborator, options={})
|
93
|
+
post("repos/collaborators/#{Repository.new(repo)}/remove/#{collaborator}")['collaborators']
|
94
|
+
end
|
95
|
+
alias :remove_collab :remove_collaborator
|
96
|
+
|
97
|
+
def pushable(options={})
|
98
|
+
get("repos/pushable", options)['repositories']
|
99
|
+
end
|
100
|
+
|
101
|
+
def repository_teams(repo, options={})
|
102
|
+
get("repos/show/#{Repository.new(repo)}/teams", options)['teams']
|
103
|
+
end
|
104
|
+
alias :repo_teams :repository_teams
|
105
|
+
alias :teams :repository_teams
|
106
|
+
|
107
|
+
def contributors(repo, anon=false, options={})
|
108
|
+
if anon
|
109
|
+
get("repos/show/#{Repository.new(repo)}/contributors/anon", options)
|
110
|
+
else
|
111
|
+
get("repos/show/#{Repository.new(repo)}/contributors", options)
|
112
|
+
end['contributors']
|
113
|
+
end
|
114
|
+
alias :contribs :contributors
|
115
|
+
|
116
|
+
def watchers(repo, options={})
|
117
|
+
get("repos/show/#{Repository.new(repo)}/watchers", options)['watchers']
|
118
|
+
end
|
119
|
+
|
120
|
+
def network(repo, options={})
|
121
|
+
get("repos/show/#{Repository.new(repo)}/network", options)['network']
|
122
|
+
end
|
123
|
+
|
124
|
+
def languages(repo, options={})
|
125
|
+
get("repos/show/#{Repository.new(repo)}/languages", options)['languages']
|
126
|
+
end
|
127
|
+
|
128
|
+
def tags(repo, options={})
|
129
|
+
get("repos/show/#{Repository.new(repo)}/tags", options)['tags']
|
130
|
+
end
|
131
|
+
|
132
|
+
def branches(repo, options={})
|
133
|
+
get("repos/show/#{Repository.new(repo)}/branches", options)['branches']
|
134
|
+
end
|
135
|
+
|
136
|
+
end
|
137
|
+
end
|
138
|
+
end
|