# frozen_string_literal: true class Flags::CreateFlag include Service::Base policy :invalid_access params do attribute :name, :string attribute :description, :string attribute :require_message, :boolean attribute :enabled, :boolean attribute :applies_to attribute :auto_action_type, :boolean validates :name, presence: true validates :description, presence: true validates :name, length: { maximum: Flag::MAX_NAME_LENGTH } validates :description, length: { maximum: Flag::MAX_DESCRIPTION_LENGTH } validates :applies_to, inclusion: { in: -> { Flag.valid_applies_to_types } }, allow_nil: false end policy :unique_name model :flag, :instantiate_flag transaction do step :create step :log end private def invalid_access(guardian:) guardian.can_create_flag? end def unique_name(params:) !Flag.custom.where(name: params.name).exists? end def instantiate_flag(params:) Flag.new(params.merge(notify_type: true)) end def create(flag:) flag.save! end def log(guardian:, flag:) StaffActionLogger.new(guardian.user).log_custom( "create_flag", { name: flag.name, description: flag.description, applies_to: flag.applies_to, require_message: flag.require_message, enabled: flag.enabled, }, ) end end