The Track API call is how you record any custom actions your users are doing, along with properties that describe the action. Custom events can capture a broad range of actions, such as clicking a button or completing a purchase. Additional information about the event can be included in the properties field. For example, for a Purchase Completed event, you may want to include the product ids of the purchased products.

Naming events

When naming events, Formo recommends establishing a consistent naming convention that uses:
  • Consistent formatting: Event names are case sensitive.
  • A consistent syntax: Adopt nouns and past tense verbs like Swap Reviewed and Order Submitted. A standard of [Noun] + [Past-Tense Verb] ensures all your events are consistent.
  • A consistent actor: Does Message Sent mean that the user sent a message or that you sent a message to the user? If all your events are named in a way that reflects the user’s perspective, the meaning is clear immediately.
This allows everyone including you 6 months from now to instantly understand the meaning of an event.

Fields

Apart from the common fields, the track call accepts the following fields:
FieldTypeRequiredDescription
eventStringName of the user action
propertiesObjectIncludes the properties associated with the event. For more information, check the Properties section below.

Properties

Properties are additional information that give more clarity of your users’ actions. Formo has reserved some standard properties listed in the following table and handles them in a special manner.

Tracking volume, revenue, points

You can track volume, revenue, and points in your events. Once tracked, they are shown on the dashboard.
Revenue tracking.

Revenue tracking.

Include these optional properties in a custom event to track values associated with an action.
PropertyTypeDescription
volumeNumberThe volume amount as a result of an event. For e.g., a token swap worth $20.00 would result in a volume of 20.00.
revenueNumberThe revenue amount as a result of an event. For e.g., a transaction with a protocol fee of $5.00 would result in a revenue of 5.00.
currencyStringThe currency of the revenue as a result of the event, set in ISO 4127 format. If this is not set, Formo assumes the revenue is in USD.
pointsStringAn abstract value such as points or XP associated with an event, to be used by various teams.

Sample Payload

{
  "type": "track",
  "event": "Product Reviewed",
  "properties": {
    "revenue": "20.5",
    "currency": "USD",
    "points": "100",
    "product_id" : "9578257311",
    "rating" : 3.0,
    "review_body" : "Good value for the price."
  }
}