Sha256: be003f911532fe5d3be110c4020a9b26029694c2198f67c70881774897d53326
Contents?: true
Size: 1.66 KB
Versions: 9
Compression:
Stored size: 1.66 KB
Contents
module Warden class Proxy # :api: public def errors @env['warden.errors'] ||= Errors.new end # Lifted from DataMapper's dm-validations plugin :) # @author Guy van den Berg # @since DM 0.9 class Errors include Enumerable # Clear existing authentication errors. def clear! errors.clear end # Add a authentication error. Use the field_name :general if the errors does # not apply to a specific field of the Resource. # # @param <Symbol> field_name the name of the field that caused the error # @param <String> message the message to add def add(field_name, message) (errors[field_name] ||= []) << message end # Collect all errors into a single list. def full_messages errors.inject([]) do |list,pair| list += pair.last end end # Return authentication errors for a particular field_name. # # @param <Symbol> field_name the name of the field you want an error for def on(field_name) errors_for_field = errors[field_name] blank?(errors_for_field) ? nil : errors_for_field end def each errors.map.each do |k,v| next if blank?(v) yield(v) end end def empty? entries.empty? end def method_missing(meth, *args, &block) errors.send(meth, *args, &block) end private def errors @errors ||= {} end def blank?(thing) thing.nil? || thing == "" || (thing.respond_to?(:empty?) && thing.empty?) end end # class Errors end # Proxy end # Warden
Version data entries
9 entries across 9 versions & 2 rubygems