- 
                Notifications
    You must be signed in to change notification settings 
- Fork 221
Description
Is your feature request related to a problem? Please describe.
We are trying to pass in a tokenized storedPaymentMethodId to a guest-cart checkout, and right now there doesn't appear to be a way to link the shopperReference with the guest user. In the current plugin, the shopperReference is either the customerID or a UUID, causing our guest-cart payment to fail, as there is no way to get or change the uuid value prior to submission.
// in Helper/Requests.php
    public function getShopperReference($customerId, $orderIncrementId): string
    {
        if ($customerId) {
            $shopperReference = $this->adyenHelper->padShopperReference($customerId);
        } else {
            $uuid = Uuid::generateV4();
            $guestCustomerId = $orderIncrementId . $uuid;
            $shopperReference = $guestCustomerId;
        }
        return $shopperReference;
    }
}
For added context, we have a headless implementation which tokenizes card information by making a 0 dollar charge (per docs ). Our implementation handles raw credit card information (we are PCI certified) and we require our AdobeCommerce partners to submit a SAQ-A-EP and provision us with our own API key as to limit the scope of our tokenization flow.
We are trying to pass our tokenized payment data (we cannot pass raw card data, as this would break the PCI chain, nor can we use the AdyenJS library in our environment) to AdobeCommerce for submission. We use guest-carts since our flow collects payment information outside the usual "primary" store workflow.
Using the guest-cart flow as described above works great for Braintree and Stripe, but this shopperReference uuid seems to break our intended flow in our Adyen implementation.
Describe the solution you'd like
I think any of these things could fix this problem:
- Use the guest-cart uuid cartIdfor theshopperReferencevs the currentorderId.uuidyou use now
- Allow a shopperReferencevalue to be passed into thepaymentMethod.additional_datawhich overrides the current behavior
- Allow us to retrieve the uuidvalue prior to submission; can be attached to theguest-cart/${cartId}
Describe alternatives you've considered
I understand why you use a uuid for guests, as the assumption probably is stored payment methods belong to "stored customers".
An alternative would be for Adyen to provide a way to get a single-use-payment-token like Braintree and Stripe vs. a stored payment method (with a shopperReference), but that change is probably far too great to hope for :]
Additional context
Our website