# Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ # Check if password matches system settings class PasswordPolicy include ::Mixin::HasBackends class PasswordPolicy::Error < StandardError attr_reader :metadata def initialize(metadata) @metadata = metadata super(metadata.try(:first)) end end attr_reader :password # @param password [String, nil] to evaluate. nil is treated as empty string def initialize(password) @password = password || '' end def valid! return if valid? raise PasswordPolicy::Error, error end def valid? errors.blank? end def error errors.first end def errors @errors ||= applicable_backends .map { |backend| backend.new(password) } .reject(&:valid?) .map(&:error) end private def applicable_backends @applicable_backends ||= backends.select(&:applicable?) end end