sqreen 1.18.0-java → 1.18.1-java

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 922051da24f2022f3a83abf7f948dc5736755b1470e3c07e51ea620b4ad79d38
4
- data.tar.gz: 286a940f0c898061965af56bc612cff127123743c81f29460bdb50b74f336cac
3
+ metadata.gz: 61098cd896356da56ff7a321f2c43f694686f7b2ab8d9e48a2b249351b095af5
4
+ data.tar.gz: '05975ea91615b5cc62b80c750b02fa3773b5262f7e759063346b6b4f93934319'
5
5
  SHA512:
6
- metadata.gz: 366be041f989a6668942f1e7f41be437572a9b128ff8622f916b5482aaf21b5f45f0ecdd7df11c44f1fa69b4823abc518e8c200fcc6b421d394f98e2b942c426
7
- data.tar.gz: aec4842b37b82db5d7603a225fd1b14ece321793cf5d0f9e52f96be4acfc335427ea8056144bd3a8f0bfe960a8709b990e407c6329f746fe7a3aa03ebc30957e
6
+ metadata.gz: da30cff65326a7371fc5f3fd09253315f07516ba3fe29db4714a29131755581b2e5a661b534aad64823b8ff714dac37ac07483aea9aef2f930fc55958bb1717a
7
+ data.tar.gz: 7a36d82da8dfd18a66b0b354748a55fa6b6531f081f432a287bb813f307564db1c8275ac13404a09cd88b51c5f9b6803b8b31ea309cd7fb07ba95e9854c356ce
data/CHANGELOG.md CHANGED
@@ -1,3 +1,9 @@
1
+ ## 1.18.1
2
+
3
+ * Improve handling of scoped IPv6 addresses
4
+ * Remove spurious warning on Rails 6
5
+ * Add missing WAF constant check
6
+
1
7
  ## 1.18.0
2
8
 
3
9
  * Support In-App WAF
@@ -169,7 +169,7 @@ module Sqreen
169
169
  end
170
170
 
171
171
  def matching_actions(client_ip)
172
- parsed_ip = IPAddr.new(client_ip)
172
+ parsed_ip = IPAddr.new(client_ip.gsub(/%[^%\/]+/, ''))
173
173
  trie = parsed_ip.family == Socket::AF_INET6 ? @trie_v6 : @trie_v4
174
174
  return [] unless trie
175
175
  found = trie.search_matching(parsed_ip.to_i, parsed_ip.family)
@@ -15,6 +15,8 @@ module Sqreen
15
15
  end
16
16
 
17
17
  def inspect_middlewares
18
+ return unless ::Rails.application.middleware.respond_to?(:map)
19
+
18
20
  Sqreen.log.debug { "Middlewares: " << ::Rails.application.middleware.map(&:inspect).inspect }
19
21
  end
20
22
 
@@ -13,7 +13,7 @@ module Sqreen
13
13
  klass = case
14
14
  when defined?(::Rails) && defined?(::Rails::VERSION)
15
15
  case Rails::VERSION::MAJOR.to_i
16
- when 4, 5
16
+ when 4, 5, 6
17
17
  require 'sqreen/frameworks/rails'
18
18
  Sqreen::Frameworks::RailsFramework
19
19
  when 3
@@ -22,13 +22,17 @@ module Sqreen
22
22
  @libsqreen
23
23
  end
24
24
 
25
+ def self.waf?
26
+ Sqreen::Dependency.const_exist?('LibSqreen::WAF')
27
+ end
28
+
25
29
  attr_reader :binding_accessors, :budget, :waf_rule_name
26
30
 
27
31
  def initialize(*args)
28
32
  super(*args)
29
33
  @overtimeable = false
30
34
 
31
- unless WAFCB.libsqreen?
35
+ unless WAFCB.libsqreen? && WAFCB.waf?
32
36
  Sqreen.log.warn('libsqreen gem not found')
33
37
  return
34
38
  end
@@ -57,10 +61,7 @@ module Sqreen
57
61
  end
58
62
 
59
63
  def pre(instance, args, _budget)
60
- unless WAFCB.libsqreen?
61
- Sqreen.log.warn('libsqreen not required')
62
- return
63
- end
64
+ return unless WAFCB.libsqreen? && WAFCB.waf?
64
65
 
65
66
  request = framework.request
66
67
  return if !waf_rule_name || !request
@@ -1,5 +1,5 @@
1
1
  # Copyright (c) 2015 Sqreen. All Rights Reserved.
2
2
  # Please refer to our terms for more information: https://www.sqreen.io/terms.html
3
3
  module Sqreen
4
- VERSION = '1.18.0'.freeze
4
+ VERSION = '1.18.1'.freeze
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sqreen
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.18.0
4
+ version: 1.18.1
5
5
  platform: java
6
6
  authors:
7
7
  - Sqreen
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-10-15 00:00:00.000000000 Z
11
+ date: 2019-10-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  requirement: !ruby/object:Gem::Requirement