mailosaur 7.7.0 → 7.10.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f91c18a443ec50a2034fab26e92fef85673a3aa5c4afde59f95763ca6c84b26f
4
- data.tar.gz: 8a0ecf04c844630ac316548778135e6f0ba36ae0302b05bfd7c1b81c16bc05cf
3
+ metadata.gz: 7dfdb822b3d29505aeb7067c60e791373a77f20cc6f1c4e95b4323e6cf1a65f3
4
+ data.tar.gz: 35d5c43fefa421955864f81150a66480bdbbf30414cab12155b275c36513a697
5
5
  SHA512:
6
- metadata.gz: 5bfab6fd07260d62159be23a80d8196fe73c2f7fba2b756ccf1e7d9b9b26ec7d50dfd7fd01b065830e3fc4c0e62ef656343b6478dcc419dbcea1c03c769d8cde
7
- data.tar.gz: 837c2559149390868a1928ec653df6083b86b8830b8280687ad5dd8e2661e275943ed6bf0a7b8aaeccfa6665817b945e0767124236f94611980fdf2ea8281c9e
6
+ metadata.gz: '069da6916260150acf8b993f768140933951e4c5957a0d690a91a45259d6b1c38a7ba51bde1c81f26bef64b213efc7b9a95d1a1cce20e8648c6b60fa62aa484e'
7
+ data.tar.gz: f7c9ecede2e30ea41814656c766972bedb9bc9505b6ac7c787e4e3e47405393a01c0e62f7164c60e49a90420532ebd1bd36c6983c23a2289ff087b609ca4aa98
@@ -24,7 +24,7 @@ module Mailosaur
24
24
  def spam(email)
25
25
  response = conn.get "api/analysis/spam/#{email}"
26
26
  @handle_http_error.call(response) unless response.status == 200
27
- model = JSON.load(response.body)
27
+ model = JSON.parse(response.body)
28
28
  Mailosaur::Models::SpamAnalysisResult.new(model)
29
29
  end
30
30
  end
@@ -0,0 +1,83 @@
1
+ module Mailosaur
2
+ class Devices
3
+ #
4
+ # Creates and initializes a new instance of the Devices class.
5
+ # @param client connection.
6
+ #
7
+ def initialize(conn, handle_http_error)
8
+ @conn = conn
9
+ @handle_http_error = handle_http_error
10
+ end
11
+
12
+ # @return [Connection] the client connection.
13
+ attr_reader :conn
14
+
15
+ #
16
+ # List all devices
17
+ #
18
+ # Returns a list of your virtual security devices.
19
+ #
20
+ # @return [DeviceListResult] operation results.
21
+ #
22
+ def list
23
+ response = conn.get 'api/devices'
24
+ @handle_http_error.call(response) unless response.status == 200
25
+ model = JSON.parse(response.body)
26
+ Mailosaur::Models::DeviceListResult.new(model)
27
+ end
28
+
29
+ #
30
+ # Create a device
31
+ #
32
+ # Creates a new virtual security device and returns it.
33
+ #
34
+ # @param device_create_options [DeviceCreateOptions]
35
+ #
36
+ # @return [Device] operation results.
37
+ #
38
+ def create(device_create_options)
39
+ response = conn.post 'api/devices', device_create_options.to_json
40
+ @handle_http_error.call(response) unless response.status == 200
41
+ model = JSON.parse(response.body)
42
+ Mailosaur::Models::Device.new(model)
43
+ end
44
+
45
+ #
46
+ # Retrieve OTP
47
+ #
48
+ # Retrieves the current one-time password for a saved device, or given base32-encoded shared secret.
49
+ #
50
+ # @param query [String] Either the unique identifier of the device, or a base32-encoded shared secret.
51
+ #
52
+ # @return [OtpResult] operation results.
53
+ #
54
+ def otp(query)
55
+ if query.include? '-'
56
+ response = conn.get "api/devices/#{query}/otp"
57
+ @handle_http_error.call(response) unless response.status == 200
58
+ model = JSON.parse(response.body)
59
+ return Mailosaur::Models::OtpResult.new(model)
60
+ end
61
+
62
+ options = Mailosaur::Models::DeviceCreateOptions.new
63
+ options.shared_secret = query
64
+ response = conn.post 'api/devices/otp', options.to_json
65
+ @handle_http_error.call(response) unless response.status == 200
66
+ model = JSON.parse(response.body)
67
+ Mailosaur::Models::OtpResult.new(model)
68
+ end
69
+
70
+ #
71
+ # Delete a device
72
+ #
73
+ # Permanently deletes a device. This operation cannot be undone.
74
+ #
75
+ # @param id [String] The identifier of the device to be deleted.
76
+ #
77
+ def delete(id)
78
+ response = conn.delete "api/devices/#{id}"
79
+ @handle_http_error.call(response) unless response.status == 204
80
+ nil
81
+ end
82
+ end
83
+ end
@@ -51,7 +51,7 @@ module Mailosaur
51
51
  def get_by_id(id)
52
52
  response = conn.get "api/messages/#{id}"
53
53
  @handle_http_error.call(response) unless response.status == 200
54
- model = JSON.load(response.body)
54
+ model = JSON.parse(response.body)
55
55
  Mailosaur::Models::Message.new(model)
56
56
  end
57
57
 
@@ -96,7 +96,7 @@ module Mailosaur
96
96
 
97
97
  @handle_http_error.call(response) unless response.status == 200
98
98
 
99
- model = JSON.load(response.body)
99
+ model = JSON.parse(response.body)
100
100
  Mailosaur::Models::MessageListResult.new(model)
101
101
  end
102
102
 
@@ -137,7 +137,7 @@ module Mailosaur
137
137
  #
138
138
  # @return [MessageListResult] operation results.
139
139
  #
140
- def search(server, criteria, page: nil, items_per_page: nil, timeout: nil, received_after: nil, error_on_timeout: true) # rubocop:disable all
140
+ def search(server, criteria, page: nil, items_per_page: nil, timeout: nil, received_after: nil, error_on_timeout: true)
141
141
  url = "api/messages/search?server=#{server}"
142
142
  url += page ? "&page=#{page}" : ''
143
143
  url += items_per_page ? "&itemsPerPage=#{items_per_page}" : ''
@@ -151,7 +151,7 @@ module Mailosaur
151
151
 
152
152
  @handle_http_error.call(response) unless response.status == 200
153
153
 
154
- model = JSON.load(response.body)
154
+ model = JSON.parse(response.body)
155
155
  return Mailosaur::Models::MessageListResult.new(model) if timeout.to_i.zero? || !model['items'].empty?
156
156
 
157
157
  delay_pattern = (response.headers['x-ms-delay'] || '1000').split(',').map(&:to_i)
@@ -186,7 +186,7 @@ module Mailosaur
186
186
  def create(server, message_create_options)
187
187
  response = conn.post "api/messages?server=#{server}", message_create_options.to_json
188
188
  @handle_http_error.call(response) unless response.status == 200
189
- model = JSON.load(response.body)
189
+ model = JSON.parse(response.body)
190
190
  Mailosaur::Models::Message.new(model)
191
191
  end
192
192
 
@@ -204,7 +204,7 @@ module Mailosaur
204
204
  def forward(id, message_forward_options)
205
205
  response = conn.post "api/messages/#{id}/forward", message_forward_options.to_json
206
206
  @handle_http_error.call(response) unless response.status == 200
207
- model = JSON.load(response.body)
207
+ model = JSON.parse(response.body)
208
208
  Mailosaur::Models::Message.new(model)
209
209
  end
210
210
 
@@ -223,7 +223,7 @@ module Mailosaur
223
223
  def reply(id, message_reply_options)
224
224
  response = conn.post "api/messages/#{id}/reply", message_reply_options.to_json
225
225
  @handle_http_error.call(response) unless response.status == 200
226
- model = JSON.load(response.body)
226
+ model = JSON.parse(response.body)
227
227
  Mailosaur::Models::Message.new(model)
228
228
  end
229
229
  end
@@ -0,0 +1,16 @@
1
+ module Mailosaur
2
+ module Models
3
+ class Device < BaseModel
4
+ def initialize(data = {})
5
+ @id = data['id']
6
+ @name = data['name']
7
+ end
8
+
9
+ # @return [String] Unique identifier for the device.
10
+ attr_accessor :id
11
+
12
+ # @return [String] The name of the device.
13
+ attr_accessor :name
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,16 @@
1
+ module Mailosaur
2
+ module Models
3
+ class DeviceCreateOptions < BaseModel
4
+ def initialize(data = {})
5
+ @name = data['name']
6
+ @shared_secret = data['shared_secret']
7
+ end
8
+
9
+ # @return [String] A name used to identify the device.
10
+ attr_accessor :name
11
+
12
+ # @return [String] The base32-encoded shared secret for this device.
13
+ attr_accessor :shared_secret
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,13 @@
1
+ module Mailosaur
2
+ module Models
3
+ class DeviceListResult < BaseModel
4
+ def initialize(data = {})
5
+ @items = []
6
+ (data['items'] || []).each { |i| @items << Mailosaur::Models::Device.new(i) }
7
+ end
8
+
9
+ # @return [Array<Device>] The individual devices forming the result.
10
+ attr_accessor :items
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,16 @@
1
+ module Mailosaur
2
+ module Models
3
+ class OtpResult < BaseModel
4
+ def initialize(data = {})
5
+ @code = data['code']
6
+ @expires = data['expires']
7
+ end
8
+
9
+ # @return [String] The current one-time password.
10
+ attr_accessor :code
11
+
12
+ # @return [String] The expiry date/time of the current one-time password.
13
+ attr_accessor :expires
14
+ end
15
+ end
16
+ end
@@ -23,7 +23,7 @@ module Mailosaur
23
23
  def list
24
24
  response = conn.get 'api/servers'
25
25
  @handle_http_error.call(response) unless response.status == 200
26
- model = JSON.load(response.body)
26
+ model = JSON.parse(response.body)
27
27
  Mailosaur::Models::ServerListResult.new(model)
28
28
  end
29
29
 
@@ -39,7 +39,7 @@ module Mailosaur
39
39
  def create(server_create_options)
40
40
  response = conn.post 'api/servers', server_create_options.to_json
41
41
  @handle_http_error.call(response) unless response.status == 200
42
- model = JSON.load(response.body)
42
+ model = JSON.parse(response.body)
43
43
  Mailosaur::Models::Server.new(model)
44
44
  end
45
45
 
@@ -56,7 +56,7 @@ module Mailosaur
56
56
  def get(id)
57
57
  response = conn.get "api/servers/#{id}"
58
58
  @handle_http_error.call(response) unless response.status == 200
59
- model = JSON.load(response.body)
59
+ model = JSON.parse(response.body)
60
60
  Mailosaur::Models::Server.new(model)
61
61
  end
62
62
 
@@ -73,7 +73,7 @@ module Mailosaur
73
73
  def get_password(id)
74
74
  response = conn.get "api/servers/#{id}/password"
75
75
  @handle_http_error.call(response) unless response.status == 200
76
- model = JSON.load(response.body)
76
+ model = JSON.parse(response.body)
77
77
  model['value']
78
78
  end
79
79
 
@@ -90,7 +90,7 @@ module Mailosaur
90
90
  def update(id, server)
91
91
  response = conn.put "api/servers/#{id}", server.to_json
92
92
  @handle_http_error.call(response) unless response.status == 200
93
- model = JSON.load(response.body)
93
+ model = JSON.parse(response.body)
94
94
  Mailosaur::Models::Server.new(model)
95
95
  end
96
96
 
@@ -110,7 +110,7 @@ module Mailosaur
110
110
 
111
111
  def generate_email_address(server)
112
112
  host = ENV['MAILOSAUR_SMTP_HOST'] || 'mailosaur.net'
113
- '%s@%s.%s' % [SecureRandom.hex(3), server, host]
113
+ format('%s@%s.%s', SecureRandom.hex(3), server, host)
114
114
  end
115
115
  end
116
116
  end
@@ -22,7 +22,7 @@ module Mailosaur
22
22
  def limits
23
23
  response = conn.get 'api/usage/limits'
24
24
  @handle_http_error.call(response) unless response.status == 200
25
- model = JSON.load(response.body)
25
+ model = JSON.parse(response.body)
26
26
  Mailosaur::Models::UsageAccountLimits.new(model)
27
27
  end
28
28
 
@@ -34,7 +34,7 @@ module Mailosaur
34
34
  def transactions
35
35
  response = conn.get 'api/usage/transactions'
36
36
  @handle_http_error.call(response) unless response.status == 200
37
- model = JSON.load(response.body)
37
+ model = JSON.parse(response.body)
38
38
  Mailosaur::Models::UsageTransactionListResult.new(model)
39
39
  end
40
40
  end
@@ -1,3 +1,3 @@
1
1
  module Mailosaur
2
- VERSION = '7.7.0'.freeze
2
+ VERSION = '7.10.0'.freeze
3
3
  end
data/lib/mailosaur.rb CHANGED
@@ -14,6 +14,7 @@ module Mailosaur
14
14
  autoload :Messages, 'Mailosaur/messages.rb'
15
15
  autoload :Servers, 'Mailosaur/servers.rb'
16
16
  autoload :Usage, 'Mailosaur/usage.rb'
17
+ autoload :Devices, 'Mailosaur/devices.rb'
17
18
  autoload :MailosaurError, 'Mailosaur/mailosaur_error.rb'
18
19
 
19
20
  module Models
@@ -42,6 +43,10 @@ module Mailosaur
42
43
  autoload :UsageAccountLimit, 'Mailosaur/models/usage_account_limit.rb'
43
44
  autoload :UsageTransactionListResult, 'Mailosaur/models/usage_transaction_list_result.rb'
44
45
  autoload :UsageTransaction, 'Mailosaur/models/usage_transaction.rb'
46
+ autoload :Device, 'Mailosaur/models/device.rb'
47
+ autoload :DeviceListResult, 'Mailosaur/models/device_list_result.rb'
48
+ autoload :DeviceCreateOptions, 'Mailosaur/models/device_create_options.rb'
49
+ autoload :OtpResult, 'Mailosaur/models/otp_result.rb'
45
50
  autoload :BaseModel, 'Mailosaur/models/base_model.rb'
46
51
  end
47
52
 
@@ -81,6 +86,11 @@ module Mailosaur
81
86
  @usage ||= Usage.new(connection, method(:handle_http_error))
82
87
  end
83
88
 
89
+ # @return [Devices] usage
90
+ def devices
91
+ @devices ||= Devices.new(connection, method(:handle_http_error))
92
+ end
93
+
84
94
  private
85
95
 
86
96
  def connection
@@ -89,19 +99,37 @@ module Mailosaur
89
99
  content_type: 'application/json; charset=utf-8',
90
100
  user_agent: "mailosaur-ruby/#{Mailosaur::VERSION}"
91
101
  }
92
- }).tap { |conn| conn.request(:basic_auth, @api_key, '') }
102
+ }).tap do |conn|
103
+ case Faraday::VERSION
104
+ when /^0/
105
+ conn.basic_auth @api_key, ''
106
+ when /^1/
107
+ conn.request(:basic_auth, @api_key, '')
108
+ else
109
+ conn.request(:authorization, :basic, @api_key, '')
110
+ end
111
+ end
93
112
  end
94
113
 
95
114
  def handle_http_error(response)
115
+ message = ''
96
116
  case response.status
97
117
  when 400
98
- raise Mailosaur::MailosaurError.new('Request had one or more invalid parameters.', 'invalid_request', response.status, response.body)
118
+ begin
119
+ json = JSON.parse(response.body)
120
+ json['errors'].each do |err|
121
+ message += format('(%s) %s\r\n', err['field'], err['detail'][0]['description'])
122
+ end
123
+ rescue StandardError
124
+ message = 'Request had one or more invalid parameters.'
125
+ end
126
+ raise Mailosaur::MailosaurError.new(message, 'invalid_request', response.status, response.body)
99
127
  when 401
100
128
  raise Mailosaur::MailosaurError.new('Authentication failed, check your API key.', 'authentication_error', response.status, response.body)
101
129
  when 403
102
130
  raise Mailosaur::MailosaurError.new('Insufficient permission to perform that task.', 'permission_error', response.status, response.body)
103
131
  when 404
104
- raise Mailosaur::MailosaurError.new('Request did not find any matching resources.', 'invalid_request', response.status, response.body)
132
+ raise Mailosaur::MailosaurError.new('Not found, check input parameters.', 'invalid_request', response.status, response.body)
105
133
  else
106
134
  raise Mailosaur::MailosaurError.new('An API error occurred, see httpResponse for further information.', 'api_error', response.status, response.body)
107
135
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mailosaur
3
3
  version: !ruby/object:Gem::Version
4
- version: 7.7.0
4
+ version: 7.10.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Mailosaur
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-03-08 00:00:00.000000000 Z
11
+ date: 2022-06-14 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: faraday
@@ -16,20 +16,20 @@ dependencies:
16
16
  requirements:
17
17
  - - ">="
18
18
  - !ruby/object:Gem::Version
19
- version: '0.9'
19
+ version: '2.0'
20
20
  - - "<"
21
21
  - !ruby/object:Gem::Version
22
- version: '2'
22
+ version: '3'
23
23
  type: :runtime
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
26
26
  requirements:
27
27
  - - ">="
28
28
  - !ruby/object:Gem::Version
29
- version: '0.9'
29
+ version: '2.0'
30
30
  - - "<"
31
31
  - !ruby/object:Gem::Version
32
- version: '2'
32
+ version: '3'
33
33
  - !ruby/object:Gem::Dependency
34
34
  name: json
35
35
  requirement: !ruby/object:Gem::Requirement
@@ -56,20 +56,20 @@ dependencies:
56
56
  requirements:
57
57
  - - "~>"
58
58
  - !ruby/object:Gem::Version
59
- version: '2.6'
59
+ version: '2.7'
60
60
  - - ">="
61
61
  - !ruby/object:Gem::Version
62
- version: 2.6.1
62
+ version: 2.7.1
63
63
  type: :development
64
64
  prerelease: false
65
65
  version_requirements: !ruby/object:Gem::Requirement
66
66
  requirements:
67
67
  - - "~>"
68
68
  - !ruby/object:Gem::Version
69
- version: '2.6'
69
+ version: '2.7'
70
70
  - - ">="
71
71
  - !ruby/object:Gem::Version
72
- version: 2.6.1
72
+ version: 2.7.1
73
73
  - !ruby/object:Gem::Dependency
74
74
  name: rake
75
75
  requirement: !ruby/object:Gem::Requirement
@@ -90,54 +90,54 @@ dependencies:
90
90
  requirements:
91
91
  - - "~>"
92
92
  - !ruby/object:Gem::Version
93
- version: 1.19.0
93
+ version: 1.30.0
94
94
  type: :development
95
95
  prerelease: false
96
96
  version_requirements: !ruby/object:Gem::Requirement
97
97
  requirements:
98
98
  - - "~>"
99
99
  - !ruby/object:Gem::Version
100
- version: 1.19.0
100
+ version: 1.30.0
101
101
  - !ruby/object:Gem::Dependency
102
102
  name: shoulda-context
103
103
  requirement: !ruby/object:Gem::Requirement
104
104
  requirements:
105
105
  - - "~>"
106
106
  - !ruby/object:Gem::Version
107
- version: '1.2'
107
+ version: '2.0'
108
108
  - - ">="
109
109
  - !ruby/object:Gem::Version
110
- version: 1.2.2
110
+ version: 2.0.0
111
111
  type: :development
112
112
  prerelease: false
113
113
  version_requirements: !ruby/object:Gem::Requirement
114
114
  requirements:
115
115
  - - "~>"
116
116
  - !ruby/object:Gem::Version
117
- version: '1.2'
117
+ version: '2.0'
118
118
  - - ">="
119
119
  - !ruby/object:Gem::Version
120
- version: 1.2.2
120
+ version: 2.0.0
121
121
  - !ruby/object:Gem::Dependency
122
122
  name: test-unit
123
123
  requirement: !ruby/object:Gem::Requirement
124
124
  requirements:
125
125
  - - "~>"
126
126
  - !ruby/object:Gem::Version
127
- version: '3.2'
127
+ version: '3.5'
128
128
  - - ">="
129
129
  - !ruby/object:Gem::Version
130
- version: 3.2.7
130
+ version: 3.5.3
131
131
  type: :development
132
132
  prerelease: false
133
133
  version_requirements: !ruby/object:Gem::Requirement
134
134
  requirements:
135
135
  - - "~>"
136
136
  - !ruby/object:Gem::Version
137
- version: '3.2'
137
+ version: '3.5'
138
138
  - - ">="
139
139
  - !ruby/object:Gem::Version
140
- version: 3.2.7
140
+ version: 3.5.3
141
141
  description: The Mailosaur Ruby library lets you integrate email and SMS testing into
142
142
  your continuous integration process.
143
143
  email: code@mailosaur.com
@@ -148,12 +148,16 @@ files:
148
148
  - LICENSE
149
149
  - README.md
150
150
  - lib/Mailosaur/analysis.rb
151
+ - lib/Mailosaur/devices.rb
151
152
  - lib/Mailosaur/files.rb
152
153
  - lib/Mailosaur/mailosaur_error.rb
153
154
  - lib/Mailosaur/messages.rb
154
155
  - lib/Mailosaur/models/attachment.rb
155
156
  - lib/Mailosaur/models/base_model.rb
156
157
  - lib/Mailosaur/models/code.rb
158
+ - lib/Mailosaur/models/device.rb
159
+ - lib/Mailosaur/models/device_create_options.rb
160
+ - lib/Mailosaur/models/device_list_result.rb
157
161
  - lib/Mailosaur/models/image.rb
158
162
  - lib/Mailosaur/models/link.rb
159
163
  - lib/Mailosaur/models/message.rb
@@ -166,6 +170,7 @@ files:
166
170
  - lib/Mailosaur/models/message_reply_options.rb
167
171
  - lib/Mailosaur/models/message_summary.rb
168
172
  - lib/Mailosaur/models/metadata.rb
173
+ - lib/Mailosaur/models/otp_result.rb
169
174
  - lib/Mailosaur/models/search_criteria.rb
170
175
  - lib/Mailosaur/models/server.rb
171
176
  - lib/Mailosaur/models/server_create_options.rb
@@ -206,7 +211,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
206
211
  - !ruby/object:Gem::Version
207
212
  version: '0'
208
213
  requirements: []
209
- rubygems_version: 3.2.32
214
+ rubygems_version: 3.3.7
210
215
  signing_key:
211
216
  specification_version: 4
212
217
  summary: The Mailosaur Ruby library