# encoding: utf-8 module Github class Issues::Labels < API VALID_LABEL_INPUTS = %w[ name color ].freeze # Creates new Issues::Labels API def initialize(options = {}) super(options) end # TODO Merge repository, issues and milesonte labels insdie one query # List all labels for a repository # # = Examples # github = Github.new :user => 'user-name', :repo => 'repo-name' # github.issues.labels.list # github.issues.labels.list { |label| ... } # def list(user_name, repo_name, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _normalize_params_keys(params) response = get_request("/repos/#{user}/#{repo}/labels", params) return response unless block_given? response.each { |el| yield el } end alias :all :list # Get a single label # # = Examples # github = Github.new # github.issues.labels.find 'user-name', 'repo-name', 'label-id' # def get(user_name, repo_name, label_id, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of label_id _normalize_params_keys(params) get_request("/repos/#{user}/#{repo}/labels/#{label_id}", params) end alias :find :get # Create a label # # = Inputs # :name - Required string # :color - Required string - 6 character hex code, without leading # # # = Examples # github = Github.new :user => 'user-name', :repo => 'repo-name' # github.issues.labels.create :name => 'API', :color => 'FFFFFF' # def create(user_name, repo_name, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _normalize_params_keys(params) _filter_params_keys(VALID_LABEL_INPUTS, params) _validate_inputs(VALID_LABEL_INPUTS, params) post_request("/repos/#{user}/#{repo}/labels", params) end # Update a label # # = Inputs # :name - Required string # :color - Required string-6 character hex code, without leading # # # = Examples # @github = Github.new # @github.issues.labels.update 'user-name', 'repo-name', 'label-id', # :name => 'API', :color => "FFFFFF" # def update(user_name, repo_name, label_id, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of label_id _normalize_params_keys(params) _filter_params_keys(VALID_LABEL_INPUTS, params) _validate_inputs(VALID_LABEL_INPUTS, params) patch_request("/repos/#{user}/#{repo}/labels/#{label_id}", params) end alias :edit :update # Delete a label # # = Examples # github = Github.new # github.issues.labels.delete 'user-name', 'repo-name', 'label-id' # def delete(user_name, repo_name, label_id, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of label_id _normalize_params_keys params delete_request("/repos/#{user}/#{repo}/labels/#{label_id}", params) end # List labels on an issue # # = Examples # @github = Github.new # @github.issues.labels.issue 'user-name', 'repo-name', 'issue-id' # def issue(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_keys(params) get_request("/repos/#{user}/#{repo}/issues/#{issue_id}/labels", params) end # Add labels to an issue # # = Examples # github = Github.new # github.issues.labels.add 'user-name', 'repo-name', 'issue-id', 'label1', 'label2', ... # def add(user_name, repo_name, issue_id, *args) params = args.last.is_a?(Hash) ? args.pop : {} params['data'] = args unless args.empty? _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of(issue_id) _normalize_params_keys(params) post_request("/repos/#{user}/#{repo}/issues/#{issue_id}/labels", params) end alias :<< :add # Remove a label from an issue # # = Examples # github = Github.new # github.issues.labels.remove 'user-name', 'repo-name', 'issue-id', 'label-id' # # Remove all labels from an issue # = Examples # github = Github.new # github.issues.labels.remove 'user-name', 'repo-name', 'issue-id' # def remove(user_name, repo_name, issue_id, label_id=nil, 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_keys params if label_id delete_request("/repos/#{user}/#{repo}/issues/#{issue_id}/labels/#{label_id}", params) else delete_request("/repos/#{user}/#{repo}/issues/#{issue_id}/labels", params) end end # Replace all labels for an issue # # Sending an empty array ([]) will remove all Labels from the Issue. # # = Examples # github = Github.new # github.issues.labels.replace 'user-name', 'repo-name', 'issue-id', 'label1', 'label2', ... # def replace(user_name, repo_name, issue_id, *args) params = args.last.is_a?(Hash) ? args.pop : {} params['data'] = args unless args.empty? _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of issue_id _normalize_params_keys(params) put_request("/repos/#{user}/#{repo}/issues/#{issue_id}/labels", params) end # Get labels for every issue in a milestone # # = Examples # github = Github.new # github.issues.labels. 'user-name', 'repo-name', 'milestone-id' # def milestone(user_name, repo_name, milestone_id, params={}) _update_user_repo_params(user_name, repo_name) _validate_user_repo_params(user, repo) unless user? && repo? _validate_presence_of milestone_id response = get_request("/repos/#{user}/#{repo}/milestones/#{milestone_id}/labels", params) return response unless block_given? response.each { |el| yield el } end end # Issues::Labels end # Github