From 7dad7afbd102cc69276653ffbb2afc90e48aa109 Mon Sep 17 00:00:00 2001 From: Saksham Sharma Date: Fri, 6 Sep 2024 18:05:36 +0530 Subject: [PATCH 1/2] fix: added wild cards support --- src/CardUtils.res | 8 ++++++-- src/GlobalVars.res | 2 +- src/Payment.res | 3 ++- src/Utilities/PaymentUtils.res | 4 +++- src/Utilities/Utils.res | 5 +++++ 5 files changed, 17 insertions(+), 5 deletions(-) diff --git a/src/CardUtils.res b/src/CardUtils.res index 9ad523fb7..a20967fdc 100644 --- a/src/CardUtils.res +++ b/src/CardUtils.res @@ -458,8 +458,12 @@ let maxCardLength = cardBrand => { let cardValid = (cardNumber, cardBrand) => { let clearValueLength = cardNumber->clearSpaces->String.length - (clearValueLength == maxCardLength(cardBrand) || - (cardBrand === "Visa" && clearValueLength == 16)) && calculateLuhn(cardNumber) + if cardBrand == "" && (GlobalVars.isInteg || GlobalVars.isSandbox) { + Utils.checkIsTestCardWildcard(cardNumber) + } else { + (clearValueLength == maxCardLength(cardBrand) || + (cardBrand === "Visa" && clearValueLength == 16)) && calculateLuhn(cardNumber) + } } let blurRef = (ref: React.ref>) => { ref.current->Nullable.toOption->Option.forEach(input => input->blur)->ignore diff --git a/src/GlobalVars.res b/src/GlobalVars.res index 0580a11fb..e7be7c345 100644 --- a/src/GlobalVars.res +++ b/src/GlobalVars.res @@ -12,5 +12,5 @@ @val external maxLogsPushedPerEventName: int = "maxLogsPushedPerEventName" let targetOrigin: string = "*" let isInteg = sdkUrl === "https://dev.hyperswitch.io" -let isSandbox = sdkUrl === "https://beta.hyperswitch.io" +let isSandbox = sdkUrl === "https://beta.hyperswitch.io" || sdkUrl === "http://localhost:9050" let isProd = sdkUrl === "https://checkout.hyperswitch.io" diff --git a/src/Payment.res b/src/Payment.res index 8ead3bf2a..13dd3d733 100644 --- a/src/Payment.res +++ b/src/Payment.res @@ -87,7 +87,8 @@ let make = (~paymentMode, ~integrateError, ~logger) => { setCardValid(clearValue, setIsCardValid) if ( cardValid(clearValue, cardBrand) && - PaymentUtils.checkIsCardSupported(clearValue, supportedCardBrands)->Option.getOr(false) + (PaymentUtils.checkIsCardSupported(clearValue, supportedCardBrands)->Option.getOr(false) || + Utils.checkIsTestCardWildcard(clearValue)) ) { handleInputFocus(~currentRef=cardRef, ~destinationRef=expiryRef) } diff --git a/src/Utilities/PaymentUtils.res b/src/Utilities/PaymentUtils.res index 92a9d34c1..108f3f8c2 100644 --- a/src/Utilities/PaymentUtils.res +++ b/src/Utilities/PaymentUtils.res @@ -498,7 +498,9 @@ let getSupportedCardBrands = ( let checkIsCardSupported = (cardNumber, supportedCardBrands) => { let cardBrand = cardNumber->CardUtils.getCardBrand let clearValue = cardNumber->CardUtils.clearSpaces - if CardUtils.cardValid(clearValue, cardBrand) { + if cardBrand == "" && (GlobalVars.isInteg || GlobalVars.isSandbox) { + Some(CardUtils.cardValid(clearValue, cardBrand)) + } else if CardUtils.cardValid(clearValue, cardBrand) { switch supportedCardBrands { | Some(brands) => Some(brands->Array.includes(cardBrand->String.toLowerCase)) | None => Some(true) diff --git a/src/Utilities/Utils.res b/src/Utilities/Utils.res index 572300a53..698da7d97 100644 --- a/src/Utilities/Utils.res +++ b/src/Utilities/Utils.res @@ -1375,3 +1375,8 @@ let getFirstAndLastNameFromFullName = fullName => { (firstName, lastNameJson) } + +let checkIsTestCardWildcard = val => { + let wildcards = ["1111222233334444"] + wildcards->Array.includes(val) +} From 285ce4f14bca7d2f8e974da023e7b131d0b49561 Mon Sep 17 00:00:00 2001 From: Saksham Sharma Date: Fri, 6 Sep 2024 18:45:40 +0530 Subject: [PATCH 2/2] refactor: minor refactor --- src/Utilities/Utils.res | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/src/Utilities/Utils.res b/src/Utilities/Utils.res index 698da7d97..e6f1e9f13 100644 --- a/src/Utilities/Utils.res +++ b/src/Utilities/Utils.res @@ -1376,7 +1376,4 @@ let getFirstAndLastNameFromFullName = fullName => { (firstName, lastNameJson) } -let checkIsTestCardWildcard = val => { - let wildcards = ["1111222233334444"] - wildcards->Array.includes(val) -} +let checkIsTestCardWildcard = val => ["1111222233334444"]->Array.includes(val)