# frozen_string_literal: true
module BitBucket
class Issues::Comments < API
VALID_ISSUE_COMMENT_PARAM_NAME = %w[
content
].freeze
# Creates new Issues::Comments API
def initialize(options = {})
super(options)
end
# List comments on an issue
#
# = Examples
# bitbucket = BitBucket.new
# bitbucket.issues.comments.all 'user-name', 'repo-name', 'issue-id'
# bitbucket.issues.comments.all 'user-name', 'repo-name', 'issue-id' {|com| .. }
#
def list(user_name, repo_name, issue_id, params = {})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of issue_id
normalize! params
# _merge_mime_type(:issue_comment, params)
response = get_request("/1.0/repositories/#{user}/#{repo.downcase}/issues/#{issue_id}/comments/", params)
return response unless block_given?
response.each { |el| yield el }
end
alias all list
# Get a single comment
#
# = Examples
# bitbucket = BitBucket.new
# bitbucket.issues.comments.find 'user-name', 'repo-name', 'comment-id'
#
def get(user_name, repo_name, comment_id, params = {})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of comment_id
normalize! params
# _merge_mime_type(:issue_comment, params)
get_request("/1.0/repositories/#{user}/#{repo.downcase}/issues/comments/#{comment_id}", params)
end
alias find get
# Create a comment
#
# = Inputs
# :content Required string
#
# = Examples
# bitbucket = BitBucket.new
# bitbucket.issues.comments.create 'user-name', 'repo-name', 'issue-id',
# "content" => 'a new comment'
#
def create(user_name, repo_name, issue_id, params = {})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of issue_id
normalize! params
# _merge_mime_type(:issue_comment, params)
filter! VALID_ISSUE_COMMENT_PARAM_NAME, params
assert_required_keys(%w[content], params)
post_request("/1.0/repositories/#{user}/#{repo.downcase}/issues/#{issue_id}/comments/", params)
end
# Edit a comment
#
# = Inputs
# :content Required string
#
# = Examples
# bitbucket = BitBucket.new
# bitbucket.issues.comments.edit 'user-name', 'repo-name', 'comment-id',
# "content" => 'a new comment'
#
def edit(user_name, repo_name, comment_id, params = {})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of comment_id
normalize! params
# _merge_mime_type(:issue_comment, params)
filter! VALID_ISSUE_COMMENT_PARAM_NAME, params
assert_required_keys(%w[content], params)
put_request("/1.0/repositories/#{user}/#{repo.downcase}/issues/comments/#{comment_id}", params)
end
# Delete a comment
#
# = Examples
# bitbucket = BitBucket.new
# bitbucket.issues.comments.delete 'user-name', 'repo-name', 'comment-id'
#
def delete(user_name, repo_name, comment_id, params = {})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of comment_id
normalize! params
# _merge_mime_type(:issue_comment, params)
delete_request("/1.0/repositories/#{user}/#{repo.downcase}/issues/comments/#{comment_id}", params)
end
end # Issues::Comments
end # BitBucket