diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-01-18 19:00:14 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-01-18 19:00:14 +0000 |
commit | 05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2 (patch) | |
tree | 11d0f2a6ec31c7793c184106cedc2ded3d9a2cc5 /app/services/merge_requests/rebase_service.rb | |
parent | ec73467c23693d0db63a797d10194da9e72a74af (diff) | |
download | gitlab-ce-05f0ebba3a2c8ddf39e436f412dc2ab5bf1353b2.tar.gz |
Add latest changes from gitlab-org/gitlab@15-8-stable-eev15.8.0-rc42
Diffstat (limited to 'app/services/merge_requests/rebase_service.rb')
-rw-r--r-- | app/services/merge_requests/rebase_service.rb | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/app/services/merge_requests/rebase_service.rb b/app/services/merge_requests/rebase_service.rb index 1c4e1784b34..792f1728b88 100644 --- a/app/services/merge_requests/rebase_service.rb +++ b/app/services/merge_requests/rebase_service.rb @@ -6,6 +6,19 @@ module MergeRequests attr_reader :merge_request, :rebase_error + def validate(merge_request) + return error_response(_('Source branch does not exist')) unless + merge_request.source_branch_exists? + + return error_response(_('Cannot push to source branch')) unless + user_access.can_push_to_branch?(merge_request.source_branch) + + return error_response(_('Source branch is protected from force push')) unless + merge_request.permits_force_push? + + ServiceResponse.success + end + def execute(merge_request, skip_ci: false) @merge_request = merge_request @skip_ci = skip_ci @@ -40,5 +53,13 @@ module MergeRequests REBASE_ERROR end end + + def user_access + Gitlab::UserAccess.new(current_user, container: project) + end + + def error_response(message) + ServiceResponse.error(message: message) + end end end |