781d35c191
Also add a test for setting locked.
56 lines
1.6 KiB
Ruby
56 lines
1.6 KiB
Ruby
module Ci
|
|
module API
|
|
# Runners API
|
|
class Runners < Grape::API
|
|
resource :runners do
|
|
# Delete runner
|
|
# Parameters:
|
|
# token (required) - The unique token of runner
|
|
#
|
|
# Example Request:
|
|
# GET /runners/delete
|
|
delete "delete" do
|
|
required_attributes! [:token]
|
|
authenticate_runner!
|
|
Ci::Runner.find_by_token(params[:token]).destroy
|
|
end
|
|
|
|
# Register a new runner
|
|
#
|
|
# Note: This is an "internal" API called when setting up
|
|
# runners, so it is authenticated differently.
|
|
#
|
|
# Parameters:
|
|
# token (required) - The unique token of runner
|
|
#
|
|
# Example Request:
|
|
# POST /runners/register
|
|
post "register" do
|
|
required_attributes! [:token]
|
|
|
|
attributes = attributes_for_keys(
|
|
[:description, :tag_list, :run_untagged, :locked]
|
|
)
|
|
|
|
runner =
|
|
if runner_registration_token_valid?
|
|
# Create shared runner. Requires admin access
|
|
Ci::Runner.create(attributes.merge(is_shared: true))
|
|
elsif project = Project.find_by(runners_token: params[:token])
|
|
# Create a specific runner for project.
|
|
project.runners.create(attributes)
|
|
end
|
|
|
|
return forbidden! unless runner
|
|
|
|
if runner.id
|
|
runner.update(get_runner_version_from_params)
|
|
present runner, with: Entities::Runner
|
|
else
|
|
not_found!
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|