2021-09-30 23:02:18 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Mutations
|
|
|
|
module Security
|
|
|
|
module CiConfiguration
|
|
|
|
class BaseSecurityAnalyzer < BaseMutation
|
|
|
|
include FindsProject
|
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
argument :project_path, GraphQL::Types::ID,
|
2021-09-30 23:02:18 +05:30
|
|
|
required: true,
|
|
|
|
description: 'Full path of the project.'
|
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
field :success_path, GraphQL::Types::String, null: true,
|
2021-09-30 23:02:18 +05:30
|
|
|
description: 'Redirect path to use when the response is successful.'
|
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
field :branch, GraphQL::Types::String, null: true,
|
2021-09-30 23:02:18 +05:30
|
|
|
description: 'Branch that has the new/modified `.gitlab-ci.yml` file.'
|
|
|
|
|
|
|
|
authorize :push_code
|
|
|
|
|
|
|
|
def resolve(project_path:, **args)
|
|
|
|
project = authorized_find!(project_path)
|
|
|
|
|
|
|
|
result = configure_analyzer(project, **args)
|
|
|
|
prepare_response(result)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def configure_analyzer(project, **args)
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
def prepare_response(result)
|
|
|
|
{
|
|
|
|
branch: result.payload[:branch],
|
|
|
|
success_path: result.payload[:success_path],
|
|
|
|
errors: result.errors
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|