discourse/app/services/user/suspend.rb
Loïc Guitaut 2f334964f2 DEV: Remove hash-like access from service contracts
We decided to keep only one way to access values from a contract. This
patch thus removes the hash-like access from contracts.
2024-10-29 16:02:51 +01:00

56 lines
1.5 KiB
Ruby

# frozen_string_literal: true
class User::Suspend
include Service::Base
params do
attribute :user_id, :integer
attribute :reason, :string
attribute :message, :string
attribute :suspend_until, :datetime
attribute :other_user_ids, :array
attribute :post_id, :integer
attribute :post_action, :string
attribute :post_edit, :string
validates :user_id, presence: true
validates :reason, presence: true, length: { maximum: 300 }
validates :suspend_until, presence: true
validates :other_user_ids, length: { maximum: User::MAX_SIMILAR_USERS }
validates :post_action, inclusion: { in: %w[delete delete_replies edit] }, allow_blank: true
end
model :user
policy :not_suspended_already, class_name: User::Policy::NotAlreadySuspended
model :users
policy :can_suspend_all_users
step :suspend
model :post, optional: true
step :perform_post_action
private
def fetch_user(params:)
User.find_by(id: params.user_id)
end
def fetch_users(user:, params:)
[user, *User.where(id: params.other_user_ids.to_a.uniq).to_a]
end
def can_suspend_all_users(guardian:, users:)
users.all? { guardian.can_suspend?(_1) }
end
def suspend(guardian:, users:, params:)
context[:full_reason] = User::Action::SuspendAll.call(users:, actor: guardian.user, params:)
end
def fetch_post(params:)
Post.find_by(id: params.post_id)
end
def perform_post_action(guardian:, post:, params:)
User::Action::TriggerPostAction.call(guardian:, post:, params:)
end
end