emailhunter 0.8.1 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +1 -2
- data/bin/console +3 -3
- data/emailhunter.gemspec +17 -19
- data/lib/email_hunter/account.rb +8 -6
- data/lib/email_hunter/api.rb +10 -8
- data/lib/email_hunter/count.rb +10 -9
- data/lib/email_hunter/exist.rb +11 -8
- data/lib/email_hunter/finder.rb +11 -8
- data/lib/email_hunter/search.rb +19 -11
- data/lib/email_hunter/verify.rb +12 -8
- data/lib/email_hunter/version.rb +3 -1
- data/lib/email_hunter.rb +3 -1
- metadata +14 -14
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: aa2d9e9cc40ed470a2704f6cb875ade4b23bfb3f256ea535fc9ec772aa6d36f7
|
4
|
+
data.tar.gz: b16e0822b7b5362ac3ce01435467db482dd867d97abd9a394b40394c7f67989a
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 119c49c0e20229684a533a5bd000c33b5ba7470d2bc0ddcb075bfab48b705b1f0fe84e59227e2ed621c4ec27b335328189d7920b9db80037a5ad674864f94c22
|
7
|
+
data.tar.gz: 1de4508d1b3289004fe3a5603e48c2f03ce1b5cd4334c6a2b2efcf846e52a4f9966a2224639a342d790f0bd05b1adbcb5e322358567cae8d979930e526d7f6f4
|
data/Rakefile
CHANGED
@@ -1,2 +1 @@
|
|
1
|
-
require
|
2
|
-
|
1
|
+
require 'bundler/gem_tasks'
|
data/bin/console
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
#!/usr/bin/env ruby
|
2
2
|
|
3
|
-
require
|
4
|
-
require
|
3
|
+
require 'bundler/setup'
|
4
|
+
require 'emailhunter'
|
5
5
|
|
6
6
|
# You can add fixtures and/or initialization code here to make experimenting
|
7
7
|
# with your gem easier. You can also use a different console, if you like.
|
@@ -10,5 +10,5 @@ require "emailhunter"
|
|
10
10
|
# require "pry"
|
11
11
|
# Pry.start
|
12
12
|
|
13
|
-
require
|
13
|
+
require 'irb'
|
14
14
|
IRB.start
|
data/emailhunter.gemspec
CHANGED
@@ -1,32 +1,30 @@
|
|
1
|
-
|
2
|
-
lib = File.expand_path('../lib', __FILE__)
|
1
|
+
lib = File.expand_path('lib', __dir__)
|
3
2
|
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
|
-
require File.expand_path('
|
3
|
+
require File.expand_path('lib/email_hunter/version', __dir__)
|
5
4
|
|
6
5
|
Gem::Specification.new do |spec|
|
7
|
-
spec.name =
|
6
|
+
spec.name = 'emailhunter'
|
8
7
|
spec.version = EmailHunter::VERSION
|
9
|
-
spec.authors = [
|
10
|
-
spec.email = [
|
8
|
+
spec.authors = ['Davide Santangelo']
|
9
|
+
spec.email = ['davide.santangelo@gmail.com']
|
11
10
|
|
12
|
-
|
13
|
-
spec.
|
14
|
-
spec.
|
15
|
-
spec.license = "MIT"
|
11
|
+
spec.summary = 'A tiny ruby wrapper around Hunter.io API '
|
12
|
+
spec.description = 'A tiny ruby wrapper around Hunter.io API. Hunter.io helps sales people reach their targets and increase their sales. '
|
13
|
+
spec.license = 'MIT'
|
16
14
|
|
17
15
|
spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
|
18
|
-
spec.bindir =
|
16
|
+
spec.bindir = 'exe'
|
19
17
|
spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
20
|
-
spec.require_paths = [
|
18
|
+
spec.require_paths = ['lib']
|
21
19
|
|
22
|
-
spec.add_development_dependency
|
23
|
-
spec.add_development_dependency
|
20
|
+
spec.add_development_dependency 'bundler', '~> 2.1'
|
21
|
+
spec.add_development_dependency 'rake', '~> 10.0'
|
24
22
|
spec.add_development_dependency 'rspec'
|
25
|
-
spec.add_development_dependency
|
26
|
-
spec.add_development_dependency
|
23
|
+
spec.add_development_dependency 'typhoeus'
|
24
|
+
spec.add_development_dependency 'vcr'
|
27
25
|
|
28
|
-
spec.required_ruby_version =
|
26
|
+
spec.required_ruby_version = '>= 1.9.3'
|
29
27
|
|
30
|
-
spec.add_dependency
|
31
|
-
spec.add_dependency
|
28
|
+
spec.add_dependency 'faraday'
|
29
|
+
spec.add_dependency 'json'
|
32
30
|
end
|
data/lib/email_hunter/account.rb
CHANGED
@@ -1,11 +1,14 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'faraday'
|
2
4
|
require 'json'
|
3
5
|
|
4
|
-
|
6
|
+
API_ACCOUNT_URL = 'https://api.hunter.io/v2/account?'
|
5
7
|
|
6
8
|
module EmailHunter
|
7
9
|
class Account
|
8
|
-
attr_reader :result, :first_name, :last_name, :email, :plan_name, :plan_level, :reset_date, :team_id, :calls
|
10
|
+
attr_reader :result, :first_name, :last_name, :email, :plan_name, :plan_level, :reset_date, :team_id, :calls,
|
11
|
+
:requests
|
9
12
|
|
10
13
|
def initialize(key)
|
11
14
|
@key = key
|
@@ -19,9 +22,8 @@ module EmailHunter
|
|
19
22
|
private
|
20
23
|
|
21
24
|
def apiresponse
|
22
|
-
|
23
|
-
response
|
24
|
-
response.success? ? JSON.parse(response.body, {symbolize_names: true}) : []
|
25
|
+
response = Faraday.new("#{API_ACCOUNT_URL}&api_key=#{@key}").get
|
26
|
+
response.success? ? JSON.parse(response.body, { symbolize_names: true }) : []
|
25
27
|
end
|
26
28
|
end
|
27
|
-
end
|
29
|
+
end
|
data/lib/email_hunter/api.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'uri'
|
2
4
|
|
3
5
|
require File.expand_path(File.join(File.dirname(__FILE__), 'exist'))
|
@@ -11,28 +13,28 @@ module EmailHunter
|
|
11
13
|
class Api
|
12
14
|
attr_reader :key
|
13
15
|
|
14
|
-
|
15
|
-
|
16
|
-
|
16
|
+
def initialize(key)
|
17
|
+
@key = key
|
18
|
+
end
|
17
19
|
|
18
20
|
# Domain search API
|
19
21
|
def search(domain, params = {})
|
20
|
-
EmailHunter::Search.new(domain,
|
22
|
+
EmailHunter::Search.new(domain, key, params).hunt
|
21
23
|
end
|
22
24
|
|
23
25
|
# Email exist API
|
24
26
|
def exist(email)
|
25
|
-
EmailHunter::Exist.new(email,
|
27
|
+
EmailHunter::Exist.new(email, key).hunt
|
26
28
|
end
|
27
29
|
|
28
30
|
# Email verify API
|
29
31
|
def verify(email)
|
30
|
-
EmailHunter::Verify.new(email,
|
32
|
+
EmailHunter::Verify.new(email, key).hunt
|
31
33
|
end
|
32
34
|
|
33
35
|
# Email Finder API
|
34
36
|
def finder(domain, first_name, last_name)
|
35
|
-
EmailHunter::Finder.new(domain, first_name, last_name,
|
37
|
+
EmailHunter::Finder.new(domain, first_name, last_name, key).hunt
|
36
38
|
end
|
37
39
|
|
38
40
|
# Email Count API
|
@@ -42,7 +44,7 @@ module EmailHunter
|
|
42
44
|
|
43
45
|
# Account Information API
|
44
46
|
def account
|
45
|
-
EmailHunter::Account.new(
|
47
|
+
EmailHunter::Account.new(key).hunt
|
46
48
|
end
|
47
49
|
end
|
48
50
|
end
|
data/lib/email_hunter/count.rb
CHANGED
@@ -1,27 +1,28 @@
|
|
1
1
|
require 'faraday'
|
2
2
|
require 'json'
|
3
3
|
|
4
|
-
API_COUNT_URL = 'https://api.hunter.io/v2/email-count?'
|
4
|
+
API_COUNT_URL = 'https://api.hunter.io/v2/email-count?'.freeze
|
5
5
|
|
6
6
|
module EmailHunter
|
7
7
|
class Count
|
8
|
-
attr_reader :data, :meta
|
8
|
+
attr_reader :data, :meta, :domain
|
9
9
|
|
10
10
|
def initialize(domain)
|
11
11
|
@domain = domain
|
12
12
|
end
|
13
13
|
|
14
14
|
def hunt
|
15
|
-
|
16
|
-
Struct.new(*response.keys).new(*response.values) unless response.empty?
|
15
|
+
Struct.new(*data.keys).new(*data.values)
|
17
16
|
end
|
18
17
|
|
19
|
-
private
|
20
|
-
|
21
18
|
def apiresponse
|
22
|
-
|
23
|
-
|
24
|
-
|
19
|
+
@data ||= begin
|
20
|
+
response = Faraday.new("#{API_COUNT_URL}domain=#{domain}").get
|
21
|
+
|
22
|
+
return [] unless response.success?
|
23
|
+
|
24
|
+
JSON.parse(response.body, { symbolize_names: true })
|
25
|
+
end
|
25
26
|
end
|
26
27
|
end
|
27
28
|
end
|
data/lib/email_hunter/exist.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'faraday'
|
2
4
|
require 'json'
|
3
5
|
|
@@ -5,7 +7,7 @@ API_EXIST_URL = 'https://api.emailhunter.co/v1/exist?'
|
|
5
7
|
|
6
8
|
module EmailHunter
|
7
9
|
class Exist
|
8
|
-
attr_reader :status, :email, :exist, :sources
|
10
|
+
attr_reader :status, :email, :exist, :sources, :key
|
9
11
|
|
10
12
|
def initialize(email, key)
|
11
13
|
@email = email
|
@@ -13,16 +15,17 @@ module EmailHunter
|
|
13
15
|
end
|
14
16
|
|
15
17
|
def hunt
|
16
|
-
|
17
|
-
Struct.new(*response.keys).new(*response.values) unless response.empty?
|
18
|
+
Struct.new(*data.keys).new(*data.values)
|
18
19
|
end
|
19
20
|
|
20
|
-
|
21
|
+
def data
|
22
|
+
@data ||= begin
|
23
|
+
response = Faraday.new("#{API_EXIST_URL}email=#{email}&api_key=#{key}").get
|
24
|
+
|
25
|
+
return {} unless response.success?
|
21
26
|
|
22
|
-
|
23
|
-
|
24
|
-
response = Faraday.new(url).get
|
25
|
-
response.success? ? JSON.parse(response.body, {symbolize_names: true}) : []
|
27
|
+
JSON.parse(response.body, { symbolize_names: true })
|
28
|
+
end
|
26
29
|
end
|
27
30
|
end
|
28
31
|
end
|
data/lib/email_hunter/finder.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'faraday'
|
2
4
|
require 'json'
|
3
5
|
|
@@ -5,7 +7,7 @@ API_FINDER_URL = 'https://api.hunter.io/v2/email-finder?'
|
|
5
7
|
|
6
8
|
module EmailHunter
|
7
9
|
class Finder
|
8
|
-
attr_reader :email, :score, :sources, :domain, :meta
|
10
|
+
attr_reader :email, :score, :sources, :domain, :meta, :key, :first_name, :last_name
|
9
11
|
|
10
12
|
def initialize(domain, first_name, last_name, key)
|
11
13
|
@domain = domain
|
@@ -15,16 +17,17 @@ module EmailHunter
|
|
15
17
|
end
|
16
18
|
|
17
19
|
def hunt
|
18
|
-
|
19
|
-
Struct.new(*response.keys).new(*response.values) unless response.empty?
|
20
|
+
Struct.new(*data.keys).new(*data.values)
|
20
21
|
end
|
21
22
|
|
22
|
-
|
23
|
+
def data
|
24
|
+
@data ||= begin
|
25
|
+
response = Faraday.new("#{API_FINDER_URL}domain=#{domain}&first_name=#{first_name}&last_name=#{last_name}&api_key=#{key}").get
|
26
|
+
|
27
|
+
return [] unless response.success?
|
23
28
|
|
24
|
-
|
25
|
-
|
26
|
-
response = Faraday.new(url).get
|
27
|
-
response.success? ? JSON.parse(response.body, {symbolize_names: true}) : []
|
29
|
+
JSON.parse(response.body, { symbolize_names: true })
|
30
|
+
end
|
28
31
|
end
|
29
32
|
end
|
30
33
|
end
|
data/lib/email_hunter/search.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'faraday'
|
2
4
|
require 'json'
|
3
5
|
|
@@ -5,7 +7,7 @@ API_SEARCH_URL = 'https://api.hunter.io/v2/domain-search?'
|
|
5
7
|
|
6
8
|
module EmailHunter
|
7
9
|
class Search
|
8
|
-
attr_reader :meta, :webmail, :emails, :pattern, :domain
|
10
|
+
attr_reader :meta, :webmail, :emails, :pattern, :domain, :params, :key
|
9
11
|
|
10
12
|
def initialize(domain, key, params = {})
|
11
13
|
@domain = domain
|
@@ -14,19 +16,25 @@ module EmailHunter
|
|
14
16
|
end
|
15
17
|
|
16
18
|
def hunt
|
17
|
-
|
18
|
-
|
19
|
+
Struct.new(*data.keys).new(*data.values)
|
20
|
+
end
|
21
|
+
|
22
|
+
def limit
|
23
|
+
params[:limit] || 10
|
19
24
|
end
|
20
25
|
|
21
|
-
|
26
|
+
def offset
|
27
|
+
params[:offset] || 0
|
28
|
+
end
|
29
|
+
|
30
|
+
def data
|
31
|
+
@data ||= begin
|
32
|
+
response = Faraday.new("#{API_SEARCH_URL}domain=#{domain}&api_key=#{key}&type=#{params[:type]}&offset=#{offset}&limit=#{limit}").get
|
33
|
+
|
34
|
+
return {} unless response.success?
|
22
35
|
|
23
|
-
|
24
|
-
|
25
|
-
URI.parse(URI.encode(
|
26
|
-
"#{API_SEARCH_URL}domain=#{@domain}&api_key=#{@key}&type=#{@params[:type]}&offset=#{@params[:offset]}")
|
27
|
-
)
|
28
|
-
response = Faraday.new(url).get
|
29
|
-
response.success? ? JSON.parse(response.body, {symbolize_names: true}) : []
|
36
|
+
JSON.parse(response.body, { symbolize_names: true })
|
37
|
+
end
|
30
38
|
end
|
31
39
|
end
|
32
40
|
end
|
data/lib/email_hunter/verify.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require 'faraday'
|
2
4
|
require 'json'
|
3
5
|
|
@@ -5,7 +7,8 @@ API_VERIFY_URL = 'https://api.hunter.io/v2/email-verifier?'
|
|
5
7
|
|
6
8
|
module EmailHunter
|
7
9
|
class Verify
|
8
|
-
attr_reader :result, :score, :regexp, :gibberish, :disposable, :webmail, :mx_records, :smtp_server, :smtp_check,
|
10
|
+
attr_reader :result, :score, :regexp, :gibberish, :disposable, :webmail, :mx_records, :smtp_server, :smtp_check,
|
11
|
+
:accept_all, :sources, :meta, :key, :email
|
9
12
|
|
10
13
|
def initialize(email, key)
|
11
14
|
@email = email
|
@@ -13,16 +16,17 @@ module EmailHunter
|
|
13
16
|
end
|
14
17
|
|
15
18
|
def hunt
|
16
|
-
|
17
|
-
Struct.new(*response.keys).new(*response.values) unless response.empty?
|
19
|
+
Struct.new(*data.keys).new(*data.values)
|
18
20
|
end
|
19
21
|
|
20
|
-
|
22
|
+
def data
|
23
|
+
@data ||= begin
|
24
|
+
response = Faraday.new("#{API_VERIFY_URL}email=#{email}&api_key=#{key}").get
|
25
|
+
|
26
|
+
return [] unless response.success?
|
21
27
|
|
22
|
-
|
23
|
-
|
24
|
-
response = Faraday.new(url).get
|
25
|
-
response.success? ? JSON.parse(response.body, {symbolize_names: true}) : []
|
28
|
+
JSON.parse(response.body, { symbolize_names: true })
|
29
|
+
end
|
26
30
|
end
|
27
31
|
end
|
28
32
|
end
|
data/lib/email_hunter/version.rb
CHANGED
data/lib/email_hunter.rb
CHANGED
@@ -1,8 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require File.expand_path(File.join(File.dirname(__FILE__), 'email_hunter/api'))
|
2
4
|
require File.expand_path(File.join(File.dirname(__FILE__), 'email_hunter/version'))
|
3
5
|
|
4
6
|
module EmailHunter
|
5
|
-
|
7
|
+
module_function
|
6
8
|
|
7
9
|
def new(key)
|
8
10
|
Api.new(key)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: emailhunter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 1.0.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Davide Santangelo
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2022-08-24 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -16,14 +16,14 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: '1
|
19
|
+
version: '2.1'
|
20
20
|
type: :development
|
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: '1
|
26
|
+
version: '2.1'
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -53,7 +53,7 @@ dependencies:
|
|
53
53
|
- !ruby/object:Gem::Version
|
54
54
|
version: '0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
|
-
name:
|
56
|
+
name: typhoeus
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
59
|
- - ">="
|
@@ -67,7 +67,7 @@ dependencies:
|
|
67
67
|
- !ruby/object:Gem::Version
|
68
68
|
version: '0'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
|
-
name:
|
70
|
+
name: vcr
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
73
|
- - ">="
|
@@ -108,8 +108,8 @@ dependencies:
|
|
108
108
|
- - ">="
|
109
109
|
- !ruby/object:Gem::Version
|
110
110
|
version: '0'
|
111
|
-
description: 'A tiny ruby wrapper around
|
112
|
-
|
111
|
+
description: 'A tiny ruby wrapper around Hunter.io API. Hunter.io helps sales people
|
112
|
+
reach their targets and increase their sales. '
|
113
113
|
email:
|
114
114
|
- davide.santangelo@gmail.com
|
115
115
|
executables: []
|
@@ -137,11 +137,11 @@ files:
|
|
137
137
|
- lib/email_hunter/verify.rb
|
138
138
|
- lib/email_hunter/version.rb
|
139
139
|
- lib/emailhunter.rb
|
140
|
-
homepage:
|
140
|
+
homepage:
|
141
141
|
licenses:
|
142
142
|
- MIT
|
143
143
|
metadata: {}
|
144
|
-
post_install_message:
|
144
|
+
post_install_message:
|
145
145
|
rdoc_options: []
|
146
146
|
require_paths:
|
147
147
|
- lib
|
@@ -156,8 +156,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
156
156
|
- !ruby/object:Gem::Version
|
157
157
|
version: '0'
|
158
158
|
requirements: []
|
159
|
-
rubygems_version: 3.
|
160
|
-
signing_key:
|
159
|
+
rubygems_version: 3.2.3
|
160
|
+
signing_key:
|
161
161
|
specification_version: 4
|
162
|
-
summary: A tiny ruby wrapper around
|
162
|
+
summary: A tiny ruby wrapper around Hunter.io API
|
163
163
|
test_files: []
|