@fat-zebra/sdk 1.0.5 → 1.2.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.
- package/CHANGELOG.md +13 -0
- package/README.md +162 -0
- package/dist/applepay/applepay.d.ts +20 -0
- package/dist/applepay/applepay.js +93 -0
- package/dist/applepay/clients/apple-pay-client.d.ts +24 -0
- package/dist/applepay/clients/apple-pay-client.js +29 -0
- package/dist/applepay/clients/paynow-client.d.ts +17 -0
- package/dist/applepay/clients/paynow-client.js +55 -0
- package/dist/applepay/index.d.ts +1 -0
- package/dist/applepay/index.js +1 -0
- package/dist/env.d.ts +5 -0
- package/dist/env.development.d.ts +5 -0
- package/dist/env.development.js +5 -0
- package/dist/env.js +5 -0
- package/dist/hpp/hpp.d.ts +61 -0
- package/dist/hpp/hpp.js +186 -0
- package/dist/hpp/index.d.ts +2 -0
- package/dist/hpp/index.js +1 -0
- package/dist/index.d.ts +5 -2
- package/dist/index.js +6 -2
- package/dist/local/fatzebra.js +17728 -0
- package/dist/local/fatzebra.js.map +1 -0
- package/dist/local/index.html +247 -0
- package/dist/main.d.ts +38 -0
- package/dist/main.js +148 -0
- package/dist/paypal/paypal-button.d.ts +31 -0
- package/dist/paypal/paypal-button.js +199 -0
- package/dist/paypal/paypal-checkout.d.ts +21 -0
- package/dist/paypal/paypal-checkout.js +100 -0
- package/dist/paypal/types.d.ts +188 -0
- package/dist/paypal/types.js +5 -0
- package/dist/paypal/validation.d.ts +4 -0
- package/dist/paypal/validation.js +65 -0
- package/dist/react/VerifyCard.d.ts +2 -4
- package/dist/react/VerifyCard.js +3 -3
- package/dist/react/url.d.ts +3 -18
- package/dist/react/url.js +3 -29
- package/dist/react/useFatZebra.d.ts +2 -3
- package/dist/react/useFatZebra.js +7 -7
- package/dist/sca/cardinal.d.ts +1 -1
- package/dist/sca/cardinal.js +1 -1
- package/dist/sca/index.d.ts +8 -5
- package/dist/sca/index.js +26 -85
- package/dist/sca/sca.d.ts +42 -0
- package/dist/sca/sca.js +273 -0
- package/dist/sca/scenarios/index.d.ts +3 -2
- package/dist/sca/types.d.ts +1 -1
- package/dist/sca/types.js +1 -1
- package/dist/shared/api-gateway-client.d.ts +7 -0
- package/dist/shared/api-gateway-client.js +35 -1
- package/dist/shared/env.d.ts +5 -0
- package/dist/shared/env.development.d.ts +5 -0
- package/dist/shared/env.development.js +5 -0
- package/dist/shared/env.js +5 -0
- package/dist/shared/event-manager.d.ts +1 -1
- package/dist/shared/event-manager.js +0 -1
- package/dist/shared/post-message-client.d.ts +1 -1
- package/dist/shared/post-message-client.js +1 -1
- package/dist/shared/types.d.ts +40 -33
- package/dist/shared/types.js +7 -1
- package/dist/src/applepay/applepay.js +198 -0
- package/dist/src/applepay/applepay.js.map +1 -0
- package/dist/src/applepay/clients/apple-pay-client.js +66 -0
- package/dist/src/applepay/clients/apple-pay-client.js.map +1 -0
- package/dist/src/applepay/clients/paynow-client.js +96 -0
- package/dist/src/applepay/clients/paynow-client.js.map +1 -0
- package/dist/src/applepay/index.js +6 -0
- package/dist/src/applepay/index.js.map +1 -0
- package/dist/src/hpp/hpp.js +230 -0
- package/dist/src/hpp/hpp.js.map +1 -0
- package/dist/src/hpp/hpp.test.js +135 -0
- package/dist/src/hpp/hpp.test.js.map +1 -0
- package/dist/src/hpp/index.js +6 -0
- package/dist/src/hpp/index.js.map +1 -0
- package/dist/src/index.js +7 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/main.js +225 -0
- package/dist/src/main.js.map +1 -0
- package/dist/src/main.test.js +236 -0
- package/dist/src/main.test.js.map +1 -0
- package/dist/src/paypal/paypal-button.js +311 -0
- package/dist/src/paypal/paypal-button.js.map +1 -0
- package/dist/src/paypal/paypal-button.test.js +41 -0
- package/dist/src/paypal/paypal-button.test.js.map +1 -0
- package/dist/src/paypal/paypal-checkout.js +111 -0
- package/dist/src/paypal/paypal-checkout.js.map +1 -0
- package/dist/src/paypal/paypal-checkout.test.js +167 -0
- package/dist/src/paypal/paypal-checkout.test.js.map +1 -0
- package/dist/src/paypal/types.js +9 -0
- package/dist/src/paypal/types.js.map +1 -0
- package/dist/src/paypal/validation.js +73 -0
- package/dist/src/paypal/validation.js.map +1 -0
- package/dist/src/sca/__tests__/eci-mappings.test.js +31 -0
- package/dist/src/sca/__tests__/eci-mappings.test.js.map +1 -0
- package/dist/src/sca/__tests__/index.test.js +558 -0
- package/dist/src/sca/__tests__/index.test.js.map +1 -0
- package/dist/src/sca/cardinal.js +110 -0
- package/dist/src/sca/cardinal.js.map +1 -0
- package/dist/src/sca/eci-mappings.js +63 -0
- package/dist/src/sca/eci-mappings.js.map +1 -0
- package/dist/src/sca/eci-mappings.test.js +31 -0
- package/dist/src/sca/eci-mappings.test.js.map +1 -0
- package/dist/src/sca/index.js +388 -0
- package/dist/src/sca/index.js.map +1 -0
- package/dist/src/sca/index.test.js +558 -0
- package/dist/src/sca/index.test.js.map +1 -0
- package/dist/src/sca/scenarios/enrollment.js +150 -0
- package/dist/src/sca/scenarios/enrollment.js.map +1 -0
- package/dist/src/sca/scenarios/index.js +8 -0
- package/dist/src/sca/scenarios/index.js.map +1 -0
- package/dist/src/sca/scenarios/validation.js +128 -0
- package/dist/src/sca/scenarios/validation.js.map +1 -0
- package/dist/src/sca/types.js +57 -0
- package/dist/src/sca/types.js.map +1 -0
- package/dist/src/shared/api-gateway-client.js +150 -0
- package/dist/src/shared/api-gateway-client.js.map +1 -0
- package/dist/src/shared/bridge-client.js +24 -0
- package/dist/src/shared/bridge-client.js.map +1 -0
- package/dist/src/shared/constants.js +19 -0
- package/dist/src/shared/constants.js.map +1 -0
- package/dist/src/shared/event-manager.js +15 -0
- package/dist/src/shared/event-manager.js.map +1 -0
- package/dist/src/shared/post-message-client.js +107 -0
- package/dist/src/shared/post-message-client.js.map +1 -0
- package/dist/src/shared/post-message-client.test.js +58 -0
- package/dist/src/shared/post-message-client.test.js.map +1 -0
- package/dist/src/shared/types.js +47 -0
- package/dist/src/shared/types.js.map +1 -0
- package/dist/src/shared/types.test.js +55 -0
- package/dist/src/shared/types.test.js.map +1 -0
- package/dist/src/shared/util.js +96 -0
- package/dist/src/shared/util.js.map +1 -0
- package/dist/src/shared/util.test.js +148 -0
- package/dist/src/shared/util.test.js.map +1 -0
- package/dist/src/validation/index.js +10 -0
- package/dist/src/validation/index.js.map +1 -0
- package/dist/src/validation/validation-helper.js +10 -0
- package/dist/src/validation/validation-helper.js.map +1 -0
- package/dist/src/validation/validation-helper.test.js +34 -0
- package/dist/src/validation/validation-helper.test.js.map +1 -0
- package/dist/src/validation/validators/hpp-load-params-validator.js +17 -0
- package/dist/src/validation/validators/hpp-load-params-validator.js.map +1 -0
- package/dist/src/validation/validators/hpp-load-params-validator.test.js +56 -0
- package/dist/src/validation/validators/hpp-load-params-validator.test.js.map +1 -0
- package/dist/src/validation/validators/verify-card-params-validator.js +18 -0
- package/dist/src/validation/validators/verify-card-params-validator.js.map +1 -0
- package/dist/tests/helpers/api-gateway-mock.js +36 -0
- package/dist/tests/helpers/api-gateway-mock.js.map +1 -0
- package/dist/validation/index.d.ts +3 -0
- package/dist/validation/index.js +3 -0
- package/dist/validation/schemas/customer.json +38 -0
- package/dist/validation/schemas/hpp-load-params.json +40 -0
- package/dist/validation/schemas/hpp-options.json +48 -0
- package/dist/validation/schemas/payment-intent.json +48 -0
- package/dist/validation/schemas/payment-method.json +83 -0
- package/dist/validation/schemas/verify-card-options.json +15 -0
- package/dist/validation/schemas/verify-card-params.json +24 -0
- package/dist/validation/validation-helper.d.ts +3 -0
- package/dist/validation/validation-helper.js +6 -0
- package/dist/validation/validators/hpp-load-params-validator.d.ts +3 -0
- package/dist/validation/validators/hpp-load-params-validator.js +14 -0
- package/dist/validation/validators/verify-card-params-validator.d.ts +3 -0
- package/dist/validation/validators/verify-card-params-validator.js +16 -0
- package/docker-compose.yml +16 -0
- package/package.json +44 -13
- package/tsconfig.json +8 -18
- package/tsconfig.package.json +25 -0
- package/fat-zebra-sdk-1.0.2.tgz +0 -0
- package/fatzebra-sdk-1.0.0.tgz +0 -0
- package/index.js +0 -0
- package/jest.config.js +0 -16
- package/yarn-error.log +0 -2374
package/dist/sca/index.js
CHANGED
|
@@ -14,27 +14,21 @@ import { CardinalManager, } from './cardinal';
|
|
|
14
14
|
import { emit, } from '../shared/event-manager';
|
|
15
15
|
import { toFzSli } from './eci-mappings';
|
|
16
16
|
class Sca {
|
|
17
|
-
constructor({ gatewayClient }) {
|
|
18
|
-
this._eventEmitTarget = window;
|
|
17
|
+
constructor({ gatewayClient, successCallback, failureCallback }) {
|
|
19
18
|
this.sessionId = null;
|
|
20
19
|
this.gatewayClient = gatewayClient;
|
|
21
|
-
this.
|
|
20
|
+
this.successCallback = successCallback || emit;
|
|
21
|
+
this.failureCallback = failureCallback || emit;
|
|
22
22
|
}
|
|
23
23
|
loadScript() {
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
script.async = true;
|
|
30
|
-
script.onload = () => {
|
|
31
|
-
this._cardinal = new CardinalManager();
|
|
32
|
-
};
|
|
33
|
-
document.body.appendChild(script);
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
24
|
+
const script = document.createElement('script');
|
|
25
|
+
script.type = 'text/javascript';
|
|
26
|
+
script.src = process.env.SONGBIRD_URL;
|
|
27
|
+
script.async = true;
|
|
28
|
+
script.onload = () => {
|
|
36
29
|
this._cardinal = new CardinalManager();
|
|
37
|
-
}
|
|
30
|
+
};
|
|
31
|
+
document.body.appendChild(script);
|
|
38
32
|
}
|
|
39
33
|
get cardinal() {
|
|
40
34
|
return this._cardinal;
|
|
@@ -42,12 +36,13 @@ class Sca {
|
|
|
42
36
|
set cardinal(cardinal) {
|
|
43
37
|
this._cardinal = cardinal;
|
|
44
38
|
}
|
|
45
|
-
|
|
46
|
-
|
|
39
|
+
reportFailure(message) {
|
|
40
|
+
this.failureCallback(PublicEvent.SCA_ERROR, { errors: [message] });
|
|
41
|
+
console.log(message);
|
|
47
42
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
43
|
+
reportSuccess(message, data) {
|
|
44
|
+
this.successCallback(PublicEvent.SCA_SUCCESS, { data, message });
|
|
45
|
+
console.log(message);
|
|
51
46
|
}
|
|
52
47
|
run(config) {
|
|
53
48
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -63,12 +58,7 @@ class Sca {
|
|
|
63
58
|
cardinalJwt = yield this.createCardinalJWT();
|
|
64
59
|
}
|
|
65
60
|
catch (error) {
|
|
66
|
-
|
|
67
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
68
|
-
errors: [message],
|
|
69
|
-
data: null
|
|
70
|
-
});
|
|
71
|
-
console.log(message);
|
|
61
|
+
this.reportFailure('FatZebra.3DS: JWT creation failed.');
|
|
72
62
|
return;
|
|
73
63
|
}
|
|
74
64
|
// Init cardinal
|
|
@@ -79,24 +69,14 @@ class Sca {
|
|
|
79
69
|
// Register handler. Called after OTP is entered on challenge prompt.
|
|
80
70
|
this._cardinal.onPaymentValidated((data, error) => __awaiter(this, void 0, void 0, function* () {
|
|
81
71
|
if (typeof error == 'string') {
|
|
82
|
-
|
|
83
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
84
|
-
errors: [message],
|
|
85
|
-
data: null,
|
|
86
|
-
});
|
|
87
|
-
console.log(message);
|
|
72
|
+
this.reportFailure(`FatZebra.3DS: Validation failed. ${error}.`);
|
|
88
73
|
return;
|
|
89
74
|
}
|
|
90
75
|
const decodeSCASessionResponse = (yield this.gatewayClient.decodeSCASession({
|
|
91
76
|
token: data.jwt
|
|
92
77
|
})).data;
|
|
93
78
|
if (data.processorTransactionId !== decodeSCASessionResponse.processor_transaction_id) {
|
|
94
|
-
|
|
95
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
96
|
-
errors: [message],
|
|
97
|
-
data: null
|
|
98
|
-
});
|
|
99
|
-
console.log(message);
|
|
79
|
+
this.reportFailure("FatZebra.3DS: Validation failed. Invalid process transaction id.");
|
|
100
80
|
}
|
|
101
81
|
let validateSCAResponse;
|
|
102
82
|
try {
|
|
@@ -111,33 +91,16 @@ class Sca {
|
|
|
111
91
|
validateSCAResponse = (yield this.gatewayClient.validateSCA(requestParams)).data;
|
|
112
92
|
}
|
|
113
93
|
catch (errorResponse) {
|
|
114
|
-
|
|
115
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
116
|
-
errors: [message],
|
|
117
|
-
data: null,
|
|
118
|
-
});
|
|
119
|
-
console.log(message);
|
|
94
|
+
this.reportFailure('FatZebra.3DS: Validation failed. Server error.');
|
|
120
95
|
return;
|
|
121
96
|
}
|
|
122
97
|
const threedsData = threedsResponseData(validateSCAResponse);
|
|
123
98
|
const scenario = getValidationResult(validateSCAResponse);
|
|
124
99
|
if (scenario.outcome.success) {
|
|
125
|
-
|
|
126
|
-
emit(PublicEvent.SCA_SUCCESS, {
|
|
127
|
-
message,
|
|
128
|
-
data: threedsData,
|
|
129
|
-
});
|
|
130
|
-
console.log(message);
|
|
100
|
+
this.reportSuccess(`FatZebra.3DS: 3DS success - ${scenario.description}.`, threedsData);
|
|
131
101
|
}
|
|
132
102
|
else {
|
|
133
|
-
|
|
134
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
135
|
-
errors: [message],
|
|
136
|
-
data: {
|
|
137
|
-
errorCode: scenario.outcome.errorCode
|
|
138
|
-
},
|
|
139
|
-
});
|
|
140
|
-
console.log(message);
|
|
103
|
+
this.reportFailure(`FatZebra.3DS: 3DS error - ${scenario.description} - ${scenario.outcome.errorCode}`);
|
|
141
104
|
}
|
|
142
105
|
}));
|
|
143
106
|
}
|
|
@@ -146,24 +109,14 @@ class Sca {
|
|
|
146
109
|
yield this._cardinal.processBin(this.bin);
|
|
147
110
|
}
|
|
148
111
|
catch (err) {
|
|
149
|
-
|
|
150
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
151
|
-
errors: [message],
|
|
152
|
-
data: null
|
|
153
|
-
});
|
|
154
|
-
console.log(message);
|
|
112
|
+
this.reportFailure('FatZebra.3DS: BIN verification failed.');
|
|
155
113
|
return;
|
|
156
114
|
}
|
|
157
115
|
try {
|
|
158
116
|
yield this.check3DSEnrollment();
|
|
159
117
|
}
|
|
160
118
|
catch (err) {
|
|
161
|
-
|
|
162
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
163
|
-
errors: [message],
|
|
164
|
-
data: null
|
|
165
|
-
});
|
|
166
|
-
console.log(message);
|
|
119
|
+
this.reportFailure('FatZebra.3DS: Enrollment failed. Server error.');
|
|
167
120
|
return;
|
|
168
121
|
}
|
|
169
122
|
this.handleEnrollmentResult(this.enrollmentResult);
|
|
@@ -226,22 +179,10 @@ class Sca {
|
|
|
226
179
|
return;
|
|
227
180
|
}
|
|
228
181
|
if (scenario.outcome.success) {
|
|
229
|
-
|
|
230
|
-
emit(PublicEvent.SCA_SUCCESS, {
|
|
231
|
-
message,
|
|
232
|
-
data: threedsData,
|
|
233
|
-
});
|
|
234
|
-
console.log(message);
|
|
182
|
+
this.reportSuccess(`FatZebra.3DS: 3DS success - ${scenario.description}.`, threedsData);
|
|
235
183
|
}
|
|
236
184
|
else {
|
|
237
|
-
|
|
238
|
-
emit(PublicEvent.SCA_ERROR, {
|
|
239
|
-
errors: [message],
|
|
240
|
-
data: {
|
|
241
|
-
errorCode: scenario.outcome.errorCode
|
|
242
|
-
},
|
|
243
|
-
});
|
|
244
|
-
console.log(message);
|
|
185
|
+
this.reportFailure(`FatZebra.3DS: 3DS error - ${scenario.description} - ${scenario.outcome.errorCode}`);
|
|
245
186
|
}
|
|
246
187
|
}
|
|
247
188
|
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import * as t from './types';
|
|
2
|
+
import { Customer, CustomerSnakeCase, PaymentIntent } from '../shared/types';
|
|
3
|
+
import { CardinalManager } from './cardinal';
|
|
4
|
+
interface ScaConfig {
|
|
5
|
+
cardToken: string;
|
|
6
|
+
customer?: Customer;
|
|
7
|
+
paymentIntent: PaymentIntent;
|
|
8
|
+
bin: string;
|
|
9
|
+
challengeWindowSize?: t.ChallengeWindowSize;
|
|
10
|
+
}
|
|
11
|
+
interface ThreedsData {
|
|
12
|
+
cavv: string;
|
|
13
|
+
par: string;
|
|
14
|
+
sli: string;
|
|
15
|
+
xid: string;
|
|
16
|
+
ver: string;
|
|
17
|
+
directoryServerTxnId: string;
|
|
18
|
+
threedsVersion: string;
|
|
19
|
+
}
|
|
20
|
+
declare class Sca {
|
|
21
|
+
private _cardinal;
|
|
22
|
+
private _eventEmitTarget;
|
|
23
|
+
private enrollmentResult;
|
|
24
|
+
private paymentIntent;
|
|
25
|
+
private bin;
|
|
26
|
+
private cardToken;
|
|
27
|
+
private customer;
|
|
28
|
+
private challengeWindowSize;
|
|
29
|
+
private sessionId;
|
|
30
|
+
constructor();
|
|
31
|
+
loadScript(): void;
|
|
32
|
+
get cardinal(): CardinalManager;
|
|
33
|
+
set cardinal(cardinal: CardinalManager);
|
|
34
|
+
get eventEmitTarget(): HTMLDivElement | Window;
|
|
35
|
+
set eventEmitTarget(target: HTMLDivElement | Window);
|
|
36
|
+
run(config: ScaConfig): Promise<void>;
|
|
37
|
+
createCardinalJWT(): Promise<string>;
|
|
38
|
+
check3DSEnrollment(): Promise<void>;
|
|
39
|
+
customerProperties(customer: Customer): CustomerSnakeCase;
|
|
40
|
+
handleEnrollmentResult(enrollSCAResponse: t.EnrollSCAResponse): void;
|
|
41
|
+
}
|
|
42
|
+
export { Sca, ThreedsData, ScaConfig };
|
package/dist/sca/sca.js
ADDED
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
import { createSCASession, decodeSCASession, enrolSCA, validateSCA, } from '../shared/api-gateway-client';
|
|
11
|
+
import * as t from './types';
|
|
12
|
+
import { enrollmentScenarios, validationScenarios, } from './scenarios';
|
|
13
|
+
import { PublicEvent, } from '../shared/types';
|
|
14
|
+
import { CardinalManager, } from './cardinal';
|
|
15
|
+
import { emit, } from '../shared/event-manager';
|
|
16
|
+
import { toFzSli } from './eci-mappings';
|
|
17
|
+
class Sca {
|
|
18
|
+
constructor() {
|
|
19
|
+
this._eventEmitTarget = window;
|
|
20
|
+
this.sessionId = null;
|
|
21
|
+
}
|
|
22
|
+
loadScript() {
|
|
23
|
+
const script = document.createElement('script');
|
|
24
|
+
script.type = 'text/javascript';
|
|
25
|
+
script.src = process.env.SONGBIRD_URL;
|
|
26
|
+
script.async = true;
|
|
27
|
+
script.onload = () => {
|
|
28
|
+
this._cardinal = new CardinalManager();
|
|
29
|
+
};
|
|
30
|
+
document.body.appendChild(script);
|
|
31
|
+
}
|
|
32
|
+
get cardinal() {
|
|
33
|
+
return this._cardinal;
|
|
34
|
+
}
|
|
35
|
+
set cardinal(cardinal) {
|
|
36
|
+
this._cardinal = cardinal;
|
|
37
|
+
}
|
|
38
|
+
get eventEmitTarget() {
|
|
39
|
+
return this._eventEmitTarget;
|
|
40
|
+
}
|
|
41
|
+
// Specify the DOM element to which the SCA results are outputted.
|
|
42
|
+
set eventEmitTarget(target) {
|
|
43
|
+
this._eventEmitTarget = target;
|
|
44
|
+
}
|
|
45
|
+
run(config) {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
// Persist states until next 3DS run.
|
|
48
|
+
this.paymentIntent = config.paymentIntent;
|
|
49
|
+
this.bin = config.bin;
|
|
50
|
+
this.cardToken = config.cardToken;
|
|
51
|
+
this.customer = config.customer;
|
|
52
|
+
this.challengeWindowSize = config.challengeWindowSize || t.ChallengeWindowSize.SIZE_FULL_PAGE;
|
|
53
|
+
let cardinalJwt;
|
|
54
|
+
// Generate Cardinal JWT
|
|
55
|
+
try {
|
|
56
|
+
cardinalJwt = yield this.createCardinalJWT();
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
const message = 'FatZebra.3DS: JWT creation failed.';
|
|
60
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
61
|
+
errors: [message],
|
|
62
|
+
data: null
|
|
63
|
+
});
|
|
64
|
+
console.log(message);
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
// Init cardinal
|
|
68
|
+
this._cardinal.setup(cardinalJwt);
|
|
69
|
+
if (!this.sessionId) {
|
|
70
|
+
const paymentsSetupCompleteResponse = yield this._cardinal.onPaymentSetupComplete();
|
|
71
|
+
this.sessionId = paymentsSetupCompleteResponse.sessionId;
|
|
72
|
+
// Register handler. Called after OTP is entered on challenge prompt.
|
|
73
|
+
this._cardinal.onPaymentValidated((data, error) => __awaiter(this, void 0, void 0, function* () {
|
|
74
|
+
if (typeof error == 'string') {
|
|
75
|
+
const message = `FatZebra.3DS: Validation failed. ${error}.`;
|
|
76
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
77
|
+
errors: [message],
|
|
78
|
+
data: null,
|
|
79
|
+
});
|
|
80
|
+
console.log(message);
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
const decodeSCASessionResponse = (yield decodeSCASession({
|
|
84
|
+
token: data.jwt
|
|
85
|
+
})).data;
|
|
86
|
+
if (data.processorTransactionId !== decodeSCASessionResponse.processor_transaction_id) {
|
|
87
|
+
const message = 'FatZebra.3DS: Validation failed. Invalid process transaction id.';
|
|
88
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
89
|
+
errors: [message],
|
|
90
|
+
data: null
|
|
91
|
+
});
|
|
92
|
+
console.log(message);
|
|
93
|
+
}
|
|
94
|
+
let validateSCAResponse;
|
|
95
|
+
try {
|
|
96
|
+
const requestParams = {
|
|
97
|
+
amount: this.paymentIntent.payment.amount,
|
|
98
|
+
authentication_transaction_id: this.enrollmentResult.authentication_transaction_id,
|
|
99
|
+
card_token: this.cardToken,
|
|
100
|
+
currency: this.paymentIntent.payment.currency,
|
|
101
|
+
pareq: this.enrollmentResult.pareq,
|
|
102
|
+
reference: this.paymentIntent.payment.reference,
|
|
103
|
+
};
|
|
104
|
+
validateSCAResponse = (yield validateSCA(requestParams)).data;
|
|
105
|
+
}
|
|
106
|
+
catch (errorResponse) {
|
|
107
|
+
const message = 'FatZebra.3DS: Validation failed. Server error.';
|
|
108
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
109
|
+
errors: [message],
|
|
110
|
+
data: null,
|
|
111
|
+
});
|
|
112
|
+
console.log(message);
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
const threedsData = threedsResponseData(validateSCAResponse);
|
|
116
|
+
const scenario = getValidationResult(validateSCAResponse);
|
|
117
|
+
if (scenario.outcome.success) {
|
|
118
|
+
const message = `FatZebra.3DS: 3DS success - ${scenario.description}.`;
|
|
119
|
+
emit(PublicEvent.SCA_SUCCESS, {
|
|
120
|
+
message,
|
|
121
|
+
data: threedsData,
|
|
122
|
+
});
|
|
123
|
+
console.log(message);
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
const message = `FatZebra.3DS: 3DS error - ${scenario.description}`;
|
|
127
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
128
|
+
errors: [message],
|
|
129
|
+
data: {
|
|
130
|
+
errorCode: scenario.outcome.errorCode
|
|
131
|
+
},
|
|
132
|
+
});
|
|
133
|
+
console.log(message);
|
|
134
|
+
}
|
|
135
|
+
}));
|
|
136
|
+
}
|
|
137
|
+
// Cardinal processs BIN using directory server. This determines the 3DS version used.
|
|
138
|
+
try {
|
|
139
|
+
yield this._cardinal.processBin(this.bin);
|
|
140
|
+
}
|
|
141
|
+
catch (err) {
|
|
142
|
+
const message = 'FatZebra.3DS: BIN verification failed.';
|
|
143
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
144
|
+
errors: [message],
|
|
145
|
+
data: null
|
|
146
|
+
});
|
|
147
|
+
console.log(message);
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
try {
|
|
151
|
+
yield this.check3DSEnrollment();
|
|
152
|
+
}
|
|
153
|
+
catch (err) {
|
|
154
|
+
const message = 'FatZebra.3DS: Enrollment failed. Server error.';
|
|
155
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
156
|
+
errors: [message],
|
|
157
|
+
data: null
|
|
158
|
+
});
|
|
159
|
+
console.log(message);
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
this.handleEnrollmentResult(this.enrollmentResult);
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
createCardinalJWT() {
|
|
166
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
167
|
+
const { payment } = this.paymentIntent;
|
|
168
|
+
const response = (yield createSCASession({
|
|
169
|
+
amount: payment.amount,
|
|
170
|
+
currency: payment.currency,
|
|
171
|
+
hide_card_holder: payment.hide_card_holder,
|
|
172
|
+
})).data;
|
|
173
|
+
return response.jwt;
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
check3DSEnrollment() {
|
|
177
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
178
|
+
// Persist enrollResult state in memory for handlePaymentValidation handler
|
|
179
|
+
this.enrollmentResult = (yield enrolSCA({
|
|
180
|
+
amount: this.paymentIntent.payment.amount,
|
|
181
|
+
card_token: this.cardToken,
|
|
182
|
+
currency: this.paymentIntent.payment.currency,
|
|
183
|
+
reference: this.paymentIntent.payment.reference,
|
|
184
|
+
verification: this.paymentIntent.verification,
|
|
185
|
+
session_id: this.sessionId,
|
|
186
|
+
challenge_window_size: this.challengeWindowSize,
|
|
187
|
+
hide_card_holder: this.paymentIntent.payment.hide_card_holder,
|
|
188
|
+
customer: this.customerProperties(this.customer),
|
|
189
|
+
})).data;
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
customerProperties(customer) {
|
|
193
|
+
let properties = {};
|
|
194
|
+
if (!customer)
|
|
195
|
+
return properties;
|
|
196
|
+
if (customer.firstName)
|
|
197
|
+
properties.first_name = customer.firstName;
|
|
198
|
+
if (customer.lastName)
|
|
199
|
+
properties.last_name = customer.lastName;
|
|
200
|
+
if (customer.email)
|
|
201
|
+
properties.email = customer.email;
|
|
202
|
+
if (customer.address)
|
|
203
|
+
properties.address = customer.address;
|
|
204
|
+
if (customer.city)
|
|
205
|
+
properties.city = customer.city;
|
|
206
|
+
if (customer.state)
|
|
207
|
+
properties.state = customer.state;
|
|
208
|
+
if (customer.postcode)
|
|
209
|
+
properties.postcode = customer.postcode;
|
|
210
|
+
if (customer.country)
|
|
211
|
+
properties.country = customer.country;
|
|
212
|
+
return properties;
|
|
213
|
+
}
|
|
214
|
+
handleEnrollmentResult(enrollSCAResponse) {
|
|
215
|
+
const threedsData = threedsResponseData(enrollSCAResponse);
|
|
216
|
+
const scenario = getEnrollmentResult(enrollSCAResponse);
|
|
217
|
+
if (scenario.outcome.authenticationType === 'challenge') {
|
|
218
|
+
this._cardinal.continue(enrollSCAResponse.acs_url, enrollSCAResponse.pareq, enrollSCAResponse.authentication_transaction_id);
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
if (scenario.outcome.success) {
|
|
222
|
+
const message = `FatZebra.3DS: 3DS success - ${scenario.description}.`;
|
|
223
|
+
emit(PublicEvent.SCA_SUCCESS, {
|
|
224
|
+
message,
|
|
225
|
+
data: threedsData,
|
|
226
|
+
});
|
|
227
|
+
console.log(message);
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
const message = `FatZebra.3DS: 3DS error - ${scenario.description}`;
|
|
231
|
+
emit(PublicEvent.SCA_ERROR, {
|
|
232
|
+
errors: [message],
|
|
233
|
+
data: {
|
|
234
|
+
errorCode: scenario.outcome.errorCode
|
|
235
|
+
},
|
|
236
|
+
});
|
|
237
|
+
console.log(message);
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
const threedsResponseData = (response) => {
|
|
242
|
+
return {
|
|
243
|
+
// CAVV: Visa & Amex only
|
|
244
|
+
// AAV: Mastercard only, known as UCAF
|
|
245
|
+
cavv: response.cavv || response.aav,
|
|
246
|
+
par: response.pares,
|
|
247
|
+
sli: toFzSli(response.eci),
|
|
248
|
+
xid: response.xid,
|
|
249
|
+
ver: response.enrolled,
|
|
250
|
+
directoryServerTxnId: response.directory_server_txn_id,
|
|
251
|
+
threedsVersion: response.version,
|
|
252
|
+
};
|
|
253
|
+
};
|
|
254
|
+
const getEnrollmentResult = (enrollment) => {
|
|
255
|
+
return enrollmentScenarios.find((item) => {
|
|
256
|
+
return item.reasonCode === enrollment.reason_code &&
|
|
257
|
+
item.veresEnrolled === enrollment.enrolled &&
|
|
258
|
+
item.pares === enrollment.pares &&
|
|
259
|
+
item.threedsVersion === getMajor3dsVersion(enrollment.version);
|
|
260
|
+
});
|
|
261
|
+
};
|
|
262
|
+
const getValidationResult = (validation) => {
|
|
263
|
+
return validationScenarios.find((item) => {
|
|
264
|
+
return item.reasonCode === validation.reason_code &&
|
|
265
|
+
item.pares === validation.pares &&
|
|
266
|
+
item.threedsVersion === getMajor3dsVersion(validation.version);
|
|
267
|
+
});
|
|
268
|
+
};
|
|
269
|
+
// 3DS versioning follows SEMVER format. The first charactor is the major version number.
|
|
270
|
+
const getMajor3dsVersion = (original) => {
|
|
271
|
+
return original[0];
|
|
272
|
+
};
|
|
273
|
+
export { Sca };
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export { enrollmentScenarios } from './enrollment';
|
|
2
|
-
export type { EnrollmentScenario } from './enrollment';
|
|
3
2
|
export { validationScenarios } from './validation';
|
|
4
|
-
|
|
3
|
+
import type { EnrollmentScenario } from './enrollment';
|
|
4
|
+
import type { ValidationScenario } from './validation';
|
|
5
|
+
export type { EnrollmentScenario, ValidationScenario };
|
package/dist/sca/types.d.ts
CHANGED
|
@@ -155,5 +155,5 @@ interface GetCardRequest {
|
|
|
155
155
|
interface GetCardResponse {
|
|
156
156
|
bin: string;
|
|
157
157
|
}
|
|
158
|
-
export { ScaErrorCode, ChallengeWindowSize, CommerceIndicator, VEResEnrolled, PARes };
|
|
158
|
+
export { ScaErrorCode, ChallengeWindowSize, CommerceIndicator, VEResEnrolled, PARes, };
|
|
159
159
|
export type { CreateSCASessionRequest, CreateSCASessionResponse, EnrollSCARequest, EnrollSCAResponse, ValidateSCARequest, ValidateSCAResponse, DecodeSCASessionRequest, DecodeSCASessionResponse, GetCardRequest, GetCardResponse, ThreedsData };
|
package/dist/sca/types.js
CHANGED
|
@@ -51,4 +51,4 @@ var PARes;
|
|
|
51
51
|
PARes["NOT_COMPLETED"] = "U";
|
|
52
52
|
PARes["SUCCESS"] = "Y";
|
|
53
53
|
})(PARes || (PARes = {}));
|
|
54
|
-
export { ScaErrorCode, ChallengeWindowSize, CommerceIndicator, VEResEnrolled, PARes };
|
|
54
|
+
export { ScaErrorCode, ChallengeWindowSize, CommerceIndicator, VEResEnrolled, PARes, };
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { AxiosResponse, AxiosInstance } from "axios";
|
|
2
2
|
import * as sca from "../sca/types";
|
|
3
|
+
import * as paypal from "../paypal/types";
|
|
3
4
|
export type GatewayClientProps = {
|
|
4
5
|
accessToken: string;
|
|
5
6
|
username: string;
|
|
@@ -13,5 +14,11 @@ declare class GatewayClient {
|
|
|
13
14
|
enrolSCA(data: sca.EnrollSCARequest): Promise<AxiosResponse>;
|
|
14
15
|
validateSCA(data: sca.ValidateSCARequest): Promise<AxiosResponse>;
|
|
15
16
|
getCard(data: sca.GetCardRequest): Promise<AxiosResponse>;
|
|
17
|
+
/**************** PayPal /****************/
|
|
18
|
+
createPayPalOrder(data: paypal.CreatePayPalOrderRequest): Promise<AxiosResponse>;
|
|
19
|
+
capturePayPalOrder(data: paypal.CapturePayPalOrderRequest): Promise<AxiosResponse>;
|
|
20
|
+
authorizePayPalOrder(data: paypal.AuthorizePayPalOrderRequest): Promise<AxiosResponse>;
|
|
21
|
+
createPayPalBillingAgreement(data: paypal.CreatePayPalBillingAgreementRequest): Promise<AxiosResponse>;
|
|
22
|
+
approvePayPalBillingAgreement(data: paypal.ApprovePayPalBillingAgreementRequest): Promise<AxiosResponse>;
|
|
16
23
|
}
|
|
17
24
|
export default GatewayClient;
|
|
@@ -7,7 +7,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
7
7
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
8
|
});
|
|
9
9
|
};
|
|
10
|
-
import { RequestHeaderSdkVersion, RequestHeaderMerchantUsername, RequestTimeout, } from "./constants";
|
|
10
|
+
import { RequestHeaderSdkVersion, RequestHeaderMerchantUsername, RequestTimeout, LongRequestTimeout, } from "./constants";
|
|
11
11
|
import axios from "axios";
|
|
12
12
|
import { getSdkVersionNumber } from "./util";
|
|
13
13
|
const baseUrl = process.env.API_GATEWAY_URL;
|
|
@@ -57,5 +57,39 @@ class GatewayClient {
|
|
|
57
57
|
return this.client.get(`/credit_cards/${data.card_token}`);
|
|
58
58
|
});
|
|
59
59
|
}
|
|
60
|
+
/**************** PayPal /****************/
|
|
61
|
+
createPayPalOrder(data) {
|
|
62
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
+
return this.client.post("/paypal/orders", data, {
|
|
64
|
+
timeout: LongRequestTimeout,
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
capturePayPalOrder(data) {
|
|
69
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
+
return this.client.post(`/paypal/orders/${data.id}/capture`, null, {
|
|
71
|
+
timeout: LongRequestTimeout,
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
authorizePayPalOrder(data) {
|
|
76
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
77
|
+
return this.client.post(`/paypal/orders/${data.id}/authorize`, null, {
|
|
78
|
+
timeout: LongRequestTimeout,
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
createPayPalBillingAgreement(data) {
|
|
83
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
84
|
+
return this.client.post("/paypal/billing_agreements", data, {
|
|
85
|
+
timeout: LongRequestTimeout,
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
approvePayPalBillingAgreement(data) {
|
|
90
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
91
|
+
return this.client.post(`/paypal/billing_agreements/${data.id}/approve`, null, { timeout: LongRequestTimeout });
|
|
92
|
+
});
|
|
93
|
+
}
|
|
60
94
|
}
|
|
61
95
|
export default GatewayClient;
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
declare const bridgeUrl = "http://paynow.test";
|
|
2
|
+
declare const apiUrl = "http://api.test:3002/sdk";
|
|
3
|
+
declare const payNowUrl = "http://paynow.test:3004";
|
|
4
|
+
declare const songbirdUrl = "https://songbirdstag.cardinalcommerce.com/edge/v1/songbird.js";
|
|
5
|
+
export { bridgeUrl, apiUrl, payNowUrl, songbirdUrl };
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
declare const bridgeUrl = "http://paynow.test";
|
|
2
|
+
declare const apiUrl = "http://api.test:3002/sdk";
|
|
3
|
+
declare const payNowUrl = "http://paynow.test:3004";
|
|
4
|
+
declare const songbirdUrl = "https://songbirdstag.cardinalcommerce.com/edge/v1/songbird.js";
|
|
5
|
+
export { bridgeUrl, apiUrl, payNowUrl, songbirdUrl };
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
const bridgeUrl = "http://paynow.test";
|
|
2
|
+
const apiUrl = "http://api.test:3002/sdk";
|
|
3
|
+
const payNowUrl = "http://paynow.test:3004";
|
|
4
|
+
const songbirdUrl = "https://songbirdstag.cardinalcommerce.com/edge/v1/songbird.js";
|
|
5
|
+
export { bridgeUrl, apiUrl, payNowUrl, songbirdUrl };
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
const bridgeUrl = "http://paynow.test";
|
|
2
|
+
const apiUrl = "http://api.test:3002/sdk";
|
|
3
|
+
const payNowUrl = "http://paynow.test:3004";
|
|
4
|
+
const songbirdUrl = "https://songbirdstag.cardinalcommerce.com/edge/v1/songbird.js";
|
|
5
|
+
export { bridgeUrl, apiUrl, payNowUrl, songbirdUrl };
|
|
@@ -26,4 +26,4 @@ interface ErrorEventDetail {
|
|
|
26
26
|
declare const emit: (event: PublicEvent, data: SuccessEventDetail | ErrorEventDetail, target?: HTMLElement | Window) => void;
|
|
27
27
|
declare const on: (event: PublicEvent, callback: (e: any) => void, target?: HTMLElement | Window) => void;
|
|
28
28
|
export { emit, on };
|
|
29
|
-
export type { EventData };
|
|
29
|
+
export type { EventData, SuccessEventDetail, ErrorEventDetail };
|
|
@@ -44,5 +44,5 @@ declare class PostMessageClient {
|
|
|
44
44
|
setEventListenersLegacy(handlers: EventHandlers): void;
|
|
45
45
|
send(message: PostMessage | PostMessageLegacy): void;
|
|
46
46
|
}
|
|
47
|
-
export { PostMessageClient };
|
|
47
|
+
export { PostMessageClient, };
|
|
48
48
|
export type { CreateCardTokenPostMessageData, CreatePurchasePostMessageData, PostMessage, PostMessageLegacy, PostMessageClientConfig };
|