gman 7.0.0 → 7.0.5
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/CODEOWNERS +3 -0
- data/.github/ISSUE_TEMPLATE/bug_report.md +28 -0
- data/.github/ISSUE_TEMPLATE/feature_request.md +21 -0
- data/.github/config.yml +23 -0
- data/.github/funding.yml +1 -0
- data/.github/no-response.yml +15 -0
- data/.github/release-drafter.yml +4 -0
- data/.github/settings.yml +33 -0
- data/.github/stale.yml +29 -0
- data/.gitignore +1 -0
- data/.rspec +2 -0
- data/.rubocop.yml +14 -5
- data/.rubocop_todo.yml +84 -0
- data/.ruby-version +1 -1
- data/Gemfile +2 -0
- data/bin/gman +6 -4
- data/bin/gman_filter +5 -7
- data/config/domains.txt +8454 -168
- data/config/vendor/academic.txt +6 -7
- data/config/vendor/dotgovs.csv +5786 -5560
- data/docs/CODE_OF_CONDUCT.md +46 -0
- data/docs/CONTRIBUTING.md +92 -0
- data/{README.md → docs/README.md} +3 -3
- data/docs/SECURITY.md +3 -0
- data/docs/_config.yml +2 -0
- data/gman.gemspec +18 -17
- data/lib/gman.rb +4 -2
- data/lib/gman/country_codes.rb +17 -17
- data/lib/gman/domain_list.rb +25 -9
- data/lib/gman/identifier.rb +57 -19
- data/lib/gman/importer.rb +31 -21
- data/lib/gman/locality.rb +8 -6
- data/lib/gman/version.rb +3 -1
- data/script/add +2 -0
- data/script/alphabetize +2 -0
- data/script/cibuild +1 -1
- data/script/dedupe +2 -1
- data/script/profile +2 -1
- data/script/prune +5 -3
- data/script/reconcile-us +6 -3
- data/script/vendor-federal-de +2 -1
- data/script/vendor-municipal-de +2 -1
- data/script/vendor-nl +2 -0
- data/script/vendor-public-suffix +6 -4
- data/script/vendor-se +2 -1
- data/script/vendor-swot +3 -1
- data/script/vendor-us +5 -3
- data/spec/fixtures/domains.txt +4 -0
- data/{test → spec}/fixtures/obama.txt +0 -0
- data/spec/gman/bin_spec.rb +101 -0
- data/spec/gman/country_code_spec.rb +39 -0
- data/spec/gman/domain_list_spec.rb +110 -0
- data/spec/gman/domains_spec.rb +25 -0
- data/spec/gman/identifier_spec.rb +218 -0
- data/spec/gman/importer_spec.rb +236 -0
- data/spec/gman/locality_spec.rb +24 -0
- data/spec/gman_spec.rb +74 -0
- data/spec/spec_helper.rb +31 -0
- metadata +89 -81
- data/.rake_tasks +0 -0
- data/CONTRIBUTING.md +0 -22
- data/Rakefile +0 -22
- data/test/fixtures/domains.txt +0 -2
- data/test/helper.rb +0 -48
- data/test/test_gman.rb +0 -56
- data/test/test_gman_bin.rb +0 -75
- data/test/test_gman_country_codes.rb +0 -18
- data/test/test_gman_domain_list.rb +0 -112
- data/test/test_gman_domains.rb +0 -32
- data/test/test_gman_filter.rb +0 -17
- data/test/test_gman_identifier.rb +0 -106
- data/test/test_gman_importer.rb +0 -244
- data/test/test_gman_locality.rb +0 -10
@@ -0,0 +1,236 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Gman::Importer do
|
4
|
+
subject { described_class.new(domains) }
|
5
|
+
|
6
|
+
let(:domains) { { 'test' => ['example.com'] } }
|
7
|
+
let(:stdout) { StringIO.new }
|
8
|
+
let(:logger) { Logger.new(@stdout) }
|
9
|
+
let(:domain_list) { subject.domain_list }
|
10
|
+
|
11
|
+
before do
|
12
|
+
subject.instance_variable_set '@logger', logger
|
13
|
+
end
|
14
|
+
|
15
|
+
it 'inits the domain list' do
|
16
|
+
expect(domain_list).to be_a(Gman::DomainList)
|
17
|
+
expect(domain_list.count).to be(1)
|
18
|
+
expect(domain_list.domains.first).to eql('example.com')
|
19
|
+
end
|
20
|
+
|
21
|
+
it 'inits the logger' do
|
22
|
+
expect(subject.logger).to be_a(Logger)
|
23
|
+
end
|
24
|
+
|
25
|
+
it 'returns the current domain list' do
|
26
|
+
expect(subject.current).to be_a(Gman::DomainList)
|
27
|
+
end
|
28
|
+
|
29
|
+
it 'returns the resolver' do
|
30
|
+
expect(subject.resolver).to be_a(Resolv::DNS)
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'domain rejection' do
|
34
|
+
it 'returns false' do
|
35
|
+
expect(subject.reject('example.com', 'reasons')).to be(false)
|
36
|
+
end
|
37
|
+
|
38
|
+
it 'returns the reason why asked' do
|
39
|
+
with_env 'RECONCILING', 'true' do
|
40
|
+
expect(subject.reject('example.com', 'reasons')).to eql('reasons')
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
context 'manipulating the domain list' do
|
46
|
+
context 'normalizing domains' do
|
47
|
+
let(:domains) { { 'test' => ['www.EXAMPLE.com/'] } }
|
48
|
+
|
49
|
+
before { subject.send :normalize_domains! }
|
50
|
+
|
51
|
+
it 'normalizes the domains' do
|
52
|
+
expect(domain_list.domains.first).to eql('example.com')
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
context 'removing invalid domains' do
|
57
|
+
let(:domains) { { 'test' => ['foo.github.io', 'example.com'] } }
|
58
|
+
|
59
|
+
before { subject.send :ensure_validity! }
|
60
|
+
|
61
|
+
it 'removes invalid domains' do
|
62
|
+
expect(domain_list.count).to be(1)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
context 'with the current list stubbed' do
|
68
|
+
let(:stubbed_list) { Gman::DomainList.new(path: stubbed_list_path) }
|
69
|
+
let(:stubbed_file_contents) { File.read(stubbed_list_path) }
|
70
|
+
|
71
|
+
before { subject.instance_variable_set '@current', stubbed_list }
|
72
|
+
|
73
|
+
context 'writing' do
|
74
|
+
before { @current = subject.current.to_s }
|
75
|
+
|
76
|
+
before { subject.send :add_to_current }
|
77
|
+
|
78
|
+
after { File.write(stubbed_list_path, @current) }
|
79
|
+
|
80
|
+
context 'adding domains' do
|
81
|
+
let(:domains) do
|
82
|
+
{ 'test' => ['example.com'], 'test2' => ['github.com'] }
|
83
|
+
end
|
84
|
+
|
85
|
+
it 'adds the domains' do
|
86
|
+
expected = "// test\nexample.com\n\n// test2\ngithub.com"
|
87
|
+
expect(stubbed_file_contents).to match(expected)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
context 'importing' do
|
92
|
+
let(:domains) do
|
93
|
+
{
|
94
|
+
'test' => ['www.example.com', 'foo.github.io'],
|
95
|
+
'test2' => ['github.com', 'www.github.com', 'whitehouse.gov']
|
96
|
+
}
|
97
|
+
end
|
98
|
+
|
99
|
+
before { subject.import(skip_resolve: true) }
|
100
|
+
|
101
|
+
it 'imports' do
|
102
|
+
expected = "// test\nexample.com\nfoo.github.io"
|
103
|
+
expect(stubbed_file_contents).to match(expected)
|
104
|
+
|
105
|
+
expected = "// test2\ngithub.com\nwhitehouse.gov"
|
106
|
+
expect(stubbed_file_contents).to match(expected)
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
context 'domain validation' do
|
113
|
+
let(:domain) { '' }
|
114
|
+
let(:valid?) { subject.send(:ensure_valid, domain) }
|
115
|
+
|
116
|
+
context 'a valid domain' do
|
117
|
+
let(:domain) { 'whitehouse.gov' }
|
118
|
+
|
119
|
+
it 'is valid' do
|
120
|
+
expect(valid?).to be(true)
|
121
|
+
end
|
122
|
+
end
|
123
|
+
|
124
|
+
{
|
125
|
+
empty: '',
|
126
|
+
blacklisted: 'egovlink.com',
|
127
|
+
invalid: 'foo.invalid',
|
128
|
+
academic: 'harvard.edu',
|
129
|
+
"rejex'd": 'foo.github.io'
|
130
|
+
}.each_key do |type|
|
131
|
+
context "a #{type} domain" do
|
132
|
+
it 'is invalid' do
|
133
|
+
expect(valid?).to be(false)
|
134
|
+
end
|
135
|
+
end
|
136
|
+
end
|
137
|
+
end
|
138
|
+
|
139
|
+
context 'duplicate domains' do
|
140
|
+
let(:dupe?) { subject.send(:dupe?, domain) }
|
141
|
+
let(:ensure_not_dupe) { subject.send(:ensure_not_dupe, domain) }
|
142
|
+
|
143
|
+
context 'a unique domain' do
|
144
|
+
let(:domain) { 'gman.com' }
|
145
|
+
|
146
|
+
it 'is not a dupe' do
|
147
|
+
expect(dupe?).to be_falsy
|
148
|
+
expect(ensure_not_dupe).to be_truthy
|
149
|
+
end
|
150
|
+
end
|
151
|
+
|
152
|
+
context 'a duplicate domain' do
|
153
|
+
let(:domain) { 'gov' }
|
154
|
+
|
155
|
+
it "knows it's a dupe" do
|
156
|
+
expect(dupe?).to be_truthy
|
157
|
+
expect(ensure_not_dupe).to be_falsy
|
158
|
+
end
|
159
|
+
|
160
|
+
context 'a subdomain' do
|
161
|
+
let(:domain) { 'whitehouse.gov' }
|
162
|
+
|
163
|
+
it "know when a domain's a subdomain of an existing domain" do
|
164
|
+
expect(dupe?).to be_truthy
|
165
|
+
expect(ensure_not_dupe).to be_falsy
|
166
|
+
end
|
167
|
+
end
|
168
|
+
end
|
169
|
+
end
|
170
|
+
|
171
|
+
context 'domain resolution' do
|
172
|
+
let(:resolves?) { subject.domain_resolves?(domain) }
|
173
|
+
let(:ensure_resolves) { subject.send(:ensure_resolves, domain) }
|
174
|
+
|
175
|
+
context 'a valid domain' do
|
176
|
+
let(:domain) { 'github.com' }
|
177
|
+
|
178
|
+
it 'resolves' do
|
179
|
+
expect(resolves?).to be_truthy
|
180
|
+
expect(ensure_resolves).to be_truthy
|
181
|
+
end
|
182
|
+
end
|
183
|
+
|
184
|
+
context 'an invalid domain' do
|
185
|
+
let(:domain) { 'foo.invalid' }
|
186
|
+
|
187
|
+
it "doesn't resolve" do
|
188
|
+
expect(resolves?).to be_falsy
|
189
|
+
expect(ensure_resolves).to be_falsy
|
190
|
+
end
|
191
|
+
end
|
192
|
+
end
|
193
|
+
|
194
|
+
context 'regex checks' do
|
195
|
+
let(:ensure_regex) { subject.send(:ensure_regex, domain) }
|
196
|
+
|
197
|
+
context 'valid domains' do
|
198
|
+
let(:domain) { 'example.com' }
|
199
|
+
|
200
|
+
it 'passes' do
|
201
|
+
expect(ensure_regex).to be_truthy
|
202
|
+
end
|
203
|
+
end
|
204
|
+
|
205
|
+
[
|
206
|
+
'home.example.com', 'site.example.com', 'user.example.com',
|
207
|
+
'foo.weebly.com', 'foo.wordpress.com', 'foo.govoffice.com',
|
208
|
+
'foo.govoffice1.com', 'foo.homestead.com', 'foo.wix.com',
|
209
|
+
'foo.blogspot.com', 'foo.tripod.com', 'foo.squarespace.com',
|
210
|
+
'foo.github.io', 'ci.champaign.il.us'
|
211
|
+
].each do |domain|
|
212
|
+
context "a #{domain} domain" do
|
213
|
+
let(:domain) { domain }
|
214
|
+
|
215
|
+
it 'rejects the domain' do
|
216
|
+
expect(ensure_regex).to be_falsy
|
217
|
+
end
|
218
|
+
end
|
219
|
+
end
|
220
|
+
end
|
221
|
+
|
222
|
+
context 'normalizing domains' do
|
223
|
+
let(:normalized_domain) { subject.normalize_domain(domain) }
|
224
|
+
|
225
|
+
[
|
226
|
+
'http://example.com', 'www.example.com', 'example.com/',
|
227
|
+
'example.com/foo', 'example.com/foo/', 'EXAMPLE.com'
|
228
|
+
].each do |domain|
|
229
|
+
let(:domain) { domain }
|
230
|
+
|
231
|
+
it 'normalizes the domain' do
|
232
|
+
expect(normalized_domain).to eql('example.com')
|
233
|
+
end
|
234
|
+
end
|
235
|
+
end
|
236
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Gman::Locality do
|
4
|
+
context 'valid domains' do
|
5
|
+
['foo.state.il.us', 'ci.foo.il.us'].each do |domain|
|
6
|
+
context "the #{domain} domain" do
|
7
|
+
it 'is valid' do
|
8
|
+
expect(described_class.valid?(domain)).to be(true)
|
9
|
+
end
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
context 'invalid domains' do
|
15
|
+
['state.foo.il.us', 'foo.ci.il.us',
|
16
|
+
'k12.il.us', 'ci.foo.zx.us'].each do |domain|
|
17
|
+
context "the #{domain} domain" do
|
18
|
+
it 'is invalid' do
|
19
|
+
expect(described_class.valid?(domain)).to be(false)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
data/spec/gman_spec.rb
ADDED
@@ -0,0 +1,74 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
RSpec.describe Gman do
|
4
|
+
context 'valid domains' do
|
5
|
+
['foo.gov', 'http://foo.mil', 'foo@bar.gc.ca', 'foo.gov.au',
|
6
|
+
'https://www.foo.gouv.fr', 'foo@ci.champaign.il.us',
|
7
|
+
'foo.bar.baz.gov.au', 'foo@bar.gov.uk', 'foo.gov',
|
8
|
+
'foo.fed.us', 'foo.state.il.us', 'state.il.us',
|
9
|
+
'foo@af.mil', 'foo.gov.in'].each do |domain|
|
10
|
+
subject { described_class.new(domain) }
|
11
|
+
|
12
|
+
it "knows #{domain.inspect} is valid government domain" do
|
13
|
+
expect(described_class.valid?(domain)).to be(true)
|
14
|
+
expect(subject.valid?).to be(true)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
context 'invalid domains' do
|
20
|
+
['foo.bar.com', 'bar@foo.biz', 'http://www.foo.biz',
|
21
|
+
'foo.uk', 'gov', 'foo@k12.champaign.il.us', 'foo@kii.gov.by',
|
22
|
+
'foo', '', nil, ' ', 'foo.city.il.us', 'foo.ci.il.us',
|
23
|
+
'foo.zx.us', 'foo@mail.gov.ua', 'foo@gwu.edu'].each do |domain|
|
24
|
+
subject { described_class.new(domain) }
|
25
|
+
|
26
|
+
it "knows #{domain.inspect} is not a valid government domain" do
|
27
|
+
expect(described_class.valid?(domain)).to be(false)
|
28
|
+
expect(subject.valid?).to be(false)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
context 'localities' do
|
34
|
+
subject { described_class.new(domain) }
|
35
|
+
|
36
|
+
context 'when given github.gov' do
|
37
|
+
let(:domain) { 'github.gov' }
|
38
|
+
|
39
|
+
it "knows it's not a locality" do
|
40
|
+
expect(subject.locality?).to be(false)
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
context 'when given foo.state.il.us' do
|
45
|
+
let(:domain) { 'foo.state.il.us' }
|
46
|
+
|
47
|
+
it "knows it's a locality" do
|
48
|
+
expect(subject.locality?).to be(true)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
context 'class methods' do
|
54
|
+
it 'returns the domain list' do
|
55
|
+
expect(described_class.list).to be_a(Gman::DomainList)
|
56
|
+
end
|
57
|
+
|
58
|
+
it 'returns the academic list' do
|
59
|
+
expect(described_class.academic_list).to be_a(Gman::DomainList)
|
60
|
+
end
|
61
|
+
|
62
|
+
it 'returns the config path' do
|
63
|
+
expect(Dir.exist?(described_class.config_path)).to be(true)
|
64
|
+
end
|
65
|
+
|
66
|
+
it 'returns the list path' do
|
67
|
+
expect(File.exist?(described_class.list_path)).to be(true)
|
68
|
+
end
|
69
|
+
|
70
|
+
it 'returns the academic list path' do
|
71
|
+
expect(File.exist?(described_class.academic_list_path)).to be(true)
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
data/spec/spec_helper.rb
ADDED
@@ -0,0 +1,31 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'parallel'
|
4
|
+
require 'open3'
|
5
|
+
|
6
|
+
RSpec.configure do |config|
|
7
|
+
config.example_status_persistence_file_path = 'spec/examples.txt'
|
8
|
+
config.disable_monkey_patching!
|
9
|
+
config.default_formatter = 'doc' if config.files_to_run.one?
|
10
|
+
config.order = :random
|
11
|
+
Kernel.srand config.seed
|
12
|
+
end
|
13
|
+
|
14
|
+
require_relative '../lib/gman'
|
15
|
+
require_relative '../lib/gman/domain_list'
|
16
|
+
require_relative '../lib/gman/importer'
|
17
|
+
|
18
|
+
def fixture_path(fixture)
|
19
|
+
File.expand_path "./fixtures/#{fixture}", File.dirname(__FILE__)
|
20
|
+
end
|
21
|
+
|
22
|
+
def stubbed_list_path
|
23
|
+
File.expand_path './fixtures/domains.txt', File.dirname(__FILE__)
|
24
|
+
end
|
25
|
+
|
26
|
+
def with_env(key, value)
|
27
|
+
old_env = ENV[key]
|
28
|
+
ENV[key] = value
|
29
|
+
yield
|
30
|
+
ENV[key] = old_env
|
31
|
+
end
|
metadata
CHANGED
@@ -1,183 +1,183 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: gman
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 7.0.
|
4
|
+
version: 7.0.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ben Balter
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-11-13 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
|
-
name:
|
14
|
+
name: colored
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: '
|
19
|
+
version: '1.2'
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - "~>"
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: '
|
26
|
+
version: '1.2'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
|
-
name:
|
28
|
+
name: iso_country_codes
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '
|
33
|
+
version: '0.6'
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '
|
40
|
+
version: '0.6'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
|
-
name:
|
42
|
+
name: naughty_or_nice
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- - "
|
45
|
+
- - ">="
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version:
|
47
|
+
version: 2.1.1
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- - "
|
52
|
+
- - ">="
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version:
|
54
|
+
version: 2.1.1
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
|
-
name:
|
56
|
+
name: public_suffix
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
|
-
- - "
|
59
|
+
- - ">="
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version: '
|
62
|
-
type: :
|
61
|
+
version: '3.0'
|
62
|
+
type: :runtime
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
|
-
- - "
|
66
|
+
- - ">="
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version: '
|
68
|
+
version: '3.0'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
|
-
name:
|
70
|
+
name: addressable
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
73
|
- - "~>"
|
74
74
|
- !ruby/object:Gem::Version
|
75
|
-
version: '
|
75
|
+
version: '2.3'
|
76
76
|
type: :development
|
77
77
|
prerelease: false
|
78
78
|
version_requirements: !ruby/object:Gem::Requirement
|
79
79
|
requirements:
|
80
80
|
- - "~>"
|
81
81
|
- !ruby/object:Gem::Version
|
82
|
-
version: '
|
82
|
+
version: '2.3'
|
83
83
|
- !ruby/object:Gem::Dependency
|
84
|
-
name:
|
84
|
+
name: mechanize
|
85
85
|
requirement: !ruby/object:Gem::Requirement
|
86
86
|
requirements:
|
87
87
|
- - "~>"
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: '
|
89
|
+
version: '2.7'
|
90
90
|
type: :development
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
94
|
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version: '
|
96
|
+
version: '2.7'
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
|
-
name:
|
98
|
+
name: parallel
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
100
100
|
requirements:
|
101
101
|
- - "~>"
|
102
102
|
- !ruby/object:Gem::Version
|
103
|
-
version: '
|
103
|
+
version: '1.6'
|
104
104
|
type: :development
|
105
105
|
prerelease: false
|
106
106
|
version_requirements: !ruby/object:Gem::Requirement
|
107
107
|
requirements:
|
108
108
|
- - "~>"
|
109
109
|
- !ruby/object:Gem::Version
|
110
|
-
version: '
|
110
|
+
version: '1.6'
|
111
111
|
- !ruby/object:Gem::Dependency
|
112
|
-
name:
|
112
|
+
name: pry
|
113
113
|
requirement: !ruby/object:Gem::Requirement
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
117
|
+
version: '0.10'
|
118
118
|
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version: '
|
124
|
+
version: '0.10'
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
|
-
name:
|
126
|
+
name: rspec
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|
128
128
|
requirements:
|
129
129
|
- - "~>"
|
130
130
|
- !ruby/object:Gem::Version
|
131
|
-
version: '
|
131
|
+
version: '3.5'
|
132
132
|
type: :development
|
133
133
|
prerelease: false
|
134
134
|
version_requirements: !ruby/object:Gem::Requirement
|
135
135
|
requirements:
|
136
136
|
- - "~>"
|
137
137
|
- !ruby/object:Gem::Version
|
138
|
-
version: '
|
138
|
+
version: '3.5'
|
139
139
|
- !ruby/object:Gem::Dependency
|
140
|
-
name:
|
140
|
+
name: rubocop
|
141
141
|
requirement: !ruby/object:Gem::Requirement
|
142
142
|
requirements:
|
143
143
|
- - "~>"
|
144
144
|
- !ruby/object:Gem::Version
|
145
|
-
version: '1.
|
145
|
+
version: '1.0'
|
146
146
|
type: :development
|
147
147
|
prerelease: false
|
148
148
|
version_requirements: !ruby/object:Gem::Requirement
|
149
149
|
requirements:
|
150
150
|
- - "~>"
|
151
151
|
- !ruby/object:Gem::Version
|
152
|
-
version: '1.
|
152
|
+
version: '1.0'
|
153
153
|
- !ruby/object:Gem::Dependency
|
154
|
-
name:
|
154
|
+
name: rubocop-performance
|
155
155
|
requirement: !ruby/object:Gem::Requirement
|
156
156
|
requirements:
|
157
157
|
- - "~>"
|
158
158
|
- !ruby/object:Gem::Version
|
159
|
-
version: '
|
159
|
+
version: '1.5'
|
160
160
|
type: :development
|
161
161
|
prerelease: false
|
162
162
|
version_requirements: !ruby/object:Gem::Requirement
|
163
163
|
requirements:
|
164
164
|
- - "~>"
|
165
165
|
- !ruby/object:Gem::Version
|
166
|
-
version: '
|
166
|
+
version: '1.5'
|
167
167
|
- !ruby/object:Gem::Dependency
|
168
|
-
name:
|
168
|
+
name: rubocop-rspec
|
169
169
|
requirement: !ruby/object:Gem::Requirement
|
170
170
|
requirements:
|
171
171
|
- - "~>"
|
172
172
|
- !ruby/object:Gem::Version
|
173
|
-
version: '2.
|
173
|
+
version: '2.0'
|
174
174
|
type: :development
|
175
175
|
prerelease: false
|
176
176
|
version_requirements: !ruby/object:Gem::Requirement
|
177
177
|
requirements:
|
178
178
|
- - "~>"
|
179
179
|
- !ruby/object:Gem::Version
|
180
|
-
version: '2.
|
180
|
+
version: '2.0'
|
181
181
|
- !ruby/object:Gem::Dependency
|
182
182
|
name: ruby-prof
|
183
183
|
requirement: !ruby/object:Gem::Requirement
|
@@ -193,19 +193,19 @@ dependencies:
|
|
193
193
|
- !ruby/object:Gem::Version
|
194
194
|
version: '0.15'
|
195
195
|
- !ruby/object:Gem::Dependency
|
196
|
-
name:
|
196
|
+
name: swot
|
197
197
|
requirement: !ruby/object:Gem::Requirement
|
198
198
|
requirements:
|
199
199
|
- - "~>"
|
200
200
|
- !ruby/object:Gem::Version
|
201
|
-
version: '0
|
201
|
+
version: '1.0'
|
202
202
|
type: :development
|
203
203
|
prerelease: false
|
204
204
|
version_requirements: !ruby/object:Gem::Requirement
|
205
205
|
requirements:
|
206
206
|
- - "~>"
|
207
207
|
- !ruby/object:Gem::Version
|
208
|
-
version: '0
|
208
|
+
version: '1.0'
|
209
209
|
description: |2
|
210
210
|
A ruby gem to check if the owner of a given email address is working for
|
211
211
|
THE MAN.
|
@@ -216,21 +216,33 @@ executables:
|
|
216
216
|
extensions: []
|
217
217
|
extra_rdoc_files: []
|
218
218
|
files:
|
219
|
+
- ".github/CODEOWNERS"
|
220
|
+
- ".github/ISSUE_TEMPLATE/bug_report.md"
|
221
|
+
- ".github/ISSUE_TEMPLATE/feature_request.md"
|
222
|
+
- ".github/config.yml"
|
223
|
+
- ".github/funding.yml"
|
224
|
+
- ".github/no-response.yml"
|
225
|
+
- ".github/release-drafter.yml"
|
226
|
+
- ".github/settings.yml"
|
227
|
+
- ".github/stale.yml"
|
219
228
|
- ".gitignore"
|
220
|
-
- ".
|
229
|
+
- ".rspec"
|
221
230
|
- ".rubocop.yml"
|
231
|
+
- ".rubocop_todo.yml"
|
222
232
|
- ".ruby-version"
|
223
233
|
- ".travis.yml"
|
224
|
-
- CONTRIBUTING.md
|
225
234
|
- Gemfile
|
226
235
|
- LICENSE
|
227
|
-
- README.md
|
228
|
-
- Rakefile
|
229
236
|
- bin/gman
|
230
237
|
- bin/gman_filter
|
231
238
|
- config/domains.txt
|
232
239
|
- config/vendor/academic.txt
|
233
240
|
- config/vendor/dotgovs.csv
|
241
|
+
- docs/CODE_OF_CONDUCT.md
|
242
|
+
- docs/CONTRIBUTING.md
|
243
|
+
- docs/README.md
|
244
|
+
- docs/SECURITY.md
|
245
|
+
- docs/_config.yml
|
234
246
|
- gman.gemspec
|
235
247
|
- lib/gman.rb
|
236
248
|
- lib/gman/country_codes.rb
|
@@ -258,23 +270,22 @@ files:
|
|
258
270
|
- script/vendor-se
|
259
271
|
- script/vendor-swot
|
260
272
|
- script/vendor-us
|
261
|
-
-
|
262
|
-
-
|
263
|
-
-
|
264
|
-
-
|
265
|
-
-
|
266
|
-
-
|
267
|
-
-
|
268
|
-
-
|
269
|
-
-
|
270
|
-
-
|
271
|
-
-
|
272
|
-
- test/test_gman_locality.rb
|
273
|
+
- spec/fixtures/domains.txt
|
274
|
+
- spec/fixtures/obama.txt
|
275
|
+
- spec/gman/bin_spec.rb
|
276
|
+
- spec/gman/country_code_spec.rb
|
277
|
+
- spec/gman/domain_list_spec.rb
|
278
|
+
- spec/gman/domains_spec.rb
|
279
|
+
- spec/gman/identifier_spec.rb
|
280
|
+
- spec/gman/importer_spec.rb
|
281
|
+
- spec/gman/locality_spec.rb
|
282
|
+
- spec/gman_spec.rb
|
283
|
+
- spec/spec_helper.rb
|
273
284
|
homepage: https://github.com/benbalter/gman
|
274
285
|
licenses:
|
275
286
|
- MIT
|
276
287
|
metadata: {}
|
277
|
-
post_install_message:
|
288
|
+
post_install_message:
|
278
289
|
rdoc_options: []
|
279
290
|
require_paths:
|
280
291
|
- lib
|
@@ -282,29 +293,26 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
282
293
|
requirements:
|
283
294
|
- - "~>"
|
284
295
|
- !ruby/object:Gem::Version
|
285
|
-
version: '2.
|
296
|
+
version: '2.5'
|
286
297
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
287
298
|
requirements:
|
288
299
|
- - ">="
|
289
300
|
- !ruby/object:Gem::Version
|
290
301
|
version: '0'
|
291
302
|
requirements: []
|
292
|
-
|
293
|
-
|
294
|
-
signing_key:
|
303
|
+
rubygems_version: 3.0.3
|
304
|
+
signing_key:
|
295
305
|
specification_version: 4
|
296
306
|
summary: Check if a given domain or email address belong to a governemnt entity
|
297
307
|
test_files:
|
298
|
-
-
|
299
|
-
-
|
300
|
-
-
|
301
|
-
-
|
302
|
-
-
|
303
|
-
-
|
304
|
-
-
|
305
|
-
-
|
306
|
-
-
|
307
|
-
-
|
308
|
-
-
|
309
|
-
- test/test_gman_locality.rb
|
310
|
-
has_rdoc:
|
308
|
+
- spec/fixtures/domains.txt
|
309
|
+
- spec/fixtures/obama.txt
|
310
|
+
- spec/gman/bin_spec.rb
|
311
|
+
- spec/gman/country_code_spec.rb
|
312
|
+
- spec/gman/domain_list_spec.rb
|
313
|
+
- spec/gman/domains_spec.rb
|
314
|
+
- spec/gman/identifier_spec.rb
|
315
|
+
- spec/gman/importer_spec.rb
|
316
|
+
- spec/gman/locality_spec.rb
|
317
|
+
- spec/gman_spec.rb
|
318
|
+
- spec/spec_helper.rb
|