title: Automating usage reporting with the REST API
intro: >-
Learn how to automate reporting on your use of paid features using the REST
API.
shortTitle: Automate usage reporting
redirect_from:
- /billing/using-the-new-billing-platform/automating-usage-reporting
- /billing/managing-your-billing/automating-usage-reporting
versions:
fpt: '*'
ghec: '*'
topics:
- Enterprise
- Billing
- REST
permissions: Enterprise owners, organization owners, and billing managers
product: '{% data reusables.billing.enhanced-billing-platform-product %}'
contentType: tutorials
You can automatically pull data from {% data variables.product.github %} to populate the business systems you use to monitor costs and usage using the REST API. If you haven't used the {% data variables.product.github %} REST API before, see AUTOTITLE.
Overview of endpoints
You need to use different endpoints to gather data depending on your account type and the information level you want.
{% rowheaders %}
| Account | Report | Access | Endpoint | More information |
|---|---|---|---|---|
| Users | Usage data for all paid products | Account holder | /users/{username}/settings/billing/usage |
AUTOTITLE |
| Organizations | Premium request consumption, with details of quota and billed usage | Organization owners and billing managers | /organizations/{org}/settings/billing/premium_request/usage |
AUTOTITLE |
| Organizations | Usage data for all paid products | Organization owners and billing managers | /organizations/{org}/settings/billing/usage |
AUTOTITLE |
| Enterprises | Premium request consumption, with details of quota and billed usage | Enterprise owners and billing managers | /enterprises/{enterprise}/settings/billing/premium_request/usage |
AUTOTITLE |
| Enterprises | Usage data for all paid products | Enterprise owners and billing managers | /enterprises/{enterprise}/settings/billing/usage |
AUTOTITLE |
{% endrowheaders %}
Getting premium request consumption
Authenticate with {% data variables.product.github %} with one of the following methods:
- {% data variables.product.prodname_cli %}: use the
gh auth logincommand to authenticate, see AUTOTITLE. - Create a {% data variables.product.pat_v1 %}: and pass the token to in your API call, see Creating a {% data variables.product.pat_v1 %}.
- {% data variables.product.prodname_cli %}: use the
Call the required
premium_request/usageendpoint, specifying the enterprise, organization, or user that you want data for.
Getting usage data for all paid products
Authenticate with {% data variables.product.github %} with one of the following methods:
- {% data variables.product.prodname_cli %}: use the
gh auth logincommand to authenticate, see AUTOTITLE. - Create a {% data variables.product.pat_v1 %}: and pass the token to in your API call, see Creating a {% data variables.product.pat_v1 %}.
- {% data variables.product.prodname_cli %}: use the
Call the required
usageendpoint, specifying the enterprise, organization, or user that you want data for.By default, data for all products for the current year is reported. For enterprises, only data that is not associated with a cost center is reported.
You can request more specific data using query parameters.
- Specify time period by setting one or more of the following parameters:
year,month,day, andhour. - Specify a cost center to report on by identifier using the
cost_center_idquery parameter (enterprise endpoint only).
- Specify time period by setting one or more of the following parameters:
For more detailed information and an example calls and responses, see:
- Get billing usage report for an enterprise
- Get billing usage report for an organization
- Get billing usage report for a user
Migrating from the endpoints used for the previous billing platform
After you transition to metered billing, the endpoints you used to get data from the previous billing platform will no longer return accurate usage information.
- Upgrade all calls of the form:
/ACCOUNT-TYPE/NAME/settings/billing/PRODUCT - To use the equivalent:
/ACCOUNT-TYPE/NAME/settings/billing/usageendpoint
Changes in authentication
If you used a {% data variables.product.pat_v2 %} to authenticate with the previous endpoints, you will need create a {% data variables.product.pat_v1 %} to authenticate with the new endpoint.
In addition, you may want to use the new query parameters to specify a time period or cost center.
Calculating {% data variables.product.prodname_actions %} information from the new response data
Example of the previous response
{"total_minutes_used": 305, "total_paid_minutes_used": 0, "included_minutes": 3000, "minutes_used_breakdown": { "UBUNTU": 205, "MACOS": 10, "WINDOWS": 90 } }
Example of the new response
{ "usageItems": [ { "date": "2023-08-01", "product": "Actions", "sku": "Actions Linux", "quantity": 100, "unitType": "minutes", "pricePerUnit": 0.008, "grossAmount": 0.8, "discountAmount": 0, "netAmount": 0.8, "organizationName": "GitHub", "repositoryName": "github/example"} ] }
To get the same values from the new response data:
{% rowheaders %}
| Previous property | Calculate from new API response |
|------ |----------- |
| total_minutes_used |
- Filter results by
"product": "Actions"and"unitType": "minutes" - Sum
quantity
total_paid_minutes_used| This is now represented as a $ amount via netAmount.- Filter results by
"product": "Actions"and"unitType": "minutes" - Sum
netAmount
included_minutes | This is now represented as a $ amount via discountAmount.- Filter results by
"product": "Actions"and"unitType": "minutes" - Sum
discountAmount
minutes_used_breakdown | - Filter results by
"product": "Actions"and"unitType": "minutes" - Sum
quantitygrouped bysku
{% endrowheaders %}
Calculating {% data variables.product.prodname_registry %} information from the new response data
Example of the previous response
{ "total_gigabytes_bandwidth_used": 50, "total_paid_gigabytes_bandwidth_used": 40, "included_gigabytes_bandwidth": 10 }
Example of the new response
{ "usageItems": [ { "date": "2023-08-01", "product": "Packages", "sku": "Packages data transfer", "quantity": 100, "unitType": "gigabytes", "pricePerUnit": 0.008, "grossAmount": 0.8, "discountAmount": 0, "netAmount": 0.8, "organizationName": "GitHub", "repositoryName": "github/example" } ] }
{% rowheaders %}
| Previous property | Calculate from new API response |
|------ |----------- |
| total_gigabytes_bandwidth_used |
- Filter results by
"product": "Packages"and"unitType": "gigabytes" - Sum
quantity
total_paid_gigabytes_bandwidth_used| This is now represented as a $ amount via netAmount. - Filter results by
"product": "Packages"and"unitType": "gigabytes" - Sum
netAmount
included_gigabytes_bandwidth | This is now represented as a $ amount via discountAmount.- Filter results by
"product": "Packages"and"unitType": "gigabytes" - Sum
discountAmount
{% endrowheaders %}
Calculating shared storage information from the new response data
Example of the previous response
{ "days_left_in_billing_cycle": 20, "estimated_paid_storage_for_month": 15, "estimated_storage_for_month": 40 }
Example of the new response
{ "usageItems": [ { "date": "2023-08-01", "product": "Packages", "sku": "Packages storage", "quantity": 100, "unitType": "GigabyteHours", "pricePerUnit": 0.008, "grossAmount": 0.8, "discountAmount": 0, "netAmount": 0.8, "organizationName": "GitHub", "repositoryName": "github/example" } ] }
{% rowheaders %}
| Previous property | Calculate from new API response |
|------ |----------- |
| days_left_in_billing_cycle | Not available. This information can be inferred by subtracting the current day of the month from the number of days in the current month. |
| estimated_paid_storage_for_month| This is now represented as a $ amount via netAmount.
Prerequisite: pass the month and year query parameters.
For Actions storage
- Filter results by
"product": "Actions"and"unitType": "GigabyteHours" - Sum
netAmount
- Filter results by
"product": "Packages"and"unitType": "GigabyteHours" - Sum
netAmount
estimated_storage_for_month | Prerequisite: pass the month and year query parameters. For Actions storage
- Filter results by
"product": "Actions"and"unitType": "GigabyteHours" - Sum
quantity
- Filter results by
"product": "Packages"and"unitType": "GigabyteHours" - Sum
quantity
{% endrowheaders %}