AI-generated Key Takeaways
- 
          This article outlines methods for sending data to a server-side container in Google Tag Manager from websites and other sources like mobile apps and server-to-server applications. 
- 
          It explains how to configure clients within your server-side container to receive and process incoming data, including optional settings for customization. 
- 
          The guide covers sending additional parameters alongside events and utilizing the Measurement Protocol for non-website data sources. 
- 
          It assumes prior setup of a server container and tagging server in Tag Manager. 
- 
          To enhance first-party data collection, the article encourages serving Google scripts directly from your servers, linking to further instructions. 
This article describes the different ways to send events to a server-side container. If you need more background information, take a look at how server-side tagging works.
This article discusses how to:
- Send data from a website to your server-side container
- Send additional data to a server container
- Receive data in your server-side container
- Send data from sources other than websites
Before you begin
This guide assumes that you already have:
1. Send data from a website to your server-side container
You can route data through a server-side implementation via Tag Manager or gtag.js. Pick your implementation option.
Optional: Send additional parameters with each event
You can send additional two types of additional parameters: Configuration-level parameters and event-level parameters. Configuration parameters influence how your Google tag behaves and can only be set on the Google tag level.
Event parameters specify additional information about an event and can be set
for all events, select events, or page_view events.
Setup recommendations
We recommend using GA4 tag on a web page to send data to the server container. This tag can use different transport methods to ensure the best delivery rate of the events. Such methods include but not limited to
- Image pixel
- Fetch API
- XHR
- Service worker that runs in an iframe loaded from your server container domain.
To ensure that all methods are supported check the following:
Content-security policy (CSP)
| Directive | Content | Purpose | 
| img-src | [SERVER_CONTAINER_URL] | Measurement requests | 
| connect-src | [SERVER_CONTAINER_URL] | Measurement requests | 
| frame-src | [SERVER_CONTAINER_URL] | Service worker implementation | 
In addition, X-Frame-Options must not restrict iframes from being loaded from the server container URL.
Consult with https://developers.google.com/tag-platform/security/guides/csp for specific policies per product.
2. Receive data in your server-side container
When you send HTTP request to a server container, a client has to claim that request.
To view the list of available clients:
- Open your server container. 
- In the navigation bar on the left, click Clients. The GA4 client is pre-installed on your server-side container by default. 
- Click the name of the client to view or edit details. 
Optional client settings
In most cases, the client will require no modifications. However, your use case might be different and you might want to edit one of the following settings:
- Priority: Determines the order in which clients will run. Higher numbers run first, and the first client that matches the incoming request will become the active client for that request. 
- Activation Criteria: Activation criteria define when the client will respond to requests: - Default gtag.js paths for specific IDs: Use this setting to enable
gtag.js JavaScript serving through your server container URL. When
enabled, this client will activate in response to requests to the
default gtag.js request paths, e.g. /gtag/js?id=TAG_ID. Click Add Measurement ID to add one or more destination IDs.
 
- Default gtag.js paths for specific IDs: Use this setting to enable
gtag.js JavaScript serving through your server container URL. When
enabled, this client will activate in response to requests to the
default gtag.js request paths, e.g. 
Optional: Receive additional data in server-side Tag Manager
If you are sending additional parameters, you need to set up the Google Analytics 4 client in your server container to parse the additional parameters and create event data out of them.
Some server tags will include the additional parameters in their outbound requests with no setup. To exclude those parameters, create a Transformation to remove the value.
To use additional parameters in other tags:
- In your server container, click on Variables in the left navigation.
- Create a New User-defined Variable.
- In Variable Configuration, select the variable type Event Data.
- In Key Path, enter the name of the parameter.
- Give your variable a name and Save.
Now you can use the event parameter in any other tag within your server container.
3. Optional: Send data from sources other than websites
The Google Analytics Measurement Protocol can be used to enable server-side tagging support from sources such as mobile apps and server-to-server applications. This option lets you send events to your container in the Measurement Protocol format. The container sends those events to Google Analytics using the same mechanism as all other SGTM events.
This option doesn't support all the features of the Measurement Protocol endpoint, like deriving geographic and device information from tagging events.
Mobile apps
To get your Android or iOS app to send data to your server container, you will create a custom image tag and configure it to use the Measurement Protocol:
- In your mobile container (Android or iOS), click Tags > New.
- In Tag Configuration select the Custom Image tag type.
- Set the value of Image URL to a pixel image on the server container at
the path in the Measurement Protocol client that you specified earlier.
Append any desired Measurement Protocol parameters to the end of your pixel
URL: 
 https://custom.example.com/app?v=1&tid=TAG_ID&cid=555&t=screenview&an=myApp&version=1.6.2&aid=com.foo.myapp&cd=home
- Deselect Enable Cache Busting.
- Save the tag and publish the container.
- In your server-side container, click Clients > New.
- In Client Configuration, select the Measurement Protocol client type.
- Set Activation Path to the path of your app's collection endpoint.
- Save the client configuration and publish the server-side container.
Server-to-server apps
To send measurement protocol data to your server container, replace the
www.google-analytics.com hostname with the domain name of your server
container. For example:
POST /batch HTTP/1.1
Host: collection.example.com
v=1&tid=TAG_ID&cid=555&t=screenview&an=myApp&version=1.6.2&aid=com.foo.myapp&cd=home
To receive Measurement Protocol hits, configure your server-side Tag Manager installation with a Measurement Protocol client:
- In your server-side container, click Clients > New.
- In Client Configuration, select the Measurement Protocol client type.
- Set Activation Path to the path of your server's endpoint.
- Save the client configuration and publish the container.
Next steps
To send data in a true first-party context, you need to serve Google scripts, such as the Google Analytics library, from your own servers.
Load Google scripts through my server