spidy 0.2.7 → 0.2.8
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 +4 -4
- data/lib/spidy/connector.rb +40 -18
- data/lib/spidy/definition.rb +0 -4
- data/lib/spidy/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 43e5538d56f4d4115a1bb2cb662f0722d688ad44d8212506436492f0ee3e0570
|
4
|
+
data.tar.gz: b0db640263836c7244876a50219ed4f916c6c2f7777e11c7e13d11c2142714dc
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3d6dcfea624a7710eec941e55238334596edced66d60a09b046c5b057de06c2fb7d279c3d912a8e054ef206d9d5c148ee1e43d3394d6d8c30d364fa17fcc69fb
|
7
|
+
data.tar.gz: fe42ba4880e255aa2a09d360cfec59aaf199ec60407d045641d8ac3cad8319fb3277f2b3e91760e24ab879ec224860628c30fce2282e8c4467a6bfc75826fee5
|
data/lib/spidy/connector.rb
CHANGED
@@ -10,6 +10,18 @@ module Spidy::Connector
|
|
10
10
|
autoload :Json
|
11
11
|
autoload :Xml
|
12
12
|
|
13
|
+
#
|
14
|
+
# default user agent
|
15
|
+
#
|
16
|
+
USER_AGENT = [
|
17
|
+
'Mozilla/5.0',
|
18
|
+
'(Macintosh; Intel Mac OS X 10_12_6)',
|
19
|
+
'AppleWebKit/537.36',
|
20
|
+
'(KHTML, like Gecko)',
|
21
|
+
'Chrome/64.0.3282.186',
|
22
|
+
'Safari/537.36'
|
23
|
+
].join(' ')
|
24
|
+
|
13
25
|
module StaticAccessor
|
14
26
|
extend ActiveSupport::Concern
|
15
27
|
class_methods do
|
@@ -34,17 +46,31 @@ module Spidy::Connector
|
|
34
46
|
end
|
35
47
|
end
|
36
48
|
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
49
|
+
class Builder
|
50
|
+
attr_reader :origin_connector, :proxy_connector
|
51
|
+
|
52
|
+
def initialize(connector, socks_proxy)
|
53
|
+
@socks_proxy = socks_proxy
|
54
|
+
@origin_connector = connector
|
55
|
+
@proxy_connector =
|
56
|
+
lambda do |url, &block|
|
57
|
+
Socksify::proxy(socks_proxy[:host], socks_proxy[:port]) do
|
58
|
+
connector.call(url, &block)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def proxy_disabled?
|
64
|
+
!tor?
|
65
|
+
end
|
66
|
+
|
67
|
+
def tor?
|
68
|
+
Tor::Controller.new(host: @socks_proxy[:host], port: @socks_proxy[:port]).close
|
69
|
+
true
|
70
|
+
rescue Errno::ECONNREFUSED
|
71
|
+
false
|
72
|
+
end
|
73
|
+
end
|
48
74
|
|
49
75
|
#
|
50
76
|
# get connection handller
|
@@ -52,13 +78,9 @@ module Spidy::Connector
|
|
52
78
|
def self.get(value, wait_time: nil, user_agent: nil, socks_proxy: nil)
|
53
79
|
return value if value.respond_to?(:call)
|
54
80
|
|
55
|
-
|
56
|
-
return
|
81
|
+
builder = Builder.new(const_get(value.to_s.classify).new(wait_time: wait_time || 5, user_agent: user_agent || USER_AGENT), socks_proxy)
|
82
|
+
return builder.origin_connector if socks_proxy.nil? || builder.proxy_disabled?
|
57
83
|
|
58
|
-
|
59
|
-
Socksify::proxy(socks_proxy[:host], socks_proxy[:port]) do
|
60
|
-
connector.call(url, &block)
|
61
|
-
end
|
62
|
-
end
|
84
|
+
builder.proxy_connector
|
63
85
|
end
|
64
86
|
end
|
data/lib/spidy/definition.rb
CHANGED
data/lib/spidy/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: spidy
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- aileron
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-09-
|
11
|
+
date: 2020-09-07 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|