5589dcf8db
- Fix naming of API::CommitStatuses - Ensure we use require_dependency instead of require - Ensure the namespace is right in lib/api/api.rb, otherwise, we might require Grape::API::Helpers which defines the `#params` method. This is to avoid requiring a file multiple times and getting an "Already initialized constant" error. Signed-off-by: Rémy Coutable <remy@rymai.me>
37 lines
1.1 KiB
Ruby
37 lines
1.1 KiB
Ruby
module Ci
|
|
module API
|
|
class API < Grape::API
|
|
include ::API::APIGuard
|
|
version 'v1', using: :path
|
|
|
|
rescue_from ActiveRecord::RecordNotFound do
|
|
rack_response({ 'message' => '404 Not found' }.to_json, 404)
|
|
end
|
|
|
|
rescue_from :all do |exception|
|
|
# lifted from https://github.com/rails/rails/blob/master/actionpack/lib/action_dispatch/middleware/debug_exceptions.rb#L60
|
|
# why is this not wrapped in something reusable?
|
|
trace = exception.backtrace
|
|
|
|
message = "\n#{exception.class} (#{exception.message}):\n"
|
|
message << exception.annoted_source_code.to_s if exception.respond_to?(:annoted_source_code)
|
|
message << " " << trace.join("\n ")
|
|
|
|
API.logger.add Logger::FATAL, message
|
|
rack_response({ 'message' => '500 Internal Server Error' }, 500)
|
|
end
|
|
|
|
content_type :txt, 'text/plain'
|
|
content_type :json, 'application/json'
|
|
format :json
|
|
|
|
helpers ::Ci::API::Helpers
|
|
helpers ::API::Helpers
|
|
helpers Gitlab::CurrentSettings
|
|
|
|
mount ::Ci::API::Builds
|
|
mount ::Ci::API::Runners
|
|
mount ::Ci::API::Triggers
|
|
end
|
|
end
|
|
end
|