Innkeepr
Home
  • Home
    • Welcome to Innkeepr
    • Getting Started
  • Guides
    • A Basic Installation
    • Server-Side Installation
  • Connections
    • Overview
    • The Innkeepr Spec
      • Spec: Identify
      • Spec: Track
      • Spec: Ecommerce Events
    • Sources Catalog
      • Innkeepr.js
      • Google Ads
      • Google Analytics 4
      • Meta Ads
      • Shopify
      • TikTok Ads
  • References
    • Audiences
    • Events
      • Standard events
      • Custom events
  • Support
    • Resources
      • Cookie Consent
      • Data Protection Statement
    • FAQ
    • Contact
Powered by GitBook
On this page
  • Example
  • Identities
  • Event
  • Properties
  1. Connections
  2. The Innkeepr Spec

Spec: Track

PreviousSpec: IdentifyNextSpec: Ecommerce Events

Last updated 11 months ago

The track API call is how you record any actions your users perform, along with any properties that describe the action.

Each action is known as an event. Each event has a name, like User Registered, and properties. For example, a User Registered event might have properties like plan or accountType. Calling track in one of our sources is one of the first steps to getting started with Innkeepr.

Here’s the payload of a typical track call with most common fields removed:

{
  "type": "track",
  "event": "User Registered",
  "properties": {
    "plan": "Pro Annual",
    "accountType" : "Facebook"
  }
}

And here’s the corresponding JavaScript event that would generate the above payload:

Innkeepr.track("User Registered", {
  plan: "Pro Annual",
  accountType: "Facebook"
});

Beyond the common fields, the track call has the following fields:

FIELD
TYPE
DESCRIPTION

event

required

String

properties

optional

Object

Example

Here’s a complete example of a track call:

{
  "anonymousId": "636908973e90a7aca7d309fb",
  "context": {
    "library": {
      "name": "innkeepr.js",
      "version": "1.0"
    },
    "page": {
      "path": "/academy/",
      "referrer": "",
      "search": "",
      "title": "Analytics Academy",
      "url": "https://innkeepr.ai/docs"
    },
    "userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.86 Safari/537.36"
  },
  "event": "Course Clicked",
  "messageId": "ajs-f8ca1e4de5024d9430b3928bd8ac6b96",
  "properties": {
    "title": "Intro to Analytics"
  },
  "timestamp": "2015-12-12T19:11:01.249Z",
  "type": "track",
  "userId": "AiUGstSDIg"
}

Identities

The User ID is a unique identifier for the user performing the actions. Check out the User ID docs for more detail.

The Anonymous ID can be any pseudo-unique identifier, for cases where you don’t know who the user is, but you still want to tie them to an event. Check out the Anonymous ID docs for more detail.

Note: In our browser and mobile libraries a User ID is automatically added from the state stored by a previous identify call, so you do not need to add it yourself. They will also automatically handle Anonymous IDs under the covers.

Event

Every track call records a single user action. We call these “events”, and recommend that you make your event names human-readable, so that everyone on your team (even you, after all that caffeine) can know what they mean instantly.

Don’t use nondescript names like Event 12 or TMDropd. Instead, use unique but recognizable names like Video Recorded and Order Completed.

We recommend event names built from a noun and past-tense verb.

Properties

Properties are extra pieces of information you can tie to events you track. They can be anything that will be useful while analyzing the events later. We recommend sending properties whenever possible because they give you a more complete picture of what your users are doing.

Innkeepr has reserved some properties that have semantic meanings, and handle them in special ways. For example, we always expect revenue to be a euro amount that we send to tools that handle revenue tracking.

You should only use reserved properties for their intended meaning.

The following are all of the reserved properties Innkeepr has standardized that apply to all events. Check out the Semantic Events docs for properties specific to individual reserved events.

PROPERTY

TYPE

DESCRIPTION

revenue

Number

Amount of revenue an event resulted in. This should be a decimal value, so a shirt worth €19.99 would result in a revenue of 19.99.

currency

String

value

Number

An abstract “value” to associate with an event. This is typically used in situations where the event doesn’t generate real-dollar revenue, but has an intrinsic value to a marketing team, like newsletter signups.

Name of the action that a user has performed. See the for more details.

Free-form dictionary of properties of the event, like revenue See the for a list of reserved property names.

Currency of the revenue an event resulted in. This should be sent in the . If this isn’t set, Innkeepr assumes the revenue to be in euros.

ISO 4127 format
Event field docs
Properties docs