# encoding: utf-8 module Github class Issues::Milestones < API VALID_MILESTONE_OPTIONS = { 'state' => %w[ open closed ], 'sort' => %w[ due_date completeness ], 'direction' => %w[ desc asc ] }.freeze # :nodoc: VALID_MILESTONE_INPUTS = %w[ title state description due_on ].freeze # :nodoc: # List milestones for a repository # # = Parameters # :state - open, closed, default: open # :sort - due_date, completeness, default: due_date # :direction - asc, desc, default: desc # # = Examples # github = Github.new :user => 'user-name', :repo => 'repo-name' # github.issues.milestones.list # # or # # github.issues.milestones.list :state => 'open', # :sort => 'due_date', # :direction => 'asc' # def list(user_name, repo_name, params={}) set :user => user_name, :repo => repo_name assert_presence_of user, repo normalize! params filter! VALID_MILESTONE_OPTIONS.keys, params assert_valid_values(VALID_MILESTONE_OPTIONS, params) response = get_request("/repos/#{user}/#{repo}/milestones", params) return response unless block_given? response.each { |el| yield el } end alias :all :list # Get a single milestone # # = Examples # github = Github.new # github.issues.milestones.get 'user-name', 'repo-name', 'milestone-id' # def get(user_name, repo_name, milestone_id, params={}) set :user => user_name, :repo => repo_name assert_presence_of user, repo, milestone_id normalize! params get_request("/repos/#{user}/#{repo}/milestones/#{milestone_id}", params) end alias :find :get # Create a milestone # # = Inputs # :title - Required string # :state - Optional string - open or closed # :description - Optional string # :due_on - Optional string - ISO 8601 time # # = Examples # github = Github.new :user => 'user-name', :repo => 'repo-name' # github.issues.milestones.create :title => 'hello-world', # :state => "open or closed", # :description => "String", # :due_on => "Time" # def create(user_name, repo_name, params={}) set :user => user_name, :repo => repo_name assert_presence_of user, repo normalize! params filter! VALID_MILESTONE_INPUTS, params assert_required_keys(%w[ title ], params) post_request("/repos/#{user}/#{repo}/milestones", params) end # Update a milestone # # = Inputs # :title - Required string # :state - Optional string - open or closed # :description - Optional string # :due_on - Optional string - ISO 8601 time # # = Examples # github = Github.new # github.issues.milestones.update 'user-name', 'repo-name', 'milestone-id', # :title => 'hello-world', # :state => "open or closed", # :description => "String", # :due_on => "Time" # def update(user_name, repo_name, milestone_id, params={}) set :user => user_name, :repo => repo_name assert_presence_of user, repo, milestone_id normalize! params filter! VALID_MILESTONE_INPUTS, params patch_request("/repos/#{user}/#{repo}/milestones/#{milestone_id}", params) end # Delete a milestone # # = Examples # github = Github.new # github.issues.milestones.delete 'user-name', 'repo-name', 'milestone-id' # def delete(user_name, repo_name, milestone_id, params={}) set :user => user_name, :repo => repo_name assert_presence_of user, repo, milestone_id normalize! params delete_request("/repos/#{user}/#{repo}/milestones/#{milestone_id}", params) end end # Issues::Milestones end # Github