browser 2.5.2 → 5.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.github/ISSUE_TEMPLATE.md +1 -1
- data/.github/workflows/tests.yml +57 -0
- data/.gitignore +1 -0
- data/.prettierignore +1 -0
- data/.rubocop.yml +22 -107
- data/CHANGELOG.md +192 -11
- data/FUNDING.yml +3 -0
- data/Gemfile +2 -0
- data/README.md +139 -89
- data/Rakefile +11 -3
- data/bot_exceptions.yml +2 -0
- data/bots.yml +302 -247
- data/browser.gemspec +12 -7
- data/gemfiles/rails6_0.gemfile +6 -0
- data/gemfiles/rails6_1.gemfile +6 -0
- data/lib/browser/accept_language.rb +12 -9
- data/lib/browser/action_controller.rb +1 -3
- data/lib/browser/aliases.rb +5 -5
- data/lib/browser/alipay.rb +2 -2
- data/lib/browser/base.rb +101 -19
- data/lib/browser/blackberry.rb +3 -3
- data/lib/browser/bot/empty_user_agent_matcher.rb +11 -0
- data/lib/browser/bot/keyword_matcher.rb +11 -0
- data/lib/browser/bot/known_bots_matcher.rb +11 -0
- data/lib/browser/bot.rb +39 -27
- data/lib/browser/browser.rb +65 -54
- data/lib/browser/chrome.rb +18 -5
- data/lib/browser/detect_version.rb +5 -5
- data/lib/browser/device/android.rb +20 -0
- data/lib/browser/device/blackberry_playbook.rb +1 -1
- data/lib/browser/device/ipad.rb +1 -1
- data/lib/browser/device/iphone.rb +1 -1
- data/lib/browser/device/ipod_touch.rb +1 -1
- data/lib/browser/device/kindle.rb +1 -1
- data/lib/browser/device/kindle_fire.rb +1 -1
- data/lib/browser/device/playstation3.rb +1 -1
- data/lib/browser/device/playstation4.rb +1 -1
- data/lib/browser/device/psp.rb +1 -1
- data/lib/browser/device/psvita.rb +1 -1
- data/lib/browser/device/samsung.rb +33 -0
- data/lib/browser/device/surface.rb +2 -4
- data/lib/browser/device/switch.rb +19 -0
- data/lib/browser/device/tv.rb +1 -1
- data/lib/browser/device/unknown.rb +1 -1
- data/lib/browser/device/wii.rb +1 -1
- data/lib/browser/device/wiiu.rb +1 -1
- data/lib/browser/device/xbox_360.rb +1 -1
- data/lib/browser/device/xbox_one.rb +1 -1
- data/lib/browser/device.rb +47 -30
- data/lib/browser/duck_duck_go.rb +22 -0
- data/lib/browser/edge.rb +6 -2
- data/lib/browser/electron.rb +2 -2
- data/lib/browser/facebook.rb +4 -2
- data/lib/browser/firefox.rb +2 -2
- data/lib/browser/google_search_app.rb +21 -0
- data/lib/browser/huawei_browser.rb +21 -0
- data/lib/browser/instagram.rb +21 -0
- data/lib/browser/internet_explorer.rb +9 -10
- data/lib/browser/maxthon.rb +21 -0
- data/lib/browser/meta/base.rb +0 -1
- data/lib/browser/meta/generic_browser.rb +1 -3
- data/lib/browser/meta.rb +12 -13
- data/lib/browser/micro_messenger.rb +2 -2
- data/lib/browser/middleware/context/additions.rb +1 -1
- data/lib/browser/middleware.rb +4 -3
- data/lib/browser/miui_browser.rb +21 -0
- data/lib/browser/nokia.rb +2 -2
- data/lib/browser/opera.rb +2 -2
- data/lib/browser/otter.rb +2 -2
- data/lib/browser/phantom_js.rb +2 -2
- data/lib/browser/platform/adobe_air.rb +2 -2
- data/lib/browser/platform/android.rb +1 -1
- data/lib/browser/platform/base.rb +3 -2
- data/lib/browser/platform/blackberry.rb +2 -2
- data/lib/browser/platform/chrome_os.rb +1 -1
- data/lib/browser/platform/firefox_os.rb +1 -1
- data/lib/browser/platform/ios.rb +17 -4
- data/lib/browser/platform/kai_os.rb +23 -0
- data/lib/browser/platform/linux.rb +1 -1
- data/lib/browser/platform/mac.rb +5 -3
- data/lib/browser/platform/{other.rb → unknown.rb} +3 -3
- data/lib/browser/platform/windows.rb +2 -2
- data/lib/browser/platform/windows_mobile.rb +1 -1
- data/lib/browser/platform/windows_phone.rb +1 -1
- data/lib/browser/platform.rb +37 -28
- data/lib/browser/qq.rb +5 -5
- data/lib/browser/rails.rb +11 -5
- data/lib/browser/safari.rb +19 -4
- data/lib/browser/samsung_browser.rb +21 -0
- data/lib/browser/snapchat.rb +21 -0
- data/lib/browser/sougou_browser.rb +24 -0
- data/lib/browser/sputnik.rb +21 -0
- data/lib/browser/uc_browser.rb +2 -2
- data/lib/browser/{generic.rb → unknown.rb} +6 -8
- data/lib/browser/version.rb +1 -1
- data/lib/browser/weibo.rb +2 -2
- data/lib/browser/yandex.rb +21 -0
- data/lib/browser.rb +2 -2
- data/samsung.yml +138 -0
- data/search_engines.yml +2 -2
- data/test/browser_test.rb +42 -10
- data/test/rails_test.rb +10 -0
- data/test/sample_app.rb +14 -0
- data/test/test_helper.rb +9 -1
- data/test/ua.yml +147 -109
- data/test/ua_bots.yml +98 -45
- data/test/ua_search_engines.yml +7 -6
- data/test/unit/accept_language_test.rb +24 -0
- data/test/unit/adobe_air_test.rb +1 -1
- data/test/unit/alipay_test.rb +6 -0
- data/test/unit/blackberry_test.rb +0 -6
- data/test/unit/bots_test.rb +37 -27
- data/test/unit/chrome_test.rb +8 -19
- data/test/unit/console_test.rb +2 -2
- data/test/unit/device_test.rb +60 -3
- data/test/unit/duck_duck_go_test.rb +37 -0
- data/test/unit/edge_test.rb +49 -5
- data/test/unit/facebook_test.rb +20 -0
- data/test/unit/firefox_test.rb +0 -3
- data/test/unit/google_search_app_test.rb +54 -0
- data/test/unit/huawei_browser_test.rb +25 -0
- data/test/unit/instagram_test.rb +30 -0
- data/test/unit/internet_explorer_test.rb +0 -12
- data/test/unit/ios_test.rb +7 -5
- data/test/unit/kai_os_test.rb +31 -0
- data/test/unit/kindle_test.rb +0 -2
- data/test/unit/maxthon_test.rb +25 -0
- data/test/unit/meta_test.rb +10 -2
- data/test/unit/micro_messenger_test.rb +21 -6
- data/test/unit/miui_browser_test.rb +25 -0
- data/test/unit/opera_test.rb +1 -2
- data/test/unit/platform_test.rb +34 -8
- data/test/unit/qq_test.rb +12 -0
- data/test/unit/safari_test.rb +12 -7
- data/test/unit/samsung_browser_test.rb +23 -0
- data/test/unit/snapchat_test.rb +40 -0
- data/test/unit/sougou_browser_test.rb +41 -0
- data/test/unit/sputnik_test.rb +22 -0
- data/test/unit/yandex_test.rb +37 -0
- metadata +83 -26
- data/.bundle/config +0 -2
- data/.travis.yml +0 -16
- data/bin/rake +0 -17
- data/gemfiles/rails4.gemfile +0 -4
- data/lib/browser/meta/modern.rb +0 -11
data/lib/browser/meta.rb
CHANGED
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
require "browser/meta/device"
|
|
3
|
+
require_relative "meta/base"
|
|
4
|
+
require_relative "meta/generic_browser"
|
|
5
|
+
require_relative "meta/id"
|
|
6
|
+
require_relative "meta/ie"
|
|
7
|
+
require_relative "meta/ios"
|
|
8
|
+
require_relative "meta/mobile"
|
|
9
|
+
require_relative "meta/platform"
|
|
10
|
+
require_relative "meta/proxy"
|
|
11
|
+
require_relative "meta/safari"
|
|
12
|
+
require_relative "meta/webkit"
|
|
13
|
+
require_relative "meta/tablet"
|
|
14
|
+
require_relative "meta/device"
|
|
@@ -11,11 +11,11 @@ module Browser
|
|
|
11
11
|
end
|
|
12
12
|
|
|
13
13
|
def full_version
|
|
14
|
-
ua[%r
|
|
14
|
+
ua[%r{(?:MicroMessenger)/([\d.]+)}i, 1] || "0.0"
|
|
15
15
|
end
|
|
16
16
|
|
|
17
17
|
def match?
|
|
18
|
-
ua
|
|
18
|
+
ua.match?(/MicroMessenger/i)
|
|
19
19
|
end
|
|
20
20
|
end
|
|
21
21
|
end
|
data/lib/browser/middleware.rb
CHANGED
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
3
|
require "uri"
|
|
4
|
-
|
|
4
|
+
require_relative "middleware/context"
|
|
5
5
|
|
|
6
6
|
module Browser
|
|
7
7
|
class Middleware
|
|
8
8
|
# Detect the most common assets.
|
|
9
|
-
ASSETS_REGEX =
|
|
9
|
+
ASSETS_REGEX =
|
|
10
|
+
/\.(css|png|jpe?g|gif|js|svg|ico|flv|mov|m4v|ogg|swf)\z/i.freeze
|
|
10
11
|
|
|
11
12
|
# Detect the ACCEPT header. IE8 send */*.
|
|
12
|
-
ACCEPT_REGEX = %r
|
|
13
|
+
ACCEPT_REGEX = %r{(text/html|\*/\*)}.freeze
|
|
13
14
|
|
|
14
15
|
def initialize(app, &block)
|
|
15
16
|
raise ArgumentError, "Browser::Middleware requires a block" unless block
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Browser
|
|
4
|
+
class MiuiBrowser < Base
|
|
5
|
+
def id
|
|
6
|
+
:miui_browser
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def name
|
|
10
|
+
"Miui Browser"
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def full_version
|
|
14
|
+
ua[%r{MiuiBrowser/([\d.]+)}, 1] || "0.0"
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def match?
|
|
18
|
+
ua.include?("MiuiBrowser")
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
data/lib/browser/nokia.rb
CHANGED
data/lib/browser/opera.rb
CHANGED
|
@@ -11,11 +11,11 @@ module Browser
|
|
|
11
11
|
end
|
|
12
12
|
|
|
13
13
|
def full_version
|
|
14
|
-
ua[%r
|
|
14
|
+
ua[%r{OPR/([\d.]+)}, 1] || ua[%r{Version/([\d.]+)}, 1] || "0.0"
|
|
15
15
|
end
|
|
16
16
|
|
|
17
17
|
def match?
|
|
18
|
-
ua
|
|
18
|
+
ua.match?(%r{(Opera|OPR/)})
|
|
19
19
|
end
|
|
20
20
|
end
|
|
21
21
|
end
|
data/lib/browser/otter.rb
CHANGED
data/lib/browser/phantom_js.rb
CHANGED
|
@@ -4,7 +4,7 @@ module Browser
|
|
|
4
4
|
class Platform
|
|
5
5
|
class BlackBerry < Base
|
|
6
6
|
def match?
|
|
7
|
-
ua
|
|
7
|
+
ua.match?(/BB10|BlackBerry/)
|
|
8
8
|
end
|
|
9
9
|
|
|
10
10
|
def name
|
|
@@ -16,7 +16,7 @@ module Browser
|
|
|
16
16
|
end
|
|
17
17
|
|
|
18
18
|
def version
|
|
19
|
-
ua[%r
|
|
19
|
+
ua[%r{(?:Version|BlackBerry[\da-z]+)/([\d.]+)}, 1]
|
|
20
20
|
end
|
|
21
21
|
end
|
|
22
22
|
end
|
data/lib/browser/platform/ios.rb
CHANGED
|
@@ -3,11 +3,24 @@
|
|
|
3
3
|
module Browser
|
|
4
4
|
class Platform
|
|
5
5
|
class IOS < Base
|
|
6
|
-
MATCHER = /(iPhone|iPad|iPod)
|
|
7
|
-
VERSION_MATCHER =
|
|
6
|
+
MATCHER = /(iPhone|iPad|iPod)/.freeze
|
|
7
|
+
VERSION_MATCHER =
|
|
8
|
+
/OS (?<major>\d+)_(?<minor>\d+)_?(?<patch>\d+)?/.freeze
|
|
8
9
|
|
|
9
10
|
def version
|
|
10
|
-
|
|
11
|
+
matches = VERSION_MATCHER.match(ua)
|
|
12
|
+
|
|
13
|
+
return "0" unless matches
|
|
14
|
+
|
|
15
|
+
versions = [matches[:major]]
|
|
16
|
+
|
|
17
|
+
if matches[:patch]
|
|
18
|
+
versions.push(matches[:minor], matches[:patch])
|
|
19
|
+
else
|
|
20
|
+
versions.push(matches[:minor]) unless matches[:minor] == "0"
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
versions.join(".")
|
|
11
24
|
end
|
|
12
25
|
|
|
13
26
|
def name
|
|
@@ -19,7 +32,7 @@ module Browser
|
|
|
19
32
|
end
|
|
20
33
|
|
|
21
34
|
def match?
|
|
22
|
-
ua
|
|
35
|
+
ua.match?(MATCHER)
|
|
23
36
|
end
|
|
24
37
|
|
|
25
38
|
def device
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Browser
|
|
4
|
+
class Platform
|
|
5
|
+
class KaiOS < Base
|
|
6
|
+
def version
|
|
7
|
+
ua[%r{KAIOS/([\d.]+)}, 1]
|
|
8
|
+
end
|
|
9
|
+
|
|
10
|
+
def name
|
|
11
|
+
"KaiOS"
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def id
|
|
15
|
+
:kai_os
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
def match?
|
|
19
|
+
ua.include?("KAIOS")
|
|
20
|
+
end
|
|
21
|
+
end
|
|
22
|
+
end
|
|
23
|
+
end
|
data/lib/browser/platform/mac.rb
CHANGED
|
@@ -4,11 +4,13 @@ module Browser
|
|
|
4
4
|
class Platform
|
|
5
5
|
class Mac < Base
|
|
6
6
|
def version
|
|
7
|
-
(ua[/Mac OS X\s*([0-9_
|
|
7
|
+
(ua[/Mac OS X\s*([0-9_.]+)?/, 1] || "0").tr("_", ".")
|
|
8
8
|
end
|
|
9
9
|
|
|
10
10
|
def name
|
|
11
|
-
"
|
|
11
|
+
return "macOS" if platform.mac?(">= 10.12")
|
|
12
|
+
|
|
13
|
+
"Mac OS X"
|
|
12
14
|
end
|
|
13
15
|
|
|
14
16
|
def id
|
|
@@ -16,7 +18,7 @@ module Browser
|
|
|
16
18
|
end
|
|
17
19
|
|
|
18
20
|
def match?
|
|
19
|
-
ua
|
|
21
|
+
ua.include?("Mac")
|
|
20
22
|
end
|
|
21
23
|
end
|
|
22
24
|
end
|
|
@@ -4,7 +4,7 @@ module Browser
|
|
|
4
4
|
class Platform
|
|
5
5
|
class Windows < Base
|
|
6
6
|
def version
|
|
7
|
-
ua[/Windows NT\s*([0-9_
|
|
7
|
+
ua[/Windows NT\s*([0-9_.]+)?/, 1] || "0"
|
|
8
8
|
end
|
|
9
9
|
|
|
10
10
|
def name
|
|
@@ -16,7 +16,7 @@ module Browser
|
|
|
16
16
|
end
|
|
17
17
|
|
|
18
18
|
def match?
|
|
19
|
-
ua
|
|
19
|
+
ua.include?("Windows")
|
|
20
20
|
end
|
|
21
21
|
end
|
|
22
22
|
end
|
data/lib/browser/platform.rb
CHANGED
|
@@ -1,18 +1,19 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
3
|
+
require_relative "platform/base"
|
|
4
|
+
require_relative "platform/ios"
|
|
5
|
+
require_relative "platform/linux"
|
|
6
|
+
require_relative "platform/windows"
|
|
7
|
+
require_relative "platform/mac"
|
|
8
|
+
require_relative "platform/windows_phone"
|
|
9
|
+
require_relative "platform/windows_mobile"
|
|
10
|
+
require_relative "platform/firefox_os"
|
|
11
|
+
require_relative "platform/blackberry"
|
|
12
|
+
require_relative "platform/android"
|
|
13
|
+
require_relative "platform/unknown"
|
|
14
|
+
require_relative "platform/chrome_os"
|
|
15
|
+
require_relative "platform/adobe_air"
|
|
16
|
+
require_relative "platform/kai_os"
|
|
16
17
|
|
|
17
18
|
module Browser
|
|
18
19
|
class Platform
|
|
@@ -32,10 +33,11 @@ module Browser
|
|
|
32
33
|
BlackBerry,
|
|
33
34
|
IOS,
|
|
34
35
|
Mac,
|
|
36
|
+
KaiOS,
|
|
35
37
|
FirefoxOS,
|
|
36
38
|
Windows,
|
|
37
39
|
Linux,
|
|
38
|
-
|
|
40
|
+
Unknown
|
|
39
41
|
]
|
|
40
42
|
end
|
|
41
43
|
|
|
@@ -45,7 +47,7 @@ module Browser
|
|
|
45
47
|
|
|
46
48
|
def subject
|
|
47
49
|
@subject ||= self.class.matchers
|
|
48
|
-
.map {|matcher| matcher.new(ua) }
|
|
50
|
+
.map {|matcher| matcher.new(ua, self) }
|
|
49
51
|
.find(&:match?)
|
|
50
52
|
end
|
|
51
53
|
|
|
@@ -61,8 +63,8 @@ module Browser
|
|
|
61
63
|
id == :android && detect_version?(version, expected_version)
|
|
62
64
|
end
|
|
63
65
|
|
|
64
|
-
def
|
|
65
|
-
id == :
|
|
66
|
+
def unknown?
|
|
67
|
+
id == :unknown_platform
|
|
66
68
|
end
|
|
67
69
|
|
|
68
70
|
def linux?
|
|
@@ -81,6 +83,10 @@ module Browser
|
|
|
81
83
|
id == :firefox_os
|
|
82
84
|
end
|
|
83
85
|
|
|
86
|
+
def kai_os?
|
|
87
|
+
id == :kai_os
|
|
88
|
+
end
|
|
89
|
+
|
|
84
90
|
def ios?(expected_version = nil)
|
|
85
91
|
id == :ios && detect_version?(version, expected_version)
|
|
86
92
|
end
|
|
@@ -130,46 +136,46 @@ module Browser
|
|
|
130
136
|
# Detect if in an Android app webview (Lollipop and newer)
|
|
131
137
|
# https://developer.chrome.com/multidevice/user-agent#webview_user_agent
|
|
132
138
|
def android_app?
|
|
133
|
-
android? && ua
|
|
139
|
+
android? && ua.match?(/\bwv\b/)
|
|
134
140
|
end
|
|
135
141
|
alias_method :android_webview?, :android_app?
|
|
136
142
|
|
|
137
143
|
# http://msdn.microsoft.com/fr-FR/library/ms537503.aspx#PltToken
|
|
138
144
|
def windows_xp?
|
|
139
|
-
windows? && ua
|
|
145
|
+
windows? && ua.match?(/Windows NT 5\.[12]/)
|
|
140
146
|
end
|
|
141
147
|
|
|
142
148
|
def windows_vista?
|
|
143
|
-
windows? && ua
|
|
149
|
+
windows? && ua.include?("Windows NT 6.0")
|
|
144
150
|
end
|
|
145
151
|
|
|
146
152
|
def windows7?
|
|
147
|
-
windows? && ua
|
|
153
|
+
windows? && ua.include?("Windows NT 6.1")
|
|
148
154
|
end
|
|
149
155
|
|
|
150
156
|
def windows8?
|
|
151
|
-
windows? && ua
|
|
157
|
+
windows? && ua.match?(/Windows NT 6\.[2-3]/)
|
|
152
158
|
end
|
|
153
159
|
|
|
154
160
|
def windows8_1?
|
|
155
|
-
windows? && ua
|
|
161
|
+
windows? && ua.include?("Windows NT 6.3")
|
|
156
162
|
end
|
|
157
163
|
|
|
158
164
|
def windows10?
|
|
159
|
-
windows? && ua
|
|
165
|
+
windows? && ua.include?("Windows NT 10")
|
|
160
166
|
end
|
|
161
167
|
|
|
162
168
|
def windows_rt?
|
|
163
|
-
windows8? && ua
|
|
169
|
+
windows8? && ua.include?("ARM")
|
|
164
170
|
end
|
|
165
171
|
|
|
166
172
|
# Detect if current platform is Windows in 64-bit architecture.
|
|
167
173
|
def windows_x64?
|
|
168
|
-
windows? && ua
|
|
174
|
+
windows? && ua.match?(/(Win64|x64|Windows NT 5\.2)/)
|
|
169
175
|
end
|
|
170
176
|
|
|
171
177
|
def windows_wow64?
|
|
172
|
-
windows? && ua
|
|
178
|
+
windows? && ua.match?(/WOW64/i)
|
|
173
179
|
end
|
|
174
180
|
|
|
175
181
|
def windows_x64_inclusive?
|
|
@@ -177,7 +183,10 @@ module Browser
|
|
|
177
183
|
end
|
|
178
184
|
|
|
179
185
|
def windows_touchscreen_desktop?
|
|
180
|
-
windows? && ua
|
|
186
|
+
windows? && ua.include?("Touch")
|
|
181
187
|
end
|
|
188
|
+
|
|
189
|
+
private :subject
|
|
190
|
+
private :ua
|
|
182
191
|
end
|
|
183
192
|
end
|
data/lib/browser/qq.rb
CHANGED
|
@@ -11,15 +11,15 @@ module Browser
|
|
|
11
11
|
end
|
|
12
12
|
|
|
13
13
|
def full_version
|
|
14
|
-
ua[%r
|
|
15
|
-
ua[%r
|
|
16
|
-
ua[%r
|
|
17
|
-
ua[%r
|
|
14
|
+
ua[%r{(?:Mobile MQQBrowser)/([\d.]+)}i, 1] ||
|
|
15
|
+
ua[%r{(?:QQBrowserLite)/([\d.]+)}i, 1] ||
|
|
16
|
+
ua[%r{(?:QQBrowser)/([\d.]+)}i, 1] ||
|
|
17
|
+
ua[%r{(?:QQ)/([\d.]+)}i, 1] ||
|
|
18
18
|
"0.0"
|
|
19
19
|
end
|
|
20
20
|
|
|
21
21
|
def match?
|
|
22
|
-
ua
|
|
22
|
+
ua.match?(%r{QQ/|QQBrowser}i)
|
|
23
23
|
end
|
|
24
24
|
end
|
|
25
25
|
end
|
data/lib/browser/rails.rb
CHANGED
|
@@ -1,17 +1,23 @@
|
|
|
1
1
|
# frozen_string_literal: true
|
|
2
2
|
|
|
3
3
|
require "rails/railtie"
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
require_relative "action_controller"
|
|
5
|
+
require_relative "middleware/context/additions"
|
|
6
6
|
|
|
7
7
|
module Browser
|
|
8
8
|
class Railtie < Rails::Railtie
|
|
9
9
|
config.browser = ActiveSupport::OrderedOptions.new
|
|
10
10
|
|
|
11
11
|
initializer "browser" do
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
12
|
+
ActiveSupport.on_load(:action_controller) do
|
|
13
|
+
::ActionController::Base.include(Browser::ActionController)
|
|
14
|
+
|
|
15
|
+
::ActionController::Metal.include(Browser::ActionController) if defined?(::ActionController::Metal) # rubocop:disable Layout/LineLength
|
|
16
|
+
|
|
17
|
+
Browser::Middleware::Context.include(
|
|
18
|
+
Browser::Middleware::Context::Additions
|
|
19
|
+
)
|
|
20
|
+
end
|
|
15
21
|
end
|
|
16
22
|
end
|
|
17
23
|
end
|
data/lib/browser/safari.rb
CHANGED
|
@@ -11,14 +11,29 @@ module Browser
|
|
|
11
11
|
end
|
|
12
12
|
|
|
13
13
|
def full_version
|
|
14
|
-
ua[%r
|
|
15
|
-
ua[%r
|
|
16
|
-
ua[%r
|
|
14
|
+
ua[%r{Version/([\d.]+)}, 1] ||
|
|
15
|
+
ua[%r{Safari/([\d.]+)}, 1] ||
|
|
16
|
+
ua[%r{AppleWebKit/([\d.]+)}, 1] ||
|
|
17
17
|
"0.0"
|
|
18
18
|
end
|
|
19
19
|
|
|
20
20
|
def match?
|
|
21
|
-
ua
|
|
21
|
+
ua.include?("Safari") &&
|
|
22
|
+
!ua.match?(/PhantomJS|FxiOS/) &&
|
|
23
|
+
!edge? &&
|
|
24
|
+
!chrome? &&
|
|
25
|
+
!opera? &&
|
|
26
|
+
!samsung_browser? &&
|
|
27
|
+
!huawei_browser? &&
|
|
28
|
+
!miui_browser? &&
|
|
29
|
+
!duck_duck_go? &&
|
|
30
|
+
!yandex? &&
|
|
31
|
+
!sputnik? &&
|
|
32
|
+
!maxthon? &&
|
|
33
|
+
!qq? &&
|
|
34
|
+
!alipay? &&
|
|
35
|
+
!sougou_browser? &&
|
|
36
|
+
!google_search_app?
|
|
22
37
|
end
|
|
23
38
|
end
|
|
24
39
|
end
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Browser
|
|
4
|
+
class SamsungBrowser < Chrome
|
|
5
|
+
def id
|
|
6
|
+
:samsung_browser
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def name
|
|
10
|
+
"Samsung Browser"
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def full_version
|
|
14
|
+
ua[%r{SamsungBrowser/([\d.]+)}, 1] || super
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def match?
|
|
18
|
+
ua.include?("SamsungBrowser")
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module Browser
|
|
4
|
+
class Snapchat < Base
|
|
5
|
+
def id
|
|
6
|
+
:snapchat
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
def name
|
|
10
|
+
"Snapchat"
|
|
11
|
+
end
|
|
12
|
+
|
|
13
|
+
def full_version
|
|
14
|
+
ua[%r{Snapchat( ?|/)([\d.]+)}, 2] || "0.0"
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
def match?
|
|
18
|
+
ua.include?("Snapchat")
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
end
|