Module: Trackguard::RackAttack

Defined in:
lib/trackguard/rack_attack.rb

Class Method Summary collapse

Class Method Details

.configureObject



7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# File 'lib/trackguard/rack_attack.rb', line 7

def self.configure
  ::Rack::Attack.safelist("trackguard/allow local") do |req|
    [ "127.0.0.1", "::1" ].include?(req.ip)
  end

  ::Rack::Attack.safelist("trackguard/allow whitelisted ips") do |req|
    Trackguard::WhitelistedIp.whitelisted?(req.ip)
  end

  ::Rack::Attack.blocklist("trackguard/block known scanners") do |req|
    Trackguard::BlockedUserAgent.blocked?(req.user_agent)
  end

  ::Rack::Attack.blocklist("trackguard/flagged visitors") do |req|
    Trackguard::Visitor.flagged?(req.ip)
  end

  ::Rack::Attack.throttle(
    "trackguard/requests by ip",
    limit: Trackguard.throttle_limit,
    period: Trackguard.throttle_period, &:ip
  )
end