# frozen_string_literal: true module API # External applications API class Applications < Grape::API::Instance before { authenticated_as_admin! } resource :applications do helpers do def validate_redirect_uri(value) uri = ::URI.parse(value) !uri.is_a?(URI::HTTP) || uri.host rescue URI::InvalidURIError false end end desc 'Create a new application' do detail 'This feature was introduced in GitLab 10.5' success Entities::ApplicationWithSecret end params do requires :name, type: String, desc: 'Application name' requires :redirect_uri, type: String, desc: 'Application redirect URI' requires :scopes, type: String, desc: 'Application scopes' optional :confidential, type: Boolean, default: true, desc: 'Application will be used where the client secret is confidential' end post do # Validate that host in uri is specified # Please remove it when https://github.com/doorkeeper-gem/doorkeeper/pull/1440 is merged # and the doorkeeper gem version is bumped unless validate_redirect_uri(declared_params[:redirect_uri]) render_api_error!({ redirect_uri: ["must be an absolute URI."] }, :bad_request) end application = Doorkeeper::Application.new(declared_params) if application.save present application, with: Entities::ApplicationWithSecret else render_validation_error! application end end desc 'Get applications' do success Entities::Application end get do applications = ApplicationsFinder.new.execute present applications, with: Entities::Application end desc 'Delete an application' delete ':id' do application = ApplicationsFinder.new(params).execute application.destroy no_content! end end end end