"Best analytics tool I've used in 14 years"

List visitors

GET https://datafa.st/api/v1/visitors

Search visitor IDs by behavior and filters, then use Get visitor data to drill into a single visitor. Requires Bearer Token authentication.

Common use cases

  • Find visitors who visited a specific page
  • Find visitors who completed a goal
  • Find mobile visitors from Google in a specific country
  • Find visitors from a UTM campaign

Query parameters

ParameterDescription
startAt / endAtOptional date range. Use YYYY-MM-DD for calendar days or ISO timestamps with Z/offset for exact instants. Both must be provided together.
limitNumber of visitors to return. Default 100, max 250.
offsetNumber of visitors to skip. Default 0.
visitedPageExact page path, e.g. /pricing.
visitedPageContainsPartial page match, e.g. /docs.
completedGoalVisitors who completed a goal or event, e.g. signup.
country, region, cityLocation filters. Country names and country codes are supported.
device, browser, osDevice and browser filters.
referrer, hostnameTraffic source and hostname filters.
utm_source, utm_medium, utm_campaign, utm_term, utm_contentUTM filters.
ref, source, viaURL parameter filters.
isCustomer=trueVisitors with a payment event.

Examples

GET /api/v1/visitors?visitedPage=/pricing&startAt=2026-04-01&endAt=2026-05-01
GET /api/v1/visitors?visitedPageContains=/docs&completedGoal=signup&limit=100
GET /api/v1/visitors?referrer=Google&country=France&device=mobile
GET /api/v1/visitors?utm_campaign=launch&isCustomer=true

Response

The data array contains up to limit matching visitors. Use pagination.offset, pagination.limit, and pagination.hasMore to fetch more results.
{
  "status": "success",
  "data": [
    {
      "visitorId": "a3ab2331-989f-4cfa-91c6-2461c9e3c6bd",
      "lastSeenAt": "2026-05-05T12:00:00Z",
      "currentUrl": "datafa.st/pricing",
      "identity": {
        "country": "US",
        "region": "CA",
        "city": "San Francisco",
        "browser": "Chrome",
        "os": "Mac OS",
        "device": "desktop"
      },
      "acquisition": {
        "referrer": "https://google.com",
        "utm_source": "google",
        "utm_campaign": "launch"
      }
    },
    {
      "visitorId": "7c5d3f16-6f9f-4d1b-9d9d-8fb74f6e3b6a",
      "lastSeenAt": "2026-05-04T18:30:00Z",
      "currentUrl": "datafa.st/docs/api-introduction",
      "identity": {
        "country": "FR",
        "region": "IDF",
        "city": "Paris",
        "browser": "Safari",
        "os": "iOS",
        "device": "mobile"
      },
      "acquisition": {
        "referrer": "https://x.com",
        "utm_source": null,
        "utm_campaign": null
      }
    }
    // More matching visitors can be returned here, up to the requested limit.
  ],
  "pagination": {
    "limit": 100,
    "offset": 0,
    "total": 1234,
    "hasMore": true
  }
}
This endpoint is paginated on purpose. Use it to find matching visitor IDs, then call GET /api/v1/visitors/{datafast_visitor_id} for full visitor details.

✍️ Something missing? Suggest features.

🤖 AI agent or LLM? Read this page as markdown