Skip to content

Commit

Permalink
feat(payments): INT-275 Add a mapper for Cryptogram Payment instrument
Browse files Browse the repository at this point in the history
  • Loading branch information
rodna-bc committed May 17, 2018
1 parent c207c52 commit b1ddf87
Show file tree
Hide file tree
Showing 2 changed files with 86 additions and 0 deletions.
20 changes: 20 additions & 0 deletions src/payment/v1/payment-mappers/payment-mapper.js
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,10 @@ export default class PaymentMapper {
token: nonce,
},
});
} else if (payment.cryptogramId) {
objectAssign(payload, {
credit_card_cryptogram: this.mapToCryptogram(data),
});
} else {
objectAssign(payload, {
credit_card: this.mapToCreditCard(data),
Expand Down Expand Up @@ -110,4 +114,20 @@ export default class PaymentMapper {
verification_value: payment.ccCvv,
});
}

/**
* @private
* @param {PaymentRequestData} data
* @return {Object}
*/
mapToCryptogram({ payment }) {
return omitNil({
payment_cryptogram: payment.cryptogramId,
eci: payment.eci,
xid: payment.transactionId,
month: payment.ccExpiry ? toNumber(payment.ccExpiry.month) : null,
number: payment.ccNumber,
year: payment.ccExpiry ? toNumber(payment.ccExpiry.year) : null,
});
}
}
66 changes: 66 additions & 0 deletions test/payment/v1/payment-mappers/payment-mapper.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,72 @@ describe('PaymentMapper', () => {
});
});

it('maps the input object into a payment object with cryptogram', () => {
data = merge({}, data, {
payment: {
cryptogramId: 'cryptogram123',
eci: 'eci123',
transactionId: 'transaction123',
},
});

const output = paymentMapper.mapToPayment(data);

expect(output.cryptogramId).toBeUndefined();
expect(output).toEqual(
jasmine.objectContaining({
device: {
fingerprint_id: data.orderMeta.deviceFingerprint,
},
device_info: data.quoteMeta.request.deviceSessionId,
gateway: data.paymentMethod.id,
notify_url: data.order.callbackUrl,
return_url: data.paymentMethod.returnUrl,
credit_card_cryptogram: {
payment_cryptogram: data.payment.cryptogramId,
eci: data.payment.eci,
xid: data.payment.transactionId,
number: data.payment.ccNumber,
month: parseInt(data.payment.ccExpiry.month, 10),
year: parseInt(data.payment.ccExpiry.year, 10),
},
})
);
});

it('maps the input object into a payment object with cryptogram without expiration', () => {
data = merge({}, data, {
payment: {
cryptogramId: 'cryptogram123',
eci: 'eci123',
transactionId: 'transaction123',
ccNumber: 'aa',
ccExpiry: null,
},
});

const output = paymentMapper.mapToPayment(data);

expect(output.cryptogramId).toBeUndefined();
expect(output).toEqual(
jasmine.objectContaining({
device: {
fingerprint_id: data.orderMeta.deviceFingerprint,
},
device_info: data.quoteMeta.request.deviceSessionId,
gateway: data.paymentMethod.id,
notify_url: data.order.callbackUrl,
return_url: data.paymentMethod.returnUrl,
credit_card_cryptogram: {
payment_cryptogram: data.payment.cryptogramId,
eci: data.payment.eci,
xid: data.payment.transactionId,
number: data.payment.ccNumber,
},
})
);
});

it('maps vaulting data to the payload', () => {
data = merge({}, data, {
payment: {
Expand Down

0 comments on commit b1ddf87

Please sign in to comment.