vpos 1.0.4 → 2.0.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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 4afd795dda51f97e50f6cd03781acca39a4f5d36619bddfe55d4515ad8506f5f
4
- data.tar.gz: 3f7553fc7b5705c86c074c0e76fce57528683cb81ca1c3ec1192e6ef6f00e9c0
3
+ metadata.gz: 8ce8a846da74d76619ecc28a4c433c7a84d2e759ab0ce7c1dd9a6ad06e3a9fa0
4
+ data.tar.gz: ecd2849235767f671634540dd75491d8069b200ae21b2984c3e68a8429e6a094
5
5
  SHA512:
6
- metadata.gz: d1d4d000a8aa386223660b120a015dd0bb45a7092355d22d7ad097a4add8bd31314891f976faca280c07c88bc2f8b234d0ce07db68265bb244331ca926ba10f2
7
- data.tar.gz: 817be562e7dfcacaf0bbad89a71bbd6a2e9f5c0b2385b360803795cb0d1293f3d0dcfb01ac3a55b11d4052af74dea307fa58ef56841426dbbd3377c6eb8be5ba
6
+ metadata.gz: 3b414e72948061cbe3b478202df5196cb6f468da6071286f3623f80beb946b79f2b6c2e328430ff34f37675b464e74b0f0761b91c16af5eb3d80a7cef703b58c
7
+ data.tar.gz: 87214e410ace8ec0aae927cdd91df7553d1da9b271352db6fad413ea352c488d4949becd6104514f7e3bbceb22dfff1f1855d107e5b1d086bd4da73459fb82d9
data/.gitignore CHANGED
@@ -24,3 +24,4 @@ test/version_tmp
24
24
  tmp
25
25
  example.rb
26
26
  .idea
27
+ vendor/*
data/.ruby-version CHANGED
@@ -1 +1 @@
1
- 2.5.8
1
+ 3.0.2
data/Gemfile.lock CHANGED
@@ -1,35 +1,33 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- vpos (1.0.3)
5
- httparty (~> 0.18.1)
6
- rspec (~> 3.9, >= 3.9.0)
4
+ vpos (2.0.0)
5
+ faraday (~> 2.3)
6
+ rspec (~> 3.11, >= 3.11.0)
7
7
 
8
8
  GEM
9
9
  remote: https://rubygems.org/
10
10
  specs:
11
- diff-lcs (1.4.4)
12
- httparty (0.18.1)
13
- mime-types (~> 3.0)
14
- multi_xml (>= 0.5.2)
15
- mime-types (3.3.1)
16
- mime-types-data (~> 3.2015)
17
- mime-types-data (3.2021.0225)
18
- multi_xml (0.6.0)
11
+ diff-lcs (1.5.0)
12
+ faraday (2.3.0)
13
+ faraday-net_http (~> 2.0)
14
+ ruby2_keywords (>= 0.0.4)
15
+ faraday-net_http (2.0.3)
19
16
  rake (12.3.3)
20
- rspec (3.9.0)
21
- rspec-core (~> 3.9.0)
22
- rspec-expectations (~> 3.9.0)
23
- rspec-mocks (~> 3.9.0)
24
- rspec-core (3.9.3)
25
- rspec-support (~> 3.9.3)
26
- rspec-expectations (3.9.4)
17
+ rspec (3.11.0)
18
+ rspec-core (~> 3.11.0)
19
+ rspec-expectations (~> 3.11.0)
20
+ rspec-mocks (~> 3.11.0)
21
+ rspec-core (3.11.0)
22
+ rspec-support (~> 3.11.0)
23
+ rspec-expectations (3.11.0)
27
24
  diff-lcs (>= 1.2.0, < 2.0)
28
- rspec-support (~> 3.9.0)
29
- rspec-mocks (3.9.1)
25
+ rspec-support (~> 3.11.0)
26
+ rspec-mocks (3.11.1)
30
27
  diff-lcs (>= 1.2.0, < 2.0)
31
- rspec-support (~> 3.9.0)
32
- rspec-support (3.9.4)
28
+ rspec-support (~> 3.11.0)
29
+ rspec-support (3.11.0)
30
+ ruby2_keywords (0.0.5)
33
31
 
34
32
  PLATFORMS
35
33
  ruby
@@ -40,4 +38,4 @@ DEPENDENCIES
40
38
  vpos!
41
39
 
42
40
  BUNDLED WITH
43
- 2.2.6
41
+ 2.2.27
data/README.md CHANGED
@@ -23,7 +23,7 @@ See our documentation on [developer.vpos.ao](https://developer.vpos.ao)
23
23
 
24
24
  ## Installation
25
25
  ```ruby
26
- gem 'vpos', '~> 1.0.0'
26
+ gem 'vpos', '~> 2.0.0'
27
27
  ```
28
28
 
29
29
  or
@@ -37,6 +37,7 @@ This ruby library requires you to have:
37
37
  - POS_ID provided by EMIS that can be requested through your support bank.
38
38
  - Supervisor Card provided by EMIS that can be requested through your support bank.
39
39
  - Token provided by vPOS that can be generated through vPOS [merchant](https://merchant.vpos.ao) portal.
40
+ - Ruby 2.6 or higher
40
41
 
41
42
  Don't have this information? [Talk to us](suporte@vpos.ao)
42
43
 
@@ -52,17 +53,16 @@ The next section will show the various actions that can be performed by you, the
52
53
  require 'vpos'
53
54
 
54
55
  # use the default environment variables option
55
- merchant = Vpos.new
56
+ vpos = Vpos.new
56
57
 
57
58
  # or use optional arguments option
58
- merchant = Vpos.new(token: 'your_token_here', environment: 'PRD')
59
+ vpos = Vpos.new(token: 'your_token_here')
59
60
  ```
60
61
 
61
62
  #### Environment variables
62
63
  | Variable | Description | Required |
63
64
  | --- | --- | --- |
64
65
  | `GPO_POS_ID` | The Point of Sale ID provided by EMIS | true |
65
- | `GPO_SUPERVISOR_CARD` | The Supervisor card ID provided by EMIS | true |
66
66
  | `MERCHANT_VPOS_TOKEN` | The API token provided by vPOS | true |
67
67
  | `PAYMENT_CALLBACK_URL` | The URL that will handle payment notifications | false |
68
68
  | `REFUND_CALLBACK_URL` | The URL that will handle refund notifications | false |
@@ -74,65 +74,156 @@ or using one of the optional arguments
74
74
  | --- | --- | --- |
75
75
  | `token` | Token generated at [vPOS](https://merchant.vpos.ao) dashboard | `string`
76
76
  | `pos_id` | Merchant POS ID provided by EMIS | `string`
77
- | `supervisor_card` | Merchant Supervisor Card number provided by EMIS | `string`
78
77
  | `payment_callback_url` | Merchant application JSON endpoint to accept the callback payment response | `string`
79
78
  | `refund_callback_url` | Merchant application JSON endpoint to accept the callback refund response | `string`
80
- | `environment` | The vPOS environment, leave empty for `sandbox` mode and use `"PRD"` for `production`. | `string` |
81
-
82
- ### Get all Transactions
83
- This endpoint retrieves all transactions.
84
-
85
- ```ruby
86
- transaction = merchant.get_transactions
87
- ```
88
79
 
89
80
  ### Get a specific Transaction
90
- Retrieves a transaction given a valid transaction ID.
81
+ Retrieves a transaction given a valid transaction ID:
91
82
 
92
83
  ```ruby
93
- transaction = merchant.get_transaction('1jHbXEbRTIbbwaoJ6w06nLcRG7X')
84
+ # Using a env variable token MERCHANT_VPOS_TOKEN
85
+ transaction = vpos.get_transaction(transaction_id: '1jHbXEbRTIbbwaoJ6w06nLcRG7X')
86
+ # Or using a explicitly stated token
87
+ transaction = vpos.get_transaction(transaction_id: '1jHbXEbRTIbbwaoJ6w06nLcRG7X', token: 'EbRTIbb1jHbXEbRTIbbwaoJ6w06nLcRG7X')
88
+ # {
89
+ # :status_code=>200,
90
+ # :message=>"OK",
91
+ # :data=> {
92
+ # :amount=>"1.23",
93
+ # :clearing_period=>156,
94
+ # :id=>"29fTRtkFaf8cQklRuHTvGDaecj4",
95
+ # :mobile=>"900000000",
96
+ # :parent_transaction_id=>nil,
97
+ # :pos_id=>111,
98
+ # :status=>"accepted",
99
+ # :status_datetime=>"2022-05-25T18:25:39Z",
100
+ # :status_reason=>nil,
101
+ # :type=>"payment"
102
+ # }
103
+ # }
94
104
  ```
95
105
 
96
- | Argument | Description | Type |
97
- | --- | --- | --- |
98
- | `id` | An existing Transaction ID | `string`
106
+ | Argument | Description | Type | Required |
107
+ | --- | --- | --- | --- |
108
+ | `transaction_id` | An existing Transaction ID | `string` | Yes |
109
+ | `token` | Merchant token generated at vPOS merchant portal | `string` | No (if set as env variable) |
99
110
 
100
111
  ### New Payment Transaction
101
112
  Creates a new payment transaction given a valid mobile number associated with a `MULTICAIXA` account
102
- and a valid amount.
113
+ and a valid amount:
103
114
 
104
115
  ```ruby
105
- payment = merchant.new_payment('900111222', '123.45')
116
+ # Using a env variable token MERCHANT_VPOS_TOKEN
117
+ request = vpos.new_payment(customer: '900111222', amount: '123.45')
118
+ # Or using a explicitly stated token
119
+ request = vpos.new_payment(customer: '900111222', amount: '123.45', token: 'EbRTIbb1jHbXEbRTIbbwaoJ6w06nLcRG7X')
120
+ # {:status_code=>202, :message=>"ACCEPTED", :location=>"/api/v1/requests/29fTRtkFaf8cQklRuHTvGDaecj4"}
121
+
122
+ request_id = vpos.get_request_id(request)
123
+ # "29fTRtkFaf8cQklRuHTvGDaecj4"
124
+
125
+ transaction = vpos.get_transaction(transaction_id: "29fTRtkFaf8cQklRuHTvGDaecj4")
126
+ # {
127
+ # :status_code=>200,
128
+ # :message=>"OK",
129
+ # :data=> {
130
+ # :amount=>"1.23",
131
+ # :clearing_period=>156,
132
+ # :id=>"29fTRtkFaf8cQklRuHTvGDaecj4",
133
+ # :mobile=>"900000000",
134
+ # :parent_transaction_id=>nil,
135
+ # :pos_id=>111,
136
+ # :status=>"accepted",
137
+ # :status_datetime=>"2022-05-25T18:25:39Z",
138
+ # :status_reason=>nil,
139
+ # :type=>"payment"
140
+ # }
141
+ # }
106
142
  ```
107
143
 
108
- | Argument | Description | Type |
109
- | --- | --- | --- |
110
- | `mobile` | The mobile number of the client who will pay | `string`
111
- | `amount` | The amount the client should pay, eg. "259.99", "259000.00" | `string`
144
+ | Argument | Description | Type | Required |
145
+ | --- | --- | --- | --- |
146
+ | `customer` | The mobile number of the client who will pay | `string` | Yes |
147
+ | `amount` | The amount the client should pay, eg. "259.99", "259000.00" | `string` | Yes |
148
+ | `token` | Merchant token generated at vPOS merchant portal | `string` | No (if set as env variable) |
149
+ | `callback_url` | A valid https url where vPOS is going to callback as soon he finishes to process | `string` | No |
112
150
 
113
151
  ### Request Refund
114
- Given an existing `parent_transaction_id`, request a refund.
152
+ Given an existing `parent_transaction_id`, request a refund using a env variable token.
115
153
 
116
154
  ```ruby
117
- refund = merchant.new_refund('1kTFGhJH8i58uD9MdJpMjWnoE')
155
+ # Using a env variable token MERCHANT_VPOS_TOKEN
156
+ request = vpos.new_refund(parent_transaction_id: '29fTRtkFaf8cQklRuHTvGDaecj4')
157
+ # Or using a explicitly stated token
158
+ request = vpos.new_refund(parent_transaction_id: '29fTRtkFaf8cQklRuHTvGDaecj4', token: 'EbRTIbb1jHbXEbRTIbbwaoJ6w06nLcRG7X')
159
+ # {:status_code=>202, :message=>"ACCEPTED", :location=>"/api/v1/requests/29fTRtkFaf8cQklRuHTvGDaecj3"}
160
+
161
+ request_id = vpos.get_request_id(request)
162
+ # "29fTRtkFaf8cQklRuHTvGDaecj3"
163
+
164
+ transaction = vpos.get_transaction(transaction_id: "29fTRtkFaf8cQklRuHTvGDaecj3")
165
+ # {
166
+ # :status_code=>200,
167
+ # :message=>"OK",
168
+ # :data=> {
169
+ # :amount=>"1.23",
170
+ # :clearing_period=>156,
171
+ # :id=>"29fTRtkFaf8cQklRuHTvGDaecj3",
172
+ # :mobile=>nil,
173
+ # :parent_transaction_id=>29fTRtkFaf8cQklRuHTvGDaecj4,
174
+ # :pos_id=>nil,
175
+ # :status=>"accepted",
176
+ # :status_datetime=>"2022-05-25T18:25:39Z",
177
+ # :status_reason=>nil,
178
+ # :type=>"refund"
179
+ # }
180
+ # }
118
181
  ```
119
182
 
120
- | Argument | Description | Type |
121
- | --- | --- | --- |
183
+ | Argument | Description | Type | Required |
184
+ | --- | --- | --- | --- |
122
185
  | `parent_transaction_id` | The ID of transaction you wish to refund | `string`
186
+ | `token` | Merchant token generated at vPOS merchant portal | `string` | No (if set as env variable) |
187
+ | `callback_url` | A valid https url where vPOS is going to callback as soon he finishes to process | `string` | No |
123
188
 
124
189
  ### Poll Transaction Status
125
- Poll the status of a transaction given a valid `request_id`.
190
+ Poll the status of a transaction given a valid `request_id`
126
191
 
127
192
  Note: The `request_id` in this context is essentially the `transaction_id` of an existing request.
128
193
 
129
194
  ```ruby
130
- transaction = merchant.get_request('1jHbXEbRTIbbwaoJ6w06nLcRG7X')
195
+ # Using a env variable token
196
+ request = vpos.get_request(request_id: '29fTRtkFaf8cQklRuHTvGDaecj5')
197
+ # Or using a explicitly stated token
198
+ request = vpos.get_request(request_id: '29fTRtkFaf8cQklRuHTvGDaecj5', token: 'EbRTIbb1jHbXEbRTIbbwaoJ6w06nLcRG7X')
199
+ # {:status_code=>303, :message=>"ACCEPTED", :location=>"/api/v1/transactions/29fTRtkFaf8cQklRuHTvGDaecj5"}
200
+
201
+ request_id = vpos.get_request_id(request)
202
+ # "29fTRtkFaf8cQklRuHTvGDaecj5"
203
+
204
+ transaction = vpos.get_transaction(transaction_id: "29fTRtkFaf8cQklRuHTvGDaecj5")
205
+ # {
206
+ # :status_code=>200,
207
+ # :message=>"OK",
208
+ # :data=> {
209
+ # :amount=>"1.23",
210
+ # :clearing_period=>156,
211
+ # :id=>"29fTRtkFaf8cQklRuHTvGDaecj5",
212
+ # :mobile=>nil,
213
+ # :parent_transaction_id=>29fTRtkFaf8cQklRuHTvGDaecj4,
214
+ # :pos_id=>nil,
215
+ # :status=>"accepted",
216
+ # :status_datetime=>"2022-05-25T18:25:39Z",
217
+ # :status_reason=>nil,
218
+ # :type=>"refund"
219
+ # }
220
+ # }
131
221
  ```
132
222
 
133
- | Argument | Description | Type |
134
- | --- | --- | --- |
135
- | `request_id` | The ID of transaction you wish to poll | `string`
223
+ | Argument | Description | Type | Required? |
224
+ | --- | --- | --- | --- |
225
+ | `request_id` | The ID of transaction you wish to poll | `string` | Yes |
226
+ | `token` | Merchant token generated at vPOS merchant portal | `string` | No (if set as env variable) |
136
227
 
137
228
  ### Have any doubts?
138
229
  In case of any doubts, bugs, or the like, please leave an issue. We would love to help.
data/bin/.ruby-version ADDED
@@ -0,0 +1 @@
1
+ 3.0.2
data/lib/vpos/version.rb CHANGED
@@ -1,3 +1,3 @@
1
1
  module VposModule
2
- VERSION = "1.0.4"
2
+ VERSION = "2.0.1"
3
3
  end
data/lib/vpos.rb CHANGED
@@ -3,36 +3,38 @@ require_relative "vpos_module"
3
3
  class Vpos
4
4
  include VposModule
5
5
 
6
- def initialize(token: set_token, pos_id: default_pos_id, supervisor_card: default_supervisor_card, payment_callback_url: default_payment_callback_url, refund_callback_url: default_refund_callback_url)
6
+ def initialize(token: set_token, pos_id: default_pos_id, payment_callback_url: default_payment_callback_url, refund_callback_url: default_refund_callback_url)
7
7
  @token = token
8
8
  @pos_id = pos_id
9
- @supervisor_card = supervisor_card
10
9
  @payment_callback_url = payment_callback_url
11
10
  @refund_callback_url = refund_callback_url
12
11
  end
13
12
 
14
13
  private
15
-
16
- def default_pos_id
17
- pos_id = ENV['GPO_POS_ID']
18
- "#{pos_id}".to_i
19
- end
20
-
21
- def default_supervisor_card
22
- supervisor_card = ENV['GPO_SUPERVISOR_CARD']
23
- "#{supervisor_card}"
24
- end
25
-
26
- def set_token
27
- token = ENV['MERCHANT_VPOS_TOKEN']
28
- "Bearer #{token}"
29
- end
30
-
31
- def default_payment_callback_url
32
- ENV['PAYMENT_CALLBACK_URL']
33
- end
34
-
35
- def default_refund_callback_url
36
- ENV['REFUND_CALLBACK_URL']
37
- end
14
+ def default_pos_id
15
+ pos_id = ENV['GPO_POS_ID']
16
+ unless !pos_id.nil?
17
+ return 111
18
+ end
19
+ "#{pos_id}".to_i
20
+ end
21
+
22
+ def set_token
23
+ token = ENV['MERCHANT_VPOS_TOKEN']
24
+ "Bearer #{token}"
25
+ end
26
+
27
+ def default_payment_callback_url
28
+ url = ENV['PAYMENT_CALLBACK_URL']
29
+ unless !url.nil?
30
+ return ""
31
+ end
32
+ end
33
+
34
+ def default_refund_callback_url
35
+ url = ENV['REFUND_CALLBACK_URL']
36
+ unless !url.nil?
37
+ return ""
38
+ end
39
+ end
38
40
  end
data/lib/vpos_module.rb CHANGED
@@ -1,39 +1,49 @@
1
1
  require "vpos/version"
2
- require "httparty"
2
+ require "faraday"
3
+ require "json"
3
4
  require "securerandom"
4
5
 
5
6
  module VposModule
6
7
  class Error < StandardError; end
7
- include HTTParty
8
- follow_redirects false
9
8
 
10
- def new_payment(customer, amount, pos_id: @pos_id, callback_url: @payment_callback_url)
11
- content = set_headers
12
- content[:body] = {type:"payment", pos_id: pos_id, mobile: customer, amount: amount, callback_url: callback_url}.to_json
13
- request = HTTParty.post("#{host}/transactions", content)
14
- return_vpos_object(request)
15
- end
16
-
17
- def new_refund(transaction_id, supervisor_card: @supervisor_card, callback_url: @refund_callback_url)
18
- content = set_headers
19
- content[:body] = {type: "refund", parent_transaction_id: transaction_id, supervisor_card: supervisor_card, callback_url: callback_url}.to_json
20
- request = HTTParty.post("#{host}/transactions", content)
21
- return_vpos_object(request)
9
+ def new_payment(
10
+ customer: required,
11
+ amount: required,
12
+ pos_id: @pos_id,
13
+ callback_url: @payment_callback_url,
14
+ token: @token
15
+ )
16
+ conn = connection
17
+ response = conn.post('transactions') do |req|
18
+ req.headers['Authorization'] = "Bearer #{token}"
19
+ req.body = { type: "payment", pos_id: pos_id, mobile: customer, amount: amount, callback_url: callback_url }.to_json
20
+ end
21
+ return_vpos_object(response)
22
22
  end
23
23
 
24
- def get_transaction(transaction_id)
25
- request = HTTParty.get("#{host}/transactions/#{transaction_id}", set_headers)
26
- return_vpos_object(request)
24
+ def new_refund(parent_transaction_id: required, token: @token, callback_url: @refund_callback_url)
25
+ conn = connection
26
+ response = conn.post('transactions') do |req|
27
+ req.headers['Authorization'] = "Bearer #{token}"
28
+ req.body = { type: "refund", parent_transaction_id: parent_transaction_id, callback_url: callback_url }.to_json
29
+ end
30
+ return_vpos_object(response)
27
31
  end
28
32
 
29
- def get_transactions
30
- request = HTTParty.get("#{host}/transactions", set_headers)
31
- return_vpos_object(request)
33
+ def get_transaction(transaction_id: required, token: @token)
34
+ conn = connection
35
+ response = conn.get("transactions/#{transaction_id}") do |req|
36
+ req.headers['Authorization'] = "Bearer #{token}"
37
+ end
38
+ return_vpos_object(response)
32
39
  end
33
40
 
34
41
  def get_request_id(response)
35
42
  if response[:location].nil?
36
- HTTParty.get("#{host}/references/invalid", set_headers)
43
+ conn = connection
44
+ response = conn.get("references/invalid") do |req|
45
+ req.headers['Authorization'] = "Bearer #{token}"
46
+ end
37
47
  else
38
48
  if response[:status_code] == 202
39
49
  response[:location].gsub("/api/v1/requests/", "")
@@ -43,31 +53,55 @@ module VposModule
43
53
  end
44
54
  end
45
55
 
46
- def get_request(request_id)
47
- request = HTTParty.get("#{host}/requests/#{request_id}", set_headers)
48
- return_vpos_object(request)
56
+ def get_request(request_id: required, token: @token)
57
+ conn = connection
58
+ response = conn.get("requests/#{request_id}") do |req|
59
+ req.headers['Authorization'] = "Bearer #{token}"
60
+ end
61
+ return_vpos_object(response)
49
62
  end
50
63
 
51
64
  private
52
- def return_vpos_object(request)
53
- case request.response.code.to_i
54
- when 200, 201
55
- return {status_code: request.response.code.to_i, message: request.response.message, data: request.parsed_response}
65
+ def return_vpos_object(response)
66
+ case response.status
67
+ when 200
68
+ return { status_code: response.status, message: 'OK', data: JSON.parse(response.body).transform_keys(&:to_sym) }
69
+ when 201
70
+ return { status_code: response.status, message: 'CREATED', data: response.body }
56
71
  when 202, 303
57
- return {status_code: request.response.code.to_i, message: request.response.message, location: request.headers["location"]}
72
+ return { status_code: response.status, message: 'ACCEPTED', location: response.headers["location"]}
73
+ when 401
74
+ return { status_code: response.status, message: 'UNAUTHORIZED' }
75
+ when 404
76
+ return { status_code: response.status, message: 'NOT FOUND' }
58
77
  else
59
- return {status_code: request.response.code.to_i, message: request.response.message, details: request.parsed_response["errors"]}
78
+ return { status_code: response.status, message: response.status, details: JSON.parse(response.body).transform_keys(&:to_sym) }
60
79
  end
61
80
  end
62
81
 
63
82
  def set_headers
64
- content = {}
65
- headers = {'Content-Type' => "application/json", 'Accept' => "application/json", 'Authorization' => @token, 'Idempotency-Key' => SecureRandom.uuid}
66
- content[:headers] = headers
67
- content
83
+ headers = {'Content-Type' => "application/json", 'Accept' => "application/json", 'Idempotency-Key' => SecureRandom.uuid}
68
84
  end
69
85
 
70
86
  def host
71
87
  "https://vpos.ao/api/v1"
72
88
  end
89
+
90
+ def params
91
+ params = {}
92
+ end
93
+
94
+ def connection
95
+ conn = Faraday.new(
96
+ url: host,
97
+ params: params,
98
+ headers: set_headers
99
+ )
100
+ end
101
+
102
+ def required
103
+ method = caller_locations(1,1)[0].label
104
+ raise ArgumentError,
105
+ "A required keyword argument was not specified when calling '#{method}'"
106
+ end
73
107
  end
data/vpos.gemspec CHANGED
@@ -22,8 +22,8 @@ Gem::Specification.new do |spec|
22
22
  spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
23
23
  spec.require_paths = ["lib"]
24
24
 
25
- spec.add_development_dependency "bundler", '~> 2.2', '>= 2.2.3'
25
+ spec.add_development_dependency 'bundler', '~> 2.2', '>= 2.3.14'
26
26
  spec.add_development_dependency 'rake', '~> 12.3', '>= 12.3.3'
27
- spec.add_dependency "httparty", "~> 0.18.1"
28
- spec.add_dependency "rspec", '~> 3.9', ">= 3.9.0"
29
- end
27
+ spec.add_dependency 'faraday', '~> 2.3'
28
+ spec.add_dependency 'rspec', '~> 3.11', ">= 3.11.0"
29
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: vpos
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.4
4
+ version: 2.0.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Sergio Maziano
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-10-01 00:00:00.000000000 Z
11
+ date: 2022-07-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -19,7 +19,7 @@ dependencies:
19
19
  version: '2.2'
20
20
  - - ">="
21
21
  - !ruby/object:Gem::Version
22
- version: 2.2.3
22
+ version: 2.3.14
23
23
  type: :development
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
@@ -29,7 +29,7 @@ dependencies:
29
29
  version: '2.2'
30
30
  - - ">="
31
31
  - !ruby/object:Gem::Version
32
- version: 2.2.3
32
+ version: 2.3.14
33
33
  - !ruby/object:Gem::Dependency
34
34
  name: rake
35
35
  requirement: !ruby/object:Gem::Requirement
@@ -51,39 +51,39 @@ dependencies:
51
51
  - !ruby/object:Gem::Version
52
52
  version: 12.3.3
53
53
  - !ruby/object:Gem::Dependency
54
- name: httparty
54
+ name: faraday
55
55
  requirement: !ruby/object:Gem::Requirement
56
56
  requirements:
57
57
  - - "~>"
58
58
  - !ruby/object:Gem::Version
59
- version: 0.18.1
59
+ version: '2.3'
60
60
  type: :runtime
61
61
  prerelease: false
62
62
  version_requirements: !ruby/object:Gem::Requirement
63
63
  requirements:
64
64
  - - "~>"
65
65
  - !ruby/object:Gem::Version
66
- version: 0.18.1
66
+ version: '2.3'
67
67
  - !ruby/object:Gem::Dependency
68
68
  name: rspec
69
69
  requirement: !ruby/object:Gem::Requirement
70
70
  requirements:
71
71
  - - "~>"
72
72
  - !ruby/object:Gem::Version
73
- version: '3.9'
73
+ version: '3.11'
74
74
  - - ">="
75
75
  - !ruby/object:Gem::Version
76
- version: 3.9.0
76
+ version: 3.11.0
77
77
  type: :runtime
78
78
  prerelease: false
79
79
  version_requirements: !ruby/object:Gem::Requirement
80
80
  requirements:
81
81
  - - "~>"
82
82
  - !ruby/object:Gem::Version
83
- version: '3.9'
83
+ version: '3.11'
84
84
  - - ">="
85
85
  - !ruby/object:Gem::Version
86
- version: 3.9.0
86
+ version: 3.11.0
87
87
  description: The one stop shop for online payments in Angola, allowing you to process
88
88
  payments requests from EMIS GPO through vPOS.
89
89
  email:
@@ -100,6 +100,7 @@ files:
100
100
  - LICENSE.txt
101
101
  - README.md
102
102
  - Rakefile
103
+ - bin/.ruby-version
103
104
  - bin/console
104
105
  - bin/setup
105
106
  - lib/vpos.rb
@@ -126,8 +127,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
126
127
  - !ruby/object:Gem::Version
127
128
  version: '0'
128
129
  requirements: []
129
- rubyforge_project:
130
- rubygems_version: 2.7.6.2
130
+ rubygems_version: 3.2.22
131
131
  signing_key:
132
132
  specification_version: 4
133
133
  summary: The one stop shop for online payments in Angola.