# Chili Piper UTM Tracking Integration

Track UTM parameters and campaign attribution with Chili Piper UTM Tracking Integration and HandL UTM Grabber on WordPress.

# Pass UTMs into Chili Piper Router Links

## UTM attribution overview

Booking pages are a common leak in attribution. Chili Piper UTM Tracking Integration needs UTMs on the booking URL when the appointment is confirmed. UTM Grabber already captured them on your WordPress site. Here is how to carry them over.

B2B teams use Chili Piper for routing. Append UTMs to router URLs from WordPress.

### Steps

1. utm-out on demo request buttons
2. Pass utm\_source into CP hidden fields if supported

Add `utm-out` to any button or link that opens your Chili Piper UTM Tracking Integration scheduler. [utm-out class guide](https://docs.utmgrabber.com/books/102-getting-started-for-handl-utm-grabber-v3/page/appending-utms-to-the-buttons-using-class-name-attributes-selectively).

For a thank-you page webhook flow, read [Send Chili Piper UTMs via Webhook](https://docs.utmgrabber.com/books/chili-piper-integration/page/end-hili-iper-s-via-ebhook).

# Send Chili Piper UTMs via Webhook

## UTM attribution overview

This walkthrough covers sending full UTM Grabber data from Chili Piper UTM Tracking Integration to Zapier, Make, or your own webhook. Handy when you need gclid, fbclid, first-touch fields, or custom params alongside the lead or order.

Start with the [main Chili Piper UTM Tracking Integration setup guide](https://docs.utmgrabber.com/books/chili-piper-integration/page/ass-s-into-hili-iper-outer-inks) if you have not wired hidden fields or checkout links yet.

### When a webhook makes sense

Native fields in Chili Piper UTM Tracking Integration often stop at basic UTMs. A webhook lets you push everything UTM Grabber stores without trimming values or losing click IDs.

### Thank-you page script

Paste this on your confirmation page. Swap in your Zapier or Make hook URL.

```
<script>
var qvars = {};
window.location.href.replace(/[?&]+([^=&]+)=([^&]*)/gi, function(m, key, value) {
    qvars[key] = decodeURIComponent(value.replace(/\+/g, ' '));
});
qvars = Object.assign({}, (typeof handl_utm !== 'undefined' ? handl_utm : {}), qvars);
setTimeout(function() {
    var data = new URLSearchParams(qvars).toString();
    var xmlHttp = new XMLHttpRequest();
    xmlHttp.open('GET', 'https://hooks.zapier.com/hooks/catch/YOUR_ID/YOUR_KEY/?' + data, true);
    xmlHttp.send(null);
}, 1000);
</script>
```

Full pattern explained in [Triggering Zapier on Thank you Page](https://docs.utmgrabber.com/books/zapier-integration/page/triggering-zapier-on-thank-you-page).

### Quick Zapier / Make checklist

1. Create a Catch Hook trigger and copy the URL
2. Run a test conversion with UTMs in the landing URL
3. Confirm gclid, utm\_source, and email (if present) show up in the payload
4. Map fields into your CRM or spreadsheet

Parameter reference: [Native WP Shortcodes](https://docs.utmgrabber.com/books/102-getting-started-for-handl-utm-grabber-v3/page/native-wp-shortcodes).

Make users: see [Make Integromat integration](https://docs.utmgrabber.com/books/integromat-integration).