Create billable metrics with Basic Filters
The Basic Filters editor is a structured query builder designed to provide out-of-the-box filters and aggregations on your usage stream. All metrics defined with the Basic Filters editor are created as streaming billable metrics.
Billable metrics can be created in both the Metronome app or using the Metronome API.
For this example, create a metric to track "API Calls" for a hypothetical cloud service.
- Navigate to the Billable Metrics section in Metronome.
- Click + Add new Billable Metric.
- Choose Basic filters.
- Name your metric (for example, API Calls).
- Select the event type (for example, api_request).
- Set filters:
- Property 1
- property_name: "status"
- operator: "In"
- value: "success" (This ensures Metronome only counts successful API calls.)
 
- Property 2
- property_name: "user_id"
 - operator: "Exists"
- (Metronome uses this as a group key to display API calls broken out by user.)
 
 
- Property 1
- Choose the aggregation method:
- To count the number of API calls, not sum or average them, select "Count".
 
- Set a group key for user_id.
- Review and save your metric.

This billable metric counts all successful API calls broken out by user_id, providing a simple but effective measure of platform usage across an organization.
Prefer using the API? Here is an example request to set up the same metric:
curl -X POST https://api.metronome.com/v1/billable-metrics/create \ 
 -H "Authorization: Bearer <TOKEN>" \ 
 -H "Content-Type: application/json" \ 
 -d '{
    "name":"API Calls",
    "event_type_filter": {
      "in_values": ["api_request"]
    },
    "property_filters": [
      {
        "name": "status",
        "exists": true,
        "in_values": ["success"]
      },
      {
        "name": "user_id",
        "exists": true
      }
    ],
    "aggregation_type": "COUNT",
    "group_keys": [["user_id"]]
  }'