Skip to main content

Proxying Plausible through CloudFront

Step 1: Create new origin

First we need to create a new origin pointing to the Plausible server. In the CloudFront console, under your distribution; create a new origin:

  • Origin Domain Name: plausible.io
  • Origin Protocol Policy: HTTPS Only

Step 2: Create custom behaviours

Now we need to define some custom behaviour for when to use our new origin. In the CloudFront console, under your distribution; create new behaviour.

First for the analytics script:

  • Path Pattern: /js/script.js (you can use /js/script.* to also match script extensions)
  • Origin or Origin Group: The origin we created in step 1
  • Viewer Protocol Policy: HTTPS Only
  • Allowed HTTP Methods: GET, HEAD

And another for the event API:

  • Path Pattern: /api/event
  • Origin or Origin Group: The origin we created in step 1
  • Viewer Protocol Policy: HTTPS Only
  • Allowed HTTP Methods: GET, HEAD, OPTIONS, PUT, POST, PATCH, DELETE
  • Origin Request Policy: Managed-UserAgentRefererHeaders

Step 3: Adjust your deployed script

With the custom origin and behaviours in place, you can change your script tag as follows:

<script defer data-domain="yourdomain.com" src="/js/script.js"></script>

In case of a subdirectory installation, you'll also need to add a data-api attribute to tell the script where the data should be sent.

<script defer data-domain="yourdomain.com" data-api="/subdirectory/api/event" src="/subdirectory/js/script.js"></script>

Deploy these changes to your CloudFront site. You can verify the proxy is working by opening your network tab. You should see a request to https://yourdomain.com/js/script.js with status 200 and another one to https://yourdomain.com/api/event with status 202.

Using our extensions such as hash-based routing, page exclusions or outbound link click tracking? Change the file name from script.js to the script you want to use: script.hash.js, script.exclusions.js or script.outbound-links.js. Want to use more than one extension? You can chain them like this: script.hash.exclusions.outbound-links.js.

Thanks to @thomasjsn for contributing these instructions!