Stape
Search
Try for free

Meta CAPI for PrestaShop via server GTM

Updated
Jan 16, 2025
Published
Nov 15, 2024

Step 1. Configure server Google Tag Manager container.

1.1. Open your WEB Google Tag Manager container.

Click Admin. Under the container column, click +

set up server gm

1.2. Type the container name, choose Server, and click Create.

set up server gm

1.3. Choose Manually provision tagging server, copy your container config and paste it in any text editor. We will need it for the next steps.

set up server gtm

1.4. Create a stape.io account or log in to your existing one.

log in or sign up to access Stape

1.5. In Stape’s admin dashboard click Create container on the top right. 

log in or sign up to access Stape

1.6. Enter your container details:

  • Container name. The name does not necessarily have to be the same as the container name in your server GTM.
  • Container configuration - paste Container Config that you copied from your Google Tag Manager Server Container.
  • Server location - select your server location based on the location of most of your clients. Please note, location can not be changed later.

Click Create Container.

create container on stape

1.7. Choose a plan for your container. You can start with a Free plan. 

stape pricing plans

1.8. You will see the status of your container, container config, and plan name. 

It takes around 5 minutes to deploy a server container. Please reload the page to update the status. If the Google Tag Manager server-side setup was done correctly, you should see the status “Running”. 

running container on stape

Step 2. Set up Custom Loader in Stape admin.

Custom Loader modifies gtag.js and gtm.js loading paths to resist ad blockers and ITPs, potentially increasing data volume by up to 40%.

2.1. Find and copy your WEB GTM ID in GTM. 

To find GTM ID log in to your Google Tag Manager account and open a Web GTM container. In the top right corner (next to the Submit and Preview buttons) you’ll see some short text that starts with "GTM-" and then contains some letters/numbers.

Find and copy your WEB GTM ID in GTM 

2.2. Open your sGTM container on Stape → Click Power-Ups.

Find Custom Loader and click Configure.

Custom Loader and click Configure

2.3. Add the following settings:

Domain - from the list of domains connected to your container, select the necessary ones. 

Web GTM ID - add web Google Tag Manager ID. Check out how to find web GTM ID in our guide.

GA4 ad block bypass - enables bypassing adblockers' impact on the GA4 tracking code. Note that this setting will affect all container domains. Be sure to debug both the web and server GTM containers after enabling this toggle.

Same Origin Path - if you are using same origin approach for configuring custom domain, please specify the proxy path for requests. Learn more.

Platform - the custom loader code differs for each platform. Select PrestaShop, click generate and follow the steps on the right.

Custom Loader and click generate

What's more, now you can select another new platform in the Custom Loader setup besides Prestashop - Wix app. The setup is similar:

Custom Loader and click generate

Step 3. Configure Stape Server GTM module for PrestaShop.

3.1. To start installing, you need to buy the module on the PrestaShop platform.

Configure Stape Server GTM module for PrestaShop

3.2. Configure settings in three tabs: General Settings, DataLayers, and Webhooks.

3.3. General Settings tab.

This tab contains all the options for configuring the GTM snippet installation on every page of your PrestaShop site.

Add the following data:

  • Insert GTM snippet - enable this field to add the GTM snippet to every page on your PrestaShop store. And add the GTM web container ID (you can find it in your GTM account in the tab “Accounts”). The format should be the following: GTM-XXXXXXX.
  • GTM server container URL - use the subdomain you created for server-side tracking.
If you don’t have a subdomain, please follow the instructions to add a custom domain to the sGTM container.
  • Stape container identifier - that’s an optional parameter, but we highly recommend adding it as it increases protection against blockers. You can find the container identifier in the container section in Stape’s admin. For more detailed instructions, follow Stape’s guide on how to find the Stape container identifier.
  • Cookie Keeper - also optional; if you turn it on, you will minimize the impact of Safari ITP restrictions.
Configure Stape Server GTM module for PrestaShop

3.4. DataLayer tab.

In this tab, you can find toggles that enable dataLayer events. With their help, you can enrich the data by adding product and user information.

See the list of events that the module will push:

  • view_collection
  • view_item
  • add_to_cart
  • view_cart
  • remove_from_cart
  • begin_checkout
  • add_shipping_info
  • add_payment_info
  • purchase
Configure Stape Server GTM module for PrestaShop

3.5. Webhooks tab.

Please note: A limitation of using webhooks on PrestaShop is that they do not include any cookie data, which is essential for tracking on any platform. Therefore, relying on webhook events should only be considered as a last resort if you are unable to track the data online through other means.

In this tab, you can configure the webhooks to be sent to a specified URL for different events, such as purchases and/or refunds.

To activate webhooks configuration, turn on “Send webhooks to server GTM container”. Then you need to add the URL of your server container (format: https://gtm.example.com/data).

Turn on the fields according to the type of event - purchase and/or refund.

Check out the blog posts on using and debugging webhooks:

Step 4. Download and import container templates from our GitHub.

Download GTM templates for PrestaShop on our GitHub

4.2. You should import the templates in both your web and server container on GTM (process is the same across the two). You need to go Admin → Import Container:

Download GTM templates for PrestaShop on our GitHub
GTM templates for Shopify

4.3. Select your template file (make sure the template matches the container type - web/server).

4.4. Pick a workspace for this import (you can create a new one for this specific purpose).

4.5. Select Overwrite or Merge.

“Overwrite” option should only be used in a fresh, empty container or if you are absolutely certain you want to do it. For this demo we’re using Merge, with “Rename conflicting tags, triggers and variables” option selected. This way, if there are any conflicts - GTM will just rename the tags, thus not touching any of the existing entities you have in your container.

Step 5. Сonfigure GTM container templates.

5.1. Templates are fully built, so triggers, payloads, and event names are all taken care of for you. 

You just need to input your specific destinations, ids, API keys etc. We’ve tried to make it as comfortable as possible, so in both containers (web and server), you will find a folder called “[Stape] _Settings”.

Web

web Сonfigure GTM container templates

Server

server Сonfigure GTM container templates

All these variables are already referenced in tags that use them; you just need to give them proper values, for example:

proper values for variables

5.2. Pixel ID and API token can found in your pixel settings:

Pixel ID and API token
Pixel ID and API token

5.3. Once you’ve changed all these variables and saved them, your last step (assuming this a new container) is to add a preview URL in your server container by going to Admin → Container Settings. If the container is not new, just skip this step.

add a preview URL in your server container

Step 6. Test the setup.

Facebook provides the ability to test Browser and Server events. That is very useful if you set up Facebook pixel using GTM Server for the first time and wish to check that all data tracked correctly.

6.1. First, you need to obtain test_event_code. For this, you need to log into your Facebook manager, choose the data source that you liked to test, and open the tab “Test events”. There you will find the test event code. It can look like this: TEST2120

test_event_code

Note: TEST id will change once in a couple of hours, if your debug sessions are spread in time make sure to check the value you’re using is still valid.

6.2. Fill the LT - Map | Debug Mode → FB Test ID variable, in your server container, with the test event code that you get from the previous step.

look up table variable

This variable is already referenced in all Facebook tags. Variable will also only populate the tag in preview mode, so you don’t necessarily need to remove it before going live.

6.3. Launch preview mode on both your containers (web & server) If done right, you will see both web and server test events on the Facebook Test Event page.

 Facebook Test Event page

Try Stape for all things server-sideright now!