get_address 0.1.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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 687f37a76cdb66c01e10b6df9161b9bbfbf50fcb
4
+ data.tar.gz: e43589a7468adeceb20ae80b884596cda0170181
5
+ SHA512:
6
+ metadata.gz: 901d7b19a0f9dfdd64f6d441c525c9d2a70b9e59d3d31fd050c8fa3eab0ac7f0d73c347d7c2b52ac593b0ad1e28b99e826842d0a117963f4a1ebc04abf23117a
7
+ data.tar.gz: 7f2097df7e7810c18c4acc089d4ff9a63522c27579aec7e7f5a6e9dbb7975482bc143d2a4834cb2f7d5280bac13fd780ed7a431b504e087fcc8a93069d8bdf29
@@ -0,0 +1,14 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /_yardoc/
4
+ /coverage/
5
+ /doc/
6
+ /pkg/
7
+ /spec/reports/
8
+ /tmp/
9
+
10
+ # rspec failure tracking
11
+ .rspec_status
12
+ *.gem
13
+ .idea
14
+ Gemfile.lock
data/.rspec ADDED
@@ -0,0 +1,3 @@
1
+ --format documentation
2
+ --color
3
+ --require spec_helper
@@ -0,0 +1,7 @@
1
+ ---
2
+ sudo: false
3
+ language: ruby
4
+ cache: bundler
5
+ rvm:
6
+ - 2.2.6
7
+ before_install: gem install bundler -v 1.16.3
data/Gemfile ADDED
@@ -0,0 +1,6 @@
1
+ source "https://rubygems.org"
2
+
3
+ git_source(:github) {|repo_name| "https://github.com/#{repo_name}" }
4
+
5
+ # Specify your gem's dependencies in get_address.gemspec
6
+ gemspec
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2018 CorsaiR
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,58 @@
1
+ # GetAddress Ruby Library
2
+
3
+ A ruby wrapper for [getaddress.io](https://getaddress.io/) API.
4
+
5
+ ## Installation
6
+
7
+ Add this line to your application's Gemfile:
8
+
9
+ ```ruby
10
+ gem 'get_address'
11
+ ```
12
+
13
+ And then execute:
14
+
15
+ $ bundle
16
+
17
+ Or install it yourself as:
18
+
19
+ $ gem install get_address
20
+
21
+ ## Usage
22
+ ```ruby
23
+ GetAddress.get_address postcode, house, options
24
+ ```
25
+
26
+ **Arguments**
27
+
28
+ - `postcode` (string). The postcode you want to find.
29
+ - `house` (string, optional). House name/number.
30
+ - `options` (hash, optional).
31
+ - `sort` (boolean). Numerically sorts the addresses.
32
+
33
+ **Returns**
34
+
35
+ Returns a list of addresses for a postcode.
36
+
37
+ **Example**
38
+
39
+ ```ruby
40
+ GetAddress.api_key = 'getaddress_api_key'
41
+
42
+ addresses = GetAddress.get_address 'XX2 00X'
43
+ addresses.each do |address|
44
+ puts "Line 1: #{address.line1}"
45
+ puts "Line 2: #{address.line2}"
46
+ puts "Line 3: #{address.line3}"
47
+ puts "Town/City: #{address.city}"
48
+ puts "County: #{address.county}"
49
+ end
50
+ ```
51
+
52
+ ## Contributing
53
+
54
+ Bug reports and pull requests are welcome on GitHub at https://github.com/elCorsaiR/get_address.
55
+
56
+ ## License
57
+
58
+ The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
@@ -0,0 +1,6 @@
1
+ require "bundler/gem_tasks"
2
+ require "rspec/core/rake_task"
3
+
4
+ RSpec::Core::RakeTask.new(:spec)
5
+
6
+ task :default => :spec
@@ -0,0 +1,32 @@
1
+ lib = File.expand_path('../lib', __FILE__)
2
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
3
+ require 'get_address/version'
4
+
5
+ Gem::Specification.new do |spec|
6
+ spec.name = "get_address"
7
+ spec.version = GetAddress::VERSION
8
+ spec.authors = ['CorsaiR']
9
+ spec.email = ['alezander82@mail.ru']
10
+
11
+ spec.summary = 'Wrapper for the getaddress.io API'
12
+ spec.description = 'A simple API for finding postal addresses'
13
+ spec.homepage = 'http://rubygems.org/gems/get_address'
14
+ spec.license = 'MIT'
15
+
16
+ # Specify which files should be added to the gem when it is released.
17
+ # The `git ls-files -z` loads the files in the RubyGem that have been added into git.
18
+ spec.files = Dir.chdir(File.expand_path('..', __FILE__)) do
19
+ `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
20
+ end
21
+
22
+ spec.require_paths = ['lib']
23
+
24
+ spec.add_dependency 'rest-client', '>= 1.8', '< 3.0'
25
+ spec.add_dependency 'virtus', '~> 1.0', '>= 1.0.5'
26
+
27
+ spec.add_development_dependency 'bundler', '~> 1.16'
28
+ spec.add_development_dependency 'rake', '~> 10.0'
29
+ spec.add_development_dependency 'rspec', '~> 3.0'
30
+ spec.add_development_dependency 'vcr', '~> 2.9'
31
+ spec.add_development_dependency 'webmock', '~> 2.3', '>= 2.3.1'
32
+ end
@@ -0,0 +1,98 @@
1
+ require 'uri'
2
+ require 'cgi'
3
+ require 'rest-client'
4
+ require 'json'
5
+
6
+ require 'get_address/version'
7
+ require 'get_address/errors'
8
+ require 'get_address/utils'
9
+ require 'get_address/address'
10
+
11
+ module GetAddress
12
+ @endpoint = 'https://api.getAddress.io'
13
+
14
+ class << self
15
+ attr_accessor :api_key, :endpoint
16
+ end
17
+
18
+
19
+ def self.get_address(postcode, house = '', options = {})
20
+ path = Utils.present?(house) ? "find/#{postcode}/#{house}" : "find/#{postcode}"
21
+ query = options[:sort].nil? ? {} : { sort: options[:sort] }
22
+ GetAddress.request :get, path, query
23
+ rescue ResourceNotFoundError => error
24
+ []
25
+ end
26
+
27
+ private
28
+
29
+ def self.request(method, path, params = {})
30
+ unless @api_key
31
+ raise AuthenticationError.new('No API Key provided')
32
+ end
33
+
34
+ url = URI.parse(resource_url(path))
35
+
36
+ params.merge!({ 'api-key' => @api_key, 'format' => true })
37
+ url.query = Utils.escape_params(params)
38
+
39
+ request_options = {
40
+ method: method,
41
+ url: url.to_s
42
+ }
43
+
44
+ begin
45
+ response = RestClient::Request.execute(request_options)
46
+ rescue RestClient::ExceptionWithResponse => error
47
+ if (code = error.http_code) && (body = error.http_body)
48
+ handle_rest_error(code, body)
49
+ else
50
+ handle_error(error)
51
+ end
52
+ rescue RestClient::Exception, Errno::ECONNREFUSED => error
53
+ handle_error(error)
54
+ end
55
+
56
+ process response.body
57
+ end
58
+
59
+ def self.resource_url(path = '')
60
+ URI.escape "#{@endpoint}/#{path}"
61
+ end
62
+
63
+ def self.handle_rest_error(http_code, http_body)
64
+ error = parse http_body
65
+ message = error['Message']
66
+
67
+ case http_code
68
+ when 401
69
+ raise AuthenticationError.new message, http_code
70
+ when 404
71
+ raise ResourceNotFoundError.new message, http_code
72
+ else
73
+ raise GetAddressError.new message, http_code
74
+ end
75
+ end
76
+
77
+ def self.process(response)
78
+ response_hash = parse response
79
+
80
+ latitude = response_hash['latitude']
81
+ longitude = response_hash['longitude']
82
+ response_hash['addresses'].map do |addr_hash|
83
+ Address.new line1: addr_hash[0], line2: addr_hash[1], line3: addr_hash[2], city: addr_hash[3],
84
+ county: addr_hash[4], latitude: latitude, longitude: longitude
85
+ end
86
+ end
87
+
88
+ def self.parse(response)
89
+ JSON.parse(response)
90
+ rescue JSON::ParserError => e
91
+ raise handle_error(e)
92
+ end
93
+
94
+ def self.handle_error(error)
95
+ raise GetAddressError.new("An unexpected error occurred: #{error.message})")
96
+ end
97
+
98
+ end
@@ -0,0 +1,15 @@
1
+ require 'virtus'
2
+
3
+ module GetAddress
4
+ class Address
5
+ include Virtus.model
6
+
7
+ attribute :line1, String
8
+ attribute :line2, String
9
+ attribute :line3, String
10
+ attribute :city, String
11
+ attribute :county, String
12
+ attribute :latitude, Float
13
+ attribute :longitude, Float
14
+ end
15
+ end
@@ -0,0 +1,18 @@
1
+ module GetAddress
2
+ class GetAddressError < StandardError
3
+ attr_reader :message
4
+ attr_reader :code
5
+
6
+ def initialize(message = nil, code = nil)
7
+ @message = message
8
+ @code = code
9
+ end
10
+
11
+ def to_s
12
+ "#{code}: #{message}"
13
+ end
14
+ end
15
+
16
+ class AuthenticationError < GetAddressError; end
17
+ class ResourceNotFoundError < GetAddressError; end
18
+ end
@@ -0,0 +1,16 @@
1
+ module GetAddress
2
+ class Utils
3
+
4
+ def self.escape_params(hash)
5
+ result = []
6
+ hash.each do |key, value|
7
+ result.push "#{CGI.escape(key.to_s)}=#{CGI.escape(value.to_s)}"
8
+ end
9
+ result.join('&')
10
+ end
11
+
12
+ def self.present?(param)
13
+ param.respond_to?(:empty?) ? !param.empty? : !param.nil?
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,3 @@
1
+ module GetAddress
2
+ VERSION = '0.1.1'
3
+ end
metadata ADDED
@@ -0,0 +1,173 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: get_address
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.1
5
+ platform: ruby
6
+ authors:
7
+ - CorsaiR
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-10-09 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rest-client
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '1.8'
20
+ - - "<"
21
+ - !ruby/object:Gem::Version
22
+ version: '3.0'
23
+ type: :runtime
24
+ prerelease: false
25
+ version_requirements: !ruby/object:Gem::Requirement
26
+ requirements:
27
+ - - ">="
28
+ - !ruby/object:Gem::Version
29
+ version: '1.8'
30
+ - - "<"
31
+ - !ruby/object:Gem::Version
32
+ version: '3.0'
33
+ - !ruby/object:Gem::Dependency
34
+ name: virtus
35
+ requirement: !ruby/object:Gem::Requirement
36
+ requirements:
37
+ - - "~>"
38
+ - !ruby/object:Gem::Version
39
+ version: '1.0'
40
+ - - ">="
41
+ - !ruby/object:Gem::Version
42
+ version: 1.0.5
43
+ type: :runtime
44
+ prerelease: false
45
+ version_requirements: !ruby/object:Gem::Requirement
46
+ requirements:
47
+ - - "~>"
48
+ - !ruby/object:Gem::Version
49
+ version: '1.0'
50
+ - - ">="
51
+ - !ruby/object:Gem::Version
52
+ version: 1.0.5
53
+ - !ruby/object:Gem::Dependency
54
+ name: bundler
55
+ requirement: !ruby/object:Gem::Requirement
56
+ requirements:
57
+ - - "~>"
58
+ - !ruby/object:Gem::Version
59
+ version: '1.16'
60
+ type: :development
61
+ prerelease: false
62
+ version_requirements: !ruby/object:Gem::Requirement
63
+ requirements:
64
+ - - "~>"
65
+ - !ruby/object:Gem::Version
66
+ version: '1.16'
67
+ - !ruby/object:Gem::Dependency
68
+ name: rake
69
+ requirement: !ruby/object:Gem::Requirement
70
+ requirements:
71
+ - - "~>"
72
+ - !ruby/object:Gem::Version
73
+ version: '10.0'
74
+ type: :development
75
+ prerelease: false
76
+ version_requirements: !ruby/object:Gem::Requirement
77
+ requirements:
78
+ - - "~>"
79
+ - !ruby/object:Gem::Version
80
+ version: '10.0'
81
+ - !ruby/object:Gem::Dependency
82
+ name: rspec
83
+ requirement: !ruby/object:Gem::Requirement
84
+ requirements:
85
+ - - "~>"
86
+ - !ruby/object:Gem::Version
87
+ version: '3.0'
88
+ type: :development
89
+ prerelease: false
90
+ version_requirements: !ruby/object:Gem::Requirement
91
+ requirements:
92
+ - - "~>"
93
+ - !ruby/object:Gem::Version
94
+ version: '3.0'
95
+ - !ruby/object:Gem::Dependency
96
+ name: vcr
97
+ requirement: !ruby/object:Gem::Requirement
98
+ requirements:
99
+ - - "~>"
100
+ - !ruby/object:Gem::Version
101
+ version: '2.9'
102
+ type: :development
103
+ prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ requirements:
106
+ - - "~>"
107
+ - !ruby/object:Gem::Version
108
+ version: '2.9'
109
+ - !ruby/object:Gem::Dependency
110
+ name: webmock
111
+ requirement: !ruby/object:Gem::Requirement
112
+ requirements:
113
+ - - "~>"
114
+ - !ruby/object:Gem::Version
115
+ version: '2.3'
116
+ - - ">="
117
+ - !ruby/object:Gem::Version
118
+ version: 2.3.1
119
+ type: :development
120
+ prerelease: false
121
+ version_requirements: !ruby/object:Gem::Requirement
122
+ requirements:
123
+ - - "~>"
124
+ - !ruby/object:Gem::Version
125
+ version: '2.3'
126
+ - - ">="
127
+ - !ruby/object:Gem::Version
128
+ version: 2.3.1
129
+ description: A simple API for finding postal addresses
130
+ email:
131
+ - alezander82@mail.ru
132
+ executables: []
133
+ extensions: []
134
+ extra_rdoc_files: []
135
+ files:
136
+ - ".gitignore"
137
+ - ".rspec"
138
+ - ".travis.yml"
139
+ - Gemfile
140
+ - LICENSE.txt
141
+ - README.md
142
+ - Rakefile
143
+ - get_address.gemspec
144
+ - lib/get_address.rb
145
+ - lib/get_address/address.rb
146
+ - lib/get_address/errors.rb
147
+ - lib/get_address/utils.rb
148
+ - lib/get_address/version.rb
149
+ homepage: http://rubygems.org/gems/get_address
150
+ licenses:
151
+ - MIT
152
+ metadata: {}
153
+ post_install_message:
154
+ rdoc_options: []
155
+ require_paths:
156
+ - lib
157
+ required_ruby_version: !ruby/object:Gem::Requirement
158
+ requirements:
159
+ - - ">="
160
+ - !ruby/object:Gem::Version
161
+ version: '0'
162
+ required_rubygems_version: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - ">="
165
+ - !ruby/object:Gem::Version
166
+ version: '0'
167
+ requirements: []
168
+ rubyforge_project:
169
+ rubygems_version: 2.4.5.2
170
+ signing_key:
171
+ specification_version: 4
172
+ summary: Wrapper for the getaddress.io API
173
+ test_files: []