issuer_response_codes 0.2.0 → 0.2.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.ruby-gemset +1 -0
- data/Gemfile.lock +1 -1
- data/README.md +78 -19
- data/lib/issuer_response_codes/code.rb +4 -4
- data/lib/issuer_response_codes/locale_library.rb +38 -1
- data/lib/issuer_response_codes/tds_code.rb +11 -21
- data/lib/issuer_response_codes/version.rb +1 -1
- data/lib/issuer_response_codes.rb +1 -1
- data/lib/locale/da.yml +130 -66
- data/lib/locale/de.yml +292 -0
- data/lib/locale/ee.yml +129 -66
- data/lib/locale/en.yml +255 -102
- data/lib/locale/it.yml +289 -0
- data/lib/locale/lt.yml +130 -66
- data/lib/locale/lv.yml +130 -66
- data/lib/locale/pl.yml +271 -100
- data/lib/locale/sv.yml +130 -66
- metadata +8 -5
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: dac9d604f2e19423d50223600a7919c737ad77eaa6d20a81478f36dadc907cbb
|
4
|
+
data.tar.gz: 92cf2b531073ec57418906a5996b3b6fcdfeb2771c3646e7879178e73f836bcd
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ac1b7680c8c076ac0f06108cc96e685c058fb506240e189f9ea14f7e4ec132d51fd279571bf39a441709adfad8f8bfcc3f798d397d16b82e5ce10f6c7a113937
|
7
|
+
data.tar.gz: 3c106d735298510ae3a73742b8ff40eb264a5cff307eb7cc6cc71a8031d6b3f21d7fdea9cda437e2e178746a48f7b0e597422d7c2248494d743ff2aa94a82891
|
data/.ruby-gemset
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
issuer_response_codes
|
data/Gemfile.lock
CHANGED
data/README.md
CHANGED
@@ -1,13 +1,15 @@
|
|
1
1
|
# IssuerResponseCodes
|
2
2
|
|
3
|
-
This gem provides a quite comprehensive library of Issuer Response Code and 3D-Secure Status Code descriptions (for both cardholders and merchants) with suggested actions in
|
3
|
+
This gem provides a quite comprehensive library of Issuer Response Code and 3D-Secure Status Code descriptions (for both cardholders and merchants) with suggested actions in 9 languages:
|
4
4
|
- Complete locales:
|
5
5
|
- en
|
6
6
|
- pl
|
7
7
|
|
8
8
|
- Incomplete locales:
|
9
9
|
- da
|
10
|
+
- de
|
10
11
|
- ee
|
12
|
+
- it
|
11
13
|
- lt
|
12
14
|
- lv
|
13
15
|
- sv
|
@@ -176,7 +178,7 @@ code = ::IssuerResponseCodes::Code.new(id: '59')
|
|
176
178
|
code.behaviour #=> "Please contact your card issuer to get more details and try again later."
|
177
179
|
```
|
178
180
|
|
179
|
-
##### description
|
181
|
+
##### description/humanize
|
180
182
|
|
181
183
|
The `description` method (aliased as `humanize`) is a combination of both the `reason` and `behaviour` of a Issuer Response Code
|
182
184
|
|
@@ -219,14 +221,41 @@ You can choose the main target of these descriptions (certain details are hidden
|
|
219
221
|
|
220
222
|
# fraud_notice is set to true by default when target = :merchant
|
221
223
|
code = ::IssuerResponseCodes::TdsCode.new(id: '11')
|
222
|
-
code.reason #=> "Suspected fraud"
|
224
|
+
code.reason #=> "Suspected fraud."
|
223
225
|
|
224
226
|
code = ::IssuerResponseCodes::TdsCode.new(id: '11', target: :merchant)
|
225
|
-
code.reason #=> "Suspected fraud"
|
227
|
+
code.reason #=> "Suspected fraud."
|
226
228
|
|
227
229
|
# fraud_notice is set to false by default when target = :cardholder
|
228
230
|
code = ::IssuerResponseCodes::TdsCode.new(id: '11', target: :cardholder)
|
229
|
-
code.reason #=> "Card authentication failed"
|
231
|
+
code.reason #=> "Card authentication failed."
|
232
|
+
```
|
233
|
+
|
234
|
+
##### Fraud notice
|
235
|
+
|
236
|
+
Certain 3D-Secure status codes may signify that the transaction may be viewed as a fraud attempt. As such, this gem provides appropriate warnings. You can manually decide whether these warnings/notices should be added to descriptions or behaviour suggestions generated by this gem.
|
237
|
+
|
238
|
+
By default descriptions targeted at merchants have these warnings, while those targeted at cardholders omit them.
|
239
|
+
|
240
|
+
```ruby
|
241
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '09', target: :merchant)
|
242
|
+
code.behaviour #=> "Please use a different card or contact issuer. Transactions with this code may be considered fraudulent."
|
243
|
+
|
244
|
+
# fraud_notice is set to false by default when target = :cardholder
|
245
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '09', target: :cardholder)
|
246
|
+
code.behaviour #=> "Please use a different card or contact issuer."
|
247
|
+
```
|
248
|
+
|
249
|
+
This however can be overridden by explicitly passing the `fraud_notice` keyword parameter
|
250
|
+
|
251
|
+
```ruby
|
252
|
+
# default options can be overridden
|
253
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '09', target: :merchant, fraud_notice: false)
|
254
|
+
code.behaviour #=> "Please use a different card or contact issuer."
|
255
|
+
|
256
|
+
# fraud_notice is set to false by default when target = :cardholder
|
257
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '09', target: :cardholder, fraud_notice: true)
|
258
|
+
code.behaviour #=> "Please use a different card or contact issuer. Transactions with this code may be considered fraudulent."
|
230
259
|
```
|
231
260
|
|
232
261
|
##### Locale
|
@@ -234,31 +263,61 @@ code.reason #=> "Card authentication failed"
|
|
234
263
|
The default locale is `:en`. There are 7 in total: `%i[en pl da ee lt lv sv]`. Only the first two are complete, the rest are partially in English.
|
235
264
|
|
236
265
|
```ruby
|
237
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '11')
|
238
|
-
code.reason #=> "
|
266
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '11', target: :cardholder)
|
267
|
+
code.reason #=> "Card authentication failed."
|
239
268
|
|
240
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '11', locale: :en)
|
241
|
-
code.reason #=> "
|
269
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '11', locale: :en, target: :cardholder)
|
270
|
+
code.reason #=> "Card authentication failed."
|
242
271
|
|
243
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '11', locale: :pl)
|
244
|
-
code.reason #=> "
|
272
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '11', locale: :pl, target: :cardholder)
|
273
|
+
code.reason #=> "Negatywny wynik silnego uwierzytelnienia w systemie banku."
|
245
274
|
```
|
246
275
|
|
247
276
|
#### Methods
|
248
277
|
|
249
|
-
#####
|
278
|
+
##### reason
|
250
279
|
|
251
|
-
The `
|
280
|
+
The `reason` method returns a relatively short description of the main reason why the 3D-Secure status code appeared in the first place.
|
252
281
|
|
253
282
|
```ruby
|
254
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '
|
255
|
-
code.
|
283
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '01')
|
284
|
+
code.reason #=> "Card authentication failed."
|
256
285
|
|
257
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '
|
258
|
-
code.
|
286
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '07')
|
287
|
+
code.reason #=> "Invalid transaction."
|
259
288
|
|
260
|
-
code = ::IssuerResponseCodes::TdsCode.new(id: '
|
261
|
-
code.
|
289
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '20')
|
290
|
+
code.reason #=> "Non-Payment transaction not supported."
|
291
|
+
```
|
292
|
+
|
293
|
+
##### behaviour
|
294
|
+
|
295
|
+
The `behaviour` method returns a suggestion of what to do when the 3D-Secure status code appeared. Mainly for cardholders.
|
296
|
+
|
297
|
+
```ruby
|
298
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '01')
|
299
|
+
code.behaviour #=> "Check entered data and try again."
|
300
|
+
|
301
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '07')
|
302
|
+
code.behaviour #=> "Please check funds on your account and try again later."
|
303
|
+
|
304
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '20')
|
305
|
+
code.behaviour #=> "Please contact your card issuer to get more details and try again later."
|
306
|
+
```
|
307
|
+
|
308
|
+
##### description/humanize
|
309
|
+
|
310
|
+
The `description` method (aliased as `humanize`) is a combination of both the `reason` and `behaviour` of a Issuer Response Code
|
311
|
+
|
312
|
+
```ruby
|
313
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '01')
|
314
|
+
code.description #=> "Invalid card number. Check entered data and try again."
|
315
|
+
|
316
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '07')
|
317
|
+
code.description #=> "Insufficient funds. Please check funds on your account and try again later."
|
318
|
+
|
319
|
+
code = ::IssuerResponseCodes::TdsCode.new(id: '20')
|
320
|
+
code.description #=> "Your bank has declined this transaction. Please contact your card issuer to get more details and try again later."
|
262
321
|
```
|
263
322
|
|
264
323
|
##### fraudulent_code?
|
@@ -32,15 +32,15 @@ module IssuerResponseCodes
|
|
32
32
|
LOCALE_LIBRARY.dig(path: id, scope: "issuer_response_codes.targeted.#{target}", locale: locale, default: :unknown)
|
33
33
|
end
|
34
34
|
|
35
|
-
def fraudulent_code?
|
36
|
-
@fraudulent_code ||= LOCALE_LIBRARY.dig(path: id, scope: "issuer_response_codes.fraudulent_codes", locale: locale)
|
37
|
-
end
|
38
|
-
|
39
35
|
def behaviour
|
40
36
|
behaviour_str = LOCALE_LIBRARY.dig(path: id, scope: "issuer_response_codes.behaviour", locale: locale, default: :unknown)
|
41
37
|
return behaviour_str unless fraud_notice && fraudulent_code?
|
42
38
|
|
43
39
|
"#{behaviour_str} #{LOCALE_LIBRARY.dig(path: 'issuer_response_codes.fraud_notice')}"
|
44
40
|
end
|
41
|
+
|
42
|
+
def fraudulent_code?
|
43
|
+
@fraudulent_code ||= LOCALE_LIBRARY.dig(path: id, scope: "issuer_response_codes.fraudulent_codes", locale: locale)
|
44
|
+
end
|
45
45
|
end
|
46
46
|
end
|
@@ -1,7 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require 'yaml'
|
4
|
-
require 'byebug'
|
5
4
|
|
6
5
|
module IssuerResponseCodes
|
7
6
|
class LocaleLibrary
|
@@ -23,6 +22,44 @@ module IssuerResponseCodes
|
|
23
22
|
result.gsub(/%{substitute}/, substitute)
|
24
23
|
end
|
25
24
|
|
25
|
+
def issuer_response_codes(locale: :en)
|
26
|
+
fraudulent_codes = locale_hash.dig(locale, :issuer_response_codes, :fraudulent_codes)
|
27
|
+
behaviours = locale_hash.dig(locale, :issuer_response_codes, :behaviour)
|
28
|
+
cardholder_reasons = locale_hash.dig(locale, :issuer_response_codes, :targeted, :cardholder)
|
29
|
+
merchant_reasons = locale_hash.dig(locale, :issuer_response_codes, :targeted, :merchant)
|
30
|
+
|
31
|
+
merchant_reasons.map do |code, merchant_reason|
|
32
|
+
[
|
33
|
+
code,
|
34
|
+
{
|
35
|
+
merchant_reason: merchant_reason,
|
36
|
+
cardholder_reason: cardholder_reasons[code],
|
37
|
+
behaviour: behaviours[code],
|
38
|
+
fraudulent: fraudulent_codes[code] == true
|
39
|
+
}
|
40
|
+
]
|
41
|
+
end.to_h
|
42
|
+
end
|
43
|
+
|
44
|
+
def tds_codes(locale: :en)
|
45
|
+
fraudulent_codes = locale_hash.dig(locale, :tds_status_codes, :fraudulent_codes)
|
46
|
+
behaviours = locale_hash.dig(locale, :tds_status_codes, :behaviour)
|
47
|
+
cardholder_reasons = locale_hash.dig(locale, :tds_status_codes, :targeted, :cardholder)
|
48
|
+
merchant_reasons = locale_hash.dig(locale, :tds_status_codes, :targeted, :merchant)
|
49
|
+
|
50
|
+
merchant_reasons.map do |code, merchant_reason|
|
51
|
+
[
|
52
|
+
code,
|
53
|
+
{
|
54
|
+
merchant_reason: merchant_reason,
|
55
|
+
cardholder_reason: cardholder_reasons[code],
|
56
|
+
behaviour: behaviours[code],
|
57
|
+
fraudulent: fraudulent_codes[code] == true
|
58
|
+
}
|
59
|
+
]
|
60
|
+
end.to_h
|
61
|
+
end
|
62
|
+
|
26
63
|
def self.symbolize_keys(hash)
|
27
64
|
h = hash.map do |k, v|
|
28
65
|
v_sym = if v.instance_of? Hash
|
@@ -1,33 +1,23 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module IssuerResponseCodes
|
4
|
-
class TdsCode
|
5
|
-
|
6
|
-
|
7
|
-
NOT_PROVIDED = ::Object.new
|
8
|
-
|
9
|
-
def initialize(id:, target: :merchant, locale: :en, fraud_notice: NOT_PROVIDED)
|
10
|
-
@id = id
|
11
|
-
@target = target
|
12
|
-
@locale = locale
|
13
|
-
|
14
|
-
raise IllegalLocale, "No such locale: #{locale.inspect}" unless AVAILABLE_LOCALES.include?(locale)
|
15
|
-
raise IllegalTarget, "No such target: #{target.inspect}" unless AVAILABLE_TARGETS.include?(target)
|
16
|
-
|
17
|
-
if fraud_notice != NOT_PROVIDED
|
18
|
-
@fraud_notice = fraud_notice
|
19
|
-
return
|
20
|
-
end
|
21
|
-
|
22
|
-
@fraud_notice = target == :merchant
|
4
|
+
class TdsCode < Code
|
5
|
+
def humanize
|
6
|
+
"#{reason} #{behaviour}"
|
23
7
|
end
|
24
8
|
|
9
|
+
alias description humanize
|
10
|
+
|
25
11
|
def reason
|
26
12
|
LOCALE_LIBRARY.dig(path: id, scope: "tds_status_codes.targeted.#{target}", locale: locale, default: :unknown)
|
27
13
|
end
|
28
14
|
|
29
|
-
|
30
|
-
|
15
|
+
def behaviour
|
16
|
+
behaviour_str = LOCALE_LIBRARY.dig(path: id, scope: "tds_status_codes.behaviour", locale: locale, default: :unknown)
|
17
|
+
return behaviour_str unless fraud_notice && fraudulent_code?
|
18
|
+
|
19
|
+
"#{behaviour_str} #{LOCALE_LIBRARY.dig(path: 'tds_status_codes.fraud_notice')}"
|
20
|
+
end
|
31
21
|
|
32
22
|
def fraudulent_code?
|
33
23
|
@fraudulent_code ||= LOCALE_LIBRARY.dig(path: id, scope: "tds_status_codes.fraudulent_codes", locale: locale)
|
@@ -11,7 +11,7 @@ module IssuerResponseCodes
|
|
11
11
|
class IllegalLocale < StandardError; end
|
12
12
|
|
13
13
|
AVAILABLE_TARGETS = %i[merchant cardholder].freeze
|
14
|
-
AVAILABLE_LOCALES = %i[en pl da ee lt lv sv].freeze
|
14
|
+
AVAILABLE_LOCALES = %i[en pl da de ee it lt lv sv].freeze
|
15
15
|
|
16
16
|
LOCALE_LIBRARY = LocaleLibrary.new
|
17
17
|
end
|
data/lib/locale/da.yml
CHANGED
@@ -4,43 +4,107 @@ da:
|
|
4
4
|
'09': true
|
5
5
|
'10': true
|
6
6
|
'11': true
|
7
|
+
behaviour:
|
8
|
+
unknown: 'Please contact our support team.'
|
9
|
+
'01': Please try again.
|
10
|
+
'02': Please try again using a different device.
|
11
|
+
'03': Please try again using a different device.
|
12
|
+
'04': Please use a different card or contact your card issuer.
|
13
|
+
'05': Please use a different card.
|
14
|
+
'06': Please use a different card or check the card number.
|
15
|
+
'07': Please use a different card.
|
16
|
+
'08': Please use a different card.
|
17
|
+
'09': Please use a different card or contact issuer.
|
18
|
+
'10': Please use a different card or contact issuer.
|
19
|
+
'11': Please use a different card or contact issuer.
|
20
|
+
'12': Please use a different card or contact issuer.
|
21
|
+
'13': Please use a different card or contact issuer.
|
22
|
+
'14': Please try again or use a different card.
|
23
|
+
'15': Please use a different card or contact issuer.
|
24
|
+
'16': Please use a different card or contact issuer.
|
25
|
+
'17': Please use a different card or contact issuer.
|
26
|
+
'18': Please use a different card or contact issuer.
|
27
|
+
'19': Please use a different card or contact issuer.
|
28
|
+
'20': Please use a different card.
|
29
|
+
'21': Please use a different card.
|
30
|
+
'22': Please try again or use a different card.
|
31
|
+
'23': Please use a different card or contact issuer.
|
32
|
+
'24': Please try again or use a different card.
|
33
|
+
'25': Please try again or use a different card.
|
34
|
+
'26': Please try again or use a different card.
|
35
|
+
'80': Please use a different card.
|
36
|
+
'81': Please try again or use a different card.
|
37
|
+
'82': Please use a different card.
|
38
|
+
'83': Please use a different card.
|
39
|
+
'84': Please try again or use a different card.
|
40
|
+
'85': Please use a different card.
|
41
|
+
'86': Please use a different card.
|
42
|
+
'87': Please use a different card.
|
43
|
+
'88': Please use a different card.
|
7
44
|
universal: &universal_tds_status_codes
|
8
45
|
unknown: "Unknown reason."
|
9
|
-
'01': Card authentication failed
|
10
|
-
'02': Unknown Device
|
11
|
-
'03': Unsupported Device
|
12
|
-
'04': Exceeds authentication frequency limit
|
13
|
-
'05': Expired card
|
14
|
-
'06': Invalid card number
|
15
|
-
'07': Invalid transaction
|
16
|
-
'08': No Card record
|
17
|
-
'
|
18
|
-
'
|
19
|
-
'
|
20
|
-
'
|
21
|
-
'
|
22
|
-
'
|
23
|
-
'18': Very High confidence
|
24
|
-
'19': Exceeds ACS maximum challenges
|
25
|
-
'20': Non-Payment transaction not supported
|
26
|
-
'21': 3RI transaction not supported
|
27
|
-
'22': ACS technical issue
|
28
|
-
'23': Decoupled Authentication required by ACS but not requested by 3DS Requestor
|
29
|
-
'24': 3DS Requestor Decoupled Max Expiry Time exceeded
|
30
|
-
'25': Decoupled Authentication was provided insufficient time to authenticate cardholder. ACS will not make attempt
|
31
|
-
'26': Authentication attempted but not performed by the cardholder
|
32
|
-
|
46
|
+
'01': Card authentication failed.
|
47
|
+
'02': Unknown Device.
|
48
|
+
'03': Unsupported Device.
|
49
|
+
'04': Exceeds authentication frequency limit.
|
50
|
+
'05': Expired card.
|
51
|
+
'06': Invalid card number.
|
52
|
+
'07': Invalid transaction.
|
53
|
+
'08': No Card record.
|
54
|
+
'15': Low confidence.
|
55
|
+
'16': Medium confidence.
|
56
|
+
'17': High confidence.
|
57
|
+
'18': Very High confidence.
|
58
|
+
'19': Exceeds ACS maximum challenges.
|
59
|
+
'20': Non-Payment transaction not supported.
|
33
60
|
targeted:
|
34
|
-
cardholder:
|
35
|
-
<<: *universal_tds_status_codes
|
36
|
-
'09': Card authentication failed # Security failure
|
37
|
-
'10': Card authentication failed # Stolen card
|
38
|
-
'11': Card authentication failed # Suspected fraud
|
39
61
|
merchant:
|
40
62
|
<<: *universal_tds_status_codes
|
41
|
-
'09': Security failure
|
42
|
-
'10': Stolen card
|
43
|
-
'11': Suspected fraud
|
63
|
+
'09': Security failure.
|
64
|
+
'10': Stolen card.
|
65
|
+
'11': Suspected fraud.
|
66
|
+
'12': Transaction not permitted to cardholder.
|
67
|
+
'13': Cardholder not enrolled in service.
|
68
|
+
'14': Transaction timed out at the ACS.
|
69
|
+
'21': 3RI transaction not supported.
|
70
|
+
'22': ACS technical issue.
|
71
|
+
'23': Decoupled Authentication required by ACS but not requested by 3DS Requestor.
|
72
|
+
'24': 3DS Requestor Decoupled Max Expiry Time exceeded.
|
73
|
+
'25': Decoupled Authentication was provided insufficient time to authenticate cardholder. ACS will not make attempt.
|
74
|
+
'26': Authentication attempted but not performed by the cardholder.
|
75
|
+
'80': Error Connecting to ACS.
|
76
|
+
'81': ACS Timed Out.
|
77
|
+
'82': Invalid Response from ACS.
|
78
|
+
'83': System Error Response from ACS.
|
79
|
+
'84': Internal Error While Generating CAVV.
|
80
|
+
'85': VMID not eligible for requested program.
|
81
|
+
'86': Protocol Version Not Supported by ACS.
|
82
|
+
'87': Transaction is excluded from Attempts Processing (includes non- reloadable pre-paid cards and Non- Payments (NPA)).
|
83
|
+
'88': Requested program not supported by the ACS.
|
84
|
+
cardholder:
|
85
|
+
<<: *universal_tds_status_codes
|
86
|
+
'09': Card authentication failed. # Security failure
|
87
|
+
'10': Card authentication failed. # Stolen card
|
88
|
+
'11': Card authentication failed. # Suspected fraud
|
89
|
+
'12': Transaction not permitted to cardholder.
|
90
|
+
'13': Cardholder not enrolled in service.
|
91
|
+
'14': Card authentication failed.
|
92
|
+
'21': Card authentication failed.
|
93
|
+
'22': Issuer technical issue.
|
94
|
+
'23': Card authentication failed
|
95
|
+
'24': Card authentication failed
|
96
|
+
'25': Card authentication failed.
|
97
|
+
'26': Card authentication failed.
|
98
|
+
'80': Card authentication failed.
|
99
|
+
'81': Card authentication failed.
|
100
|
+
'82': Card authentication failed.
|
101
|
+
'83': Card authentication failed.
|
102
|
+
'84': Card authentication failed.
|
103
|
+
'85': Card authentication failed.
|
104
|
+
'86': Card authentication failed.
|
105
|
+
'87': Card authentication failed.
|
106
|
+
'88': Card authentication failed.
|
107
|
+
|
44
108
|
issuer_response_codes:
|
45
109
|
suggestion: 'Suggestion'
|
46
110
|
fraud_notice: 'IMPORTANT NOTICE: It is forbidden to retry transactions that ended with this code. It may be recognized as a fraud attempt!'
|
@@ -49,40 +113,6 @@ da:
|
|
49
113
|
'07': true
|
50
114
|
'41': true
|
51
115
|
'43': true
|
52
|
-
universal: &issuer_response_code
|
53
|
-
'00': "En fejl opstod. Transaktionen blev afvist af Elavon på grund af ikke-understøttet korttype eller forkerte kortdata, intet svar fra udsteder / bank eller inaktiv Merchant-konto."
|
54
|
-
'05': "Banken har afvist transaktionen på grund af sikkerhedskontrol (brugt kort understøtter ikke tilbagebetalinger eller betaling uden CVV-kode), midlerne er blevet frosset eller grænsen overskredet, eller kortet understøtter ikke MOTO / internet-transaktioner."
|
55
|
-
'13': "MOTO / eCommerce betalinger på kort er inaktive eller beløbsgrænse overstiger."
|
56
|
-
'14': "Ugyldigt kortnummer."
|
57
|
-
'N7': "Negative CVV / CVC resultater."
|
58
|
-
'51': "Ikke nok penge."
|
59
|
-
'54': "Udgået kort."
|
60
|
-
'57': "Banken har afvist transaktionen, da dette kreditkort ikke kan bruges til denne type transaktion (e-handel, MOTO eller tilbagevendende)."
|
61
|
-
'61': "Banken har afvist transaktionen."
|
62
|
-
'82': "Negative CVV / CVC resultater."
|
63
|
-
# incomplete translations
|
64
|
-
unknown: "Unknown reason."
|
65
|
-
'01': "Authorization Error."
|
66
|
-
'02': "Authorization Error."
|
67
|
-
'03': "Authorization Error."
|
68
|
-
'12': "No privileges to execute this transaction for your card."
|
69
|
-
'30': "Your bank has declined this transaction"
|
70
|
-
'58': "Your bank has declined this transaction as this credit card cannot be used for this type of transaction (eccommerce, MOTO or recurring)."
|
71
|
-
'59': "Your bank has declined this transaction"
|
72
|
-
'62': "Your card can be not supported due to restrictions placed on the card or Seller country exclusion (imposition an embargo), or bank blocked a card eg. due to unacceptable debit balance."
|
73
|
-
'65': "Activity count limit exceeded."
|
74
|
-
'75': "Invalid activity count limit exceeded."
|
75
|
-
'78': "Inactive card."
|
76
|
-
'91': "Temporary issuer error."
|
77
|
-
'92': "Temporary issuer error."
|
78
|
-
'94': "Temporary issuer error."
|
79
|
-
'96': "Temporary issuer error."
|
80
|
-
'98': "Temporary issuer error."
|
81
|
-
'E3': "Transaction not executed due to a 3D-Secure error."
|
82
|
-
'E4': "Transaction not executed due to a negative 3D-Secure confirmation from your bank."
|
83
|
-
'E5': "Temporary 3D-Secure error."
|
84
|
-
'R0': "Refused by Issuer because Customer requested stop of specific recurring payments."
|
85
|
-
'R1': "Refused by Issuer because Customer requested stop of all recurring payments."
|
86
116
|
behaviour:
|
87
117
|
'00': "Prøv igen senere, kontakt med sælger eller med Espago Support Team."
|
88
118
|
'05': "Tjek venligst dine kortindstillinger for disse transaktionstyper eller brug et andet kort."
|
@@ -121,6 +151,40 @@ da:
|
|
121
151
|
'E5': "Please try again later or contact your card issuer to get more details"
|
122
152
|
'R0': "Please contact your card issuer to get more details and try again later."
|
123
153
|
'R1': "Please contact your card issuer to get more details and try again later."
|
154
|
+
universal: &issuer_response_code
|
155
|
+
'00': "En fejl opstod. Transaktionen blev afvist af Elavon på grund af ikke-understøttet korttype eller forkerte kortdata, intet svar fra udsteder / bank eller inaktiv Merchant-konto."
|
156
|
+
'05': "Banken har afvist transaktionen på grund af sikkerhedskontrol (brugt kort understøtter ikke tilbagebetalinger eller betaling uden CVV-kode), midlerne er blevet frosset eller grænsen overskredet, eller kortet understøtter ikke MOTO / internet-transaktioner."
|
157
|
+
'13': "MOTO / eCommerce betalinger på kort er inaktive eller beløbsgrænse overstiger."
|
158
|
+
'14': "Ugyldigt kortnummer."
|
159
|
+
'N7': "Negative CVV / CVC resultater."
|
160
|
+
'51': "Ikke nok penge."
|
161
|
+
'54': "Udgået kort."
|
162
|
+
'57': "Banken har afvist transaktionen, da dette kreditkort ikke kan bruges til denne type transaktion (e-handel, MOTO eller tilbagevendende)."
|
163
|
+
'61': "Banken har afvist transaktionen."
|
164
|
+
'82': "Negative CVV / CVC resultater."
|
165
|
+
# incomplete translations
|
166
|
+
unknown: "Unknown reason."
|
167
|
+
'01': "Authorization Error."
|
168
|
+
'02': "Authorization Error."
|
169
|
+
'03': "Authorization Error."
|
170
|
+
'12': "No privileges to execute this transaction for your card."
|
171
|
+
'30': "Your bank has declined this transaction"
|
172
|
+
'58': "Your bank has declined this transaction as this credit card cannot be used for this type of transaction (eccommerce, MOTO or recurring)."
|
173
|
+
'59': "Your bank has declined this transaction"
|
174
|
+
'62': "Your card can be not supported due to restrictions placed on the card or Seller country exclusion (imposition an embargo), or bank blocked a card eg. due to unacceptable debit balance."
|
175
|
+
'65': "Activity count limit exceeded."
|
176
|
+
'75': "Invalid activity count limit exceeded."
|
177
|
+
'78': "Inactive card."
|
178
|
+
'91': "Temporary issuer error."
|
179
|
+
'92': "Temporary issuer error."
|
180
|
+
'94': "Temporary issuer error."
|
181
|
+
'96': "Temporary issuer error."
|
182
|
+
'98': "Temporary issuer error."
|
183
|
+
'E3': "Transaction not executed due to a 3D-Secure error."
|
184
|
+
'E4': "Transaction not executed due to a negative 3D-Secure confirmation from your bank."
|
185
|
+
'E5': "Temporary 3D-Secure error."
|
186
|
+
'R0': "Refused by Issuer because Customer requested stop of specific recurring payments."
|
187
|
+
'R1': "Refused by Issuer because Customer requested stop of all recurring payments."
|
124
188
|
targeted:
|
125
189
|
merchant:
|
126
190
|
<<: *issuer_response_code
|