Merge remote-tracking branch 'parent/main' into upstream-20240628
This commit is contained in:
commit
6955843321
178 changed files with 1924 additions and 1178 deletions
33
app/lib/private_address_check.rb
Normal file
33
app/lib/private_address_check.rb
Normal file
|
@ -0,0 +1,33 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
module PrivateAddressCheck
|
||||
module_function
|
||||
|
||||
CIDR_LIST = [
|
||||
IPAddr.new('0.0.0.0/8'), # Current network (only valid as source address)
|
||||
IPAddr.new('100.64.0.0/10'), # Shared Address Space
|
||||
IPAddr.new('172.16.0.0/12'), # Private network
|
||||
IPAddr.new('192.0.0.0/24'), # IETF Protocol Assignments
|
||||
IPAddr.new('192.0.2.0/24'), # TEST-NET-1, documentation and examples
|
||||
IPAddr.new('192.88.99.0/24'), # IPv6 to IPv4 relay (includes 2002::/16)
|
||||
IPAddr.new('198.18.0.0/15'), # Network benchmark tests
|
||||
IPAddr.new('198.51.100.0/24'), # TEST-NET-2, documentation and examples
|
||||
IPAddr.new('203.0.113.0/24'), # TEST-NET-3, documentation and examples
|
||||
IPAddr.new('224.0.0.0/4'), # IP multicast (former Class D network)
|
||||
IPAddr.new('240.0.0.0/4'), # Reserved (former Class E network)
|
||||
IPAddr.new('255.255.255.255'), # Broadcast
|
||||
IPAddr.new('64:ff9b::/96'), # IPv4/IPv6 translation (RFC 6052)
|
||||
IPAddr.new('100::/64'), # Discard prefix (RFC 6666)
|
||||
IPAddr.new('2001::/32'), # Teredo tunneling
|
||||
IPAddr.new('2001:10::/28'), # Deprecated (previously ORCHID)
|
||||
IPAddr.new('2001:20::/28'), # ORCHIDv2
|
||||
IPAddr.new('2001:db8::/32'), # Addresses used in documentation and example source code
|
||||
IPAddr.new('2002::/16'), # 6to4
|
||||
IPAddr.new('fc00::/7'), # Unique local address
|
||||
IPAddr.new('ff00::/8'), # Multicast
|
||||
].freeze
|
||||
|
||||
def private_address?(address)
|
||||
address.private? || address.loopback? || address.link_local? || CIDR_LIST.any? { |cidr| cidr.include?(address) }
|
||||
end
|
||||
end
|
|
@ -412,7 +412,7 @@ class SearchQueryTransformer < Parslet::Transform
|
|||
end
|
||||
|
||||
rule(clause: subtree(:clause)) do
|
||||
prefix = clause[:prefix][:term].to_s if clause[:prefix]
|
||||
prefix = clause[:prefix][:term].to_s.downcase if clause[:prefix]
|
||||
operator = clause[:operator]&.to_s
|
||||
term = clause[:phrase] ? clause[:phrase].map { |term| term[:term].to_s }.join(' ') : clause[:term].to_s
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@ class Themes
|
|||
|
||||
THEME_COLORS = {
|
||||
dark: '#191b22',
|
||||
light: '#f3f5f7',
|
||||
light: '#ffffff',
|
||||
}.freeze
|
||||
|
||||
def initialize
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue