Overview
The Computer Analytics API gives Perplexity Enterprise organizations programmatic access to the same Computer usage analytics shown in the web dashboard — credits, connectors, artifacts, skills, spaces, workflows, and task durations — as bucketed time series you can pull into BI tools or internal reporting. Analytics requests are free and don’t consume API credits.This API is available to Perplexity Enterprise organizations. If you don’t see the Analytics API toggle described below, the feature may not be enabled for your organization yet — contact your Perplexity representative.
Getting Access
Access is managed by your organization’s admins from the Perplexity web app:Enable the Analytics API
In the Perplexity web app, open your organization’s Computer settings and find the Analytics section. Turn on Analytics API to provision API access for your organization.
- Org-scoped, admin-managed — the key belongs to your organization, not to the admin who created it. Any org admin can view the current key and regenerate it.
- One active key — your organization has at most one active analytics key. Regenerating revokes the previous key.
- Analytics-only — the key authenticates analytics endpoints only; it cannot call other Perplexity APIs and has no billing attached.
- Disabling revokes — turning the Analytics API toggle off permanently revokes the key.
Authentication
Pass the key as a bearer token:Querying Usage
GET /v1/analytics/computer/usage returns one time series per request, for a single dataset.
Parameters
| Parameter | Required | Description |
|---|---|---|
dataset | Yes | One of credit_usage, connectors, artifacts, skills, spaces, workflows, task_durations. |
start_time | Yes | Window start, unix seconds (UTC). Inclusive. Snapped down to the bucket grid. |
end_time | No | Window end, unix seconds (UTC). Exclusive. Defaults to now; values in the future are capped at now. |
bucket_width | No | 1d (default) or 1h. Buckets align to the UTC grid. |
limit | No | Buckets per page. 1d: default 7, max 31. 1h: default 24, max 168. |
page | No | Opaque pagination cursor from a previous response’s next_page. Valid only with the same query parameters it was issued for. |
user_email | No | Restrict results to a single member of your organization. See Filtering by member. |
Response
datacontains every bucket in the page’s window, in chronological order. Buckets without data carrycount: 0and an emptyby_category.by_categorybreaks the bucket total down by the dataset’s dimension — for example connector names forconnectors, duration bands fortask_durations, orpaid/promoforcredit_usage. Forspaces,skills, andworkflows, categories are the titles your members gave those items.- For
credit_usage,countcan exceed the sum ofby_category— usage without a category attribution counts toward the total but not the breakdown.
Time Windows and Buckets
The API serves complete UTC grid buckets only:start_timesnaps down to the start of its bucket, so the first bucket can include usage from before your requested start.end_timeis exclusive and is capped at the current time, then snapped down — the in-progress bucket is never returned. Withbucket_width=1d, today’s bucket is not included; use1hfor intraday data.- A valid window that contains no complete buckets returns
200with emptydata.
Data freshness. The analytics store is synced periodically, not in real time. A
count of 0 in a recent bucket can mean the data hasn’t synced yet rather than zero usage. When has_more is false you have reached the current data frontier — poll again later for newer buckets.Pagination
When the window spans more buckets thanlimit, the response sets has_more: true and a next_page cursor. Pass it back as page, keeping every other parameter identical — cursors are strictly validated and a cursor used with different parameters returns 400.
Filtering by Member
Passuser_email to restrict the series to a single member of your organization:
400:
Errors
Errors use a consistent envelope:| Status | type | Meaning |
|---|---|---|
400 | bad_request | A parameter failed validation (wrong type, malformed value). |
400 | invalid_request | Parameters are well-formed but semantically invalid — e.g. start_time after end_time, a window over 90 days, a misused pagination cursor, or a user_email that doesn’t match a member. |
401 | unauthorized | Missing or invalid API key. |
404 | feature_disabled | The Computer Analytics API is not enabled for your organization. |
429 | request_rate_limit_exceeded | Rate limit exceeded. Requests are limited per organization across all of its keys; retry with backoff. |
Limits
- Time windows are limited to 90 days per request (paginate within the window for long ranges).
- Requests are rate-limited per organization — all keys minted by your org share one allowance.