mirror of
https://github.com/Retrospring/retrospring.git
synced 2025-01-19 06:06:05 +01:00
9413d23a02
this also allows the UseCase classes to be hot reloaded in dev 🎉
- remove use_case requires (except for the exporter as Zeitwerk
doesn't know about the subclasses)
- move version.rb to lib/retrospring so that Zeitwerk knows where
to find Retrospring::Version
49 lines
1.2 KiB
Ruby
49 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module UseCase
|
|
module User
|
|
class Ban < UseCase::Base
|
|
REASON_SPAM = "Spam"
|
|
REASON_HARASSMENT = "Harassment"
|
|
REASON_BAN_EVASION = "Ban evasion"
|
|
|
|
option :target_user_id, type: Types::Coercible::Integer
|
|
option :expiry, types: Types::Nominal::DateTime.optional
|
|
option :source_user_id, type: Types::Coercible::Integer.optional
|
|
option :reason, type: Types::Coercible::String.optional
|
|
|
|
def call
|
|
ban = target_user.ban(expiry, reason, source_user)
|
|
|
|
if reason == REASON_SPAM
|
|
target_user.update!(
|
|
profile_picture: nil,
|
|
profile_header: nil
|
|
)
|
|
target_user.profile.update!(
|
|
display_name: nil,
|
|
description: "",
|
|
location: "",
|
|
website: ""
|
|
)
|
|
end
|
|
|
|
{
|
|
status: 201,
|
|
resource: ban,
|
|
extra: {
|
|
target_user:
|
|
}
|
|
}
|
|
end
|
|
|
|
def target_user
|
|
@target_user ||= ::User.find(target_user_id)
|
|
end
|
|
|
|
def source_user
|
|
@source_user ||= ::User.find(source_user_id) if source_user_id
|
|
end
|
|
end
|
|
end
|
|
end
|