[WooCommerce & Wordpress] Setting up Purchase Webhooks
Note: To get the webhooks working correctly, it’s important to provide the Google Tag (GA4 configuration tag) with extra parameters named marketing.user_id, marketing.session_count, and marketing.session_id.
Add DataLayer variables from the “trytagging_user_data” event.
marketing.user_id
data:image/s3,"s3://crabby-images/c3d88/c3d884ba27c85fe8e022c9bfa619e7ef6bab43b2" alt="Marketing User ID"
marketing.session_count
data:image/s3,"s3://crabby-images/bef2a/bef2a7eff241d358eee140210f9af6628fc651e3" alt="Marketing Session Count"
marketing.session_id
data:image/s3,"s3://crabby-images/b1e5b/b1e5b7903334495e11d7a585e6911dad8269965b" alt="Marketing Session Count"
Ensure that the Google Tag is triggered by the “trytagging_user_data” event; otherwise, it is not possible to retrieve the user data.
data:image/s3,"s3://crabby-images/24a5d/24a5df3ce5c4a7afb918cd337c4706f83de5fb68" alt="Trytagging_userdata trigger"
The Google Tag should always be triggered for all standard eCommerce events. If this is not possible, choose to create a Trigger group.
Add the 3 parameters created in step 1.
data:image/s3,"s3://crabby-images/8fa52/8fa528460fa41fed91004fc941b83185677965c0" alt="Variables from step 1"
ClientId = {{ marketing.user_id }}
sessionid = {{ marketing.session_id }}
sessioncount = {{ marketing.session_count }}
Add 3 event data variables
sessioncount
data:image/s3,"s3://crabby-images/a6367/a6367039057cad65c61e65bb9fffb347e25f8e91" alt="marketing_data.session_count"
sessionid
data:image/s3,"s3://crabby-images/eee00/eee00d0ff1bf577560483e26a29a40d1941eaa27" alt="marketing_data.session_id"
ClientId
data:image/s3,"s3://crabby-images/be5d5/be5d5be018ff993a90f0057713eb2ad20e4c2944" alt="marketing_data.user_id"
Create a Transformation with the type “Augment event”
data:image/s3,"s3://crabby-images/4274c/4274cd191ea0f01fd3a2c98ff2975d71d5009e25" alt="Transformation om ervoor te zorgen dat het GA4 client events gaat matchen met de Purchase webhook events"
client_id = {{ ClientId }}
ga_session_id = {{ sessionid }}
ga_session_number = {{ sessioncount }}
Now ensure that these Transformations are added to the GA4 Tag of the Server container.
data:image/s3,"s3://crabby-images/d9a09/d9a09758a4852207e2d127607f63106c9404a8fa" alt="Attach tag"
Ensure that the “purchase” event is excluded from the GA4 trigger. We do this because the Purchase events are now sent via Webhooks; otherwise, you will get duplicate data.
data:image/s3,"s3://crabby-images/f4246/f4246b843154bad1ef56fdd36d56846f0312b28b" alt="Exclude purchase from GA4 client"
For creating the Data Client, we use the Stape Data Client. You can download it here: https://github.com/stape-io/data-client
data:image/s3,"s3://crabby-images/e694b/e694bccf36eeef3a7ec1ae9f8932080bca3c29ea" alt=""
Go to templates in sGTM -> Click on new -> Import Data Client -> and click on “Save”
data:image/s3,"s3://crabby-images/edbca/edbca34e402130e8b141c89aa084f9c316491e57" alt=""
Create Data Client by going to Tags -> Click on new -> Select type Data Client Accepted Path Settings -> Add Path -> Add the endpoint such as “order_created”
data:image/s3,"s3://crabby-images/a8008/a8008ac8b9711c88ac9dcb3f2ddf0d3baec6eca4" alt=""
ecommerce.currency
data:image/s3,"s3://crabby-images/03e0a/03e0a957fa48b89b6a57fe6b74e8bb17bec512a3" alt=""
ecommerce.transaction_id
data:image/s3,"s3://crabby-images/61950/619501e728ba79686c5d3ff90ecfc2b26e05734e" alt=""
ecommerce.items
data:image/s3,"s3://crabby-images/b8647/b864721f53f05df3d8b1130be7d594022b4bed19" alt=""
ecommerce.tax
data:image/s3,"s3://crabby-images/1abd5/1abd5837c10db307f85c6c94eb65937287027f09" alt=""
ecommerce.shipping
data:image/s3,"s3://crabby-images/249e3/249e3e4984175fd8fb97d286cfd0f3f410e4305d" alt=""
ecommerce.coupon
data:image/s3,"s3://crabby-images/5cb71/5cb713c0c17587462baf98f256d9351684353594" alt=""
marketing_data.session_id
data:image/s3,"s3://crabby-images/4a8c5/4a8c5f0908a0f64644e86e769476d17268fd4b20" alt=""
marketing_data.session_count
data:image/s3,"s3://crabby-images/f52b3/f52b3c6fd76d9e59709c6b4bbec1d0d20281df17" alt=""
marketing_data.user_id
data:image/s3,"s3://crabby-images/112b3/112b33392653d026ac7b1a4472c7ba6a0df9e363" alt=""
timestamp
data:image/s3,"s3://crabby-images/f870b/f870bd04082c7bebabcc9d674698b59fec7a5e85" alt=""
page_location (depends on your CMS)
data:image/s3,"s3://crabby-images/a0cec/a0cece390370b0021ae9374e47e4fbf4404157be" alt=""
Then add these variables as parameters in the Purchase Tag
data:image/s3,"s3://crabby-images/5a195/5a195482c33ed1dbd05812135439a1438a27400d" alt=""
Create the Purchase Tag and ensure you add the following parameters as a purchase tag.
value = {{ ecommerce.value }}
currency = {{ ecommerce.currency }}
transaction_id = {{ ecommerce.transaction_id }}
items = {{ ecommerce.items }}
tax = {{ ecommerce.tax }}
shipping = {{ ecommerce.shipping }}
coupon = {{ ecommerce.coupon }}
ga_session_id = {{ marketing_data.session_id }}
ga_session_number = {{ marketing_data.session_count }}
client_id = {{ marketing_data.user_id }}
event_time = {{ timestamp }}
page_location = {{ page_location }}
Engagement_time_msec = 1564
Page_hostname = domain.com
page_title = thank you page title
Note! Make sure to check the variables to see if they are populated in preview mode and also check if they are the correct parameters. For example, if page_location has a different URL than in reality, you will need to adjust these variables.
data:image/s3,"s3://crabby-images/a2cb9/a2cb9ab8c3bebd93b961391c1703e715ce802d92" alt=""
Create a Trigger that fires based on:
Client Name equals Data Client
Event Name
data:image/s3,"s3://crabby-images/a858b/a858b5b6d73bdf4063c5b7f3b495a76f1492cfcf" alt=""
Follow the steps below to adjust the Google Tag in the web container:
Add DataLayer variables from the “trytagging_user_data” event.
marketing.user_id
data:image/s3,"s3://crabby-images/c3d88/c3d884ba27c85fe8e022c9bfa619e7ef6bab43b2" alt="Marketing User ID"
marketing.session_count
data:image/s3,"s3://crabby-images/bef2a/bef2a7eff241d358eee140210f9af6628fc651e3" alt="Marketing Session Count"
marketing.session_id
data:image/s3,"s3://crabby-images/b1e5b/b1e5b7903334495e11d7a585e6911dad8269965b" alt="Marketing Session Count"
Ensure that the Google Tag is triggered by the “trytagging_user_data” event; otherwise, it is not possible to retrieve the user data.
data:image/s3,"s3://crabby-images/24a5d/24a5df3ce5c4a7afb918cd337c4706f83de5fb68" alt="Trytagging_userdata trigger"
The Google Tag should always be triggered for all standard eCommerce events. If this is not possible, choose to create a Trigger group.
Add the 3 parameters created in step 1.
data:image/s3,"s3://crabby-images/8fa52/8fa528460fa41fed91004fc941b83185677965c0" alt="Variables from step 1"
ClientId = {{ marketing.user_id }}
sessionid = {{ marketing.session_id }}
sessioncount = {{ marketing.session_count }}
Follow the steps below to adjust the server container:
Add 3 event data variables
sessioncount
data:image/s3,"s3://crabby-images/a6367/a6367039057cad65c61e65bb9fffb347e25f8e91" alt="marketing_data.session_count"
sessionid
data:image/s3,"s3://crabby-images/eee00/eee00d0ff1bf577560483e26a29a40d1941eaa27" alt="marketing_data.session_id"
ClientId
data:image/s3,"s3://crabby-images/be5d5/be5d5be018ff993a90f0057713eb2ad20e4c2944" alt="marketing_data.user_id"
Create a Transformation with the type “Augment event”
data:image/s3,"s3://crabby-images/4274c/4274cd191ea0f01fd3a2c98ff2975d71d5009e25" alt="Transformation om ervoor te zorgen dat het GA4 client events gaat matchen met de Purchase webhook events"
client_id = {{ ClientId }}
ga_session_id = {{ sessionid }}
ga_session_number = {{ sessioncount }}
Now ensure that these Transformations are added to the GA4 Tag of the Server container.
data:image/s3,"s3://crabby-images/d9a09/d9a09758a4852207e2d127607f63106c9404a8fa" alt="Attach tag"
Ensure that the “purchase” event is excluded from the GA4 trigger. We do this because the Purchase events are now sent via Webhooks; otherwise, you will get duplicate data.
data:image/s3,"s3://crabby-images/f4246/f4246b843154bad1ef56fdd36d56846f0312b28b" alt="Exclude purchase from GA4 client"
For creating the Data Client, we use the Stape Data Client. You can download it here: https://github.com/stape-io/data-client
data:image/s3,"s3://crabby-images/e694b/e694bccf36eeef3a7ec1ae9f8932080bca3c29ea" alt=""
Go to templates in sGTM -> Click on new -> Import Data Client -> and click on “Save”
data:image/s3,"s3://crabby-images/edbca/edbca34e402130e8b141c89aa084f9c316491e57" alt=""
Create Data Client by going to Tags -> Click on new -> Select type Data Client Accepted Path Settings -> Add Path -> Add the endpoint such as “order_created”
data:image/s3,"s3://crabby-images/a8008/a8008ac8b9711c88ac9dcb3f2ddf0d3baec6eca4" alt=""
ecommerce.currency
data:image/s3,"s3://crabby-images/03e0a/03e0a957fa48b89b6a57fe6b74e8bb17bec512a3" alt=""
ecommerce.transaction_id
data:image/s3,"s3://crabby-images/61950/619501e728ba79686c5d3ff90ecfc2b26e05734e" alt=""
ecommerce.items
data:image/s3,"s3://crabby-images/b8647/b864721f53f05df3d8b1130be7d594022b4bed19" alt=""
ecommerce.tax
data:image/s3,"s3://crabby-images/1abd5/1abd5837c10db307f85c6c94eb65937287027f09" alt=""
ecommerce.shipping
data:image/s3,"s3://crabby-images/249e3/249e3e4984175fd8fb97d286cfd0f3f410e4305d" alt=""
ecommerce.coupon
data:image/s3,"s3://crabby-images/5cb71/5cb713c0c17587462baf98f256d9351684353594" alt=""
marketing_data.session_id
data:image/s3,"s3://crabby-images/4a8c5/4a8c5f0908a0f64644e86e769476d17268fd4b20" alt=""
marketing_data.session_count
data:image/s3,"s3://crabby-images/f52b3/f52b3c6fd76d9e59709c6b4bbec1d0d20281df17" alt=""
marketing_data.user_id
data:image/s3,"s3://crabby-images/112b3/112b33392653d026ac7b1a4472c7ba6a0df9e363" alt=""
timestamp
data:image/s3,"s3://crabby-images/f870b/f870bd04082c7bebabcc9d674698b59fec7a5e85" alt=""
page_location (depends on your CMS)
data:image/s3,"s3://crabby-images/a0cec/a0cece390370b0021ae9374e47e4fbf4404157be" alt=""
Then add these variables as parameters in the Purchase Tag
data:image/s3,"s3://crabby-images/5a195/5a195482c33ed1dbd05812135439a1438a27400d" alt=""
Create the Purchase Tag and ensure you add the following parameters as a purchase tag.
value = {{ ecommerce.value }}
currency = {{ ecommerce.currency }}
transaction_id = {{ ecommerce.transaction_id }}
items = {{ ecommerce.items }}
tax = {{ ecommerce.tax }}
shipping = {{ ecommerce.shipping }}
coupon = {{ ecommerce.coupon }}
ga_session_id = {{ marketing_data.session_id }}
ga_session_number = {{ marketing_data.session_count }}
client_id = {{ marketing_data.user_id }}
event_time = {{ timestamp }}
page_location = {{ page_location }}
Engagement_time_msec = 1564
Page_hostname = domain.com
page_title = thank you page title
Note! Make sure to check the variables to see if they are populated in preview mode and also check if they are the correct parameters. For example, if page_location has a different URL than in reality, you will need to adjust these variables.
data:image/s3,"s3://crabby-images/a2cb9/a2cb9ab8c3bebd93b961391c1703e715ce802d92" alt=""
Create a Trigger that fires based on:
Client Name equals Data Client
Event Name
data:image/s3,"s3://crabby-images/a858b/a858b5b6d73bdf4063c5b7f3b495a76f1492cfcf" alt=""
Updated on: 16/08/2024
Thank you!