Invalid 3DS2 implementation

Created on 1 December 2022, almost 2 years ago
Updated 14 March 2024, 9 months ago

We are regularly getting this error in the logs every day, but have been unable to reproduce it ourselves.

#3153914: Intermittent payment method creation errors on missing data was a great help because people are not getting the WSOD any more. However, they are still unable to pay and we get a lot of complaints about this. From the user's point of view they are just stuck on the payment page without an error.

What could be causing this? Something particular to the card being used? User error in some way?

🐛 Bug report
Status

Fixed

Version

1.0

Component

Code

Created by

🇬🇧United Kingdom Rob230

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇬🇧United Kingdom Rob230

    Good thinking, I've changed it to use setData() instead.

  • 🇮🇱Israel jsacksick

    This can't be committed until 🐛 Allow specifying merchant id when generating client token. Fixed is resolved (similar changes to the generateClientToken()) are implemented there.

  • 🇬🇧United Kingdom vince.rowe

    Hi, the issue linked to on the last comment was committed, does this mean this patch can now be reviewed again?

    Our site currently is not accepting any 3D Secure payments either through stable or dev release on commerce 3.6.

    Many thanks

  • 🇬🇧United Kingdom jeromebeckett

    Thanks for your work on this Rob.

    Our client has been reporting payment failures due to the same issue.

    The patch in #8 applies cleanly to 8.x-1.4 so we are going to apply this to our live site. I will report back once we know if we are seeing a reduction in the amount of payment failures due to 3DS or not.

    As stated in #10, the issue referred to in #9 has been fixed and merged. Now that has been done can we commit and merge the patch to 8.x-1.x-dev?

  • 🇬🇧United Kingdom Rob230

    Hi Jerome, we have been using patch #8 for 9 months now and aren't getting the failed payment reports any more.

    I'm surprised more people haven't reported this - broken 3DS2 implementation is pretty major. But it is up to the banks to reject and for small amounts most will allow without 3DS2. We were seeing almost every transaction over £50 be rejected by certain banks, and that no longer happens with patch #8.

    Despite hundreds of people per month being rejected, only 1 or 2 of those would bother to email us to say it wasn't working, so perhaps a lot of site admins are unaware of the problem. You'd have to pay attention to the number of unsuccessful transactions in Braintree and consider it an issue.

  • Status changed to Needs review about 1 year ago
  • 🇬🇧United Kingdom guy_schneerson

    Updated patch.
    Many of the changes made it into the module. This patch includes the remaining change.
    I am not sure I fully understand why the original code created the $three_d_payment_method and not used it so hoping this will solve my issue.
    Also storing the $payment_method against the order and restoring it does not feel like the best way to do this but if it works so be it.

    <?php
    -    $this->order->set('payment_method', $payment_method);
    +
    +    $this->order->set('payment_method', $three_d_payment_method);
    +    // We will need to change the payment method back after payment so that
    +    // recurring orders or failed payments won't use the nonce.
    +    $this->order->setData('payment_method_reusable', $payment_method->id());
    ?>

    and

    <?php
           $transaction_data['paymentMethodNonce'] = $payment_method->getRemoteId();
    +      $order = $payment->getOrder();
    +      $reusable_payment_method_id = $order->getData('payment_method_reusable');
    +      if ($reusable_payment_method_id) {
    +        $order->set('payment_method', $reusable_payment_method_id);
    +        $order->save();
    +      }
    ?>
  • 🇪🇸Spain Pandepoulus

    Hello, i can confirm i had some 3ds2 verification fails before applying the patch for big transactions.
    Same people could buy after applying the patch at #13.
    Kind regards.

  • 🇬🇧United Kingdom joehuggans Harrogate, UK

    Tested #13 on Drupal 10.2.3 and 8.x-1.5 of this module and it seems to work, can see the 3DS data on the Braintree transaction now, which wasn't there before.

  • First commit to issue fork.
  • Assigned to TomTech
  • 🇺🇸United States TomTech
  • 🇺🇸United States TomTech
  • Status changed to Fixed 9 months ago
  • 🇺🇸United States TomTech

    Thanks, all!

    Note: the last patch handles some, but not all 3ds2 issues.

    Additional work is included in the MR that was created and merged in.

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024