gitlab-org--gitlab-foss/app/services/git/branch_push_service.rb

96 lines
2.5 KiB
Ruby

# frozen_string_literal: true
module Git
class BranchPushService < ::BaseService
include Gitlab::Access
include Gitlab::Utils::StrongMemoize
include ChangeParams
# This method will be called after each git update
# and only if the provided user and project are present in GitLab.
#
# All callbacks for post receive action should be placed here.
#
# Next, this method:
# 1. Creates the push event
# 2. Updates merge requests
# 3. Recognizes cross-references from commit messages
# 4. Executes the project's webhooks
# 5. Executes the project's services
# 6. Checks if the project's main language has changed
#
def execute
return unless Gitlab::Git.branch_ref?(ref)
enqueue_update_mrs
enqueue_detect_repository_languages
enqueue_record_project_target_platforms
execute_related_hooks
stop_environments
unlock_artifacts
true
end
# Update merge requests that may be affected by this push. A new branch
# could cause the last commit of a merge request to change.
def enqueue_update_mrs
return if params[:merge_request_branches]&.exclude?(branch_name)
UpdateMergeRequestsWorker.perform_async(
project.id,
current_user.id,
oldrev,
newrev,
ref
)
end
def enqueue_detect_repository_languages
return unless default_branch?
DetectRepositoryLanguagesWorker.perform_async(project.id)
end
def enqueue_record_project_target_platforms
return unless default_branch?
project.enqueue_record_project_target_platforms
end
# Only stop environments if the ref is a branch that is being deleted
def stop_environments
return unless removing_branch?
Environments::StopService.new(project, current_user).execute_for_branch(branch_name)
end
def unlock_artifacts
return unless removing_branch?
Ci::RefDeleteUnlockArtifactsWorker.perform_async(project.id, current_user.id, ref)
end
def execute_related_hooks
BranchHooksService.new(project, current_user, params).execute
end
def removing_branch?
Gitlab::Git.blank_ref?(newrev)
end
def branch_name
strong_memoize(:branch_name) { Gitlab::Git.ref_name(ref) }
end
def default_branch?
strong_memoize(:default_branch) do
[nil, branch_name].include?(project.default_branch)
end
end
end
end
Git::BranchPushService.prepend_mod_with('Git::BranchPushService')