diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-05-19 18:44:42 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-05-19 18:44:42 +0300 |
commit | 4555e1b21c365ed8303ffb7a3325d773c9b8bf31 (patch) | |
tree | 5423a1c7516cffe36384133ade12572cf709398d /app/graphql/mutations/merge_requests/set_draft.rb | |
parent | e570267f2f6b326480d284e0164a6464ba4081bc (diff) |
Add latest changes from gitlab-org/gitlab@13-12-stable-eev13.12.0-rc42
Diffstat (limited to 'app/graphql/mutations/merge_requests/set_draft.rb')
-rw-r--r-- | app/graphql/mutations/merge_requests/set_draft.rb | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/app/graphql/mutations/merge_requests/set_draft.rb b/app/graphql/mutations/merge_requests/set_draft.rb new file mode 100644 index 00000000000..80006c6f70e --- /dev/null +++ b/app/graphql/mutations/merge_requests/set_draft.rb @@ -0,0 +1,35 @@ +# frozen_string_literal: true + +module Mutations + module MergeRequests + class SetDraft < Base + graphql_name 'MergeRequestSetDraft' + + argument :draft, + GraphQL::BOOLEAN_TYPE, + required: true, + description: <<~DESC + Whether or not to set the merge request as a draft. + DESC + + def resolve(project_path:, iid:, draft: nil) + merge_request = authorized_find!(project_path: project_path, iid: iid) + project = merge_request.project + + ::MergeRequests::UpdateService.new(project: project, current_user: current_user, params: { wip_event: wip_event(draft) }) + .execute(merge_request) + + { + merge_request: merge_request, + errors: errors_on_object(merge_request) + } + end + + private + + def wip_event(wip) + wip ? 'wip' : 'unwip' + end + end + end +end |