imperva-rails 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 632f707c626a71ce88564695c4104e9dc59400c7dc7704110ac0800de8c7b536
4
+ data.tar.gz: bb5b30cb6d595b52c4235c6ac80dea8fa7d149017ec405c4c2ac47b2a8652f5a
5
+ SHA512:
6
+ metadata.gz: 5e42a43b326ee2cdb332a67e9391dc5cb34d8f299f48a335a30159945304f2d7e3cb67e4ae072e365e4b142fc6cf700e972ff42ec259a7ec85f1865956a31e8c
7
+ data.tar.gz: 91087d59a53f21e98947308841f456bdc5538095552428dba2608b43646e92d2505e99578da2d8cfcc6635fc117ad7b2c30a2e887505534334fa6c041be7d2c1
@@ -0,0 +1,54 @@
1
+ # Ruby CircleCI 2.0 configuration file
2
+ #
3
+ # Check https://circleci.com/docs/2.0/language-ruby/ for more details
4
+ #
5
+ version: 2
6
+ jobs:
7
+ build:
8
+ docker:
9
+ # specify the version you desire here
10
+ - image: cimg/ruby:2.7
11
+
12
+ working_directory: ~/repo
13
+
14
+ steps:
15
+ - checkout
16
+
17
+ # Download and cache dependencies
18
+ - restore_cache:
19
+ keys:
20
+ - v1-dependencies-{{ checksum "cloudflare-rails.gemspec" }}-{{ checksum "Appraisals" }}
21
+ # fallback to using the latest cache if no exact match is found
22
+ - v1-dependencies-
23
+
24
+ - run:
25
+ name: install bundler
26
+ command: |
27
+ gem install bundler -v $(grep bundler cloudflare-rails.gemspec |awk {'print $4'}|sed 's/"//g')
28
+
29
+ - run:
30
+ name: install dependencies
31
+ command: |
32
+ bundle install --jobs=4 --retry=3 --path vendor/bundle
33
+
34
+ - run:
35
+ name: install appraisal versions
36
+ command: |
37
+ bundle exec appraisal install
38
+
39
+ - save_cache:
40
+ paths:
41
+ - ./vendor/bundle
42
+ key: v1-dependencies-{{ checksum "cloudflare-rails.gemspec" }}-{{ checksum "Appraisals" }}
43
+
44
+ # run tests!
45
+ - run:
46
+ name: run tests
47
+ command: |
48
+ bundle exec appraisal rake
49
+ # collect reports
50
+ - store_test_results:
51
+ path: tmp/rspec
52
+ - store_artifacts:
53
+ path: tmp/rspec
54
+ destination: test-results
@@ -0,0 +1,8 @@
1
+ version: 2
2
+ updates:
3
+ - package-ecosystem: bundler
4
+ directory: "/"
5
+ schedule:
6
+ interval: daily
7
+ time: "13:00"
8
+ open-pull-requests-limit: 10
data/.gitignore ADDED
@@ -0,0 +1,15 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ /log/
11
+ .ruby-gemset
12
+ .ruby-version
13
+ .DS_Store
14
+
15
+ *.gemfile.lock
data/.rspec ADDED
@@ -0,0 +1,4 @@
1
+ --format d
2
+ --color
3
+ --format RspecJunitFormatter
4
+ --out tmp/rspec/rspec-<%= File.basename ENV['BUNDLE_GEMFILE'] %><%= ENV["RACK_ATTACK"] ? "-rack-attack-#{ENV["RACK_ATTACK"]}" : '' %>.xml
data/.rubocop.yml ADDED
@@ -0,0 +1,5 @@
1
+ inherit_from:
2
+ - .rubocop_airbnb.yml
3
+ - .rubocop_todo.yml
4
+ AllCops:
5
+ NewCops: enable
@@ -0,0 +1,2 @@
1
+ require:
2
+ - rubocop-airbnb
data/.rubocop_todo.yml ADDED
@@ -0,0 +1,51 @@
1
+ # This configuration was generated by
2
+ # `rubocop --auto-gen-config`
3
+ # on 2022-04-14 23:18:15 UTC using RuboCop version 0.93.1.
4
+ # The point is for the user to remove these configuration records
5
+ # one by one as the offenses are removed from the code base.
6
+ # Note that changes in the inspected code, or installation of new
7
+ # versions of RuboCop, may require this file to be generated again.
8
+
9
+ # Offense count: 4
10
+ # Cop supports --auto-correct.
11
+ Layout/MultilineBlockLayout:
12
+ Exclude:
13
+ - 'spec/cloudflare/rails_spec.rb'
14
+
15
+ # Offense count: 4
16
+ # Cop supports --auto-correct.
17
+ # Configuration parameters: EnforcedStyleForEmptyBraces, SpaceBeforeBlockParameters.
18
+ # SupportedStyles: space, no_space
19
+ # SupportedStylesForEmptyBraces: space, no_space
20
+ Layout/SpaceInsideBlockBraces:
21
+ EnforcedStyle: space
22
+
23
+ # Offense count: 1
24
+ # Cop supports --auto-correct.
25
+ Rails/ApplicationController:
26
+ Exclude:
27
+ - 'spec/cloudflare/rails_spec.rb'
28
+
29
+ # Offense count: 1
30
+ # Cop supports --auto-correct.
31
+ Rails/NegateInclude:
32
+ Exclude:
33
+ - 'lib/cloudflare/rails/railtie.rb'
34
+
35
+ # Offense count: 4
36
+ # Cop supports --auto-correct.
37
+ # Configuration parameters: EnforcedStyle, ProceduralMethods, FunctionalMethods, IgnoredMethods, AllowBracesOnProceduralOneLiners, BracesRequiredMethods.
38
+ # SupportedStyles: line_count_based, semantic, braces_for_chaining
39
+ # ProceduralMethods: benchmark, bm, bmbm, create, each_with_object, measure, new, realtime, tap, with_object
40
+ # FunctionalMethods: let, let!, subject, watch
41
+ # IgnoredMethods: lambda, proc, it
42
+ Style/BlockDelimiters:
43
+ Exclude:
44
+ - 'spec/cloudflare/rails_spec.rb'
45
+
46
+ # Offense count: 9
47
+ # Cop supports --auto-correct.
48
+ # Configuration parameters: AutoCorrect, AllowHeredoc, AllowURI, URISchemes, IgnoreCopDirectives, IgnoredPatterns.
49
+ # URISchemes: http, https
50
+ Layout/LineLength:
51
+ Max: 126
data/Appraisals ADDED
@@ -0,0 +1,15 @@
1
+ appraise "rails-5.2" do
2
+ gem "rails", "~> 5.2.0"
3
+ end
4
+
5
+ appraise "rails-6.0" do
6
+ gem "rails", "~> 6.0.0"
7
+ end
8
+
9
+ appraise "rails-6.1" do
10
+ gem "rails", "~> 6.1.0"
11
+ end
12
+
13
+ appraise "rails-7.0" do
14
+ gem "rails", git: "https://github.com/rails/rails", branch: "main"
15
+ end
data/CHANGELOG.md ADDED
@@ -0,0 +1,10 @@
1
+ # Changelog
2
+ All notable changes to this project will be documented in this file.
3
+
4
+ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
5
+ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
6
+
7
+ ## [0.1.0] - 2020-09-29
8
+ ### Added
9
+
10
+ - Cloning cloudflare-rails but for imperva with imperva download.
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in imperva-rails.gemspec
4
+ gemspec
data/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License
2
+
3
+ Copyright (c) 2014-2017 jonathan schatz
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,51 @@
1
+ # Imperva::Rails [![Gem Version](https://badge.fury.io/rb/imperva-rails.svg)](https://badge.fury.io/rb/imperva-rails) [![CircleCI](https://circleci.com/gh/modosc/imperva-rails/tree/main.svg?style=shield)](https://circleci.com/gh/modosc/imperva-rails/tree/main)
2
+ This gem correctly configures Rails for [Imperva](https://www.imperva.com) so that `request.remote_ip` / `request.ip` both work correctly.
3
+
4
+ ## Rails Compatibility
5
+
6
+ This gem requires `railties`, `activesupport`, and `actionpack` >= `5.2`.
7
+
8
+ For Rails `5.0` and `5.1` use `2.0.0`.
9
+
10
+ For Rails `4.2` use `0.1.x`.
11
+
12
+ ## Installation
13
+
14
+ Add this line to your application's `Gemfile`:
15
+
16
+ ```ruby
17
+ group :production do
18
+ # or :staging or :beta or whatever environments you are using imperva in.
19
+ # you probably don't want this for :test or :development
20
+ gem 'imperva-rails'
21
+ end
22
+ ```
23
+
24
+ And then execute:
25
+
26
+ $ bundle
27
+
28
+ ## Problem
29
+
30
+ Using Imperva means it's hard to identify the IP address of incoming requests since all requests are proxied through Imperva's infrastructure. Imperva provides a [Incap-Client-IP](https://docs.imperva.com/bundle/cloud-application-security/page/onboarding/setup-checklist.htm#:~:text=When%20working%20with%20Imperva%20your,7.) header which can be used to identify the originating IP address of a request. However, this header alone doesn't verify a request is legitimate. If an attacker has found the actual IP address of your server they could spoof this header and masquerade as legitimate traffic.
31
+
32
+ `imperva-rails` mitigates this attack by checking that the originating ip address of any incoming connection is from one of Imperva's ip address ranges. If so, the incoming `X-Forwarded-For` header is trusted and used as the ip address provided to `rack` and `rails` (via `request.ip` and `request.remote_ip`). If the incoming connection does not originate from a Imperva server then the `X-Forwarded-For` header is ignored and the actual remote ip address is used.
33
+
34
+ ## Usage
35
+ This codef will fetch Imperva's current [IPv4 and IPv6](https://my.imperva.com/api/integration/v1/ips) list, store them in `Rails.cache`, and add them to `config.imperva.ips`. The `X-Forwarded-For` header will then be trusted only from those ip addresses.
36
+
37
+ You can configure the HTTP `timeout` and `expires_in` cache parameters inside of your rails config:
38
+ ```ruby
39
+ config.imperva.expires_in = 12.hours # default value
40
+ config.imperva.timeout = 5.seconds # default value
41
+ ```
42
+
43
+ ## Development
44
+
45
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
46
+
47
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
48
+
49
+ ## Contributing
50
+
51
+ Bug reports and pull requests are welcome on GitHub at https://github.com/modosc/imperva-rails.
data/Rakefile ADDED
@@ -0,0 +1,24 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :without_rack_attack do
7
+ ENV.delete 'RACK_ATTACK'
8
+ Rake::Task["spec"].reenable
9
+ Rake::Task["spec"].invoke
10
+ end
11
+
12
+ task :with_rack_attack_first do
13
+ ENV['RACK_ATTACK'] = 'first'
14
+ Rake::Task["spec"].reenable
15
+ Rake::Task["spec"].invoke
16
+ end
17
+
18
+ task :with_rack_attack_last do
19
+ ENV['RACK_ATTACK'] = 'last'
20
+ Rake::Task["spec"].reenable
21
+ Rake::Task["spec"].invoke
22
+ end
23
+
24
+ task :default => [:without_rack_attack, :with_rack_attack_first, :with_rack_attack_last]
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "imperva/rails"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/setup ADDED
@@ -0,0 +1,7 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+
5
+ bundle install
6
+
7
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,2 @@
1
+ ---
2
+ BUNDLE_RETRY: "1"
@@ -0,0 +1,7 @@
1
+ # This file was generated by Appraisal
2
+
3
+ source "https://rubygems.org"
4
+
5
+ gem "rails", "~> 5.2.0"
6
+
7
+ gemspec path: "../"
@@ -0,0 +1,7 @@
1
+ # This file was generated by Appraisal
2
+
3
+ source "https://rubygems.org"
4
+
5
+ gem "rails", "~> 6.0.0"
6
+
7
+ gemspec path: "../"
@@ -0,0 +1,7 @@
1
+ # This file was generated by Appraisal
2
+
3
+ source "https://rubygems.org"
4
+
5
+ gem "rails", "~> 6.1.0"
6
+
7
+ gemspec path: "../"
@@ -0,0 +1,7 @@
1
+ # This file was generated by Appraisal
2
+
3
+ source "https://rubygems.org"
4
+
5
+ gem "rails", git: "https://github.com/rails/rails", branch: "main"
6
+
7
+ gemspec path: "../"
@@ -0,0 +1,40 @@
1
+ # coding: utf-8
2
+
3
+ lib = File.expand_path('../lib', __FILE__)
4
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
5
+ require 'imperva/rails/version'
6
+
7
+ Gem::Specification.new do |spec|
8
+ spec.name = "imperva-rails"
9
+ spec.version = Imperva::Rails::VERSION
10
+ spec.authors = ["jonathan schatz/jorge cuevas"]
11
+ spec.email = ["jocuman@users.noreply.github.com"]
12
+
13
+ spec.summary = "This gem configures Rails for Imperva so that request.ip and request.remote_ip and work correctly."
14
+ spec.description = ""
15
+ spec.homepage = "https://github.com/jocuman/imperva-rails"
16
+ spec.license = "MIT"
17
+
18
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
19
+ spec.bindir = "exe"
20
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
21
+ spec.require_paths = ["lib"]
22
+
23
+ spec.add_development_dependency "bundler", ">= 2.1.2"
24
+ spec.add_development_dependency "rake", "~> 13.0.1"
25
+ spec.add_development_dependency "rspec_junit_formatter", "~> 0.5.1"
26
+ spec.add_development_dependency "rspec-rails", "~> 5.0.1"
27
+ spec.add_development_dependency "rspec", "~> 3.11.0"
28
+ spec.add_development_dependency "rubocop-airbnb", "~> 4.0.0"
29
+ spec.add_development_dependency "webmock", "~> 3.14.0"
30
+ spec.add_development_dependency "rack-attack", "~> 6.6.1"
31
+ spec.add_development_dependency "pry-byebug"
32
+ spec.add_development_dependency "appraisal"
33
+
34
+ spec.add_dependency "railties", ">= 5.2", "< 7.1.0"
35
+ spec.add_dependency "activesupport", ">= 5.2", "< 7.1.0"
36
+ spec.add_dependency "actionpack", ">= 5.2", "< 7.1.0"
37
+
38
+ # we need Module#prepend
39
+ spec.required_ruby_version = '>= 2.0'
40
+ end
@@ -0,0 +1,114 @@
1
+ require "active_support/core_ext/integer/time"
2
+
3
+ module Imperva
4
+ module Rails
5
+ class Railtie < ::Rails::Railtie
6
+ # patch rack::request::helpers to use our imperva ips - this way request.ip is
7
+ # correct inside of rack and rails
8
+ module CheckTrustedProxies
9
+ def trusted_proxy?(ip)
10
+ matching = ::Rails.application.config.imperva.ips.any? do |proxy|
11
+ begin
12
+ proxy === ip
13
+ rescue IPAddr::InvalidAddressError
14
+ end
15
+ end
16
+ matching || super
17
+ end
18
+ end
19
+
20
+ # patch ActionDispatch::RemoteIP to use our imperva ips - this way
21
+ # request.remote_ip is correct inside of rails
22
+ module RemoteIpProxies
23
+ def proxies
24
+ super + ::Rails.application.config.imperva.ips
25
+ end
26
+ end
27
+
28
+ class Importer
29
+ # Exceptions contain the Net::HTTP
30
+ # response object accessible via the {#response} method.
31
+ class ResponseError < StandardError
32
+ # Returns the response of the last request
33
+ # @return [Net::HTTPResponse] A subclass of Net::HTTPResponse, e.g.
34
+ # Net::HTTPOK
35
+ attr_reader :response
36
+
37
+ # Instantiate an instance of ResponseError with a Net::HTTPResponse object
38
+ # @param [Net::HTTPResponse]
39
+ def initialize(response)
40
+ @response = response
41
+ super(response)
42
+ end
43
+ end
44
+
45
+ BASE_URL = 'https://my.imperva.com/api/integration/v1/ips'.freeze
46
+
47
+ class << self
48
+ def fetch
49
+ uri = URI("#{BASE_URL}")
50
+
51
+ resp = Net::HTTP.start(uri.host,
52
+ uri.port,
53
+ use_ssl: true,
54
+ read_timeout: 5) do |http|
55
+ req = Net::HTTP::Post.new(uri)
56
+ req.set_form_data('resp_format' => 'text')
57
+
58
+ http.request(req)
59
+ end
60
+
61
+ if resp.is_a?(Net::HTTPSuccess)
62
+ resp.body.split("\n").reject(&:blank?).map { |ip| IPAddr.new ip }
63
+ else
64
+ raise ResponseError, resp
65
+ end
66
+ end
67
+
68
+ def fetch_with_cache
69
+ ::Rails.cache.fetch("imperva-rails:ips", expires_in: ::Rails.application.config.imperva.expires_in) do
70
+ send :fetch
71
+ end
72
+ end
73
+ end
74
+ end
75
+
76
+ # setup defaults before we configure our app.
77
+ DEFAULTS = {
78
+ expires_in: 12.hours,
79
+ timeout: 5.seconds,
80
+ ips: [],
81
+ }.freeze
82
+
83
+ config.before_configuration do |app|
84
+ app.config.imperva = ActiveSupport::OrderedOptions.new
85
+ app.config.imperva.reverse_merge! DEFAULTS
86
+ end
87
+
88
+ # we set config.imperva.ips after_initialize so that our cache will
89
+ # be correctly setup. we rescue and log errors so that failures won't prevent
90
+ # rails from booting
91
+ config.after_initialize do |app|
92
+ begin
93
+ ::Rails.application.config.imperva.ips = Importer.fetch_with_cache
94
+ rescue Importer::ResponseError => e
95
+ ::Rails.logger.error "Imperva::Rails: Couldn't import ip blocks from Imperva: #{e.response}"
96
+ rescue StandardError => e
97
+ ::Rails.logger.error "Imperva::Rails: Got exception importing: #{e}"
98
+ end
99
+ end
100
+ initializer "my_railtie.configure_rails_initialization" do
101
+ Rack::Request::Helpers.prepend Imperva::Rails::Railtie::CheckTrustedProxies
102
+
103
+ ObjectSpace.each_object(Class).
104
+ select do |c|
105
+ c.included_modules.include?(Rack::Request::Helpers) &&
106
+ !c.included_modules.include?(Imperva::Rails::Railtie::CheckTrustedProxies)
107
+ end.
108
+ map { |c| c .prepend Imperva::Rails::Railtie::CheckTrustedProxies }
109
+
110
+ ActionDispatch::RemoteIp.prepend Imperva::Rails::Railtie::RemoteIpProxies
111
+ end
112
+ end
113
+ end
114
+ end
@@ -0,0 +1,5 @@
1
+ module Imperva
2
+ module Rails
3
+ VERSION = "0.1.0".freeze
4
+ end
5
+ end
@@ -0,0 +1,10 @@
1
+ require "imperva/rails/version"
2
+ require 'net/http'
3
+ require 'uri'
4
+
5
+ module Imperva
6
+ module Rails
7
+ end
8
+ end
9
+
10
+ require "imperva/rails/railtie"
metadata ADDED
@@ -0,0 +1,268 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: imperva-rails
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - jonathan schatz/jorge cuevas
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2022-08-26 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: 2.1.2
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: 2.1.2
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 13.0.1
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 13.0.1
41
+ - !ruby/object:Gem::Dependency
42
+ name: rspec_junit_formatter
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: 0.5.1
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: 0.5.1
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec-rails
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: 5.0.1
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: 5.0.1
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: 3.11.0
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: 3.11.0
83
+ - !ruby/object:Gem::Dependency
84
+ name: rubocop-airbnb
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: 4.0.0
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: 4.0.0
97
+ - !ruby/object:Gem::Dependency
98
+ name: webmock
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: 3.14.0
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: 3.14.0
111
+ - !ruby/object:Gem::Dependency
112
+ name: rack-attack
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: 6.6.1
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: 6.6.1
125
+ - !ruby/object:Gem::Dependency
126
+ name: pry-byebug
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - ">="
130
+ - !ruby/object:Gem::Version
131
+ version: '0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - ">="
137
+ - !ruby/object:Gem::Version
138
+ version: '0'
139
+ - !ruby/object:Gem::Dependency
140
+ name: appraisal
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - ">="
144
+ - !ruby/object:Gem::Version
145
+ version: '0'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - ">="
151
+ - !ruby/object:Gem::Version
152
+ version: '0'
153
+ - !ruby/object:Gem::Dependency
154
+ name: railties
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - ">="
158
+ - !ruby/object:Gem::Version
159
+ version: '5.2'
160
+ - - "<"
161
+ - !ruby/object:Gem::Version
162
+ version: 7.1.0
163
+ type: :runtime
164
+ prerelease: false
165
+ version_requirements: !ruby/object:Gem::Requirement
166
+ requirements:
167
+ - - ">="
168
+ - !ruby/object:Gem::Version
169
+ version: '5.2'
170
+ - - "<"
171
+ - !ruby/object:Gem::Version
172
+ version: 7.1.0
173
+ - !ruby/object:Gem::Dependency
174
+ name: activesupport
175
+ requirement: !ruby/object:Gem::Requirement
176
+ requirements:
177
+ - - ">="
178
+ - !ruby/object:Gem::Version
179
+ version: '5.2'
180
+ - - "<"
181
+ - !ruby/object:Gem::Version
182
+ version: 7.1.0
183
+ type: :runtime
184
+ prerelease: false
185
+ version_requirements: !ruby/object:Gem::Requirement
186
+ requirements:
187
+ - - ">="
188
+ - !ruby/object:Gem::Version
189
+ version: '5.2'
190
+ - - "<"
191
+ - !ruby/object:Gem::Version
192
+ version: 7.1.0
193
+ - !ruby/object:Gem::Dependency
194
+ name: actionpack
195
+ requirement: !ruby/object:Gem::Requirement
196
+ requirements:
197
+ - - ">="
198
+ - !ruby/object:Gem::Version
199
+ version: '5.2'
200
+ - - "<"
201
+ - !ruby/object:Gem::Version
202
+ version: 7.1.0
203
+ type: :runtime
204
+ prerelease: false
205
+ version_requirements: !ruby/object:Gem::Requirement
206
+ requirements:
207
+ - - ">="
208
+ - !ruby/object:Gem::Version
209
+ version: '5.2'
210
+ - - "<"
211
+ - !ruby/object:Gem::Version
212
+ version: 7.1.0
213
+ description: ''
214
+ email:
215
+ - jocuman@users.noreply.github.com
216
+ executables: []
217
+ extensions: []
218
+ extra_rdoc_files: []
219
+ files:
220
+ - ".circleci/config.yml"
221
+ - ".github/dependabot.yml"
222
+ - ".gitignore"
223
+ - ".rspec"
224
+ - ".rubocop.yml"
225
+ - ".rubocop_airbnb.yml"
226
+ - ".rubocop_todo.yml"
227
+ - Appraisals
228
+ - CHANGELOG.md
229
+ - Gemfile
230
+ - LICENSE
231
+ - README.md
232
+ - Rakefile
233
+ - bin/console
234
+ - bin/setup
235
+ - gemfiles/.bundle/config
236
+ - gemfiles/rails_5.2.gemfile
237
+ - gemfiles/rails_6.0.gemfile
238
+ - gemfiles/rails_6.1.gemfile
239
+ - gemfiles/rails_7.0.gemfile
240
+ - imperva-rails.gemspec
241
+ - lib/imperva/rails.rb
242
+ - lib/imperva/rails/railtie.rb
243
+ - lib/imperva/rails/version.rb
244
+ homepage: https://github.com/jocuman/imperva-rails
245
+ licenses:
246
+ - MIT
247
+ metadata: {}
248
+ post_install_message:
249
+ rdoc_options: []
250
+ require_paths:
251
+ - lib
252
+ required_ruby_version: !ruby/object:Gem::Requirement
253
+ requirements:
254
+ - - ">="
255
+ - !ruby/object:Gem::Version
256
+ version: '2.0'
257
+ required_rubygems_version: !ruby/object:Gem::Requirement
258
+ requirements:
259
+ - - ">="
260
+ - !ruby/object:Gem::Version
261
+ version: '0'
262
+ requirements: []
263
+ rubygems_version: 3.1.6
264
+ signing_key:
265
+ specification_version: 4
266
+ summary: This gem configures Rails for Imperva so that request.ip and request.remote_ip
267
+ and work correctly.
268
+ test_files: []