Class: Mutations::Snippets::Update

Inherits:
Base
  • Object
show all
Includes:
ServiceCompatibility, Mutations::SpamProtection
Defined in:
app/graphql/mutations/snippets/update.rb

Constant Summary

Constants included from Mutations::SpamProtection

Mutations::SpamProtection::NEEDS_CAPTCHA_RESPONSE_MESSAGE, Mutations::SpamProtection::NeedsCaptchaResponseError, Mutations::SpamProtection::SPAM_DISALLOWED_MESSAGE, Mutations::SpamProtection::SpamActionError, Mutations::SpamProtection::SpamDisallowedError

Constants inherited from BaseMutation

BaseMutation::ERROR_MESSAGE

Constants included from Gitlab::Graphql::Authorize::AuthorizeResource

Gitlab::Graphql::Authorize::AuthorizeResource::ConfigurationError, Gitlab::Graphql::Authorize::AuthorizeResource::RESOURCE_ACCESS_ERROR

Instance Method Summary collapse

Methods included from Spam::Concerns::HasSpamActionResponseFields

#spam_action_response_fields

Methods included from ServiceCompatibility

#convert_blob_actions_to_snippet_actions!

Methods inherited from BaseMutation

#api_user?, authorization, authorized?, authorizes_object?, #current_user, #errors_on_object, #load_application_object, #read_only?, #ready?, #unauthorized_object

Methods included from Gitlab::Graphql::Authorize::AuthorizeResource

#authorize!, #authorized_find!, #authorized_resource?, #find_object, #raise_resource_not_available_error!

Instance Method Details

#resolve(id:, **args) ⇒ Object



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# File 'app/graphql/mutations/snippets/update.rb', line 31

def resolve(id:, **args)
  snippet = authorized_find!(id: id)

  process_args_for_params!(args)

  service = ::Snippets::UpdateService.new(project: snippet.project, current_user: current_user, params: args, perform_spam_check: true)
  service_response = service.execute(snippet)

  # TODO: DRY this up - From here down, this is all duplicated with Mutations::Snippets::Create#resolve, except for
  #    `snippet.reset`, which is required in order to return the object in its non-dirty, unmodified, database state
  #    See issue here: https://gitlab.com/gitlab-org/gitlab/-/issues/300250

  # Only when the user is not an api user and the operation was successful
  if !api_user? && service_response.success?
    ::Gitlab::UsageDataCounters::EditorUniqueCounter.track_snippet_editor_edit_action(author: current_user, project: snippet.project)
  end

  snippet = service_response.payload[:snippet]
  check_spam_action_response!(snippet)

  {
    snippet: service_response.success? ? snippet : snippet.reset,
    errors: errors_on_object(snippet)
  }
end