diff --git a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/constants/AdyenControllerConstants.java b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/constants/AdyenControllerConstants.java index 85200493d..a9d72cc0c 100644 --- a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/constants/AdyenControllerConstants.java +++ b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/constants/AdyenControllerConstants.java @@ -28,7 +28,7 @@ public interface AdyenControllerConstants String SUMMARY_CHECKOUT_PREFIX = "/checkout/multi/adyen/summary"; String COMPONENT_PREFIX = "/adyen/component"; String AMAZON_RETURN_URL = "/checkout/multi/adyen/summary/amazonpay/placeorder"; - + String CHECKOUT_RESULT_URL = "/checkout-adyen-response"; /** * Class with view name constants */ diff --git a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/controllers/pages/AdyenComponentController.java b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/controllers/pages/AdyenComponentController.java index 67836b4bf..b2a041b2d 100644 --- a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/controllers/pages/AdyenComponentController.java +++ b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/src/com/adyen/v6/controllers/pages/AdyenComponentController.java @@ -58,13 +58,16 @@ import javax.servlet.http.HttpServletRequest; import java.util.Arrays; import java.util.List; +import java.util.Objects; +import static com.adyen.v6.constants.AdyenControllerConstants.CHECKOUT_RESULT_URL; import static com.adyen.v6.constants.AdyenControllerConstants.COMPONENT_PREFIX; import static com.adyen.v6.constants.AdyenControllerConstants.SUMMARY_CHECKOUT_PREFIX; import static com.adyen.v6.constants.Adyenv6coreConstants.PAYMENT_METHOD_AMAZONPAY; import static com.adyen.v6.constants.Adyenv6coreConstants.PAYMENT_METHOD_BCMC_MOBILE; import static com.adyen.v6.constants.Adyenv6coreConstants.PAYMENT_METHOD_PIX; + @RestController @RequestMapping(COMPONENT_PREFIX) public class AdyenComponentController extends AbstractCheckoutController { @@ -116,6 +119,9 @@ public ResponseEntity componentPayment(@RequestHeader String ho LOGGER.error("ApiException: " + e); throw new AdyenComponentException("checkout.error.authorization.payment.refused"); } catch (AdyenNonAuthorizedPaymentException e) { + if (Objects.nonNull(e.getPaymentsResponse()) && Objects.nonNull(e.getPaymentsResponse().getAction())) { + return ResponseEntity.ok().body(e.getPaymentsResponse()); + } LOGGER.warn("AdyenNonAuthorizedPaymentException occurred. Payment " + e.getPaymentResult().getPspReference() + "is refused."); throw new AdyenComponentException("checkout.error.authorization.payment.refused"); } catch (Exception e) { @@ -183,7 +189,8 @@ private String getReturnUrl(String paymentMethod) { //Google Pay will only use returnUrl if redirected to 3DS authentication url = SUMMARY_CHECKOUT_PREFIX + "/authorise-3d-adyen-response"; } else { - url = COMPONENT_PREFIX + "/submit-details"; + url = SUMMARY_CHECKOUT_PREFIX + CHECKOUT_RESULT_URL; + ; } BaseSiteModel currentBaseSite = baseSiteService.getCurrentBaseSite(); return siteBaseUrlResolutionService.getWebsiteUrlForSite(currentBaseSite, true, url); diff --git a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/WEB-INF/views/responsive/pages/checkout/multi/checkoutSummaryPage.jsp b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/WEB-INF/views/responsive/pages/checkout/multi/checkoutSummaryPage.jsp index eb54c5de9..b5704de9e 100644 --- a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/WEB-INF/views/responsive/pages/checkout/multi/checkoutSummaryPage.jsp +++ b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/WEB-INF/views/responsive/pages/checkout/multi/checkoutSummaryPage.jsp @@ -109,6 +109,11 @@ fnCallbackArray['initiateBlik'] = callbackConfig + + AdyenCheckoutHybris.configureButton($("#placeOrderForm-hidden-xs"), true, "hidden-xs"); + AdyenCheckoutHybris.configureButton($("#placeOrderForm-visible-xs"), true, "visible-xs"); + + <%-- API only payments methods --%> fnCallbackArray['initiatePayment'] = { diff --git a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/_ui/responsive/common/js/adyen.checkout.js b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/_ui/responsive/common/js/adyen.checkout.js index 738a9335a..496f79f4e 100644 --- a/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/_ui/responsive/common/js/adyen.checkout.js +++ b/adyenv6b2ccheckoutaddon/acceleratoraddon/web/webroot/_ui/responsive/common/js/adyen.checkout.js @@ -1099,8 +1099,10 @@ var AdyenCheckoutHybris = (function () { contentType: "application/json; charset=utf-8", success: function (response) { try { - if (response.action && (response.resultCode && response.resultCode === 'Pending' || - response.resultCode && (response.resultCode === 'RedirectShopper'))) { + if (response.action && (response.resultCode && (response.resultCode === 'Pending' || + response.resultCode === 'RedirectShopper' || response.resultCode === 'IdentifyShopper' || + response.resultCode === 'ChallengeShopper' || response.resultCode === 'PresentToShopper' || + response.resultCode === 'Await') || (response.action && response.action.type))) { component.handleAction(response.action); } else if (response.resultCode && (response.resultCode === 'Authorised')) { handleResult(response, false); diff --git a/adyenv6core/src/com/adyen/v6/facades/impl/DefaultAdyenCheckoutFacade.java b/adyenv6core/src/com/adyen/v6/facades/impl/DefaultAdyenCheckoutFacade.java index f602731af..110a596fc 100644 --- a/adyenv6core/src/com/adyen/v6/facades/impl/DefaultAdyenCheckoutFacade.java +++ b/adyenv6core/src/com/adyen/v6/facades/impl/DefaultAdyenCheckoutFacade.java @@ -113,7 +113,16 @@ import javax.servlet.http.HttpServletRequest; import java.io.IOException; import java.math.BigDecimal; -import java.util.*; +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.HashSet; +import java.util.List; +import java.util.Map; +import java.util.Objects; +import java.util.Optional; +import java.util.Set; +import java.util.UUID; import java.util.concurrent.TimeUnit; import java.util.stream.Collectors; @@ -472,7 +481,9 @@ public PaymentResponse componentPayment(final HttpServletRequest request, final requestInfo.setShopperLocale(getShopperLocale()); PaymentResponse paymentResponse = getAdyenPaymentService().componentPayment(cartData, paymentRequest, requestInfo, getCheckoutCustomerStrategy().getCurrentUserForCheckout()); - if (PaymentResponse.ResultCodeEnum.PENDING == paymentResponse.getResultCode() || PaymentResponse.ResultCodeEnum.REDIRECTSHOPPER == paymentResponse.getResultCode()) { + if (PaymentResponse.ResultCodeEnum.PENDING == paymentResponse.getResultCode() || + PaymentResponse.ResultCodeEnum.REDIRECTSHOPPER == paymentResponse.getResultCode() || + PaymentResponse.ResultCodeEnum.PRESENTTOSHOPPER == paymentResponse.getResultCode()) { LOGGER.info("Placing pending order"); placePendingOrder(paymentResponse.getResultCode().getValue()); return paymentResponse; @@ -482,7 +493,6 @@ public PaymentResponse componentPayment(final HttpServletRequest request, final createAuthorizedOrder(paymentResponse); return paymentResponse; } - throw new AdyenNonAuthorizedPaymentException(paymentResponse); } diff --git a/adyenv6core/src/com/adyen/v6/factory/AdyenRequestFactory.java b/adyenv6core/src/com/adyen/v6/factory/AdyenRequestFactory.java index c7a4f74aa..f755fd535 100644 --- a/adyenv6core/src/com/adyen/v6/factory/AdyenRequestFactory.java +++ b/adyenv6core/src/com/adyen/v6/factory/AdyenRequestFactory.java @@ -123,9 +123,6 @@ public PaymentRequest createPaymentsRequest(final String merchantAccount, final Boolean is3DS2allowed = is3DS2Allowed(); final PaymentRequest paymentsRequest = new PaymentRequest(); - if (adyenPaymentMethod == null) { - throw new IllegalArgumentException("Payment method is null"); - } //Update payment request for generic information for all payment method types setCommonInfoOnPaymentRequest(merchantAccount, cartData, requestInfo, customerModel, paymentsRequest); paymentsRequest.setApplicationInfo(createApplicationInfo());