Documentation
Huntress n8n Node
© Huntress - All rights reserved
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.
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" | base64curl "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.
For example, 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 result 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
Huntress follows HTTP standards when delivering responses: a 2xx response is a success, a 4xx response indicates an issue with the client request, and a 5xx response indicates an issue with Huntress servers.
Specific error codes are detailed in the following table:
| Error Status Code | Details |
|---|---|
| 400 | There is an unexpected value in the API request being made. |
| 401 | Your request could not be authenticated. Check that your API key is properly formatted and included in the Authorization header. |
| 404 | The requested resource is unavailable: either it doesn't exist, or your account does not hold correct permissions to access it. |
| 429 | You have made too many requests within the rate limit timeframe. See the previous section on rate_limits for details. |
| 500 | An error has occurred within Huntress servers. You could retry the request, but if you encounter continued errors, please contact Support with details of your error. If all traffic from Huntress is resulting in 500 responses, please check our Huntress Status Page. |
Pagination
Certain Huntress API endpoints utilize a page_token and limit parameter to specify a window location and size, respectively, to the resources currently being requested.
Each API request will also return a pagination object with details about your current pagination state based on the parameters provided. The pagination object contains:
| Key | Type | Description |
|---|---|---|
| next_page_token | string | The token used to request the next page in paginated results. If no page token is included, the first page contains all results. |
| 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. Only displays when another page can be accessed. |
Following is a formatted example of the pagination object in an API response:
"pagination": { "next_page_url": "https://api.huntress.io/v1/agents?page_token=MjAyMi0wMy0wMVQxODo1NDoyNFo&limit=10", "next_page_token": "MjAyMi0wMy0wMVQxODo1NDoyNFo"}Request and Response Format
Request
curl "https://api.huntress.io/v1/agents?organization_id=1&page_token=MjAyMi0wMy0wMVQxODo1NDoyNFo" -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 and /v1/actor endpoints, 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 sequential page with the same filter active would look like api.huntress.io/v1/agents?organization_id=1&page_token=MjAyMi0wMy0wMVQxODo1NDoyNFo.
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": { ... }}
When accessing a list of resources, the JSON response contains two keys at the root level. The first key is the plural representation of that resource. 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.
Table of Contents
Installation
Follow the n8n community node installation guide.
Or install directly via npm:
npm install @avantguardllc/n8n-nodes-huntress
Authentication
This node authenticates using Basic Auth (API Key + API Secret).
| Setting | Value |
|---|---|
| Type | Basic Auth |
| Field 1 | API Key |
| Field 2 | API Secret |
| Base URL | https://api.huntress.io (editable in credentials) |
Tip: The Base URL can be changed in the credential settings if your instance uses a different host.
Resources & Operations
Base URL: https://api.huntress.io
Accounts
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/account |
Get Account |
Reseller
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/accounts |
List Accounts |
🟢 POST |
/v1/accounts |
Create Account |
🔵 GET |
/v1/accounts/{account_id} |
Get Specific Account |
🟣 PATCH |
/v1/accounts/{account_id} |
Update Account |
🔴 DELETE |
/v1/accounts/{account_id} |
Permanently Disable an Account |
🔵 GET |
/v1/accounts/{account_id}/agents |
List Agents |
🔵 GET |
/v1/accounts/{account_id}/agents/{id} |
Get Agent |
🔵 GET |
/v1/accounts/{account_id}/billing_reports |
List Account Billing Reports |
🔵 GET |
/v1/accounts/{account_id}/billing_reports/{id} |
Get Account Billing Report |
🔵 GET |
/v1/accounts/{account_id}/incident_reports |
List Incident Reports |
🔵 GET |
/v1/accounts/{account_id}/incident_reports/{id} |
Get Incident Report |
🟢 POST |
/v1/accounts/{account_id}/incident_reports/{id}/resolution |
Create an Incident Report Resolution |
🔵 GET |
/v1/accounts/{account_id}/memberships |
List Memberships |
🟢 POST |
/v1/accounts/{account_id}/memberships |
Create a Membership |
🔵 GET |
/v1/accounts/{account_id}/memberships/{id} |
Get Membership |
🟣 PATCH |
/v1/accounts/{account_id}/memberships/{id} |
Update a User's membership |
🔴 DELETE |
/v1/accounts/{account_id}/memberships/{id} |
Delete Membership |
🔵 GET |
/v1/accounts/{account_id}/organizations |
List Organizations |
🟢 POST |
/v1/accounts/{account_id}/organizations |
Create an Organization |
🔵 GET |
/v1/accounts/{account_id}/organizations/{id} |
Get Organization |
🟣 PATCH |
/v1/accounts/{account_id}/organizations/{id} |
Update an Organization |
🔴 DELETE |
/v1/accounts/{account_id}/organizations/{id} |
Delete an Organization |
🔵 GET |
/v1/accounts/{account_id}/incident_reports/{incident_report_id}/remediations |
List Remediations |
🔵 GET |
/v1/accounts/{account_id}/incident_reports/{incident_report_id}/remediations/{remediation_id} |
Get Remediation |
🟢 POST |
/v1/accounts/{account_id}/incident_reports/{incident_report_id}/remediations/bulk_approval |
Bulk Approve Remediations |
🟢 POST |
/v1/accounts/{account_id}/incident_reports/{incident_report_id}/remediations/bulk_rejection |
Bulk Reject Remediations |
🔵 GET |
/v1/accounts/{account_id}/reports |
List Summary Reports |
🔵 GET |
/v1/accounts/{account_id}/reports/{id} |
Get Summary Report |
🔵 GET |
/v1/accounts/{account_id}/signals |
List Signals |
🔵 GET |
/v1/accounts/{account_id}/signals/{id} |
Get Signal |
Actor
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/actor |
Get Actor |
Agents
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/agents |
List Agents |
🔵 GET |
/v1/agents/{id} |
Get Agent |
BillingReports
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/billing_reports |
List Account Billing Reports |
🔵 GET |
/v1/billing_reports/{id} |
Get Account Billing Report |
Escalations
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/escalations |
List Escalations |
🔵 GET |
/v1/escalations/{id} |
Get Escalation |
🟢 POST |
/v1/escalations/{id}/resolution |
Create an Escalation Resolution |
IncidentReports
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/incident_reports |
List Incident Reports |
🔵 GET |
/v1/incident_reports/{id} |
Get Incident Report |
🟢 POST |
/v1/incident_reports/{id}/resolution |
Create an Incident Report Resolution |
🔵 GET |
/v1/incident_reports/{incident_report_id}/remediations |
List Remediations |
🔵 GET |
/v1/incident_reports/{incident_report_id}/remediations/{remediation_id} |
Get Remediation |
🟢 POST |
/v1/incident_reports/{incident_report_id}/remediations/bulk_approval |
Bulk Approve Remediations |
🟢 POST |
/v1/incident_reports/{incident_report_id}/remediations/bulk_rejection |
Bulk Reject Remediations |
Users
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/memberships |
List Memberships |
🟢 POST |
/v1/memberships |
Create a Membership |
🔵 GET |
/v1/memberships/{id} |
Get Membership |
🟣 PATCH |
/v1/memberships/{id} |
Update a User's membership |
🔴 DELETE |
/v1/memberships/{id} |
Delete Membership |
Organizations
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/organizations |
List Organizations |
🟢 POST |
/v1/organizations |
Create an Organization |
🔵 GET |
/v1/organizations/{id} |
Get Organization |
🟣 PATCH |
/v1/organizations/{id} |
Update an Organization |
🔴 DELETE |
/v1/organizations/{id} |
Delete an Organization |
SummaryReports
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/reports |
List Summary Reports |
🔵 GET |
/v1/reports/{id} |
Get Summary Report |
Signals
| Endpoint | Description | |
|---|---|---|
🔵 GET |
/v1/signals |
List Signals |
🔵 GET |
/v1/signals/{id} |
Get Signal |
Compatibility
- n8n version: 1.0+ (tested on 2.x)
- Node.js version: 18+