Introduction
The Huntress API follows a RESTful pattern. Requests are made via resource-oriented URLs as described in this document and API responses are formatted as JSON data.
To test out the Huntress APIs quickly, use the Swagger Interface. You can also navigate there directly by clicking the "Preview the API (Swagger)" link.
If you'd like to request additional API endpoints or capabilities, submit feedback through our feedback portal.
API Overview
Authentication
$KEY = echo "$HUNTRESS_PUBLIC_KEY:$HUNTRESS_PRIVATE_KEY" | base64
curl "https://api.huntress.io/v1/agents" \
-H "Authorization: Basic $KEY"
To begin, generate your API Key at <your_account_subdomain>.huntress.io
. Once you are logged into your account on the Huntress site, check the dropdown menu at the top-right corner of the site header. You should see API Credentials
among the options if your account has been granted access to the Huntress API. Click on the option to continue to the API Key generation page.
Once on the API Key generation page, click on the green Setup button to begin the process to generate your API Key. You will be redirected to a page where you will be prompted to generate your API Key. Click the Generate button to generate a public and private key pair for Huntress API access. The inputs on the page will be filled in with your access credentials once you have done so.
Your API Private Key will only be visible at this stage of API Key generation. Be sure to save the value provided somewhere secure, as once you navigate away from this page, this value will no longer be accessible and you must regenerate your API credentials if your secret key value is lost.
If necessary, you can repeat the process to regenerate your API credentials with a new API Key and API Secret Key on the same API Key generation page, at <your_account_subdomain>.huntress.io/account/api_credentials
.
The Huntress API implements basic access authentication. Once you have your API Key and API Secret Key, provide these values as the result of a Base64 encoded string in every request to the Huntress API via the Authorization
header. Your request header should look something like Authorization: Basic [Base64Encode(<your_api_key>:<your_api_secret_key>)]
. Please refer to the code snippets for further examples.
Rate Limits
Every Huntress API account is rate limited to 60 requests per minute, on a sliding window. This means that no more than 60 requests can be made within a 60 second time interval between the first request and the last request.
As an example for developers unfamiliar with this structure, if request 1 is made at T0, request 2 is made at T5, and requests 3 through 60 are made at T10, making request 61 at T55 would request in a 429 error response. Making request 61 at T61 would succeed, however making request 62 at T61 would fail, at least until the time has passed T65, corresponding to a minute after request 2 was made.
HTTP Response Codes
Response Code | Details |
---|---|
200 | Request is okay, response is okay. |
400 | There is an unexpected value in the API request being made. |
404 | The requested resource is unavailable to you, either because it doesn't exist or because your account does not hold permissions to access it. |
429 | You have made too many requests within the rate limit timeframe. |
500 | An error has occurred on the Huntress API. Please contact support with details of your error. |
Pagination
"pagination": {
"current_page": 1,
"current_page_count": 10,
"limit": 10,
"total_count": 20,
"next_page": 2,
"next_page_url": "https://api.huntress.io/v1/agents?page=2&limit=10"
}
The Huntress API utilizes a page
and limit
parameter to specify a window location and size, respectively, to the resources currently being accessed. By default, not specifying a page
and limit
argument to an API call defaults these values to page=1
and limit=10
, which corresponds to the first 10 results within the resource set you are attempting to access. Note that the minimum value of limit
is 1 and the maximum value is 500. Providing a value outside of this range will result in a 400 response.
Each API call will also return a pagination object with details about your current pagination state based on the parameters provided when making the API call. The pagination object contains:
Key | Type | Description |
---|---|---|
current_page | integer | The current page that this API request is accessing. |
current_page_count | integer | The number of items returned on this page. |
limit | integer | The number of results returned within this request. |
total_count | integer | The total number of results for the resource being accessed. |
next_page | integer | The next page number to use in another request in order to continue sequentially accessing resources. Only displays when another page can be accessed. |
next_page_url | string | URL containing the next page and the limit provided in the original API request, to be used to continue sequentially accessing resources. |
Request and Response Format
Request
curl "https://api.huntress.io/v1/agents?organization_id=1&page=2" \
-H "Authorization: Basic <Your B64 encoded hash>"
The base URL for API requests is api.huntress.io/v1/
, followed by the resource requested. Resources can be requested either singularly or as a list, which correspond to /v1/<resources>/:id
or /v1/<resources>
respectively, with the exception of the /v1/account
endpoint, which only returns the account associated with the API credentials provided.
As an example, api.huntress.io/v1/agents
would return a list of agents, while api.huntress.io/v1/agents/1
would return a singular agent with ID: 1.
Parameters are provided to the API through a query string. As an example, providing the organization_id filter as a parameter to the /v1/agents
endpoint would look like api.huntress/io/v1/agents?organization_id=1
. Accessing a second page with the same filter active would look like api.huntress.io/v1/agents?organization_id=1&page=2
.
Response
The Huntress API responds with a JSON object containing requested resources if the request is valid and authorized.
Singular Case
{
"report": {...}
}
In the case of accessing a singular resource, the JSON object in question will contain one key that maps the singular resource to the singular representation of the resource name. As an example, if you were to request api.huntress.io/v1/reports/1
, the JSON response would contain a single key report
that maps to the report with ID: 1.
Multiple Case
{
"reports": [...],
"pagination": {...}
}
In the case of accessing a list of resources, the JSON response will contain two keys at its root level. The first is the plural representation fo the resource in question. The second is a pagination
key that represents the current state of pagination based on parameters provided in the original request. As an example, a request to api.huntress.io/v1/reports
returns a JSON object with the keys reports
and pagination
at its root level. Further details on the fields within the pagination object can be seen at the relevant section.
API Resources
Account
Request
curl "https://api.huntress.io/v1/account" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"account": {
"id": 1,
"name": "Your Account Name",
"subdomain": "exampleaccount",
"status": "active"
}
}
The account endpoint shows details of the account associated with your API credentials.
An account is structured as:
Key | Type | Description |
---|---|---|
id | integer | A unique identifier for the account. |
name | string | The public facing display name for the account. |
subdomain | string | The subdomain for the account. |
status | string | The current status on the account. Can be one of <enabled, disabled> . |
No additional parameters are available for this endpoint.
Organizations
Request
curl "https://api.huntress.io/v1/organizations/1" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"organization": {
"id": 1,
"name": "Test",
"created_at": "2022-03-01T18:54:02Z",
"updated_at": "2022-03-01T18:54:02Z",
"account_id": 5,
"key": "test1",
"microsoft_365_tenant_id": "dcd219dd-bc68-4b9b-bf0b-4a33a796be35",
"notify_emails": [],
"incident_reports_count": 42,
"agents_count": 42,
"microsoft_365_users_count": 42,
"sat_learner_count": 42,
"logs_sources_count": 42
}
}
Request
curl "https://api.huntress.io/v1/organizations" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"organizations": [
{
"id": 1,
"name": "Test",
"created_at": "2022-03-01T18:54:02Z",
"updated_at": "2022-03-01T18:54:02Z",
"account_id": 5,
"key": "test1",
"microsoft_365_tenant_id": "dcd219dd-bc68-4b9b-bf0b-4a33a796be35",
"notify_emails": ["test@example.com"],
"incident_reports_count": 42,
"agents_count": 42,
"microsoft_365_users_count": 42
},
{
"id": 2,
"name": "Test 2",
"created_at": "2022-03-01T18:54:16Z",
"updated_at": "2022-03-01T18:54:16Z",
"account_id": 5,
"key": "test2",
"microsoft_365_tenant_id": "dcd219dd-bc68-4b9b-bf0b-4a33a796be35",
"notify_emails": [],
"incident_reports_count": 42,
"agents_count": 42,
"microsoft_365_users_count": 42
"sat_learner_count": 42,
"logs_sources_count": 42
},
...
{
"id": 10,
"name": "Test 10",
"created_at": "2022-03-01T18:54:24Z",
"updated_at": "2022-03-01T18:54:24Z",
"account_id": 5,
"key": "test10",
"microsoft_365_tenant_id": "dcd219dd-bc68-4b9b-bf0b-4a33a796be35",
"notify_emails": [],
"incident_reports_count": 42,
"agents_count": 42,
"microsoft_365_users_count": 42
"sat_learner_count": 42,
"logs_sources_count": 42
}
],
"pagination": {
"current_page": 1,
"current_page_count": 10,
"limit": 10,
"total_count": 32
}
}
The organizations endpoint shows details of organizations belonging to the account associated with your API credentials.
Organizations are accessible via both the /v1/organizations
endpoint to list accessible organizations and the /v1/organizations/:id
endpoint to show a single organization by ID.
An organization is structured as:
Key | Type | Description |
---|---|---|
id | integer | The Huntress internal ID for this organization. |
name | string | The public facing name for this organization. |
created_at | string | A timestamp for when the organization was created, formatted as per ISO8601. |
updated_at | string | A timestamp for when the organization was last updated, formatted as per ISO8601. |
account_id | integer | The unique identifier of the account associated with the orgnaization. |
key | string | The subdomain associated with the organization. |
microsoft_365_tenant_id | string | The Microsoft 365 Tenant ID associated with the organization |
notify_emails | array |
A list of emails the organization is configured to send emails to when notifications are sent. |
incident_reports_count | integer | Number of incident reports for the organization. |
agents_count | integer | Number of agents for the organization. |
microsoft_365_users_count | integer | Number of billable Microsoft 365 users for the organization. |
sat_learner_count | integer | Number of SAT learners |
logs_sources_count | integer | Number of SIEM sources |
The /v1/organizations
endpoint accepts the following optional parameters:
Parameter | Type | Description |
---|---|---|
page | integer | The window location for the current resource. In conjunction with the limit field, shows results beginning with page * limit up to (page + 1) * limit . Must be an integer greater than 0 or a 400 error will occur. |
limit | integer | The number of elements to show per page. Must be an integer between 1 and 500, otherwise a 400 error will occur. |
created_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the created_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
created_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the created_at date. If provided with created_at_min , created_at_max must be greater than created_at_min or a 400 error will occur. |
updated_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the updated_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
updated_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the updated_at date. If provided with updated_at_min , updated_at_max must be greater than updated_at_min or a 400 error will occur. |
Agents
Request
curl "https://api.huntress.io/v1/agents/1" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"agent": {
"id": 1,
"version": "0.11.3",
"arch": "x86_64",
"win_build_number": null,
"domain_name": null,
"created_at": "2022-03-01T20:05:10Z",
"hostname": "laptop01",
"ipv4_address": "146.134.139.9",
"external_ip": null,
"mac_addresses": ["7c:a7:b0:16:2f:78", ...],
"updated_at": "2022-03-01T20:05:10Z",
"last_survey_at": null,
"last_callback_at": "2022-03-01T20:05:10Z",
"account_id": 5,
"organization_id": 7,
"platform": "windows",
"os": "Windows 8 Pro",
"service_pack_major": 0,
"service_pack_minor": 0,
"tags": [],
"os_major": 6,
"os_minor": 2,
"os_patch": 0,
"version_number": 720899,
"edr_version": "0.3.20",
"os_build_version": 19044,
"serial_number": "wtIe1bvDbh",
"defender_status": "Healthy",
"defender_substatus": "Up to date",
"defender_policy_status": "Compliant"
}
}
Request
curl "https://api.huntress.io/v1/agents" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"agents": [
{
"id": 1,
"version": "0.11.3",
"arch": "x86_64",
"win_build_number": null,
"domain_name": null,
"created_at": "2022-03-01T20:05:10Z",
"hostname": "laptop01",
"ipv4_address": "146.134.139.9",
"external_ip": null,
"mac_addresses": ["7c:a7:b0:16:2f:78", ...],
"updated_at": "2022-03-01T20:05:10Z",
"last_survey_at": null,
"last_callback_at": "2022-03-01T20:05:10Z",
"account_id": 5,
"organization_id": 7,
"platform": "windows",
"os": "Windows 8 Pro",
"service_pack_major": 0,
"service_pack_minor": 0,
"tags": [],
"os_major": 6,
"os_minor": 2,
"os_patch": 0,
"version_number": 720899,
"edr_version": "0.3.20",
"os_build_version": 19044,
"serial_number": "wtIe1bvDbh",
"defender_status": "Healthy",
"defender_substatus": "Up to date",
"defender_policy_status": "Compliant"
},
...
{
"id": 10,
"version": "0.11.3",
"arch": "x86_64",
"win_build_number": null,
"domain_name": null,
"created_at": "2022-03-01T20:06:03Z",
"hostname": "laptop01",
"ipv4_address": "71.136.18.183",
"external_ip": null,
"mac_addresses": ["7c:a7:b0:16:2f:78", ...],
"updated_at": "2022-03-01T20:06:03Z",
"last_survey_at": null,
"last_callback_at": "2022-03-01T20:06:03Z",
"account_id": 5,
"organization_id": 16,
"platform": "windows",
"os": "Windows 8 Pro",
"service_pack_major": 0,
"service_pack_minor": 0,
"tags": [],
"os_major": 6,
"os_minor": 2,
"os_patch": 0,
"version_number": 720899,
"edr_version": "0.3.20",
"os_build_version": 19044,
"serial_number": "wtIe1bvDbh",
"defender_status": "Healthy",
"defender_substatus": "Up to date",
"defender_policy_status": "Compliant"
}
],
"pagination": {
"current_page": 1,
"current_page_count": 10,
"limit": 10,
"total_count": 10
}
}
The agents endpoint shows agents associated with your account.
An agent is structured as:
Key | Type | Description |
---|---|---|
id | integer | A unique identifier for an agent. |
version | string | The semantic versioning number of the agent installed on the host machine. |
arch | string | The architecture on the host machine. |
win_build_number | integer | The Windows Build Number. Should correspond to information on the Microsoft site. |
domain_name | string | Domain that refers to the host machine. |
created_at | string | A timestamp for when the agent was created, formatted as per ISO8601. |
hostname | string | The hostname of the host machine. |
ipv4_address | string | The internal IP of the host machine. |
external_ip | string | The external IP of the host machine, if applicable. |
mac_addresses | array | The unique media access control (MAC) addresses associated with the agent. |
updated_at | string | A timestamp for when the agent was last updated, formatted as per ISO8601. |
last_survey_at | string | A timestamp for when the last Microsoft Defender survey was received by Huntress for this host machine. |
last_callback_at | string | A timestamp for when the last time Huntress was able to access the host machine. |
account_id | integer | The unique identifier of the account associated with the agent. |
organization_id | integer | The unique identifier of the organization associated with the agent. |
platform | string | The platform of the host machine (darwin or windows ). |
os | string | The operating system of the host machine. |
service_pack_major | integer | The major version of the Windows service pack installed on the host machine. |
service_pack_minor | integer | The minor version of the Windows service pack installed on the host machine. |
tags | array |
User classifications on the host machine. |
os_major | integer | The major OS version of the host machine. Corresponds with the major releases of Windows operating systems. A list is accessible here. |
os_minor | integer | The minor OS version of the host machine. Refer to the os_major field details for further details. |
os_patch | integer | The patch version of the macOS update installed on the host machine, such as 1 in version 12.5.1. |
version_number | integer | Windows version number. |
edr_version | string | The semantic versioning number of the Huntress EDR software installed on the machine or null if EDR is not installed. |
os_build_version | string | The operating system build number of the host machine corresponding to its platform (windows or darwin). |
serial_number | string | The serial number of the host machine as reported to the operating system. |
defender_status | string | Status of Defender AV Managed Antivirus. |
defender_substatus | string | Sub-status of Defender AV Managed Antivirus. |
defender_policy_status | string | Policy status of Defender AV for Managed Antivirus. |
The /v1/agents
endpoint accepts the following optional parameters:
Parameter | Type | Description |
---|---|---|
page | integer | The window location for the current resource. In conjunction with the limit field, shows results beginning with page * limit up to (page + 1) * limit . Must be an integer greater than 0 or a 400 error will occur. |
limit | integer | The number of elements to show per page. Must be an integer between 1 and 500, otherwise a 400 error will occur. |
created_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the created_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
created_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the created_at date. If provided with created_at_min , created_at_max must be greater than created_at_min or a 400 error will occur. |
updated_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the updated_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
updated_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the updated_at date. If provided with updated_at_min , updated_at_max must be greater than updated_at_min or a 400 error will occur. |
organization_id | integer | The unique identifier of an organization under the account associated with your API credentials. Will only select agents under this organization. |
platform | string | The platform of the host machine (darwin or windows ). |
Incident Reports
Request
curl "https://api.huntress.io/v1/incident_reports/1" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"incident_report": {
"id": 1,
"status": "closed",
"summary": null,
"body": "<Content>",
"updated_at": "2022-03-01T20:31:30Z",
"agent_id": 12,
"status_updated_at": null,
"organization_id": 4,
"sent_at": null,
"account_id": 5,
"subject": "LOW - Incident on laptop01 (Test)",
"created_by_id": null,
"remediation_instructions": null,
"footholds": "<Content>",
"severity": "low",
"assigned_to_id": null,
"closed_at": null,
"indicator_types": [
"footholds"
],
"indicator_counts": {
"footholds": 1,
"monitored_files": 0,
"process_detections": 0,
"ransomware_canaries": 0,
"antivirus_detections": 0
},
"details": {}
}
}
Request
curl "https://api.huntress.io/v1/incident_reports" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"incident_reports": [
{
"id": 1,
"status": "closed",
"summary": null,
"body": "<Content>",
"updated_at": "2022-03-01T20:31:30Z",
"agent_id": 12,
"platform": "windows",
"status_updated_at": null,
"organization_id": 4,
"sent_at": null,
"account_id": 5,
"subject": "LOW - Incident on laptop01 (Test)",
"created_by_id": null,
"remediation_instructions": null,
"footholds": "<Content>",
"notes": "<Content>",
"severity": "low",
"assigned_to_id": null,
"closed_at": null,
"indicator_types": [
"footholds"
],
"indicator_counts": {
"footholds": 1,
"monitored_files": 0,
"process_detections": 0,
"ransomware_canaries": 0,
"antivirus_detections": 0
},
"details": {}
},
{
"id": 2,
"status": "closed",
"summary": null,
"body": "<Content>",
"updated_at": "2022-03-01T20:31:59Z",
"agent_id": 13,
"status_updated_at": null,
"organization_id": 4,
"sent_at": null,
"account_id": 5,
"subject": "LOW - Incident on laptop01 (Test)",
"created_by_id": null,
"remediation_instructions": null,
"footholds": "<Content>",
"severity": "low",
"assigned_to_id": null,
"closed_at": null,
"indicator_types": [
"footholds"
],
"indicator_counts": {
"footholds": 1,
"monitored_files": 0,
"process_detections": 0,
"ransomware_canaries": 0,
"antivirus_detections": 0
},
"details": {}
}
],
"pagination": {
"current_page": 1,
"current_page_count": 2,
"limit": 10,
"total_count": 2
}
}
An incident report is structured as:
Key | Type | Description |
---|---|---|
id | integer | Unique identifier for the incident report. |
status | string | Status of the incident report. Can be one of <sent, closed, dismissed> |
summary | string | Details of the incident report, as provided by a Huntress SOC analyst. |
body | string | Autogenerated content describing the details of the incident in question. |
updated_at | string | ISO8601 formatted timestamp for when this incident report was last updated. |
agent_id | integer | Unique identifier for the agent this incident report is associated with. |
platform | string | The platform of the host machine (darwin or windows or microsoft_365 ). |
status_updated_at | string | ISO8601 formatted timestamp for when the status of this incident report was last updated. |
organization_id | integer | Unique identifier for the organization this incident report is associated with. |
sent_at | string | ISO8601 formatted timestamp for when a Huntress SOC analyst has notified necessary parties regarding this incident report. Null if not sent. |
account_id | integer | Unique identifier for the account this incident report is associated with. |
subject | string | Autogenerated one-line description of the incident. |
created_by_id | integer | Unique identifier for the user that created the incident report. |
remediation_instructions | string | Details provided by Huntress SOC analysts for how to resolve the issues noted in the incident report. |
footholds | string | Details on footholds found within the scope of this incident report. |
severity | string | The severity of the incident report. Can be one of <low, high, critical> . |
assigned_to_id | integer | Unique identifier for the user that is assigned to this incident report. |
closed_at | string | ISO8601 formatted timestamp for when this incident report had its status set to closed . Null if non-applicable. |
indicator_types | array |
Unique list of threat indicators that have been found in the context of this incident report. |
indicator_counts | object | Mapping of indicator types to number of incidences of that threat in the context of this incident report. |
details | object | Additional details attached to this report. |
The /v1/incident_reports
endpoint takes the following optional parameters:
Key | Type | Description |
---|---|---|
page | integer | The window location for the current resource. In conjunction with the limit field, shows results beginning with page * limit up to (page + 1) * limit . Must be an integer greater than 0 or a 400 error will occur. |
limit | integer | The number of elements to show per page. Must be an integer between 1 and 500, otherwise a 400 error will occur. |
updated_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the updated_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
updated_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the updated_at date. If provided with updated_at_min , updated_at_max must be greater than updated_at_min or a 400 error will occur. |
status | string | The status of the incident report. Must be one of <sent, closed, dismissed> . Will return only incident reports matching the status provided. |
severity | string | The severity of the incident report. Must be one of <low, high, critical> . Will return only incident reports matching the severity provided. |
organization_id | integer | The unique identifier of an organization under the account associated with your API credentials. Will only select incident reports under this organization. |
agent_id | integer | The unique identifier of an agent under the account associated with your API credentials. Will only select incident reports under this organization. |
platform | string | The platform of the host machine (darwin or windows or microsoft_365 ). |
indicator_type | string | An indicator type to filter reports by. Must be one of <footholds, monitored_files, ransomware_canaries, antivirus_detections, process_detections, managed_identity> . Will return only incident reports whose indicator types include the specified value. |
Summary Reports
Request
curl "https://api.huntress.io/v1/reports/1" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"report": {
"id": 1,
"type": "monthly_summary",
"period": "2022-02-01...2022-03-02",
"organization_id": null,
"created_at": "2022-03-01T20:56:15Z",
"updated_at": "2022-03-01T20:56:15Z",
"url": "https://huntress.io/rails/active_storage/blobs/redirect/uuid.pdf?disposition=download"
}
}
Request
curl "https://api.huntress.io/v1/reports" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"reports": [
{
"id": 1,
"type": "monthly_summary",
"period": "2022-02-01...2022-03-02",
"organization_id": null,
"created_at": "2022-03-01T20:56:15Z",
"updated_at": "2022-03-01T20:56:15Z",
"url": "https://huntress.io/rails/active_storage/blobs/redirect/uuid.pdf?disposition=download"
},
{
"id": 2,
"type": "monthly_summary",
"period": "2022-02-01...2022-03-02",
"organization_id": null,
"created_at": "2022-03-01T20:56:20Z",
"updated_at": "2022-03-01T20:56:20Z",
"url": "https://huntress.io/rails/active_storage/blobs/redirect/uuid.pdf?disposition=download"
}
],
"pagination": {
"current_page": 1,
"current_page_count": 2,
"limit": 10,
"total_count": 2
}
}
A summary report is structured as:
Key | Type | Description |
---|---|---|
id | integer | A unique identifier for the summary report. |
type | string | The report type. Can be one of <monthly_summary, quarterly_summary, yearly_summary> . |
period | string | A date range representing the coverage of the report, formatted as start_date...end_date . |
organization_id | integer | Unique identifier for the organization this summary report is associated with. |
created_at | string | ISO8601 formatted timestamp for when this summary report was created. |
updated_at | string | ISO8601 formatted timestamp for when this summary report was last updated. |
url | string | The direct url to the pdf version of this summary report. |
The /v1/reports
endpoint takes the following optional parameters:
Key | Type | Description |
---|---|---|
page | integer | The window location for the current resource. In conjunction with the limit field, shows results beginning with page * limit up to (page + 1) * limit . Must be an integer greater than 0 or a 400 error will occur. |
limit | integer | The number of elements to show per page. Must be an integer between 1 and 500, otherwise a 400 error will occur. |
created_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the created_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
created_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the created_at date. If provided with created_at_min , created_at_max must be greater than created_at_min or a 400 error will occur. |
updated_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the updated_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
updated_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the updated_at date. If provided with updated_at_min , updated_at_max must be greater than updated_at_min or a 400 error will occur. |
period_min | string | An ISO860 formatted date string representing the lower bound of a filter window on the period field. Returns summary reports where the upper bound of the period is greater than period_min . If provided in conjunction with period_max , if period_max is less than period_min , a 400 error is returned. |
period_max | string | An ISO860 formatted date string representing the upper bound of a filter window on the period field. Returns summary reports where the lower bound of the period is less than period_max . |
organization_id | integer | The unique identifier of an organization under the account associated with your API credentials. Will only select summary reports associated with this organization. |
type | string | The type of the summary report. Accepts <monthly_summary, quarterly_summary, yearly_summary> . |
Billing Reports
Request
curl "https://api.huntress.io/v1/billing_reports/1" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"billing_report": {
"id": 1,
"plan": "Huntress Partner 100 Agents",
"quantity": 101,
"amount": 303,
"currency_type": "USD",
"receipt": "https://pay.stripe/com/invoice/invst_uuid",
"status": "paid",
"created_at": "2022-03-01T20:56:15Z",
"updated_at": "2022-03-01T20:56:15Z"
}
}
Request
curl "https://api.huntress.io/v1/billing_reports" \
-H "Authorization: Basic <Your B64 encoded hash>"
Response
{
"billing_reports": [
{
"id": 1,
"plan": "Huntress Partner 100 Agents",
"quantity": 101,
"amount": 303,
"currency_type": "USD",
"receipt": "https://pay.stripe/com/invoice/invst_uuid",
"status": "paid",
"created_at": "2022-03-01T20:56:15Z",
"updated_at": "2022-03-01T20:56:15Z"
},
{
"id": 2,
"plan": "Huntress Partner 200 Agents",
"quantity": 202,
"amount": 606,
"currency_type": "USD",
"receipt": "https://pay.stripe/com/invoice/invst_uuid",
"status": "paid",
"created_at": "2022-03-01T20:56:15Z",
"updated_at": "2022-03-01T20:56:15Z"
}
],
"pagination": {
"current_page": 1,
"current_page_count": 2,
"limit": 10,
"total_count": 2
}
}
A billing report is structured as:
Key | Type | Description |
---|---|---|
id | integer | A unique identifier for the billing report. |
plan | string | The corresponding name of huntress subscription plan sku. |
quantity | integer | The total count of licensed agents accounted for in this billing report. |
amount | integer | The Amount intended to be collected by this billing report. Mimics Stripe. |
currency_type | string | The currency type. Can be one of <USD, CAD, AUD> . |
receipt | string | A direct link to stripe payment invoice for this billing report. |
status | string | The billing report status. Can be one of <open, paid, failed, partial_refund, full_refund> . |
created_at | string | ISO8601 formatted timestamp for when this billing report was created. |
updated_at | string | ISO8601 formatted timestamp for when this billing report was last updated. |
The /v1/billing_reports
endpoint takes the following optional parameters:
Key | Type | Description |
---|---|---|
page | integer | The window location for the current resource. In conjunction with the limit field, shows results beginning with page * limit up to (page + 1) * limit . Must be an integer greater than 0 or a 400 error will occur. |
limit | integer | The number of elements to show per page. Must be an integer between 1 and 500, otherwise a 400 error will occur. |
created_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the created_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
created_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the created_at date. If provided with created_at_min , created_at_max must be greater than created_at_min or a 400 error will occur. |
updated_at_min | string | An ISO8601 formatted date string representing the lower bound of the search range for the updated_at date. Must provide a date greater than January 1st, 2010 or a 400 error will occur. |
updated_at_max | string | An ISO8601 formatted date string representing the upper bound of the search range for the updated_at date. If provided with updated_at_min , updated_at_max must be greater than updated_at_min or a 400 error will occur. |
status | string | The status of the billing report. Accepts <open, paid, failed, partial_refund, full_refund> . |