Commit e227410b authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'grapify-system-hooks' into 'master'

Grapify system hooks API

## What does this MR do?

Add the Grape-DSL to the system-hook API.

## What are the relevant issue numbers?

Related to #22928

See merge request !6861
parents 1f4352af e836b904
......@@ -7,38 +7,36 @@ module API
end
resource :hooks do
# Get the list of system hooks
#
# Example Request:
# GET /hooks
desc 'Get the list of system hooks' do
success Entities::Hook
end
get do
@hooks = SystemHook.all
present @hooks, with: Entities::Hook
hooks = SystemHook.all
present hooks, with: Entities::Hook
end
# Create new system hook
#
# Parameters:
# url (required) - url for system hook
# Example Request
# POST /hooks
desc 'Create a new system hook' do
success Entities::Hook
end
params do
requires :url, type: String, desc: 'The URL for the system hook'
end
post do
attrs = attributes_for_keys [:url]
required_attributes! [:url]
@hook = SystemHook.new attrs
if @hook.save
present @hook, with: Entities::Hook
hook = SystemHook.new declared(params).to_h
if hook.save
present hook, with: Entities::Hook
else
not_found!
end
end
# Test a hook
#
# Example Request
# GET /hooks/:id
desc 'Test a hook'
params do
requires :id, type: Integer, desc: 'The ID of the system hook'
end
get ":id" do
@hook = SystemHook.find(params[:id])
hook = SystemHook.find(params[:id])
data = {
event_name: "project_create",
name: "Ruby",
......@@ -47,20 +45,20 @@ module API
owner_name: "Someone",
owner_email: "example@gitlabhq.com"
}
@hook.execute(data, 'system_hooks')
hook.execute(data, 'system_hooks')
data
end
# Delete a hook. This is an idempotent function.
#
# Parameters:
# id (required) - ID of the hook
# Example Request:
# DELETE /hooks/:id
desc 'Delete a hook' do
success Entities::Hook
end
params do
requires :id, type: Integer, desc: 'The ID of the system hook'
end
delete ":id" do
begin
@hook = SystemHook.find(params[:id])
@hook.destroy
hook = SystemHook.find(params[:id])
present hook.destroy, with: Entities::Hook
rescue
# SystemHook raises an Error if no hook with id found
end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment