Server Side Tracking
Disclaimer
Server-side tracking is an advanced feature that differs significantly from client-side tracking commonly implemented through platforms like Google Tag Manager (GTM). While GTM allows for relatively straightforward analytics setup by marketing professionals or non-technical users, server-side tracking requires a deeper technical understanding and direct implementation within your server's codebase.Server-side tracking provides a robust method for capturing events directly from your backend systems, offering enhanced data privacy and bypassing limitations of client-side tracking. This guide outlines the process for setting up server-side tracking with Dreamdata.
Before proceeding, ensure you have the following:
- Access to your server/backend environment.
- Dreamdata Source API Key: This is required for authenticating with the
Tracking API. You can locate your API Key in the Dreamdata platform under
Data Platform > Sources > Server Side Analytics APIs.
Key Differences:
- Implementation Complexity: Server-side tracking cannot be set up through GTM and requires a developer for implementation.
- Data Control: It offers more control over the data being sent, improving privacy and data security.
- Technical Knowledge: Understanding of backend development and server architecture is necessary. Server-side tracking is recommended for teams seeking advanced analytics capabilities and those with access to technical resources for implementation.
Authentication to the Tracking API
To authenticate with the Dreamdata Tracking API, you'll use HTTP Basic Auth.
This process requires encoding your Dreamdata source API Key in base64,
formatted as username:password — with your API key as the username and leaving
the password field empty.
For example, if your API key is abc123, you authenticate like this:
curl -u "abc123:" -X POST https://api.dreamdata.cloud/v1/batch \
  -H 'Content-Type: application/json' \
  -d ...
Encoding Your API Key in Base64 (Unix-based Systems)
- Open your Terminal.
- Use the echocommand combined withbase64to encode your API Key. Ensure you add a colon (:) after your API Key before encoding it since the format should beusername:passwordand the password is empty.
echo -n 'your_api_key_here:' | base64
Replace your_api_key_here with your actual Dreamdata source API Key.
This command will output a base64-encoded string that represents your API Key followed by a colon. You'll use this encoded string in your authentication header when making API requests.
Example
If your API Key is abc123, you would run:
echo -n 'abc123:' | base64
The output will be something like YWJjMTIzOg==, which you'll use in your
authentication header:
curl -u "YWJjMTIzOg==" -X POST https://api.dreamdata.cloud/v1/batch \
  -H 'Content-Type: application/json' \
  -d ...
Note: The -n flag in the echo command prevents a newline character from
being added at the end of the string, ensuring the encoding is accurate.
Sending Data: Track & Identify Events
Dreamdata's endpoint supports sending batches of data, limited to 500kb per
request. These batches can include a mix of identify and track events.
Here's how to format such a request:
{
  "messageId": "6f47f5a0-4118-42de-9e15-95cf9ed2a426",
  "sentAt": "2015-12-02T00:30:08.276Z",
  "batch": [
    {
      "type": "identify",
      "messageId": "6ad2be86-6d78-43bd-8a5b-846ddbc042c2",
      "userId": "019mr8mf4r",
      "traits": {
        "email": "jake@yahoo.com",
        "name": "Jake Peterson",
        "age": 26
      },
      "context": {
        "ip": "24.5.68.47",
        "library": {
          "name": "customer",
          "version": "v1"
        },
        "campaign": {
          "name": "my_campaign",
          "source": "demo",
          "medium": "calendly",
          "term": "",
          "content": ""
        }
      },
      "timestamp": "2012-12-02T00:30:08.276Z"
    },
    {
      "type": "track",
      "messageId": "3f8236bc-c010-43bb-a341-cd30b5228e9d",
      "userId": "019mr8mf4r",
      "event": "Song Played",
      "properties": {
        "name": "Fallin for You",
        "artist": "Dierks Bentley"
      },
      "context": {
        "ip": "24.5.68.47",
        "page": {
          "referrer": "http://localhost:3000/test",
          "url": "http://localhost:3000/test/path?param=a088fb06-a208-4552-b4b7-28fb7f95aeaf"
        },
        "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36",
        "campaign": {
          "name": "my_campaign",
          "source": "demo",
          "medium": "calendly",
          "term": "",
          "content": ""
        }
      },
      "timestamp": "2012-12-02T00:30:12.984Z"
    }
  ]
}
Replace placeholders with actual data relevant to your tracking needs. Each
event needs a unique messageId, and timestamps should be in ISO 8601 format.
Endpoint for Sending Events
To submit your events to Dreamdata, make a POST request with your batch payload to:
curl -u "your-api-key:" -X POST https://api.dreamdata.cloud/v1/batch \
  -H 'Content-Type: application/json' \
  -d @path-to-your-json-file
Replace your-api-key with your actual Dreamdata API key and
path-to-your-json-file with the file path of your JSON payload.
SDK Support
Dreamdata provides SDKs for easier integration within your application:
- NodeJS SDK: Documented in our GitHub repository.
- Go SDK: Also available on GitHub.
Example CURL Request
To send your events using curl, assuming your JSON payload is saved in
example.json:
curl -u "your-api-key:" -X POST https://api.dreamdata.cloud/v1/batch \
  -H 'Content-Type: application/json' \
  -d @example.json