Skip to content

Testing webhooks during development

predrag.krstojevic edited this page Mar 2, 2021 · 1 revision

It's possible to receive real webhooks from Mollie, even if you develop locally.

This is especially useful when developing features that trigger workflows after a webhook has been received.

The Mollie module allows you to add a custom shop domain, which will then be used when building webhook URLs for a payment.

This domain should forward requests to your local development environment. So Mollie will push data to this domain, which is then received by your local instance.

We highly recommend services like NGROK for this.

Sign up for an account, download NGROK, and run a command such as this:

./ngrok http --host-header=rewrite my-local-orocommerce-domain:443

This will start the NGROK service that forwards all requests to your local HTTPS port and rewrites the headers to match the one from your local OroCommerce shop configuration.

It gives you a public URL such as this: https://123456789.ngrok.io

All you need to do now is to add that domain to the Mollie OroCommerce Mollie\Bundle\PaymentBundle\Mapper\MollieDtoMapper in the method specifically created for this purpose ensureDebugWebhookUrl

/**
 * Replaces schema and host from the provided url with debug url set in configuration. Used for development to set
 * tunneling (ngrok) url for webhooks.
 *
 * @param string $url
 *
 * @return string
*/
protected function ensureDebugWebhookUrl($url)
{  
   return preg_replace(
      '/http(s)?:\/\/[^\/]*\//i',
      'https://123456789.ngrok.io/',
      $url
   );
}

Now simply create a new order in your local OroCommerce shop, and you will see that webhooks are received immediately.

If you open the Mollie dashboard, you will recognize that your NGROK domain has been used for the Webhook URL.

You can also skip this for most use cases, but only do it when you want to receive webhooks for a specific task you have. So no need, to have NGROK running all the time.

Please keep in mind, that your local environment will be public with this approach. NGROK has different authorization options, such as Basic Auth, IP restrictions, and more. In this guide, we distance ourselves from security settings, as well as from promoting NGROK, due to the option to also use other services.