Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/workers/remove_expired_members_worker.rb')
-rw-r--r--app/workers/remove_expired_members_worker.rb21
1 files changed, 15 insertions, 6 deletions
diff --git a/app/workers/remove_expired_members_worker.rb b/app/workers/remove_expired_members_worker.rb
index 35844fdf297..fc2ec047e1c 100644
--- a/app/workers/remove_expired_members_worker.rb
+++ b/app/workers/remove_expired_members_worker.rb
@@ -2,20 +2,29 @@
class RemoveExpiredMembersWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker
- include CronjobQueue # rubocop:disable Scalability/CronWorkerContext
+ include CronjobQueue
feature_category :authentication_and_authorization
worker_resource_boundary :cpu
# rubocop: disable CodeReuse/ActiveRecord
def perform
- Member.expired.preload(:user).find_each do |member|
- Members::DestroyService.new.execute(member, skip_authorization: true)
+ Member.expired.preload(:user, :source).find_each do |member|
+ context = {
+ user: member.user,
+ # The ApplicationContext will reject type-mismatches. So a GroupMemeber will only populate `namespace`.
+ # while a `ProjectMember` will populate `project
+ project: member.source,
+ namespace: member.source
+ }
+ with_context(context) do
+ Members::DestroyService.new.execute(member, skip_authorization: true)
- expired_user = member.user
+ expired_user = member.user
- if expired_user.project_bot?
- Users::DestroyService.new(nil).execute(expired_user, skip_authorization: true)
+ if expired_user.project_bot?
+ Users::DestroyService.new(nil).execute(expired_user, skip_authorization: true)
+ end
end
rescue => ex
logger.error("Expired Member ID=#{member.id} cannot be removed - #{ex}")