Merge remote-tracking branch 'origin/background-delete-process'
This commit is contained in:
commit
f862b4ae0f
11 changed files with 44 additions and 9 deletions
|
@ -42,6 +42,7 @@ v 8.4.1
|
|||
- Fix redirect loop during import
|
||||
- Fix diff highlighting for all syntax themes
|
||||
- Warn admin during OAuth of granting admin rights (Zeger-Jan van de Weg)
|
||||
- Delete project and associations in a background worker
|
||||
|
||||
v 8.4.0
|
||||
- Allow LDAP users to change their email if it was not set by the LDAP server
|
||||
|
|
|
@ -93,6 +93,10 @@ class ProjectsController < ApplicationController
|
|||
return
|
||||
end
|
||||
|
||||
if @project.pending_delete?
|
||||
flash[:alert] = "Project queued for delete."
|
||||
end
|
||||
|
||||
respond_to do |format|
|
||||
format.html do
|
||||
if @project.repository_exists?
|
||||
|
@ -120,8 +124,8 @@ class ProjectsController < ApplicationController
|
|||
def destroy
|
||||
return access_denied! unless can?(current_user, :remove_project, @project)
|
||||
|
||||
::Projects::DestroyService.new(@project, current_user, {}).execute
|
||||
flash[:alert] = "Project '#{@project.name}' was deleted."
|
||||
::Projects::DestroyService.new(@project, current_user, {}).pending_delete!
|
||||
flash[:alert] = "Project '#{@project.name}' will be deleted."
|
||||
|
||||
redirect_to dashboard_projects_path
|
||||
rescue Projects::DestroyService::DestroyError => ex
|
||||
|
|
|
@ -36,6 +36,7 @@
|
|||
# build_coverage_regex :string
|
||||
# build_allow_git_fetch :boolean default(TRUE), not null
|
||||
# build_timeout :integer default(3600), not null
|
||||
# pending_delete :boolean
|
||||
#
|
||||
|
||||
require 'carrierwave/orm/activerecord'
|
||||
|
|
|
@ -13,7 +13,7 @@ class DeleteUserService
|
|||
user.personal_projects.each do |project|
|
||||
# Skip repository removal because we remove directory with namespace
|
||||
# that contain all this repositories
|
||||
::Projects::DestroyService.new(project, current_user, skip_repo: true).execute
|
||||
::Projects::DestroyService.new(project, current_user, skip_repo: true).pending_delete!
|
||||
end
|
||||
|
||||
user.destroy
|
||||
|
|
|
@ -9,7 +9,7 @@ class DestroyGroupService
|
|||
@group.projects.each do |project|
|
||||
# Skip repository removal because we remove directory with namespace
|
||||
# that contain all this repositories
|
||||
::Projects::DestroyService.new(project, current_user, skip_repo: true).execute
|
||||
::Projects::DestroyService.new(project, current_user, skip_repo: true).pending_delete!
|
||||
end
|
||||
|
||||
@group.destroy
|
||||
|
|
|
@ -6,6 +6,12 @@ module Projects
|
|||
|
||||
DELETED_FLAG = '+deleted'
|
||||
|
||||
def pending_delete!
|
||||
project.update_attribute(:pending_delete, true)
|
||||
|
||||
ProjectDestroyWorker.perform_in(1.minute, project.id, current_user.id, params)
|
||||
end
|
||||
|
||||
def execute
|
||||
return false unless can?(current_user, :remove_project, project)
|
||||
|
||||
|
|
17
app/workers/project_destroy_worker.rb
Normal file
17
app/workers/project_destroy_worker.rb
Normal file
|
@ -0,0 +1,17 @@
|
|||
class ProjectDestroyWorker
|
||||
include Sidekiq::Worker
|
||||
|
||||
sidekiq_options queue: :default
|
||||
|
||||
def perform(project_id, user_id, params)
|
||||
begin
|
||||
project = Project.find(project_id)
|
||||
rescue ActiveRecord::RecordNotFound
|
||||
return
|
||||
end
|
||||
|
||||
user = User.find(user_id)
|
||||
|
||||
::Projects::DestroyService.new(project, user, params).execute
|
||||
end
|
||||
end
|
|
@ -0,0 +1,5 @@
|
|||
class AddPendingDeleteToProject < ActiveRecord::Migration
|
||||
def change
|
||||
add_column :projects, :pending_delete, :boolean, default: false
|
||||
end
|
||||
end
|
|
@ -677,6 +677,7 @@ ActiveRecord::Schema.define(version: 20160128233227) do
|
|||
t.string "build_coverage_regex"
|
||||
t.boolean "build_allow_git_fetch", default: true, null: false
|
||||
t.integer "build_timeout", default: 3600, null: false
|
||||
t.boolean "pending_delete", default: false
|
||||
end
|
||||
|
||||
add_index "projects", ["builds_enabled", "shared_runners_enabled"], name: "index_projects_on_builds_enabled_and_shared_runners_enabled", using: :btree
|
||||
|
|
|
@ -187,7 +187,7 @@ module API
|
|||
else
|
||||
present @forked_project, with: Entities::Project,
|
||||
user_can_admin_project: can?(current_user, :admin_project, @forked_project)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
# Update an existing project
|
||||
|
@ -246,7 +246,7 @@ module API
|
|||
# DELETE /projects/:id
|
||||
delete ":id" do
|
||||
authorize! :remove_project, user_project
|
||||
::Projects::DestroyService.new(user_project, current_user, {}).execute
|
||||
::Projects::DestroyService.new(user_project, current_user, {}).pending_delete!
|
||||
end
|
||||
|
||||
# Mark this project as forked from another
|
||||
|
|
|
@ -36,7 +36,7 @@ describe SystemHook, models: true do
|
|||
it "project_destroy hook" do
|
||||
user = create(:user)
|
||||
project = create(:empty_project, namespace: user.namespace)
|
||||
Projects::DestroyService.new(project, user, {}).execute
|
||||
Projects::DestroyService.new(project, user, {}).pending_delete!
|
||||
expect(WebMock).to have_requested(:post, @system_hook.url).with(
|
||||
body: /project_destroy/,
|
||||
headers: { 'Content-Type'=>'application/json', 'X-Gitlab-Event'=>'System Hook' }
|
||||
|
@ -65,7 +65,7 @@ describe SystemHook, models: true do
|
|||
project = create(:project)
|
||||
project.team << [user, :master]
|
||||
expect(WebMock).to have_requested(:post, @system_hook.url).with(
|
||||
body: /user_add_to_team/,
|
||||
body: /user_add_to_team/,
|
||||
headers: { 'Content-Type'=>'application/json', 'X-Gitlab-Event'=>'System Hook' }
|
||||
).once
|
||||
end
|
||||
|
@ -76,7 +76,7 @@ describe SystemHook, models: true do
|
|||
project.team << [user, :master]
|
||||
project.project_members.destroy_all
|
||||
expect(WebMock).to have_requested(:post, @system_hook.url).with(
|
||||
body: /user_remove_from_team/,
|
||||
body: /user_remove_from_team/,
|
||||
headers: { 'Content-Type'=>'application/json', 'X-Gitlab-Event'=>'System Hook' }
|
||||
).once
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue