# encoding: utf-8
module Github
class Repos::Comments < API
REQUIRED_COMMENT_OPTIONS = %w[ body ].freeze
VALID_COMMENT_OPTIONS = %w[
body
line
path
position
].freeze
# List commit comments for a repository
#
# = Examples
# github = Github.new
# github.repos.comments.list 'user-name', 'repo-name'
# github.repos.comments.list 'user-name', 'repo-name' { |com| ... }
#
# List comments for a single commit
#
# = Examples
# github.repos.comments.list 'user-name', 'repo-name',
# :sha => '6dcb09b5b57875f334f61aebed695e2e4193db5e'
#
def list(user_name, repo_name, params={})
set :user => user_name, :repo => repo_name
assert_presence_of user, repo
normalize! params
response = if (sha = params.delete('sha'))
get_request("/repos/#{user}/#{repo}/commits/#{sha}/comments", params)
else
get_request("/repos/#{user}/#{repo}/comments", params)
end
return response unless block_given?
response.each { |el| yield el }
end
alias :all :list
# Gets a single commit comment
#
# = Examples
# github = Github.new
# github.repos.comments.get 'user-name', 'repo-name', 'comment-id'
#
def get(user_name, repo_name, comment_id, params={})
set :user => user_name, :repo => repo_name
assert_presence_of user, repo, comment_id
normalize! params
get_request("/repos/#{user}/#{repo}/comments/#{comment_id}", params)
end
alias :find :get
# Creates a commit comment
#
# = Inputs
# * :body - Required string.
# * :comment_id - Required string - Sha of the commit to comment on.
# * :line - Required number - Line number in the file to comment on.
# * :path - Required string - Relative path of the file to comment on.
# * :position - Required number - Line index in the diff to comment on.
#
# = Examples
# github = Github.new
# github.repos.comments.create 'user-name', 'repo-name', 'sha-key',
# "body" => "Nice change",
# "commit_id" => "6dcb09b5b57875f334f61aebed695e2e4193db5e",
# "line" => 1,
# "path" => "file1.txt",
# "position" => 4
#
def create(user_name, repo_name, sha, params={})
set :user => user_name, :repo => repo_name
assert_presence_of user, repo, sha
normalize! params
filter! VALID_COMMENT_OPTIONS, params
assert_required_keys(REQUIRED_COMMENT_OPTIONS, params)
post_request("/repos/#{user}/#{repo}/commits/#{sha}/comments", params)
end
# Update a commit comment
#
# = Inputs
# * :body - Required string.
#
# = Examples
# github = Github.new
# github.repos.comments.update 'user-name', 'repo-name',
# 'comment-id', "body" => "Nice change"
#
def update(user_name, repo_name, comment_id, params={})
set :user => user_name, :repo => repo_name
assert_presence_of user, repo, comment_id
normalize! params
assert_required_keys(REQUIRED_COMMENT_OPTIONS, params)
patch_request("/repos/#{user}/#{repo}/comments/#{comment_id}", params)
end
# Deletes a commit comment
#
# = Examples
# github = Github.new
# github.repos.comments.delete 'user-name', 'repo-name', 'comment-id'
#
def delete(user_name, repo_name, comment_id, params={})
set :user => user_name, :repo => repo_name
assert_presence_of user, repo, comment_id
normalize! params
delete_request("/repos/#{user}/#{repo}/comments/#{comment_id}", params)
end
end # Repos::Comments
end # Github