vpos 1.0.5 → 2.0.2
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 +4 -4
- data/.ruby-version +1 -1
- data/Gemfile.lock +20 -22
- data/README.md +124 -25
- data/bin/.ruby-version +1 -0
- data/lib/vpos/version.rb +1 -1
- data/lib/vpos.rb +27 -25
- data/lib/vpos_module.rb +69 -30
- data/vpos.gemspec +2 -2
- metadata +9 -9
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ae324e2a78d84e4cf8cca1967734ea03719b8ff46946564ec0f7c8228653fa71
|
4
|
+
data.tar.gz: 061aff774b1b88b38449ac1b9c522a461bec2c54369bc028002579af4430b653
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bb720f3a72e627b84f46b0019bc5d1b3c625597a75265d69dae8e8c6367d81e52f0a76481cba71099c17c2e54324395fd0a19ea8f5284f2d497b5da9a9cf4d3f
|
7
|
+
data.tar.gz: c4643e9b2131c53b33d8662811bed43529173fcc3c6f0bfb3fa18288819f47ec8e23ffaff65e7d5403f10db1d0c6db35a7c18b0f23fc4be3d61261528430cec7
|
data/.ruby-version
CHANGED
@@ -1 +1 @@
|
|
1
|
-
|
1
|
+
3.0.2
|
data/Gemfile.lock
CHANGED
@@ -1,35 +1,33 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
vpos (
|
5
|
-
|
6
|
-
rspec (~> 3.
|
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.
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
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.
|
21
|
-
rspec-core (~> 3.
|
22
|
-
rspec-expectations (~> 3.
|
23
|
-
rspec-mocks (~> 3.
|
24
|
-
rspec-core (3.
|
25
|
-
rspec-support (~> 3.
|
26
|
-
rspec-expectations (3.
|
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.
|
29
|
-
rspec-mocks (3.
|
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.
|
32
|
-
rspec-support (3.
|
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
|
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', '~>
|
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
|
-
|
56
|
+
vpos = Vpos.new
|
56
57
|
|
57
58
|
# or use optional arguments option
|
58
|
-
|
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,57 +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
79
|
|
81
80
|
### Get a specific Transaction
|
82
|
-
Retrieves a transaction given a valid transaction ID
|
81
|
+
Retrieves a transaction given a valid transaction ID:
|
83
82
|
|
84
83
|
```ruby
|
85
|
-
|
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
|
+
# }
|
86
104
|
```
|
87
105
|
|
88
|
-
| Argument | Description | Type |
|
89
|
-
| --- | --- | --- |
|
90
|
-
| `
|
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) |
|
91
110
|
|
92
111
|
### New Payment Transaction
|
93
112
|
Creates a new payment transaction given a valid mobile number associated with a `MULTICAIXA` account
|
94
|
-
and a valid amount
|
113
|
+
and a valid amount:
|
95
114
|
|
96
115
|
```ruby
|
97
|
-
|
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
|
+
# }
|
98
142
|
```
|
99
143
|
|
100
|
-
| Argument | Description | Type |
|
101
|
-
| --- | --- | --- |
|
102
|
-
| `
|
103
|
-
| `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 |
|
104
150
|
|
105
151
|
### Request Refund
|
106
|
-
Given an existing `parent_transaction_id`, request a refund.
|
152
|
+
Given an existing `parent_transaction_id`, request a refund using a env variable token.
|
107
153
|
|
108
154
|
```ruby
|
109
|
-
|
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
|
+
# }
|
110
181
|
```
|
111
182
|
|
112
|
-
| Argument | Description | Type |
|
113
|
-
| --- | --- | --- |
|
183
|
+
| Argument | Description | Type | Required |
|
184
|
+
| --- | --- | --- | --- |
|
114
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 |
|
115
188
|
|
116
189
|
### Poll Transaction Status
|
117
|
-
Poll the status of a transaction given a valid `request_id
|
190
|
+
Poll the status of a transaction given a valid `request_id`
|
118
191
|
|
119
192
|
Note: The `request_id` in this context is essentially the `transaction_id` of an existing request.
|
120
193
|
|
121
194
|
```ruby
|
122
|
-
|
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
|
+
# }
|
123
221
|
```
|
124
222
|
|
125
|
-
| Argument | Description | Type |
|
126
|
-
| --- | --- | --- |
|
127
|
-
| `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) |
|
128
227
|
|
129
228
|
### Have any doubts?
|
130
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
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,
|
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
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
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
|
+
"#{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,34 +1,49 @@
|
|
1
1
|
require "vpos/version"
|
2
|
-
require "
|
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(
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
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)
|
15
22
|
end
|
16
23
|
|
17
|
-
def new_refund(
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
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)
|
22
31
|
end
|
23
32
|
|
24
|
-
def get_transaction(transaction_id)
|
25
|
-
|
26
|
-
|
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)
|
27
39
|
end
|
28
40
|
|
29
41
|
def get_request_id(response)
|
30
42
|
if response[:location].nil?
|
31
|
-
|
43
|
+
conn = connection
|
44
|
+
response = conn.get("references/invalid") do |req|
|
45
|
+
req.headers['Authorization'] = "Bearer #{token}"
|
46
|
+
end
|
32
47
|
else
|
33
48
|
if response[:status_code] == 202
|
34
49
|
response[:location].gsub("/api/v1/requests/", "")
|
@@ -38,31 +53,55 @@ module VposModule
|
|
38
53
|
end
|
39
54
|
end
|
40
55
|
|
41
|
-
def get_request(request_id)
|
42
|
-
|
43
|
-
|
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)
|
44
62
|
end
|
45
63
|
|
46
64
|
private
|
47
|
-
def return_vpos_object(
|
48
|
-
case
|
49
|
-
when 200
|
50
|
-
return {status_code:
|
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 }
|
51
71
|
when 202, 303
|
52
|
-
return {status_code:
|
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' }
|
53
77
|
else
|
54
|
-
return {status_code:
|
78
|
+
return { status_code: response.status, message: response.status, details: JSON.parse(response.body).transform_keys(&:to_sym) }
|
55
79
|
end
|
56
80
|
end
|
57
81
|
|
58
82
|
def set_headers
|
59
|
-
|
60
|
-
headers = {'Content-Type' => "application/json", 'Accept' => "application/json", 'Authorization' => @token, 'Idempotency-Key' => SecureRandom.uuid}
|
61
|
-
content[:headers] = headers
|
62
|
-
content
|
83
|
+
headers = {'Content-Type' => "application/json", 'Accept' => "application/json", 'Idempotency-Key' => SecureRandom.uuid}
|
63
84
|
end
|
64
85
|
|
65
86
|
def host
|
66
87
|
"https://vpos.ao/api/v1"
|
67
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
|
68
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.
|
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 '
|
27
|
+
spec.add_dependency 'faraday', '~> 2.3'
|
28
28
|
spec.add_dependency 'rspec', '~> 3.11', ">= 3.11.0"
|
29
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:
|
4
|
+
version: 2.0.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Sergio Maziano
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-
|
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.
|
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.
|
32
|
+
version: 2.3.14
|
33
33
|
- !ruby/object:Gem::Dependency
|
34
34
|
name: rake
|
35
35
|
requirement: !ruby/object:Gem::Requirement
|
@@ -51,19 +51,19 @@ dependencies:
|
|
51
51
|
- !ruby/object:Gem::Version
|
52
52
|
version: 12.3.3
|
53
53
|
- !ruby/object:Gem::Dependency
|
54
|
-
name:
|
54
|
+
name: faraday
|
55
55
|
requirement: !ruby/object:Gem::Requirement
|
56
56
|
requirements:
|
57
57
|
- - "~>"
|
58
58
|
- !ruby/object:Gem::Version
|
59
|
-
version:
|
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:
|
66
|
+
version: '2.3'
|
67
67
|
- !ruby/object:Gem::Dependency
|
68
68
|
name: rspec
|
69
69
|
requirement: !ruby/object:Gem::Requirement
|
@@ -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
|
-
|
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.
|