# encoding: utf-8
module Github
# The Repository Hooks API manages the post-receive web and
# service hooks for a repository.
class Repos::Hooks < API
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(*args)
arguments(args, :required => [:user, :repo])
response = get_request("/repos/#{user}/#{repo}/hooks", arguments.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', 'hook-id'
#
def get(*args)
arguments(args, :required => [:user, :repo, :id])
get_request("/repos/#{user}/#{repo}/hooks/#{id}", arguments.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(*args)
arguments(args, :required => [:user, :repo]) do
sift VALID_HOOK_PARAM_NAMES, :recursive => false
assert_required REQUIRED_PARAMS
end
post_request("/repos/#{user}/#{repo}/hooks", arguments.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', 'hook-id',
# "name" => "campfire",
# "active" => true,
# "config" => {
# "subdomain" => "github",
# "room" => "Commits",
# "token" => "abc123"
# }
#
def edit(*args)
arguments(args, :required => [:user, :repo, :id]) do
sift VALID_HOOK_PARAM_NAMES, :recursive => false
assert_required REQUIRED_PARAMS
end
patch_request("/repos/#{user}/#{repo}/hooks/#{id}", arguments.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(*args)
arguments(args, :required => [:user, :repo, :id])
params = arguments.params
post_request("/repos/#{user}/#{repo}/hooks/#{id}/test", params)
end
# Delete a hook
#
# = Examples
# github = Github.new
# github.repos.hooks.delete 'user-name', 'repo-name', 'hook-id'
#
def delete(*args)
arguments(args, :required => [:user, :repo, :id])
params = arguments.params
delete_request("/repos/#{user}/#{repo}/hooks/#{id}", params)
end
end # Repos::Hooks
end # Github