Analytics - Extensions
Gets a URL that extension developers can use to download analytics reports (CSV files) for their extensions. The URL is valid for 5 minutes. For details about analytics and the fields returned, see the Insights & Analytics guide.
Method Definition
@RequestLine("GET /analytics/extensions?after={after}&ended_at={ended_at}&first={first}&extension_id={extension_id}&started_at={started_at}&type={type}")
@Headers("Authorization: Bearer {token}")
HystrixCommand<ExtensionAnalyticsList> getExtensionAnalyticUrl(
	@Param("token") String authToken,
	@Param("after") String after,
	@Param("first") Integer limit,
	@Param("extension_id") String extensionId,
	@Param("type") String type,
	@Param("started_at") String startedAt,
	@Param("ended_at") String endedAt
);
Required Parameters
| Name | Type | Description | 
|---|---|---|
| authToken | string | User Access Token with the analytics:read:extensionsscope. | 
Optional Parameters
| Name | Type | Description | 
|---|---|---|
| after | string | Cursor for forward pagination: tells the server where to start fetching the next set of results, in a multi-page response. This applies only to queries without extension_id. If anextension_idis specified, it supersedes any cursor/offset combinations. The cursor value specified here is from the pagination response field of a prior query. | 
| limit | integer | Maximum number of objects to return. Maximum: 100. Default: 20. | 
| type | string | The type of analytics report to get. Possible values are: "overview_v2". | 
| extension_id | string | Client ID value assigned to the extension when it is created. If this is specified, the returned URL points to an analytics report for just the specified extension. If this is not specified, the response includes multiple URLs (paginated), pointing to separate analytics reports for each of the authenticated user’s extensions. | 
| started_at | string | Starting date/time for returned reports, in RFC3339 format with the hours, minutes, and seconds zeroed out and the UTC timezone: YYYY-MM-DDT00:00:00Z. This must be on or after January 31, 2018.If this is provided, ended_atalso must be specified. Ifstarted_atis earlier than the default start date, the default date is used. Default: January 31, 2018 (overview_v2) or 90 days (overview_v1) before the report was issued. The file contains one row of data per day. | 
| ended_at | string | Ending date/time for returned reports, in RFC3339 format with the hours, minutes, and seconds zeroed out and the UTC timezone: YYYY-MM-DDT00:00:00Z. The report covers the entire ending date; e.g., if2018-05-01T00:00:00Zis specified, the report covers up to2018-05-01T23:59:59Z.If this is provided, started_atalso must be specified. Ifended_atis later than the default end date, the default date is used. Default: 1-2 days before the request was issued (depending on report availability). | 
Code-Snippets
print report url (to download the files)
- Java
- Kotlin
- Groovy
ExtensionAnalyticsList resultList = twitchClient.getHelix().getExtensionAnalyticUrl(accessToken, null, 10, null, null, null, null).execute();
resultList.getExtensionAnalytics().forEach(analytic -> {
	System.out.println("URL: " + analytic.getURL());
});
val resultList = twitchClient.helix.getExtensionAnalyticUrl(accessToken, null, 10, null, null, null, null).execute();
resultList.extensionAnalytics.forEach { analytic ->
	println("URL: ${analytic.uRL}");
}
def resultList = twitchClient.helix.getExtensionAnalyticUrl(accessToken, null, 10, null, null, null, null).execute();
resultList.extensionAnalytics.each { analytic ->
	System.out.println "URL: ${analytic.uRL}"
}