# encoding: utf-8
module Github
class Repos::Hooks < API
# The Repository Hooks API manages the post-receive web and service hooks for a repository.
VALID_HOOK_PARAM_NAMES = %w[
name
config
active
events
add_events
remove_events
].freeze # :nodoc:
# Active hooks can be configured to trigger for one or more events. The default event is push.
# The available events are:
VALID_HOOK_PARAM_VALUES = {
'events' => %w[
push
issues
issue_comment
commit_comment
pull_request
gollum
watch
download
fork
fork_apply
member
public
]
}.freeze # :nodoc:
REQUIRED_PARAMS = %w[ name config ].freeze # :nodoc:
# List repository hooks
#
# = Examples
# github = Github.new
# github.repos.hooks.list 'user-name', 'repo-name'
# github.repos.hooks.list 'user-name', 'repo-name' { |hook| ... }
#
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
response = get_request("/repos/#{user}/#{repo}/hooks", params)
return response unless block_given?
response.each { |el| yield el }
end
alias :all :list
# Get a single hook
#
# = Examples
# github = Github.new
# github.repos.hooks.get 'user-name', 'repo-name'
#
def get(user_name, repo_name, hook_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of hook_id
normalize! params
get_request("/repos/#{user}/#{repo}/hooks/#{hook_id}", params)
end
alias :find :get
# Create a hook
#
# = Inputs
# * :name - Required string - the name of the service that is being called.
# * :config - Required hash - A Hash containing key/value pairs to provide settings for this hook.
# * :events - Optional array - Determines what events the hook is triggered for. Default: ["push"]
# * :active - Optional boolean - Determines whether the hook is actually triggered on pushes.
#
# = Examples
# github = Github.new
# github.repos.hooks.create 'user-name', 'repo-name',
# "name" => "web",
# "active" => true,
# "config" => {
# "url" => "http://something.com/webhook"
# }
# }
#
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
filter! VALID_HOOK_PARAM_NAMES, params, :recursive => false
assert_required_keys(REQUIRED_PARAMS, params)
post_request("/repos/#{user}/#{repo}/hooks", params)
end
# Edit a hook
#
# = Inputs
# * :name - Required string - the name of the service that is being called.
# * :config - Required hash - A Hash containing key/value pairs to provide settings for this hook.
# * :events - Optional array - Determines what events the hook is triggered for. This replaces the entire array of events. Default: ["push"].
# * :add_events - Optional array - Determines a list of events to be added to the list of events that the Hook triggers for.
# * :remove_events - Optional array - Determines a list of events to be removed from the list of events that the Hook triggers for.
# * :active - Optional boolean - Determines whether the hook is actually triggered on pushes.
#
# = Examples
# github = Github.new
# github.repos.hooks.edit 'user-name', 'repo-name',
# "name" => "campfire",
# "active" => true,
# "config" => {
# "subdomain" => "github",
# "room" => "Commits",
# "token" => "abc123"
# }
#
def edit(user_name, repo_name, hook_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of hook_id
normalize! params
filter! VALID_HOOK_PARAM_NAMES, params, :recursive => false
assert_required_keys(REQUIRED_PARAMS, params)
patch_request("/repos/#{user}/#{repo}/hooks/#{hook_id}", params)
end
# Test a hook
#
# This will trigger the hook with the latest push to the current repository.
#
# = Examples
# github = Github.new
# github.repos.hooks.test 'user-name', 'repo-name', 'hook-id'
#
def test(user_name, repo_name, hook_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of hook_id
normalize! params
post_request("/repos/#{user}/#{repo}/hooks/#{hook_id}/test", params)
end
# Delete a hook
#
# = Examples
# github = Github.new
# github.repos.hooks.delete 'user-name', 'repo-name', 'hook-id'
#
def delete(user_name, repo_name, hook_id, params={})
_update_user_repo_params(user_name, repo_name)
_validate_user_repo_params(user, repo) unless user? && repo?
_validate_presence_of hook_id
normalize! params
delete_request("/repos/#{user}/#{repo}/hooks/#{hook_id}", params)
end
end # Repos::Hooks
end # Github