Class: Labkit::RateLimit::Result

Inherits:
Data
  • Object
show all
Defined in:
lib/labkit/rate_limit/result.rb

Overview

Result is the return value of Limiter#check. matched? - true if a rule’s match conditions were satisfied exceeded? - true if the matched rule’s counter exceeded its limit action - the outcome: what the caller should do

:block = rule matched, exceeded, rule configured to block
:log   = rule matched, exceeded, rule configured to log only
:allow = rule matched but count within limit, or
         no rule matched, or error (fail-open)
The rule's configured action is available via rule.action

rule - the matched Rule object (nil when matched? is false) error? - true if Redis was unavailable; result fails open (exceeded? is false)

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(matched:, action:, exceeded: false, rule: nil, error: false) ⇒ Result

Returns a new instance of Result.



17
18
19
# File 'lib/labkit/rate_limit/result.rb', line 17

def initialize(matched:, action:, exceeded: false, rule: nil, error: false)
  super
end

Instance Attribute Details

#actionObject (readonly)

Returns the value of attribute action

Returns:

  • (Object)

    the current value of action



16
17
18
# File 'lib/labkit/rate_limit/result.rb', line 16

def action
  @action
end

#errorObject (readonly)

Returns the value of attribute error

Returns:

  • (Object)

    the current value of error



16
17
18
# File 'lib/labkit/rate_limit/result.rb', line 16

def error
  @error
end

#exceededObject (readonly)

Returns the value of attribute exceeded

Returns:

  • (Object)

    the current value of exceeded



16
17
18
# File 'lib/labkit/rate_limit/result.rb', line 16

def exceeded
  @exceeded
end

#matchedObject (readonly)

Returns the value of attribute matched

Returns:

  • (Object)

    the current value of matched



16
17
18
# File 'lib/labkit/rate_limit/result.rb', line 16

def matched
  @matched
end

#ruleObject (readonly)

Returns the value of attribute rule

Returns:

  • (Object)

    the current value of rule



16
17
18
# File 'lib/labkit/rate_limit/result.rb', line 16

def rule
  @rule
end

Instance Method Details

#error?Boolean

Returns:

  • (Boolean)


29
30
31
# File 'lib/labkit/rate_limit/result.rb', line 29

def error?
  error
end

#exceeded?Boolean

Returns:

  • (Boolean)


25
26
27
# File 'lib/labkit/rate_limit/result.rb', line 25

def exceeded?
  exceeded
end

#matched?Boolean

Returns:

  • (Boolean)


21
22
23
# File 'lib/labkit/rate_limit/result.rb', line 21

def matched?
  matched
end