This PR will remain in draft as a preview of upcoming documentation changes for 4.82.0 --------- Co-authored-by: Jordan Montgomery <elijah.jordan.montgomery@gmail.com> Co-authored-by: Marko Lisica <83164494+marko-lisica@users.noreply.github.com> Co-authored-by: Magnus Jensen <magnus@fleetdm.com> Co-authored-by: Victor Lyuboslavsky <2685025+getvictor@users.noreply.github.com> Co-authored-by: Noah Talerman <47070608+noahtalerman@users.noreply.github.com> Co-authored-by: Dante Catalfamo <43040593+dantecatalfamo@users.noreply.github.com> Co-authored-by: melpike <79950145+melpike@users.noreply.github.com> Co-authored-by: Mike Thomas <78363703+mike-j-thomas@users.noreply.github.com> Co-authored-by: Nico <32375741+nulmete@users.noreply.github.com> Co-authored-by: Scott Gress <scottmgress@gmail.com>
181 KiB
API for contributors
🚧 Don't use these API endpoints. Please use the public Fleet REST API documentation instead.
The API endpoints in this document are only used when contributing to Fleet. They're for the Fleet UI, Fleet Desktop, and fleetctl clients and frequently change to reflect current functionality. Other usage of these endpoints will have unintended consequences.
If you see an endpoint documented here that you'd like to use, please file a feature request to bring it into the stable API.
- Authentication
- Packs
- Mobile device management (MDM)
- Get or apply configuration files
- Live query
- Trigger cron schedule
- Device-authenticated routes
- Orbit-authenticated routes
- Setup
- Scripts
- Software
- Certificates
- Users
- Conditional access
- Host identity
Authentication
Create session
POST /api/v1/fleet/sessions
Parameters
| Name | Type | In | Description | | token | string | body | Required. The token retrieved from the magic link email. |
Response
See the Log in endpoint for the current successful response format.
Packs
Scheduling queries in Fleet is the best practice for collecting data from hosts. To learn how to schedule queries, check out the docs here.
The API routes to control packs are supported for backwards compatibility.
- Create pack
- Modify pack
- Get pack
- List packs
- Delete pack
- Delete pack by ID
- Get scheduled queries in a pack
- Add scheduled query to a pack
- Get scheduled query
- Modify scheduled query
- Delete scheduled query
Create pack
POST /api/v1/fleet/packs
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | body | Required. The pack's name. |
| description | string | body | The pack's description. |
| host_ids | list | body | A list containing the targeted host IDs. |
| label_ids | list | body | A list containing the targeted label's IDs. |
| team_ids | list | body | Available in Fleet Premium A list containing the targeted teams' IDs. |
Example
POST /api/v1/fleet/packs
Request query parameters
{
"description": "Collects osquery data.",
"host_ids": [],
"label_ids": [6],
"name": "query_pack_1"
}
Default response
Status: 200
{
"pack": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 17,
"name": "query_pack_1",
"description": "Collects osquery data.",
"query_count": 0,
"total_hosts_count": 223,
"host_ids": [],
"label_ids": [
6
],
"team_ids": []
}
}
Modify pack
PATCH /api/v1/fleet/packs/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The pack's id. |
| name | string | body | The pack's name. |
| description | string | body | The pack's description. |
| host_ids | list | body | A list containing the targeted host IDs. |
| label_ids | list | body | A list containing the targeted label's IDs. |
| team_ids | list | body | Available in Fleet Premium A list containing the targeted teams' IDs. |
Example
PATCH /api/v1/fleet/packs/{id}
Request query parameters
{
"description": "MacOS hosts are targeted",
"host_ids": [],
"label_ids": [7]
}
Default response
Status: 200
{
"pack": {
"created_at": "2021-01-25T22:32:45Z",
"updated_at": "2021-01-25T22:32:45Z",
"id": 17,
"name": "Title2",
"description": "MacOS hosts are targeted",
"query_count": 0,
"total_hosts_count": 110,
"host_ids": [],
"label_ids": [
7
],
"team_ids": []
}
}
Get pack
GET /api/v1/fleet/packs/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The pack's id. |
Example
GET /api/v1/fleet/packs/17
Default response
Status: 200
{
"pack": {
"created_at": "2021-01-25T22:32:45Z",
"updated_at": "2021-01-25T22:32:45Z",
"id": 17,
"name": "Title2",
"description": "MacOS hosts are targeted",
"disabled": false,
"type": null,
"query_count": 0,
"total_hosts_count": 110,
"host_ids": [],
"label_ids": [
7
],
"team_ids": []
}
}
List packs
GET /api/v1/fleet/packs
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| order_key | string | query | What to order results by. Can be any column in the packs table. |
| order_direction | string | query | Requires order_key. The direction of the order given the order key. Options include asc and desc. Default is asc. |
Example
GET /api/v1/fleet/packs
Default response
Status: 200
{
"packs": [
{
"created_at": "2021-01-05T21:13:04Z",
"updated_at": "2021-01-07T19:12:54Z",
"id": 1,
"name": "pack_number_one",
"description": "This pack has a description",
"disabled": true,
"query_count": 1,
"total_hosts_count": 53,
"host_ids": [],
"label_ids": [
8
],
"team_ids": []
},
{
"created_at": "2021-01-19T17:08:31Z",
"updated_at": "2021-01-19T17:08:31Z",
"id": 2,
"name": "query_pack_2",
"query_count": 5,
"total_hosts_count": 223,
"host_ids": [],
"label_ids": [
6
],
"team_ids": []
}
]
}
Delete pack
Delete pack by name.
DELETE /api/v1/fleet/packs/{name}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | path | Required. The pack's name. |
Example
DELETE /api/v1/fleet/packs/pack_number_one
Default response
Status: 200
Delete pack by ID
DELETE /api/v1/fleet/packs/id/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The pack's ID. |
Example
DELETE /api/v1/fleet/packs/id/1
Default response
Status: 200
Get scheduled queries in a pack
GET /api/v1/fleet/packs/{id}/scheduled
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The pack's ID. |
Example
GET /api/v1/fleet/packs/1/scheduled
Default response
Status: 200
{
"scheduled": [
{
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 49,
"pack_id": 15,
"name": "new_query",
"query_id": 289,
"query_name": "new_query",
"query": "SELECT * FROM osquery_info",
"interval": 456,
"snapshot": false,
"removed": true,
"platform": "windows",
"version": "4.6.0",
"shard": null,
"denylist": null
},
{
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 50,
"pack_id": 15,
"name": "new_title_for_my_query",
"query_id": 288,
"query_name": "new_title_for_my_query",
"query": "SELECT * FROM osquery_info",
"interval": 677,
"snapshot": true,
"removed": false,
"platform": "windows",
"version": "4.6.0",
"shard": null,
"denylist": null
},
{
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 51,
"pack_id": 15,
"name": "osquery_info",
"query_id": 22,
"query_name": "osquery_info",
"query": "SELECT i.*, p.resident_size, p.user_time, p.system_time, time.minutes AS counter FROM osquery_info i, processes p, time WHERE p.pid = i.pid;",
"interval": 6667,
"snapshot": true,
"removed": false,
"platform": "windows",
"version": "4.6.0",
"shard": null,
"denylist": null
}
]
}
Add scheduled query to a pack
POST /api/v1/fleet/schedule
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| pack_id | integer | body | Required. The pack's ID. |
| query_id | integer | body | Required. The query's ID. |
| interval | integer | body | Required. The amount of time, in seconds, the query waits before running. |
| snapshot | boolean | body | Required. Whether the queries logs show everything in its current state. |
| removed | boolean | body | Required. Whether "removed" actions should be logged. |
| platform | string | body | The computer platform where this query will run (other platforms ignored). Empty value runs on all platforms. |
| shard | integer | body | Restrict this query to a percentage (1-100) of target hosts. |
| version | string | body | The minimum required osqueryd version installed on a host. |
Example
POST /api/v1/fleet/schedule
Request body
{
"interval": 120,
"pack_id": 15,
"query_id": 23,
"removed": true,
"shard": null,
"snapshot": false,
"version": "4.5.0",
"platform": "windows"
}
Default response
Status: 200
{
"scheduled": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 56,
"pack_id": 17,
"name": "osquery_events",
"query_id": 23,
"query_name": "osquery_events",
"query": "SELECT name, publisher, type, subscriptions, events, active FROM osquery_events;",
"interval": 120,
"snapshot": false,
"removed": true,
"platform": "windows",
"version": "4.5.0",
"shard": 10
}
}
Get scheduled query
GET /api/v1/fleet/schedule/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The scheduled query's ID. |
Example
GET /api/v1/fleet/schedule/56
Default response
Status: 200
{
"scheduled": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"id": 56,
"pack_id": 17,
"name": "osquery_events",
"query_id": 23,
"query_name": "osquery_events",
"query": "SELECT name, publisher, type, subscriptions, events, active FROM osquery_events;",
"interval": 120,
"snapshot": false,
"removed": true,
"platform": "windows",
"version": "4.5.0",
"shard": 10,
"denylist": null
}
}
Modify scheduled query
PATCH /api/v1/fleet/schedule/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The scheduled query's ID. |
| interval | integer | body | The amount of time, in seconds, the query waits before running. |
| snapshot | boolean | body | Whether the queries logs show everything in its current state. |
| removed | boolean | body | Whether "removed" actions should be logged. |
| platform | string | body | The computer platform where this query will run (other platforms ignored). Empty value runs on all platforms. |
| shard | integer | body | Restrict this query to a percentage (1-100) of target hosts. |
| version | string | body | The minimum required osqueryd version installed on a host. |
Example
PATCH /api/v1/fleet/schedule/56
Request body
{
"platform": ""
}
Default response
Status: 200
{
"scheduled": {
"created_at": "2021-01-28T19:40:04Z",
"updated_at": "2021-01-28T19:40:04Z",
"id": 56,
"pack_id": 17,
"name": "osquery_events",
"query_id": 23,
"query_name": "osquery_events",
"query": "SELECT name, publisher, type, subscriptions, events, active FROM osquery_events;",
"interval": 120,
"snapshot": false,
"removed": true,
"platform": "",
"version": "4.5.0",
"shard": 10
}
}
Delete scheduled query
DELETE /api/v1/fleet/schedule/{id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required. The scheduled query's ID. |
Example
DELETE /api/v1/fleet/schedule/56
Default response
Status: 200
Mobile device management (MDM)
Only Fleet MDM specific endpoints are located within the root /mdm/ path.
The MDM endpoints exist to support the related command-line interface sub-commands of fleetctl, such as fleetctl generate mdm-apple and fleetctl get mdm-apple, as well as the Fleet UI.
- Generate Apple Business Manager public key (ADE)
- Request Certificate Signing Request (CSR)
- Upload APNS certificate
- Add ABM token
- Count ABM tokens
- Turn off Apple MDM
- Update ABM token's teams
- Renew ABM token
- Delete ABM token
- Add VPP token
- Update VPP token's teams
- Renew VPP token
- Delete VPP token
- Batch-apply MDM custom settings
- Batch-apply packages
- Batch-apply App Store apps
- Get token to download package
- Download package using a token
- Initiate SSO during DEP enrollment
- Complete SSO during DEP enrollment
- Over the air enrollment
- Preassign profiles to devices
- Match preassigned profiles
- Get FileVault statistics
- Upload VPP content token
- Disable VPP
- SCEP proxy
- Get Android Enterprise signup URL
- Connect Android Enterprise
- Delete Android Enterprise
- Get Android enrollment token
- Create Android enrollment token
- Get Android Enterprise server-sent event
- Android Enterprise PubSub push endpoint
Generate Apple Business Manager public key (ADE)
GET /api/v1/fleet/mdm/apple/abm_public_key
Example
GET /api/v1/fleet/mdm/apple/abm_public_key
Default response
Status: 200
{
"public_key": "23K9LCBGG26gc2AjcmV9Kz="
}
Request Certificate Signing Request (CSR)
GET /api/v1/fleet/mdm/apple/request_csr
Example
GET /api/v1/fleet/mdm/apple/request_csr
Default response
Status: 200
{
"csr": "lKT5LCBJJ20gc2VjcmV0Cg="
}
Upload APNS certificate
POST /api/v1/fleet/mdm/apple/apns_certificate
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| certificate | file | form | Required The file containing the APNS certificate (.pem) |
Example
POST /api/v1/fleet/mdm/apple/apns_certificate
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="certificate"; filename="apns_cert.pem"
Content-Type: application/octet-stream
<CERTIFICATE_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
Add ABM token
POST /api/v1/fleet/abm_tokens
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | file | form | Required The file containing the token (.p7m) from Apple Business Manager |
Example
POST /api/v1/fleet/abm_tokens
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="token"; filename="server_token_abm.p7m"
Content-Type: application/octet-stream
<TOKEN_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
"abm_token": {
"id": 1,
"apple_id": "apple@example.com",
"org_name": "Fleet Device Management Inc.",
"mdm_server_url": "https://example.com/mdm/apple/mdm",
"renew_date": "2024-10-20T00:00:00Z",
"terms_expired": false,
"macos_team": null,
"ios_team": null,
"ipados_team": null
}
Count ABM tokens
GET /api/v1/fleet/abm_tokens/count
Get the number of ABM tokens on the Fleet server.
Parameters
None.
Example
GET /api/v1/fleet/abm_tokens/count
Default response
Status: 200
{
"count": 1
}
Turn off Apple MDM
DELETE /api/v1/fleet/mdm/apple/apns_certificate
Example
DELETE /api/v1/fleet/mdm/apple/apns_certificate
Default response
Status: 204
Update ABM token's teams
PATCH /api/v1/fleet/abm_tokens/:id/teams
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The ABM token's ID |
| macos_team_id | integer | body | macOS hosts are automatically added to this team in Fleet when they appear in Apple Business Manager. If not specified, defaults to "No team". |
| ios_team_id | integer | body | iOS hosts are automatically added to this team in Fleet when they appear in Apple Business Manager. If not specified, defaults to "No team". |
| ipados_team_id | integer | body | iPadOS hosts are automatically added to this team in Fleet when they appear in Apple Business Manager. If not specified, defaults to "No team". |
Example
PATCH /api/v1/fleet/abm_tokens/1/teams
Request body
{
"macos_team_id": 1,
"ios_team_id": 2,
"ipados_team_id": 3
}
Default response
Status: 200
"abm_token": {
"id": 1,
"apple_id": "apple@example.com",
"org_name": "Fleet Device Management Inc.",
"mdm_server_url": "https://example.com/mdm/apple/mdm",
"renew_date": "2024-11-29T00:00:00Z",
"terms_expired": false,
"macos_team": 1,
"ios_team": 2,
"ipados_team": 3
}
Renew ABM token
PATCH /api/v1/fleet/abm_tokens/:id/renew
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The ABM token's ID |
Example
PATCH /api/v1/fleet/abm_tokens/1/renew
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="token"; filename="server_token_abm.p7m"
Content-Type: application/octet-stream
<TOKEN_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
"abm_token": {
"id": 1,
"apple_id": "apple@example.com",
"org_name": "Fleet Device Management Inc.",
"mdm_server_url": "https://example.com/mdm/apple/mdm",
"renew_date": "2025-10-20T00:00:00Z",
"terms_expired": false,
"macos_team": null,
"ios_team": null,
"ipados_team": null
}
Delete ABM token
DELETE /api/v1/fleet/abm_tokens/:id
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The ABM token's ID |
Example
DELETE /api/v1/fleet/abm_tokens/1
Default response
Status: 204
Add VPP token
POST /api/v1/fleet/vpp_tokens
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | file | form | Required The file containing the content token (.vpptoken) from Apple Business Manager |
Example
POST /api/v1/fleet/vpp_tokens
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="token"; filename="sToken_for_Acme.vpptoken"
Content-Type: application/octet-stream
<TOKEN_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
"vpp_token": {
"id": 1,
"org_name": "Fleet Device Management Inc.",
"location": "https://example.com/mdm/apple/mdm",
"renew_date": "2024-10-20T00:00:00Z",
"terms_expired": false,
"teams": null
}
Update VPP token's teams
PATCH /api/v1/fleet/vpp_tokens/:id/teams
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The ABM token's ID |
| team_ids | list | body | If you choose specific teams, App Store apps in this VPP account will only be available to install on hosts in these teams. If not specified, defaults to all teams. |
Example
PATCH /api/v1/fleet/vpp_tokens/1/teams
Request body
{
"team_ids": [1, 2, 3]
}
Default response
Status: 200
"vpp_token": {
"id": 1,
"org_name": "Fleet Device Management Inc.",
"location": "https://example.com/mdm/apple/mdm",
"renew_date": "2024-10-20T00:00:00Z",
"terms_expired": false,
"teams": [
{
"team_id": 1,
"name": "Team 1"
},
{
"team_id": 2,
"name": "Team 2"
},
{
"team_id": 2,
"name": "Team 3"
},
]
}
Renew VPP token
PATCH /api/v1/fleet/vpp_tokens/:id/renew
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The VPP token's ID |
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="token"; filename="sToken_for_Acme.vpptoken"
Content-Type: application/octet-stream
<TOKEN_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
"vpp_token": {
"id": 1,
"org_name": "Fleet Device Management Inc.",
"location": "https://example.com/mdm/apple/mdm",
"renew_date": "2025-10-20T00:00:00Z",
"terms_expired": false,
"teams": [1, 2, 3]
}
Delete VPP token
DELETE /api/v1/fleet/vpp_token/:id
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | Required The VPP token's ID |
Example
DELETE /api/v1/fleet/vpp_tokens/1
Default response
Status: 204
Batch-apply MDM custom settings
POST /api/v1/fleet/mdm/profiles/batch
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_id | number | query | Available in Fleet Premium The team ID to apply the custom settings to. Only one of team_name/team_id can be provided. |
| team_name | string | query | Available in Fleet Premium The name of the team to apply the custom settings to. Only one of team_name/team_id can be provided. |
| dry_run | bool | query | Validate the provided profiles and return any validation errors, but do not apply the changes. |
| no_cache | bool | query | Do not use the cached version of Fleet's configuration. This parameter should only be used when the configuration was updated less than 1 second ago. |
| profiles | json | body | An array of objects, consisting of a profile base64-encoded .mobileconfig or JSON for macOS and XML (Windows) file, labels_include_all, labels_include_any, or labels_exclude_any array of strings (label names), and name display name (for Windows configuration profiles and macOS declaration profiles). |
If no team (id or name) is provided, the profiles are applied for all hosts (for Fleet Free) or for hosts that are not assigned to any team (for Fleet Premium). After the call, the provided list of profiles will be the active profiles for that team (or no team) - that is, any existing profile that is not part of that list will be removed, and an existing profile with the same payload identifier (macOS) as a new profile will be edited. If the list of provided profiles is empty, all profiles are removed for that team (or no team).
Example
POST /api/v1/fleet/mdm/profiles/batch
Default response
204
Initiate SSO for end-user authentication during macOS, Windows or Linux setup
This endpoint initiates the SSO flow, the response contains an URL that the client can use to redirect the user to initiate the SSO flow in the configured IdP.
POST /api/v1/fleet/mdm/sso
A successful response contains an HTTP cookie __Host-FLEETSSOSESSIONID that needs to be sent on the POST /api/v1/fleet/mdm/sso/callback request (this HTTP cookie is used to identify the SSO login session).
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| initiator | string | body | Used to differentiate between account driven enrollment and DEP or other flows for SSO callback purposes. The callback will use the Account Driven Enrollment behavior if account_driven_enroll is passed as the value of this parameter. Use setup_experience to initiate a web-based SSO login outside of the DEP flow. |
| user_identifier | string | body | Passed by Apple for account-driven enrollment. |
| host_uuid | string | body | The hardware UUID of the device to enroll when using the setup_experience value for initiator. |
Example
POST /api/v1/fleet/mdm/sso
Default response
{
"url": "https://idp-provider.com/saml?SAMLRequest=...",
}
Example response cookie in the HTTP Set-Cookie header:
Set-Cookie: __Host-FLEETSSOSESSIONID=slI727JZ+j0FvyBRLyD/gri1rxtwpaZT; Path=/; Max-Age=300; HttpOnly; Secure
Complete SSO during DEP or Account Driven enrollment
This is the callback endpoint that the identity provider will use to send security assertions to Fleet. This is where Fleet receives and processes the response from the identify provider.
POST /api/v1/fleet/mdm/sso/callback
The __Host-FLEETSSOSESSIONID HTTP cookie must be set for MDM SSO login requests. The value for this cookie is returned in the POST /api/v1/fleet/mdm/sso request.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| SAMLResponse | string | body | Required. The SAML response from the identity provider. |
| __Host-FLEETSSOSESSIONID | string | cookie | Required. HTTP Cookie returned in the POST /api/v1/fleet/mdm/sso request. |
Example
POST /api/v1/fleet/mdm/sso/callback
Request body
{
"SAMLResponse": "<SAML response from IdP>"
}
Example session cookie set in the Cookie request header:
Cookie: __Host-FLEETSSOSESSIONID=slI727JZ+j0FvyBRLyD/gri1rxtwpaZT
Default response
Status: 302
If the credentials are valid and no value was passed for the initiator parameter during initiation
of SSO, the server redirects the client to the Fleet UI. The URL contains the
following query parameters that can be used to complete the DEP enrollment flow:
enrollment_referencea reference that must be passed along withprofile_tokento the endpoint to download an enrollment profile.profile_tokenis a token that can be used to download an enrollment profile (.mobileconfig).eula_token(optional) if an EULA was uploaded, this contains a token that can be used to view the EULA document.
If the credentials are valid and account_driven_enroll was passed for the initiator parameter
during initiation of SSO, the server redirects the client to
apple-remotemanagement-user-login://authentication-results . The URL contains the following query
parameter which is used by the Apple MDM client on the device to complete the account driven
enrollment flow:
access-tokena token that is passed by the device in the Authorization header on the second call to the Account Driven Enrollment endpoint to download an enrollment profile.
Over the air enrollment
This endpoint handles over the air (OTA) MDM enrollments
POST /api/v1/fleet/ota_enrollment
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| enroll_secret | string | url | Required Assigns the host to a team with a matching enroll secret |
| XML device response | XML | body | Required. The XML response from the device. See Apple configuration profile documentation for examples. |
Note: enroll secrets can contain special characters. Ensure any special characters are properly escaped.
Example
POST /api/v1/fleet/ota_enrollment?enroll_secret=0Z6IuKpKU4y7xl%2BZcrp2gPcMi1kKNs3p
Default response
Status: 200
Per the spec, the response is different depending on the signature of the XML device response:
- If the body is signed with a certificate that can be validated by our root SCEP certificate, it returns an enrollment profile.
- Otherwise, it returns a SCEP payload.
Preassign profiles to devices
The Puppet module API endpoints are deprecated as of Fleet 4.66. They are maintained for backwards compatibility.
Available in Fleet Premium
This endpoint stores a profile to be assigned to a host at some point in the future. The actual assignment happens when the Match preassigned profiles endpoint is called. The reason for this "pre-assign" step is to collect all profiles that are meant to be assigned to a host, and match the list of profiles to an existing team (or create one with that set of profiles if none exist) so that the host can be assigned to that team and inherit its list of profiles.
POST /api/v1/fleet/mdm/apple/profiles/preassign
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| external_host_identifier | string | body | Required. The identifier of the host as generated by the external service (e.g. Puppet). |
| host_uuid | string | body | Required. The UUID of the host. |
| profile | string | body | Required. The base64-encoded .mobileconfig content of the MDM profile. |
| group | string | body | The group label associated with that profile. This information is used to generate team names if they need to be created. |
| exclude | boolean | body | Whether to skip delivering the profile to this host. |
Example
POST /api/v1/fleet/mdm/apple/profiles/preassign
Request body
{
"external_host_identifier": "id-01234",
"host_uuid": "c0532a64-bec2-4cf9-aa37-96fe47ead814",
"profile": "<base64-encoded profile>",
"group": "Workstations",
"exclude": false
}
Default response
Status: 204
Get FileVault statistics
Available in Fleet Premium
Get aggregate status counts of disk encryption enforced on macOS hosts.
The summary can optionally be filtered by team id.
GET /api/v1/fleet/mdm/apple/filevault/summary
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_id | string | query | Available in Fleet Premium The team id to filter the summary. |
Example
Get aggregate status counts of Apple disk encryption profiles applying to macOS hosts enrolled to Fleet's MDM that are not assigned to any team.
GET /api/v1/fleet/mdm/apple/filevault/summary
Default response
Status: 200
{
"verified": 123,
"verifying": 123,
"action_required": 123,
"enforcing": 123,
"failed": 123,
"removing_enforcement": 123
}
Match preassigned profiles
The Puppet module API endpoints are deprecated as of Fleet 4.66. They are maintained for backwards compatibility.
Available in Fleet Premium
This endpoint uses the profiles stored by the Preassign profiles to devices endpoint to match the set of profiles to an existing team if possible, creating one if none exists. It then assigns the host to that team so that it receives the associated profiles. It is meant to be called only once all desired profiles have been pre-assigned to the host.
POST /api/v1/fleet/mdm/apple/profiles/match
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| external_host_identifier | string | body | Required. The identifier of the host as generated by the external service (e.g. Puppet). |
Example
POST /api/v1/fleet/mdm/apple/profiles/match
Request body
{
"external_host_identifier": "id-01234"
}
Default response
Status: 204
Upload VPP content token
POST /api/v1/fleet/mdm/apple/vpp_token
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | file | form | Required The file containing the content token (.vpptoken) from Apple Business Manager |
Example
POST /api/v1/fleet/mdm/apple/vpp_token
Request header
Content-Length: 850
Content-Type: multipart/form-data; boundary=------------------------f02md47480und42y
Request body
--------------------------f02md47480und42y
Content-Disposition: form-data; name="token"; filename="sToken_for_Acme.vpptoken"
Content-Type: application/octet-stream
<TOKEN_DATA>
--------------------------f02md47480und42y
Default response
Status: 200
Disable VPP
DELETE /api/v1/fleet/mdm/apple/vpp_token
Example
DELETE /api/v1/fleet/mdm/apple/vpp_token
Default response
Status: 204
SCEP proxy
/mdm/scep/proxy/{identifier}
This endpoint is used to proxy SCEP requests to the configured SCEP server. It uses the SCEP protocol. The identifier is in the format hostUUID,profileUUID,caName (URL escaped).
Get Android Enterprise signup URL
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows.
This endpoint is used to generate a URL, which opens Google's wizard to create Android Enterprise.
GET /api/v1/fleet/android_enterprise/signup_url
Example
GET /api/v1/fleet/android_enterprise/signup_url
Default response
Status: 200
{
"android_enterprise_signup_url": "https://enterprise.google.com/signup/android/email?origin=android&thirdPartyToken=S7512150D1D59A3BK"
}
Connect Android Enterprise
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows. This endpoint is used to connect (bind) Android Enterprise to Fleet and to turn on Android MDM features.
GET /api/v1/fleet/android_enterprise/connect/:token
This is callback URL that will be open after user completes Google's signup flow. It will self-close and return user to settings page.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | Required. The signup token associated with Android Enterprise in Fleet. |
| enterpriseToken | string | query | Required. The enterprise token that's returned from Google API. |
Example
GET /api/v1/fleet/android_enterprise/connect/6177a9cb410ff61f20015ad?enterpriseToken=FEKXFy427_jz9Nfhq19SGDOKR2nZ4ZqhSAuYqOQw1B1G2OdBkQ5IDfSkLiO0rUqL8ptAXoa5_cZdh5GBRdyLj29m5A8DcZ1dptSp6YMNY6MQv0UiqcQqRC8D
Default response
Status: 200
<html><!-- self-closing page --></html>
Delete Android Enterprise
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows. This endpoint is used to delete Android Enterprise. Once deleted, hosts that belong to Android Enterprise will be un-enrolled and Android MDM features will be turned off.
DELETE /api/v1/fleet/android_enterprise/
Example
DELETE /api/v1/fleet/android_enterprise
Default response
Status: 200
Get Android enrollment token
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows. This endpoint is used to retrieve an Android enrollment token and enrollment URL or QR Code contents using a Fleet enroll secret which opens the Android enrollment wizard (settings app) to enroll the Android host. The QR Code contents can only be used to trigger enrollment of an Android host that has been factory reset and is at the initial setup screen, and likewise if fully_managed is true, the host can only be enrolled at this initial setup screen.
GET /api/v1/fleet/android_enterprise/enrollment_token
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| enroll_secret | string | query | Required. The enroll secret of a team in Fleet. |
| fully_managed | bool | query | Optional. If set to true, creates the enrollment token with AllowPersonalUsage set to PERSONAL_USAGE_DISALLOWED |
Example
GET /api/v1/fleet/android/enterprise/enrollment_token?enroll_secret=0Z6IuKpKU4y7xl%2BZcrp2gPcMi1kKNs3p
Default response
Status: 200
{
"android_enrollment_token": "OJDDNCYSEZPAUZZOXHDF",
"android_enrollment_url": "https://enterprise.google.com/android/enroll?et=OJDDNCYSEZPAUZZOXHDF",
"android_enrollment_qrcode": "{\"android.app.extra.PROVISIONING_DEVICE_ADMIN_COMPONENT_NAME\":\"com.google.android.apps.work.clouddpc\/.receivers.CloudDeviceAdminReceiver\",\"android.app.extra.PROVISIONING_DEVICE_ADMIN_SIGNATURE_CHECKSUM\":\"I9DvS1O5hXZ46mb01AlRjq4oJJGs2kuZcHvCkACEXlg\",\"android.app.extra.PROVISIONING_DEVICE_ADMIN_PACKAGE_DOWNLOAD_LOCATION\":\"https:\/\/play.google.com\/managed\/downloadManagingApp?identifier=setup\",\"android.app.extra.PROVISIONING_ADMIN_EXTRAS_BUNDLE\":{\"com.google.android.apps.work.clouddpc.EXTRA_ENROLLMENT_TOKEN\":\"OJDDNCYSEZPAUZZOXHDF\"}}"
}
Get Android Enterprise server-sent event
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows.
This endpoint is used to get server-sent events (SSE) messages, so that UI know if Android Enterprise is created and bound to Fleet.
GET /api/v1/fleet/android_enterprise/signup_sse
Example
GET /api/v1/fleet/android_enterprise/signup_sse
Default response
Status: 200
Android Enterprise successfully connected
Android Enterprise PubSub push endpoint
Experimental feature. This feature is undergoing rapid improvement, which may result in breaking changes to the API or configuration surface. It is not recommended for use in automated workflows.
This endpoint is used by Google Pub/Sub subscription to push messages to Fleet.
POST /api/v1/fleet/android_enterprise/pubsub
Get Apple Account Driven User Enrollment Profile
This endpoint initiates Account Driven User Enrollment on iOS and iPadOS devices and is used by the Apple. Devices are directed to this endpoint via Apple Account Driven Enrollment service discovery. The first request made to this endpoint is unauthenticated and will return a 401 Unauthorized including a Www-Authenticate header with a URL redirecting them to /mdm/sso. After authentication, the client will return to this endpoint and make a second request including the returned token in the Authorization header and an enrollment profile will be returned. Devices that fail to identify via plist or that identify as other than iPhone or iPad will return a 400 Bad Request.
POST /api/mdm/apple/account_driven_enroll
Parameters
A plist including LANGUAGE, VERSION, PRODUCT, SOFTWARE_UPDATE_DEVICE_ID, SUPPLEMENTAL_BUILD_VERSION and VERSION
Get Apple Account Driven User Enrollment service discovery payload
This endpoint will be used by devices to get the data needed to initiate an account driven user
enrollment into MDM. The devices will get the URL for the mdm server and will call that endpoint
while passing the mdm-byod enrollment type.
GET /api/mdm/apple/service_discovery
Example
GET /api/mdm/apple/service_discovery
Response
Status 200
{
"Servers": [
{
"Version": "mdm-byod",
"BaseURL": "<fleet_server_url>/api/mdm/apple/account_driven_enroll"
}
]
}
Get or apply configuration files
These API routes are used by the fleetctl CLI tool. Users can manage Fleet with fleetctl and configuration files in YAML syntax.
- Get queries
- Get query
- Apply queries
- Apply policies
- Get packs
- Apply packs
- Get pack by name
- Apply team
- Apply labels
- Get labels
- Get label
- Get enroll secrets
- Modify enroll secrets
- Store secret variables
Get queries
Returns a list of all queries in the Fleet instance. Each item returned includes the name, description, and SQL of the query.
GET /api/v1/fleet/spec/queries
Parameters
None.
Example
GET /api/v1/fleet/spec/queries
Default response
Status: 200
{
"specs": [
{
"name": "query1",
"description": "query",
"query": "SELECT * FROM osquery_info"
},
{
"name": "osquery_schedule",
"description": "Report performance stats for each file in the query schedule.",
"query": "SELECT name, interval, executions, output_size, wall_time, (user_time/executions) AS avg_user_time, (system_time/executions) AS avg_system_time, average_memory, last_executed FROM osquery_schedule;"
}
]
}
Get query
Returns the name, description, and SQL of the query specified by name.
GET /api/v1/fleet/spec/queries/{name}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | path | Required. The name of the query. |
Example
GET /api/v1/fleet/spec/queries/query1
Default response
Status: 200
{
"specs": {
"name": "query1",
"description": "query",
"query": "SELECT * FROM osquery_info"
}
}
Apply queries
Creates and/or modifies the queries included in the list. To modify an existing query, the name of the query must already be used by an existing query. If a query with the specified name doesn't exist in Fleet, a new query will be created.
If a query field is not specified in the "spec" then its default value depending on its type will be assumed, e.g. if interval is not set then 0 will be assumed, if discard_data is omitted then false will be assumed, etc.
POST /api/v1/fleet/spec/queries
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| specs | list | body | Required. The list of the queries to be created or modified. |
For more information about the query fields, please refer to the Create query endpoint.
Example
POST /api/v1/fleet/spec/queries
Request body
{
"specs": [
{
"name": "new_query",
"description": "This will be a new query because a query with the name 'new_query' doesn't exist in Fleet.",
"query": "SELECT * FROM osquery_info"
},
{
"name": "osquery_schedule",
"description": "This queries description and SQL will be modified because a query with the name 'osquery_schedule' exists in Fleet.",
"query": "SELECT * FROM osquery_info"
}
]
}
Default response
Status: 200
Get packs
Returns all packs in the Fleet instance.
GET /api/v1/fleet/spec/packs
Example
GET /api/v1/fleet/spec/packs
Default response
Status: 200
{
"specs": [
{
"id": 1,
"name": "pack_1",
"description": "Description",
"disabled": false,
"targets": {
"labels": ["All Hosts"],
"teams": null
},
"queries": [
{
"query": "new_query",
"name": "new_query",
"description": "",
"interval": 456,
"snapshot": false,
"removed": true,
"platform": "windows",
"version": "4.5.0"
},
{
"query": "new_title_for_my_query",
"name": "new_title_for_my_query",
"description": "",
"interval": 677,
"snapshot": true,
"removed": false,
"platform": "",
"version": ""
},
{
"query": "osquery_info",
"name": "osquery_info",
"description": "",
"interval": 6667,
"snapshot": true,
"removed": false,
"platform": "",
"version": ""
},
{
"query": "query1",
"name": "query1",
"description": "",
"interval": 7767,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
},
{
"query": "osquery_events",
"name": "osquery_events",
"description": "",
"interval": 454,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
},
{
"query": "osquery_events",
"name": "osquery_events-1",
"description": "",
"interval": 120,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
}
]
},
{
"id": 2,
"name": "pack_2",
"disabled": false,
"targets": {
"labels": null,
"teams": null
},
"queries": [
{
"query": "new_query",
"name": "new_query",
"description": "",
"interval": 333,
"snapshot": false,
"removed": true,
"platform": "windows",
"version": "4.5.0",
"shard": 10,
"denylist": null
}
]
}
]
}
Apply policies
Creates and/or modifies the policies included in the list. To modify an existing policy, the name of the policy included in the list must already be used by an existing policy. If a policy with the specified name doesn't exist in Fleet, a new policy will be created.
NOTE: when updating a policy, team and platform will be ignored.
POST /api/v1/fleet/spec/policies
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| specs | list | body | Required. The list of the policies to be created or modified. |
Example
POST /api/v1/fleet/spec/policies
Request body
{
"specs": [
{
"name": "new policy",
"description": "This will be a new policy because a policy with the name 'new policy' doesn't exist in Fleet.",
"query": "SELECT * FROM osquery_info",
"team": "No team",
"resolution": "some resolution steps here",
"critical": false
},
{
"name": "Is FileVault enabled on macOS devices?",
"query": "SELECT 1 FROM disk_encryption WHERE user_uuid IS NOT “” AND filevault_status = ‘on’ LIMIT 1;",
"team": "Workstations",
"description": "Checks to make sure that the FileVault feature is enabled on macOS devices.",
"resolution": "Choose Apple menu > System Preferences, then click Security & Privacy. Click the FileVault tab. Click the Lock icon, then enter an administrator name and password. Click Turn On FileVault.",
"platform": "darwin",
"critical": true,
"script_id": 123
},
{
"name": "Is Adobe Acrobat installed and up to date?",
"query": "SELECT 1 FROM apps WHERE name = 'Adobe Acrobat Reader.app' AND version_compare(bundle_short_version, '23.001.20687') >= 0;",
"team": "Workstations",
"description": "Checks to make sure that Adobe Acrobat is installed and up to date.",
"platform": "darwin",
"critical": false,
"software_title_id": 12
},
]
}
The fields critical, script_id, and software_title_id are available in Fleet Premium.
Default response
Status: 200
Apply packs
Creates and/or modifies the packs included in the list.
POST /api/v1/fleet/spec/packs
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| specs | list | body | Required. A list that includes the specs for each pack to be added to the Fleet instance. |
Example
POST /api/v1/fleet/spec/packs
Request body
{
"specs": [
{
"id": 1,
"name": "pack_1",
"description": "Description",
"disabled": false,
"targets": {
"labels": ["All Hosts"],
"teams": null
},
"queries": [
{
"query": "new_query",
"name": "new_query",
"description": "",
"interval": 456,
"snapshot": false,
"removed": true
},
{
"query": "new_title_for_my_query",
"name": "new_title_for_my_query",
"description": "",
"interval": 677,
"snapshot": true,
"removed": false
},
{
"query": "osquery_info",
"name": "osquery_info",
"description": "",
"interval": 6667,
"snapshot": true,
"removed": false
},
{
"query": "query1",
"name": "query1",
"description": "",
"interval": 7767,
"snapshot": false,
"removed": true
},
{
"query": "osquery_events",
"name": "osquery_events",
"description": "",
"interval": 454,
"snapshot": false,
"removed": true
},
{
"query": "osquery_events",
"name": "osquery_events-1",
"description": "",
"interval": 120,
"snapshot": false,
"removed": true
}
]
},
{
"id": 2,
"name": "pack_2",
"disabled": false,
"targets": {
"labels": null,
"teams": null
},
"queries": [
{
"query": "new_query",
"name": "new_query",
"description": "",
"interval": 333,
"snapshot": false,
"removed": true,
"platform": "windows"
}
]
}
]
}
Default response
Status: 200
Get pack by name
Returns a pack.
GET /api/v1/fleet/spec/packs/{name}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | path | Required. The pack's name. |
Example
GET /api/v1/fleet/spec/packs/pack_1
Default response
Status: 200
{
"specs": {
"id": 15,
"name": "pack_1",
"description": "Description",
"disabled": false,
"targets": {
"labels": ["All Hosts"],
"teams": null
},
"queries": [
{
"query": "new_title_for_my_query",
"name": "new_title_for_my_query",
"description": "",
"interval": 677,
"snapshot": true,
"removed": false,
"platform": "",
"version": ""
},
{
"query": "osquery_info",
"name": "osquery_info",
"description": "",
"interval": 6667,
"snapshot": true,
"removed": false,
"platform": "",
"version": ""
},
{
"query": "query1",
"name": "query1",
"description": "",
"interval": 7767,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
},
{
"query": "osquery_events",
"name": "osquery_events",
"description": "",
"interval": 454,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
},
{
"query": "osquery_events",
"name": "osquery_events-1",
"description": "",
"interval": 120,
"snapshot": false,
"removed": true,
"platform": "",
"version": ""
}
]
}
}
Apply team
Available in Fleet Premium
If the name specified is associated with an existing team, this API route, completely replaces this team's existing agent_options and secrets with those that are specified.
If the name is not already associated with an existing team, this API route creates a new team with the specified name, agent_options, and secrets.
POST /api/v1/fleet/spec/teams
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | body | Required. The team's name. |
| agent_options | object | body | The agent options spec that is applied to the hosts assigned to the specified to team. These agent options completely override the global agent options specified in the GET /api/v1/fleet/config API route |
| features | object | body | The features that are applied to the hosts assigned to the specified to team. These features completely override the global features specified in the GET /api/v1/fleet/config API route |
| secrets | array | body | A list of plain text strings is used as the enroll secrets. Existing secrets are replaced with this list, or left unmodified if this list is empty. Note that there is a limit of 50 secrets allowed. |
| mdm | object | body | The team's MDM configuration options. |
| mdm.macos_updates | object | body | The OS updates macOS configuration options for Nudge. |
| mdm.macos_updates.minimum_version | string | body | The required minimum operating system version. |
| mdm.macos_updates.deadline | string | body | The required installation date for Nudge to enforce the operating system version. |
| mdm.macos_settings | object | body | The macOS-specific MDM settings. |
| mdm.macos_settings.custom_settings | array | body | The list of objects consists of a path to .mobileconfig or JSON file and labels_include_all, labels_include_any, or labels_exclude_any list of label names. |
| mdm.windows_settings | object | body | The Windows-specific MDM settings. |
| mdm.windows_settings.custom_settings | array | body | The list of objects consists of a path to XML files and labels_include_all, labels_include_any, or labels_exclude_any list of label names. |
| scripts | array | body | A list of script files to add to this team so they can be executed at a later time. |
| software | object | body | The team's software that will be available for install. |
| software.app_store_apps | array | body | An array of objects with values below. |
| software.app_store_apps.app_store_id | string | body | ID of the App Store app. |
| software.app_store_apps.self_service | boolean | body | Specifies whether or not end users can install self-service. |
| software.app_store_apps.labels_include_any | array | body | Specifies whether the app will only be available for install on hosts that have any of these labels. Only one of either labels_include_any or labels_exclude_any can be specified. |
| software.app_store_apps.labels_exclude_any | array | body | Specifies whether the app will only be available for install on hosts that don't have any of these labels. Only one of either labels_include_any or labels_exclude_any can be specified. |
| software.packages | array | body | An array of objects with values below. |
| software.packages.url | string | body | URL to the software package (PKG, MSI, EXE or DEB). |
| software.packages.install_script | string | body | Command that Fleet runs to install software. |
| software.packages.pre_install_query | string | body | Condition query that determines if the install will proceed. |
| software.packages.post_install_script | string | body | Script that runs after software install. |
| software.packages.uninstall_script | string | body | Command that Fleet runs to uninstall software. |
| software.packages.self_service | boolean | body | If true lists software in the self-service. |
| software.packages.labels_include_any | array | body | Target hosts that have any label in the array. Only one of labels_include_any or labels_exclude_any can be included. If neither are included, all hosts are targeted. |
| software.packages.labels_exclude_any | array | body | Target hosts that don't have any label in the array. Only one of labels_include_any or labels_exclude_any can be included. If neither are included, all hosts are targeted. |
| mdm.macos_settings.enable_disk_encryption | bool | body | Whether disk encryption should be enabled for hosts that belong to this team. |
| force | bool | query | Force apply the spec even if there are (ignorable) validation errors. Those are unknown keys and agent options-related validations. |
| dry_run | bool | query | Validate the provided JSON for unknown keys and invalid value types and return any validation errors, but do not apply the changes. |
Example
POST /api/v1/fleet/spec/teams
Request body
{
"specs": [
{
"name": "Client Platform Engineering",
"features": {
"enable_host_users": false,
"enable_software_inventory": true,
"additional_queries": {
"foo": "SELECT * FROM bar;"
}
},
"agent_options": {
"spec": {
"config": {
"options": {
"pack_delimiter": "/",
"logger_tls_period": 10,
"distributed_plugin": "tls",
"disable_distributed": false,
"logger_tls_endpoint": "/api/v1/osquery/log",
"distributed_interval": 10,
"distributed_tls_max_attempts": 3
},
"decorators": {
"load": [
"SELECT uuid AS host_uuid FROM system_info;",
"SELECT hostname AS hostname FROM system_info;"
]
}
},
"overrides": {}
}
},
"secrets": [
{
"secret": "fTp52/twaxBU6gIi0J6PHp8o5Sm1k1kn"
},
{
"secret": "bhD5kiX2J+KBgZSk118qO61ZIdX/v8On"
}
],
"mdm": {
"macos_updates": {
"minimum_version": "12.3.1",
"deadline": "2023-12-01"
},
"macos_settings": {
"custom_settings": [
{
"path": "path/to/profile1.mobileconfig"
"labels_include_all": ["Label 1", "Label 2"]
},
{
"path": "path/to/profile2.json"
"labels_exclude_any": ["Label 3", "Label 4"]
},
],
"enable_disk_encryption": true
},
"windows_settings": {
"custom_settings": [
{
"path": "path/to/profile3.xml"
"labels_include_all": ["Label 1", "Label 2"]
}
]
}
},
"scripts": ["path/to/script.sh"],
"software": {
"packages": [
{
"url": "https://cdn.zoom.us/prod/5.16.10.26186/x64/ZoomInstallerFull.msi",
"pre_install_query": "SELECT 1 FROM macos_profiles WHERE uuid='c9f4f0d5-8426-4eb8-b61b-27c543c9d3db';",
"post_install_script": "sudo /Applications/Falcon.app/Contents/Resources/falconctl license 0123456789ABCDEFGHIJKLMNOPQRSTUV-WX",
"self_service": true,
}
],
"app_store_apps": [
{
"app_store_id": "12464567",
"self_service": true
}
]
}
}
]
}
Default response
Status: 200
{
"team_ids_by_name": {
"Client Platform Engineering": 123
}
}
Apply labels
Adds the supplied labels to Fleet. Each label requires the name, and label_membership_type properties.
If the label_membership_type is set to dynamic, the query property must also be specified with the value set to a query in SQL syntax.
If the label_membership_type is set to manual, the hosts property must also be specified with the value set to a list of hostnames.
POST /api/v1/fleet/spec/labels
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_id | int | query | The ID of the team to set labels to; omit to set global labels |
| specs | object[] | body | A list of the label to apply. Each label requires the name, query, and label_membership_type properties |
| names_to_move | string[] | body | A list of names of labels that are both in specs in the current request and already exist on other teams. If the requesting user has permission to modify those labels, this endpoint will rename the specified labels so new labels on the correct team can be created. The request will fail with no changes if one or more of the specified labels cannot be moved. |
The purpose of names_to_move is to allow a GitOps run to move a Fleet instance from having a label on one team (or global) to using that same label name on another team (or switching a team label to a global label). Once labels are created on the correct teams, the old labels are cleaned up when GitOps is run on the old team via explicit DELETE calls.
Example
POST /api/v1/fleet/spec/labels
Request body
{
"specs": [
{
"name": "Ubuntu",
"description": "Filters Ubuntu hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'ubuntu';",
"label_membership_type": "dynamic"
},
{
"name": "local_machine",
"description": "Includes only my local machine",
"label_membership_type": "manual",
"hosts": ["snacbook-pro.local"]
}
],
"names_to_move": ["local_machine"]
}
Default response
Status: 200
Get labels
Gets all labels visible to the currently logged-in user.
GET /api/v1/fleet/spec/labels
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_id | int | query | The ID of the team to view all labels from; omit to see all labels, supply 0 to see only global labels |
Example
GET /api/v1/fleet/spec/labels
Default response
Status: 200
{
"specs": [
{
"id": 6,
"name": "All Hosts",
"description": "All hosts which have enrolled in Fleet",
"query": "SELECT 1;",
"label_type": "builtin",
"label_membership_type": "dynamic",
"team_id": null,
"team_name": null
},
{
"id": 7,
"name": "macOS",
"description": "All macOS hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'darwin';",
"platform": "darwin",
"label_type": "builtin",
"label_membership_type": "dynamic",
"team_id": null,
"team_name": null
},
{
"id": 8,
"name": "Ubuntu Linux",
"description": "All Ubuntu hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'ubuntu';",
"platform": "ubuntu",
"label_type": "builtin",
"label_membership_type": "dynamic",
"team_id": null,
"team_name": null
},
{
"id": 9,
"name": "CentOS Linux",
"description": "All CentOS hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'centos' OR name LIKE '%centos%'",
"label_type": "builtin",
"label_membership_type": "dynamic",
"team_id": null,
"team_name": null
},
{
"id": 10,
"name": "MS Windows",
"description": "All Windows hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'windows';",
"platform": "windows",
"label_type": "builtin",
"label_membership_type": "dynamic",
"team_id": null,
"team_name": null
},
{
"id": 11,
"name": "Ubuntu",
"description": "Filters Ubuntu hosts",
"query": "SELECT 1 FROM os_version WHERE platform = 'ubuntu';",
"label_type": "builtin",
"label_membership_type": "dynamic",,
"team_id": null,
"team_name": null
},
{
"id": 4663,
"name": "Team: g-software",
"description": "Workstations used by team g-software",
"query": "",
"platform": "",
"label_type": "regular",
"label_membership_type": "manual",
"display_text": "Team: g-software",
"team_id": 1,
"team_name": "Workstations"
}
]
}
Get label
Returns the label specified by name if it exists and its team (if any) is accessible by the current user.
GET /api/v1/fleet/spec/labels/{name}
Parameters
None.
Example
GET /api/v1/fleet/spec/labels/local_machine
Default response
Status: 200
{
"specs": {
"id": 12,
"name": "local_machine",
"description": "Includes only my local machine",
"query": "",
"label_membership_type": "manual",
"team_id": null
}
}
Get enroll secrets
Returns the valid global enroll secrets.
GET /api/v1/fleet/spec/enroll_secret
Parameters
None.
Example
GET /api/v1/fleet/spec/enroll_secret
Default response
Status: 200
{
"spec": {
"secrets": [
{
"secret": "fTp52/twaxBU6gIi0J6PHp8o5Sm1k1kn",
"created_at": "2021-01-07T19:40:04Z"
},
{
"secret": "bhD5kiX2J+KBgZSk118qO61ZIdX/v8On",
"created_at": "2021-01-04T21:18:07Z"
}
]
}
}
Modify enroll secrets
This replaces the active global enroll secrets with the secrets specified.
POST /api/v1/fleet/spec/enroll_secret
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| secrets | list | body | Required. The plain text string used as the enroll secret. Note that there is a limit of 50 secrets allowed. |
Example
Request body
{
"spec": {
"secrets": [
{
"secret": "fTp52/twaxBU6gIi0J6PHp8o5Sm1k1kn"
}
]
}
}
POST /api/v1/fleet/spec/enroll_secret
Default response
Status: 200
Store secret variables
Stores secret variables prefixed with $FLEET_SECRET_ to Fleet.
PUT /api/v1/fleet/spec/secret_variables
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| secrets | list | body | Required. List of objects consisting of fields: name and value |
| dry_run | boolean | body | Optional. If true, validates the provided secrets and returns any validation errors, but does not apply the changes. |
Example
PUT /api/v1/fleet/spec/secret_variables
Request body
{
"secrets": [
{
"name": "FLEET_SECRET_SOME_API_TOKEN",
"value": "971ef02b93c74ca9b22b694a9251f1d6"
}
]
}
Default response
Status: 200
Live query
These API routes are used by the Fleet UI.
- Check live query status
- Check result store status
- Search targets
- Count targets
- Run live query
- Run live query by name
- Retrieve live query results (standard WebSocket API)
- Retrieve live query results (SockJS)
Check live query status
This checks the status of Fleet's ability to run a live query. If an error is present in the response, Fleet won't be able to run a live query successfully. The Fleet UI uses this endpoint to make sure that the Fleet instance is correctly configured to run live queries.
GET /api/v1/fleet/status/live_query
Parameters
None.
Example
GET /api/v1/fleet/status/live_query
Default response
Status: 200
Check result store status
This checks Fleet's result store status. If an error is present in the response, Fleet won't be able to run a live query successfully. The Fleet UI uses this endpoint to make sure that the Fleet instance is correctly configured to run live queries.
GET /api/v1/fleet/status/result_store
Parameters
None.
Example
GET /api/v1/fleet/status/result_store
Default response
Status: 200
Search targets
Accepts a search query and a list of host IDs to omit and returns a set of up to ten matching hosts. If a query ID is provided and the referenced query allows observers to run, targets will include hosts for which the user has an observer role.
POST /api/latest/fleet/hosts/search
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| query | string | body | The query used to identify hosts to target. Searchable items include a display_name, hostname, hardware_serial, uuid or primary_ip. |
| query_id | integer | body | The saved query (if any) that will be run. The observer_can_run property on the query and the user's roles affect which targets are included. |
| excluded_host_ids | array | body | The list of host ids to omit from the search results. |
Example
POST /api/v1/fleet/hosts/search
Request body
{
"query": "foo",
"query_id": 42,
"selected": {
"hosts": [],
"labels": [],
"teams": [1]
}
}
Default response
{
"targets": {
"hosts": [
{
"created_at": "2021-02-03T16:11:43Z",
"updated_at": "2021-02-03T21:58:19Z",
"id": 1337,
"detail_updated_at": "2021-02-03T21:58:10Z",
"label_updated_at": "2021-02-03T21:58:10Z",
"last_enrolled_at": "2021-02-03T16:11:43Z",
"seen_time": "2021-02-03T21:58:20Z",
"hostname": "foof41482833",
"uuid": "a2064cef-0000-0000-afb9-283e3c1d487e",
"platform": "rhel",
"osquery_version": "4.5.1",
"os_version": "CentOS 6.10.0",
"build": "",
"platform_like": "rhel",
"code_name": "",
"uptime": 32688000000000,
"memory": 2086899712,
"cpu_type": "x86_64",
"cpu_subtype": "142",
"cpu_brand": "Intel(R) Core(TM) i5-8279U CPU @ 2.40GHz",
"cpu_physical_cores": 4,
"cpu_logical_cores": 4,
"hardware_vendor": "",
"hardware_model": "",
"hardware_version": "",
"hardware_serial": "",
"computer_name": "foof41482833",
"display_name": "foof41482833",
"primary_ip": "172.20.0.3",
"primary_mac": "02:42:ac:14:00:03",
"distributed_interval": 10,
"config_tls_refresh": 10,
"logger_tls_period": 10,
"additional": {},
"status": "offline",
"display_text": "foof41482833"
}
]
}
}
Count targets
Counts the number of online and offline hosts included in a given set of selected targets.
POST /api/latest/fleet/targets/count
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| query_id | integer | body | The saved query (if any) that will be run. The observer_can_run property on the query and the user's roles determine which targets are included. |
| selected | object | body | The object includes lists of selected host IDs (selected.hosts), label IDs (selected.labels), and team IDs (selected.teams). When provided, builtin label IDs, custom label IDs and team IDs become AND filters. Within each selector, selecting two or more teams, two or more builtin labels, or two or more custom labels, behave as OR filters. There's one special case for the builtin label "All hosts", if such label is selected, then all other label and team selectors are ignored (and all hosts will be selected). If a host ID is explicitly included in selected.hosts, then it is assured that the query will be selected to run on it (no matter the contents of selected.labels and selected.teams). Use 0 team ID to filter by hosts assigned to "No team". See examples below. |
Example
POST /api/latest/fleet/targets/count
Request body
{
"query_id": 1337,
"selected": {
"hosts": [],
"labels": [42],
"teams": []
}
}
Default response
{
"targets_count": 813,
"targets_offline": 813,
"targets_online": 0
}
Run live query
Runs the specified query as a live query on the specified hosts or group of hosts and returns a new live query campaign. Individual hosts must be specified with the host's ID. Label IDs also specify groups of hosts.
After you initiate the query, get results via WebSocket.
POST /api/v1/fleet/queries/run
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| query | string | body | The SQL if using a custom query. |
| query_id | integer | body | The saved query (if any) that will be run. Required if running query as an observer. The observer_can_run property on the query effects which targets are included. |
| selected | object | body | Required. The object includes lists of selected host IDs (selected.hosts), label IDs (selected.labels), and team IDs (selected.teams). When provided, builtin label IDs, custom label IDs and team IDs become AND filters. Within each selector, selecting two or more teams, two or more builtin labels, or two or more custom labels, behave as OR filters. There's one special case for the builtin label "All hosts", if such label is selected, then all other label and team selectors are ignored (and all hosts will be selected). If a host ID is explicitly included in selected.hosts, then it is assured that the query will be selected to run on it (no matter the contents of selected.labels and selected.teams). Use 0 team ID to filter by hosts assigned to "No team". See examples below. |
One of query and query_id must be specified.
Example with one host targeted by ID
POST /api/v1/fleet/queries/run
Request body
{
"query": "SELECT instance_id FROM system_info",
"selected": {
"hosts": [171]
}
}
Default response
Status: 200
{
"campaign": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"Metrics": {
"TotalHosts": 1,
"OnlineHosts": 0,
"OfflineHosts": 1,
"MissingInActionHosts": 0,
"NewHosts": 1
},
"id": 1,
"query_id": 3,
"status": 0,
"user_id": 1
}
}
Example with multiple hosts targeted by label ID
POST /api/v1/fleet/queries/run
Request body
{
"query": "SELECT instance_id FROM system_info;",
"selected": {
"labels": [7]
}
}
Default response
Status: 200
{
"campaign": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"Metrics": {
"TotalHosts": 102,
"OnlineHosts": 0,
"OfflineHosts": 24,
"MissingInActionHosts": 0,
"NewHosts": 0
},
"id": 2,
"query_id": 3,
"status": 0,
"user_id": 1
}
}
Run live query by name
Runs the specified saved query as a live query on the specified targets. Returns a new live query campaign. Individual hosts must be specified with the host's hostname. Groups of hosts are specified by label name.
After the query has been initiated, get results via WebSocket.
POST /api/v1/fleet/queries/run_by_identifiers
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| query | string | body | The SQL of the query. |
| query_id | integer | body | The saved query (if any) that will be run. The observer_can_run property on the query effects which targets are included. |
| selected | object | body | Required. The object includes lists of selected hostnames (selected.hosts), label names (labels). When provided, builtin label names and custom label names become AND filters. Within each selector, selecting two or more builtin labels, or two or more custom labels, behave as OR filters. If a label provided could not be found in the database, a 400 bad request will be returned specifying which label is invalid. There's one special case for the builtin label "All hosts", if such label is selected, then all other label and team selectors are ignored (and all hosts will be selected). If a host's hostname is explicitly included in selected.hosts, then it is assured that the query will be selected to run on it (no matter the contents of selected.labels). See examples below. |
One of query and query_id must be specified.
Example with one host targeted by hostname
POST /api/v1/fleet/queries/run_by_identifiers
Request body
{
"query_id": 1,
"selected": {
"hosts": ["macbook-pro.local"]
}
}
Default response
Status: 200
{
"campaign": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"Metrics": {
"TotalHosts": 1,
"OnlineHosts": 0,
"OfflineHosts": 1,
"MissingInActionHosts": 0,
"NewHosts": 1
},
"id": 1,
"query_id": 3,
"status": 0,
"user_id": 1
}
}
Example with multiple hosts targeted by label name
POST /api/v1/fleet/queries/run_by_identifiers
Request body
{
"query": "SELECT instance_id FROM system_info",
"selected": {
"labels": ["All Hosts"]
}
}
Default response
Status: 200
{
"campaign": {
"created_at": "0001-01-01T00:00:00Z",
"updated_at": "0001-01-01T00:00:00Z",
"Metrics": {
"TotalHosts": 102,
"OnlineHosts": 0,
"OfflineHosts": 24,
"MissingInActionHosts": 0,
"NewHosts": 1
},
"id": 2,
"query_id": 3,
"status": 0,
"user_id": 1
}
}
Example with invalid label
POST /api/v1/fleet/queries/run_by_identifiers
Request body
{
"query": "SELECT instance_id FROM system_info",
"selected": {
"labels": ["Windows", "Banana", "Apple"]
}
}
Default response
Status: 400
{
"message": "Bad request",
"errors": [
{
"name": "base",
"reason": "Invalid label name(s): Banana, Apple."
}
],
"uuid": "303649f4-5e45-4379-bae9-64ec0ef56287"
}
Retrieve live query results (standard WebSocket API)
You can retrieve the results of a live query using the standard WebSocket API.
Before you retrieve the live query results, you must create a live query campaign by running the live query. Use the Run live query or Run live query by name endpoints to create a live query campaign.
Note that live queries are automatically cancelled if this method is not called to start retrieving the results within 60 seconds of initiating the query.
/api/v1/fleet/results/websocket
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | Required. The token used to authenticate with the Fleet API. | |
| campaignID | integer | Required. The ID of the live query campaign. |
Example
Example script to handle request and response
const socket = new WebSocket('wss://<your-base-url>/api/v1/fleet/results/websocket');
socket.onopen = () => {
socket.send(JSON.stringify({ type: 'auth', data: { token: <auth-token> } }));
socket.send(JSON.stringify({ type: 'select_campaign', data: { campaign_id: <campaign-id> } }));
};
socket.onmessage = ({ data }) => {
console.log(data);
const message = JSON.parse(data);
if (message.type === 'status' && message.data.status === 'finished') {
socket.close();
}
}
Detailed request and response walkthrough with example data
webSocket.onopen()
Response data
o
webSocket.send()
Request data
[
{
"type": "auth",
"data": { "token": <insert_token_here> }
}
]
[
{
"type": "select_campaign",
"data": { "campaign_id": 12 }
}
]
webSocket.onmessage()
Response data
// Sends the total number of hosts targeted and segments them by status
[
{
"type": "totals",
"data": {
"count": 24,
"online": 6,
"offline": 18,
"missing_in_action": 0
}
}
]
// Sends the expected results, actual results so far, and the status of the live query
[
{
"type": "status",
"data": {
"expected_results": 6,
"actual_results": 0,
"status": "pending"
}
}
]
// Sends the result for a given host
[
{
"type": "result",
"data": {
"distributed_query_execution_id": 39,
"host": {
"id": 42,
"hostname": "foobar",
"display_name": "foobar"
},
"rows": [
// query results data for the given host
],
"error": null
}
}
]
// Sends the status of "finished" when messages with the results for all expected hosts have been sent
[
{
"type": "status",
"data": {
"expected_results": 6,
"actual_results": 6,
"status": "finished"
}
}
]
Retrieve live query results (SockJS)
You can also retrieve live query results with a SockJS client. The script to handle the request and response messages will look similar to the standard WebSocket API script with slight variations. For example, the constructor used for SockJS is SockJS while the constructor used for the standard WebSocket API is WebSocket.
Note that SockJS has been found to be substantially less reliable than the standard WebSockets approach.
/api/v1/fleet/results/
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | Required. The token used to authenticate with the Fleet API. | |
| campaignID | integer | Required. The ID of the live query campaign. |
Example
Example script to handle request and response
const socket = new SockJS(`<your-base-url>/api/v1/fleet/results`, undefined, {});
socket.onopen = () => {
socket.send(JSON.stringify({ type: 'auth', data: { token: <token> } }));
socket.send(JSON.stringify({ type: 'select_campaign', data: { campaign_id: <campaignID> } }));
};
socket.onmessage = ({ data }) => {
console.log(data);
const message = JSON.parse(data);
if (message.type === 'status' && message.data.status === 'finished') {
socket.close();
}
}
Detailed request and response walkthrough
socket.onopen()
Response data
o
socket.send()
Request data
[
{
"type": "auth",
"data": { "token": <insert_token_here> }
}
]
[
{
"type": "select_campaign",
"data": { "campaign_id": 12 }
}
]
socket.onmessage()
Response data
// Sends the total number of hosts targeted and segments them by status
[
{
"type": "totals",
"data": {
"count": 24,
"online": 6,
"offline": 18,
"missing_in_action": 0
}
}
]
// Sends the expected results, actual results so far, and the status of the live query
[
{
"type": "status",
"data": {
"expected_results": 6,
"actual_results": 0,
"status": "pending"
}
}
]
// Sends the result for a given host
[
{
"type": "result",
"data": {
"distributed_query_execution_id": 39,
"host": {
"id": 42,
"hostname": "foobar",
"display_name": "foobar"
},
"rows": [
// query results data for the given host
],
"error": null
}
}
]
// Sends the status of "finished" when messages with the results for all expected hosts have been sent
[
{
"type": "status",
"data": {
"expected_results": 6,
"actual_results": 6,
"status": "finished"
}
}
]
Trigger cron schedule
This API is used by the fleetctl CLI tool to make requests to trigger an ad hoc run of all jobs in
a specified cron schedule.
Trigger
This makes a request to trigger the specified cron schedule. Upon receiving the request, the Fleet server first checks the current status of the schedule, and it returns an error if a run is currently pending.
POST /api/latest/fleet/trigger
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| name | string | query | The name of the cron schedule to trigger. Supported trigger names are apple_mdm_dep_profile_assigner, automations, cleanups_then_aggregation, integrations, mdm_apple_profile_manager, usage_statistics, and vulnerabilities |
Example
POST /api/latest/fleet/trigger?name=automations
Default response
Status: 200
Device-authenticated routes
Device-authenticated routes are routes used by the Fleet Desktop application. Unlike most other routes, Fleet user's API token does not authenticate them. They use a device-specific token.
- Get device's Google Chrome profiles
- Get device's mobile device management (MDM) and Munki information
- Get Fleet Desktop information
- Get device's software
- Get device's software install results
- Get device's software MDM command results
- Install self-service software
- Uninstall software via self-service
- Get uninstall results via self-service
- Get device's policies
- Get device's certificate
- Get device's API features
- Get device's transparency URL
- Download device's MDM manual enrollment profile
- Migrate device to Fleet from another MDM solution
- Trigger Linux disk encryption escrow
- Report an agent error
Get device's Google Chrome profiles
Same as Get host's Google Chrome profiles for the current device.
GET /api/v1/fleet/device/{token}/device_mapping
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Get device's mobile device management (MDM) and Munki information
Same as Get host's mobile device management and Munki information for the current device.
GET /api/v1/fleet/device/{token}/macadmins
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Ping Server with Device Token
Ping the server. OK response expected if the device token is still valid.
HEAD /api/v1/fleet/device/{token}/ping
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
HEAD /api/v1/fleet/device/abcdef012456789/ping
Default response
Status: 200
Get Fleet Desktop information
Available in Fleet Premium
Gets all information required by Fleet Desktop, this includes things like the number of failed policies or notifications to show/hide menu items.
GET /api/v1/fleet/device/{token}/desktop
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
GET /api/v1/fleet/device/abcdef012456789/desktop
Default response
Status: 200
{
"failing_policies_count": 3,
"self_service": true,
"notifications": {
"needs_mdm_migration": true,
"renew_enrollment_profile": false,
},
"config": {
"org_info": {
"org_name": "Fleet",
"org_logo_url": "https://example.com/logo.jpg",
"org_logo_url_light_background": "https://example.com/logo-light.jpg",
"contact_url": "https://fleetdm.com/company/contact"
},
"mdm": {
"macos_migration": {
"mode": "forced"
}
}
}
}
In regards to the notifications key:
needs_mdm_migrationmeans that the device fits all the requirements to allow the user to initiate an MDM migration to Fleet.renew_enrollment_profilemeans that the device is currently unmanaged from MDM but should be DEP enrolled into Fleet.
Get device's software
Lists the software installed on the current device.
GET /api/v1/fleet/device/{token}/software
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
| self_service | bool | query | Filter self_service software. |
| query | string | query | Search query keywords. Searchable fields include name. |
| page | integer | query | Page number of the results to fetch. |
| per_page | integer | query | Results per page. |
Request headers
This endpoint accepts the X-Client-Cert-Serial header for authentication in addition to device token authentication.
The Authorization header must be formatted as follows:
X-Client-Cert-Serial: <fleet_identity_scep_cert_serial>
Example
GET /api/v1/fleet/device/bbb7cdcc-f1d9-4b39-af9e-daa0f35728e8/software
Default response
Status: 200
{
"count": 3,
"software": [
{
"id": 121,
"name": "Google Chrome.app",
"display_name": "Chrome",
"icon_url": "/api/v1/fleet/device/bbb7cdcc-f1d9-4b39-af9e-daa0f35728e8/software/titles/121/icon",
"software_package": {
"name": "GoogleChrome.pkg",
"version": "125.12.2",
"self_service": true,
"categories": ["Browsers"],
"last_install": {
"install_uuid": "8bbb8ac2-b254-4387-8cba-4d8a0407368b",
"installed_at": "2024-05-15T15:23:57Z"
},
},
"app_store_app": null,
"source": "apps",
"status": "failed",
"installed_versions": [
{
"version": "121.0",
"last_opened_at": "2024-04-01T23:03:07Z",
"vulnerabilities": ["CVE-2023-1234","CVE-2023-4321","CVE-2023-7654"],
"installed_paths": ["/Applications/Google Chrome.app"]
}
],
"software_package": {
"name": "google-chrome-124-0-6367-207.pkg",
"version": "121.0",
"self_service": true,
"icon_url": null,
"last_install": null
},
"app_store_app": null
},
{
"id": 143,
"name": "Firefox.app",
"display_name": "Firefox",
"icon_url": "https://is1-ssl.mzstatic.com/image/thumb/Purple221/v4/d1/2f/ff/d12fff5b-fe7b-a41b-e55a-96606c7193b1/electron.png/512x512bb.png",
"software_package": null,
"app_store_app": null,
"source": "apps",
"status": null,
"installed_versions": [
{
"version": "125.6",
"last_opened_at": "2024-04-01T23:03:07Z",
"vulnerabilities": [],
"installed_paths": ["/Applications/Slack.app"]
}
],
"software_package": null,
"app_store_app": {
"app_store_id": "618783545",
"categories": ["Communication"],
"version": "25.08.10",
"self_service": false,
"last_install": null
},
},
{
"id": 144,
"name": "Prettier",
"software_package": null,
"app_store_app": null,
"source": "vscode_extensions",
"extesnion_for": "cursor",
"status": null,
"installed_versions": [
{
"version": "1.2.6",
"last_opened_at": "2024-04-01T23:03:07Z",
"vulnerabilities": ["CVE-2023-1234","CVE-2023-4321","CVE-2023-7654"],
"installed_paths": ["/Users/admin/.cursor/extensions/prettier"]
}
],
}
],
"meta": {
"has_next_results": false,
"has_previous_results": false
}
}
Download device software icon
Available in Fleet Premium.
Retrieve the icon added via Fleet or icon from App Store (VPP).
GET /api/v1/fleet/device/:token/software/titles/121/icon
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| id | integer | path | ID of the software title to get icon for. |
Request headers
This endpoint accepts the X-Client-Cert-Serial header for authentication in addition to device token authentication.
The Authorization header must be formatted as follows:
X-Client-Cert-Serial: <fleet_identity_scep_cert_serial>
This endpoint will redirect (302) to the Apple-hosted URL of an icon if an icon override isn't set and a VPP app is added for the title on the host's team.
Example
GET /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/titles/121/icon
Default response
Status: 200
Status: 200
Content-Type: image/png
Content-Disposition: inline; filename="zoom-icon-512x512.png"
Content-Length: 124567
<BINARY_IMAGE_DATA>
Get device's software install results
Available in Fleet Premium.
GET /api/v1/fleet/device/{token}/software/install/{install_uuid}/results
Get the results of a Fleet-maintained app or custom package install if it was performed on the authenticated host.
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | Required. The device's authentication token. |
| install_uuid | string | path | Required. The software installation UUID. |
Example
GET /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/install/b15ce221-e22e-4c6a-afe7-5b3400a017da/results
Default response
Status: 200
{
"install_uuid": "b15ce221-e22e-4c6a-afe7-5b3400a017da",
"software_title": "Falcon.app",
"software_title_id": 8353,
"software_package": "FalconSensor-6.44.pkg",
"host_id": 123,
"host_display_name": "Marko's MacBook Pro",
"status": "failed_install",
"output": "Installing software...\nError: The operation can’t be completed because the item “Falcon” is in use.",
"pre_install_query_output": "Query returned result\nSuccess",
"post_install_script_output": "Running script...\nExit code: 1 (Failed)\nRolling back software install...\nSuccess"
}
Get device's software MDM command results
This endpoint returns the results for a specific MDM command associated with a software (un)install.
GET /api/v1/fleet/device/{token}/software/commands/{command_uuid}/results
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | Required. The device's authentication token. |
| command_uuid | string | path | The unique identifier of the command. |
Example
GET /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/commands/a2064cef-0000-1234-afb9-283e3c1d487e/results
Default response
Status: 200
{
"results": [
{
"host_uuid": "145cafeb-87c7-4869-84d5-e4118a927746",
"command_uuid": "a2064cef-0000-1234-afb9-283e3c1d487e",
"status": "Acknowledged",
"updated_at": "2023-04-04:00:00Z",
"request_type": "InstallApplication",
"hostname": "mycomputer",
"payload": "[base64]",
"result": "[base64]"
}
]
}
Note: If the server has not yet received a result for a command, it will return an empty object (
{}).
Install self-service software
Install self-service software on macOS, Windows, or Linux (Ubuntu) host. The software must have a self_service flag true to be installed.
POST /api/v1/fleet/device/{token}/software/install/{software_title_id}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | Required. The device's authentication token. |
| software_title_id | string | path | Required. The software title's ID. |
Request headers
This endpoint accepts the X-Client-Cert-Serial header for authentication in addition to device token authentication.
The Authorization header must be formatted as follows:
X-Client-Cert-Serial: <fleet_identity_scep_cert_serial>
Example
POST /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/install/123
Default response
Status: 202
Uninstall software via self-service
Uninstalls software from a host via the My device page.
POST /api/v1/fleet/device/{token}/software/uninstall/:software_title_id
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | Required. The device's authentication token. |
| software_title_id | integer | path | Required. The software title's ID. |
Request headers
This endpoint accepts the X-Client-Cert-Serial header for authentication in addition to device token authentication.
The Authorization header must be formatted as follows:
X-Client-Cert-Serial: <fleet_identity_scep_cert_serial>
Example
POST /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/uninstall/123
Default response
Status: 202
Get uninstall results via self-service
Gets the result of a uninstall performed on a host, viewed from the My device page.
GET /api/v1/fleet/device/{token}/software/uninstall/{execution_id}/results
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| execution_id | string | path | Required. The execution id of the script. |
Example
GET /api/v1/fleet/device/22aada07-dc73-41f2-8452-c0987543fd29/software/uninstall/22aada07-dc73-41f2-8452-c0987543fd29/results
Default response
Status: 200
{
"script_contents": "echo 'hello'",
"exit_code": 0,
"output": "hello",
"message": "",
"hostname": "Test Host",
"host_timeout": false,
"host_id": 1,
"execution_id": "e797d6c6-3aae-11ee-be56-0242ac120002",
"runtime": 20,
"created_at": "2024-09-11T20:30:24Z"
}
Get device's policies
Available in Fleet Premium
Lists the policies applied to the current device.
GET /api/v1/fleet/device/{token}/policies
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
GET /api/v1/fleet/device/abcdef012456789/policies
Default response
Status: 200
{
"policies": [
{
"id": 1,
"name": "SomeQuery",
"query": "SELECT * FROM foo;",
"description": "this is a query",
"resolution": "fix with these steps...",
"platform": "windows,linux",
"response": "pass"
},
{
"id": 2,
"name": "SomeQuery2",
"query": "SELECT * FROM bar;",
"description": "this is another query",
"resolution": "fix with these other steps...",
"platform": "darwin",
"response": "fail"
},
{
"id": 3,
"name": "SomeQuery3",
"query": "SELECT * FROM baz;",
"description": "",
"resolution": "",
"platform": "",
"response": ""
}
]
}
Get device's certificates
Available for macOS, iOS, and iPadOS hosts only. Requires Fleet's MDM properly enabled and configured.
Lists the certificates installed on the current device.
GET /api/v1/fleet/device/{token}/certificates
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
| page | integer | query | Page number of the results to fetch. |
| per_page | integer | query | Results per page. |
| order_key | string | query | What to order results by. Options include common_name and not_valid_after. Default is common_name. |
| order_direction | string | query | Requires order_key. The direction of the order given the order key. Options include asc and desc. Default is asc. |
Example
GET /api/v1/fleet/device/bbb7cdcc-f1d9-4b39-af9e-daa0f35728e8/certificates
Default response
Status: 200
{
"certificates": [
{
"id": 3,
"not_valid_after": "2021-08-19T02:02:17Z",
"not_valid_before": "2021-08-19T02:02:17Z",
"certificate_authority": true,
"common_name": "FleetDM",
"key_algorithm": "rsaEncryption",
"key_strength": 2048,
"key_usage": "CRL Sign, Key Cert Sign",
"serial": 1,
"signing_algorithm": "sha256WithRSAEncryption",
"subject": {
"country": "US",
"organization": "Fleet Device Management Inc.",
"organizational_unit": "Fleet Device Management Inc.",
"common_name": "FleetDM"
},
"issuer": {
"country": "US",
"organization": "Fleet Device Management Inc.",
"organizational_unit": "Fleet Device Management Inc.",
"common_name": "FleetDM"
},
"source": "user",
"username": "alice"
}
],
"meta": {
"has_next_results": false,
"has_previous_results": false
}
}
Get device's transparency URL
Returns the URL to open when clicking the "About Fleet" menu item in Fleet Desktop. Note that Fleet Premium is required to configure a custom transparency URL.
GET /api/v1/fleet/device/{token}/transparency
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Request headers
This endpoint accepts the X-Client-Cert-Serial header for authentication in addition to device token authentication.
The Authorization header must be formatted as follows:
X-Client-Cert-Serial: <fleet_identity_scep_cert_serial>
Example
GET /api/v1/fleet/device/abcdef012456789/transparency
Default response
Status: 307
Redirects to the transparency URL.
Download device's MDM manual enrollment profile
Returns the URL to open to provide installation instructions and allow a user to download a manual enrollment profile for a device. A user may be required to complete SSO authenticaton if configured on the team before being presented with the download option.
GET /api/v1/fleet/device/{token}/mdm/apple/manual_enrollment_profile
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
GET /api/v1/fleet/device/abcdef012456789/mdm/apple/manual_enrollment_profile
Default response
Status: 200
{
"enroll_url": "https://your-fleet-server-url.com/enroll?enroll_secret=ABCzmPbtEECxZhHlFlz9uTWApZmXsCND"
}
Migrate device to Fleet from another MDM solution
Signals the Fleet server to send a webbook request with the device UUID and serial number to the webhook URL configured for MDM migration. Requires Fleet Premium license
POST /api/v1/fleet/device/{token}/migrate_mdm
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
POST /api/v1/fleet/device/abcdef012456789/migrate_mdm
Default response
Status: 204
Trigger Linux disk encryption escrow
Available in Fleet Premium
Signals the Fleet server to queue up the LUKS disk encryption escrow process (LUKS passphrase and slot key). If validation succeeds (disk encryption must be enforced for the team, the host's platform must be supported, the host's disk must already be encrypted, and the host's Orbit version must be new enough), this adds a notification flag for Orbit that, triggers escrow from the Orbit side.
POST /api/v1/fleet/device/{token}/mdm/linux/trigger_escrow
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
POST /api/v1/fleet/device/abcdef012456789/mdm/linux/trigger_escrow
Default response
Status: 204
Get the setup experience status for the device
Available in Fleet Premium
POST /api/v1/fleet/device/{token}/setup_experience/status
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| token | string | path | The device's authentication token. |
Example
POST /api/v1/fleet/device/7d940b6e-130a-493b-b58a-2b6e9f9f8bfc/setup_experience/status
Default response
Status: 200
{
"setup_experience_results": {
"software": [
{
"name": "1password-latest.tar.gz",
"status": "running",
"software_title_id": 3007
},
{
"name": "slack.deb",
"status": "pending",
"software_title_id": 3008,
"display_name": "My Slack",
"icon_url": "/api/latest/fleet/device/7d940b6e-130a-493b-b58a-2b6e9f9f8bfc/software/titles/3008/icon"
}
]
}
}
Report an agent error
Notifies the server about an agent error, resulting in two outcomes:
- The error gets saved in Redis and can later be accessed using
fleetctl debug archive.
Note: to allow
fleetdagents to use this endpoint, you need to set a custom environment variable.fleetdagents will always report vital errors to Fleet.
POST /api/v1/fleet/device/{token}/debug/errors
Parameters
| Name | Type | Description |
|---|---|---|
| error_source | string | Process name that error originated from ex. orbit, fleet-desktop |
| error_source_version | string | version of error_source |
| error_timestamp | datetime | Time in UTC that error occurred |
| error_message | string | error message |
| error_additional_info | obj | Any additional identifiers to assist debugging |
| vital | boolean | Whether the error is vital and should also be reported to Fleet via usage statistics. Do not put sensitive information into vital errors. |
Default response
Status: 200
Orbit-authenticated routes
- Escrow LUKS data
- Get the status of a device in the setup experience
- Set or update device token
- Get orbit script
- Post orbit script result
- Put orbit device mapping
- Post orbit software install result
- Download software installer
- Get orbit software install details
- Post disk encryption key
Escrow LUKS data
POST /api/fleet/orbit/luks_data
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| client_error | string | body | An error description if the LUKS key escrow process fails client-side. If provided, passphrase/salt/key slot request parameters are ignored and may be omitted. |
| passphrase | string | body | The LUKS passphrase generated for Fleet (the end user's existing passphrase is not transmitted) |
| key_slot | int | body | The LUKS key slot ID corresponding to the provided passphrase |
| salt | string | body | The salt corresponding to the specified LUKS key slot. Provided to track cases where an end user rotates LUKS credentials (at which point we'll no longer be able to decrypt data with the escrowed passphrase). |
Example
POST /api/v1/fleet/orbit/luks_data
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"passphrase": "6e657665-7220676f-6e6e6120-67697665-20796f75-207570",
"salt": "d34db33f",
"key_slot": 1,
"client_error": ""
}
Default response
Status: 204
Get the status of a device in the setup experience
POST /api/fleet/orbit/setup_experience/status
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| force_release | boolean | body | Force a host release from ADE flow, in case the setup is taking too long. |
Example
POST /api/v1/fleet/orbit/setup_experience/status
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"force_release":false
}
Default response
Status: 200
{
"setup_experience_results": {
"script": {
"name": "setup_script.sh",
"status": "success",
"execution_id": "b16fdd31-71cc-4258-ab27-744490809ebd"
},
"software": [
{
"name": "Zoom Workplace",
"status": "success",
"software_title_id": 957
},
{
"name": "Bear: Markdown Notes",
"status": "success",
"software_title_id": 287
},
{
"name": "Evernote",
"status": "success",
"software_title_id": 1313,
"display_name": "My Evernote",
"icon_url": "/api/latest/fleet/software/titles/1313/icon?team_id=0"
}
],
"configuration_profiles": [
{
"profile_uuid": "ae6a9efd5-9166-11ef-83af-0242ac12000b",
"name": "Fleetd configuration",
"status": "verified"
},
{
"profile_uuid": "ae6aa8108-9166-11ef-83af-0242ac12000b",
"name": "Fleet root certificate authority (CA)",
"status": "verified"
}
],
"org_logo_url": ""
}
}
Start the setup experience
POST /api/fleet/orbit/setup_experience/init
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
Example
POST /api/fleet/orbit/setup_experience/init
Request body
{
"orbit_node_key":"TuvSsWf0RwBEecUlNBTLmBcjGFAdzqt/"
}
Default response
Status: 200
Returns enabled set to true if items (e.g. software) for the setup experience were queued for the host.
{
"result": {
"enabled": true
}
}
Set or update device token
POST /api/fleet/orbit/device_token
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| device_auth_token | string | body | The device auth token to set for this host. |
Example
POST /api/v1/fleet/orbit/device_token
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"device_auth_token": "2267a440-4cfb-48af-804b-d52224a05e1b"
}
Default response
Status: 200
Get Orbit config
POST /api/fleet/orbit/config
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
Example
POST /api/fleet/orbit/config
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/"
}
Default response
Status: 200
{
"script_execution_timeout": 3600,
"command_line_startup_flags": {
"--verbose": true
},
"extensions": {
"hello_world_linux": {
"channel": "stable",
"platform": "linux"
}
},
"nudge_config": {
"osVersionRequirements": [
{
"requiredInstallationDate": "2024-12-04T20:00:00Z",
"requiredMinimumOSVersion": "15.1.1",
"aboutUpdateURLs": [
{
"_language": "en",
"aboutUpdateURL": "https://fleetdm.com/learn-more-about/os-updates"
}
]
}
],
"userInterface": {
"simpleMode": true,
"showDeferralCount": false,
"updateElements": [
{
"_language": "en",
"actionButtonText": "Update",
"mainHeader": "Your device requires an update"
}
]
},
"userExperience": {
"initialRefreshCycle": 86400,
"approachingRefreshCycle": 86400,
"imminentRefreshCycle": 7200,
"elapsedRefreshCycle": 3600
}
},
"notifications": {
"renew_enrollment_profile": true,
"rotate_disk_encryption_key": true,
"needs_mdm_migration": true,
"needs_programmatic_windows_mdm_enrollment": true,
"windows_mdm_discovery_endpoint": "/some/path/here",
"needs_programmatic_windows_mdm_unenrollment": true,
"pending_script_execution_ids": [
"a129a440-4cfb-48af-804b-d52224a05e1b"
],
"enforce_bitlocker_encryption": true,
"pending_software_installer_ids": [
"2267a440-4cfb-48af-804b-d52224a05e1b"
],
"run_setup_experience": true,
"run_disk_encryption_escrow": true
},
"update_channels": {
"orbit": "stable",
"osqueryd": "stable",
"desktop": "stable"
}
}
Get script execution result by execution ID
POST /api/fleet/orbit/scripts/request
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| execution_id | string | body | The UUID of the script execution. |
Example
POST /api/fleet/orbit/scripts/request
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"execution_id": "006112E7-7383-4F21-999C-8FA74BB3F573"
}
Default response
Status: 200
{
"host_id": 12,
"execution_id": "006112E7-7383-4F21-999C-8FA74BB3F573",
"script_contents": "echo hello",
"output": "hello",
"runtime": 1,
"exit_code": 0,
"timeout": 30,
"script_id": 42,
"policy_id": 10,
"team_id": 1,
"message": ""
}
Upload Orbit script result
POST /api/fleet/orbit/scripts/result
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| host_id | number | body | The ID of the host on which the script ran. |
| execution_id | string | body | The UUID of the script execution. |
| output | string | body | The output of the script. |
| runtime | string | number | The amount of time the script ran for (in seconds). |
| exit_code | string | number | The exit code of the script. |
| timeout | string | number | The maximum amount of time this script was allowed to run (in seconds). |
Example
POST /api/fleet/orbit/scripts/result
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"host_id": 12,
"execution_id": "006112E7-7383-4F21-999C-8FA74BB3F573",
"output": "hello",
"runtime": 1,
"exit_code": 0,
"timeout": 30
}
Default response
Status: 200
Set Orbit device mapping
PUT /api/fleet/orbit/device_mapping
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| string | body | The email to use for the device mapping. |
Example
PUT /api/fleet/orbit/device_mapping
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"email": "test@example.com"
}
Default response
Status: 200
Upload Orbit software install result
POST /api/fleet/orbit/software_install/result
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| host_id | number | body | The ID of the host on which the software was installed. |
| install_uuid | string | body | The UUID of the installation attempt. |
| pre_install_condition_output | string | body | The output from the pre-install condition query. |
| install_script_exit_code | number | body | The exit code from the install script. |
| install_script_output | string | body | The output from the install script. |
| post_install_script_exit_code | number | body | The exit code from the post-install script. |
| post_install_script_output | string | body | The output from the post-install script. |
| retries_remaining | number | body | The number of retries remaining for this installation. When > 0, the server treats this as an intermediate failure. |
Example
POST /api/fleet/orbit/software_install/result
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"host_id ": 12,
"install_uuid ": "4D91F9C3-919B-4D5B-ABFC-528D648F27D1",
"pre_install_condition_output ": "example",
"install_script_exit_code ": 0,
"install_script_output ": "software installed",
"post_install_script_exit_code ": 1,
"post_install_script_output ": "error: post-install script failed",
"retries_remaining": 0
}
Default response
Status: 204
Download software installer
POST /api/fleet/orbit/software_install/package
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| installer_id | number | body | The ID of the software installer to download. |
| alt | string | query | Indicates whether to download the package. Must be set to "media". |
Example
POST /api/fleet/orbit/software_install/package
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"installer_id": 15
}
Default response
Status: 200
Status: 200
Content-Type: application/octet-stream
Content-Disposition: attachment
Content-Length: <length>
Body: <blob>
Get orbit software install details
POST /api/fleet/orbit/software_install/details
Note: The
installer_urlin the response will only be populated if AWS S3 and CloudFront URL signing are configured.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| install_uuid | string | body | The UUID of the software installation attempt. |
Example
POST /api/fleet/orbit/software_install/details
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"install_uuid": "1652210E-619E-43BA-B3CC-17F4247823F3"
}
Default response
Status: 200
{
"install_id": "1652210E-619E-43BA-B3CC-17F4247823F3",
"installer_id": 12,
"pre_install_condition": "SELECT * FROM osquery_info;",
"install_script": "sudo run-installer",
"uninstall_script": "sudo run-uninstaller",
"post_install_script": "echo done",
"self_service": true,
"max_retries": 2,
"installer_url": {
"url": "https://d1nsa5964r3p4i.cloudfront.net/software-installers/98330e7e6db3507b444d576dc437a9ac4d82333a88a6bb6ef36a91fe3d85fa92?Expires=1736178766&Signature=HpcpyniNSBkS695mZhkZRjXo6UQ5JtXQ2sk0poLEMDMeF063IjsBj2O56rruzk3lomYFjqoxc3BdnFqEjrEXQSieSALiCufZ2LjTfWffs7f7qnNVZwlkg-upZd5KBfrCHSIyzMYSPhgWFPOpNRVqOc4NFXx8fxRLagK7NBKFAEfCAwo0~KMCSJiof0zWOdY0a8p0NNAbBn0uLqK7vZLwSttVpoK6ytWRaJlnemofWNvLaa~Et3p5wJJRfYGv73AK-pe4FMb8dc9vqGNSZaDAqw2SOdXrLhrpvSMjNmMO3OvTcGS9hVHMtJvBmgqvCMAWmHBK6v5C9BobSh4TCNLIuA__&Key-Pair-Id=K1HFGXOMBB6TFF",
"filename": "my-installer.pkg"
}
}
Upload disk encryption key
POST /api/fleet/orbit/disk_encryption_key
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| orbit_node_key | string | body | The Orbit node key for authentication. |
| encryption_key | string | body | The encryption key bytes. |
| client_error | string | body | The error reported by the client, if any. |
Example
POST /api/fleet/orbit/disk_encryption_key
Request body
{
"orbit_node_key":"FbvSsWfTRwXEecUlCBTLmBcjGFAdzqd/",
"encryption_key": "Zm9vYmFyem9vYmFyZG9vYmFybG9vYmFy",
"client_error": "example error",
}
Default response
Status: 204
Setup
Sets up a new Fleet instance with the given parameters.
POST /api/v1/setup
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| admin | object | body | Required. Contains the following admin user details: admin, email, name, password, and password_confirmation. |
| org_info | object | body | Required. Contains the following organizational details: org_name. |
| server_url | string | body | Required. The URL of the Fleet instance. |
Request body
{
"admin": {
"admin": true,
"email": "janedoe@example.com",
"name": "Jane Doe",
"password": "password!234",
"password_confirmation": "password!234"
},
"org_info": {
"org_name": "Fleet Device Management"
},
"server_url": "https://localhost:8080"
}
Default response
Status: 200
If the Fleet instance is provided required parameters to complete setup.
{
"admin": {
"created_at": "2021-01-07T19:40:04Z",
"updated_at": "2021-01-07T19:40:04Z",
"id": 1,
"name": "Jane Doe",
"email": "janedoe@example.com",
"force_password_reset": false,
"gravatar_url": "",
"sso_enabled": false,
"global_role": "admin",
"api_only": false,
"teams": []
},
"org_info": {
"org_name": "Fleet Device Management",
"org_logo_url": "https://fleetdm.com/logo.png"
},
"server_url": "https://localhost:8080",
"osquery_enroll_secret": null,
"token": "ur4RWGBeiNmNzer/dnGzgUQ+jxrJe19xuHg/LhLkbhuZMQu35scyBHUHs68+RJxZynxQnuTz4WTHXayAJJaGgg=="
}
Scripts
Batch-apply scripts
Available in Fleet Premium
POST /api/v1/fleet/scripts/batch
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_id | number | query | The ID of the team to add the scripts to. Only one team identifier (team_id or team_name) can be included in the request, omit this parameter if using team_name. |
| team_name | string | query | The name of the team to add the scripts to. Only one team identifier (team_id or team_name) can be included in the request, omit this parameter if using team_id. |
| dry_run | bool | query | Validate the provided scripts and return any validation errors, but do not apply the changes. |
| scripts | array | body | An array of objects with the scripts payloads. Each item must contain name with the script name and script_contents with the script contents encoded in base64 |
If both team_id and team_name parameters are included, this endpoint will respond with an error.
If no team_name or team_id is provided, the scripts will be applied for all hosts.
Script contents are uploaded verbatim, without CRLF -> LF conversion.
Note that this endpoint replaces all the active scripts for the specified team (or no team). Any existing script that is not included in the list will be removed, and existing scripts with the same name as a new script will be edited. Providing an empty list of scripts will remove existing scripts.
Example
POST /api/v1/fleet/scripts/batch
Default response
Status: 200
{
"scripts": [
{
"team_id": 3,
"id": 6690,
"name": "Ensure shields are up"
},
{
"team_id": 3,
"id": 10412,
"name": "Ensure flux capacitor is charged"
}
]
}
Run live script
Run a live script and get results back (5 minute timeout). Live scripts only runs on the host if it has no other scripts running.
POST /api/v1/fleet/scripts/run/sync
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| host_id | integer | body | Required. The ID of the host to run the script on. |
| script_id | integer | body | The ID of the existing saved script to run. Only one of either script_id, script_contents, or script_name can be included. |
| script_contents | string | body | The contents of the script to run. Only one of either script_id, script_contents, or script_name can be included. |
| script_name | integer | body | The name of the existing saved script to run. If specified, requires team_id. Only one of either script_id, script_contents, or script_name can be included. |
| team_id | integer | body | The ID of the existing saved script to run. If specified, requires script_name. Only one of either script_id, script_contents, or script_name can be included in the request. |
Note that if any combination of
script_id,script_contents, andscript_nameare included in the request, this endpoint will respond with an error.
Example
POST /api/v1/fleet/scripts/run/sync
Default response
Status: 200
{
"host_id": 1227,
"execution_id": "e797d6c6-3aae-11ee-be56-0242ac120002",
"script_contents": "echo 'hello'",
"output": "hello",
"message": "",
"runtime": 1,
"host_timeout": false,
"exit_code": 0
}
Software
Confirm installer hashes exist
GET /api/v1/fleet/software/package_hashes
| Name | Type | In | Description |
|---|---|---|---|
| team_name | string | query | The name of the team to filter the check to. If not supplied, the user must have global access, and hashes are checked across the entire instance. |
| sha256 | string | query | Required. A comma-separated list of SHA256 hashes, (64 hex characters apiece) to check. Endpoint returns 200 if all specified hashes exist, 404 otherwise. |
Example
GET /api/v1/fleet/software/package_hashes?sha256=0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef
Default response
200 OK
Update software title name
PATCH /api/v1/fleet/software/titles/:software_title_id/name
Only available for software titles that have a non-empty bundle ID, as titles without a bundle ID will be added back as new rows on the next software ingest with the same name. Endpoint authorization limited to global admins as this changes the software title's name across all teams.
Experimental endpoint. This endpoint is not guaranteed to continue to exist on future minor releases of Fleet.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| software_title_id | integer | path | Required. The ID of the software title to modify. |
| name | string | body | Required. The new name of the title. |
Example
PATCH /api/v1/fleet/software/titles/1/name
{
"name": "2 Chrome 2 Furious.app"
}
Default response
Status: 205
Batch-apply software
Available in Fleet Premium.
POST /api/v1/fleet/software/batch
This endpoint is asynchronous, meaning it will start a background process to download and apply the software and return a request_uuid in the JSON response that can be used to query the status of the batch-apply (using the GET /api/v1/fleet/software/batch/:request_uuid endpoint defined below).
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_name | string | query | The name of the team to add the software package to. Omitting these parameters will add software to 'No Team'. |
| dry_run | bool | query | If true, will validate the provided software packages and return any validation errors, but will not apply the changes. |
| software | object | body | The team's software that will be available for install. |
| software.packages | array | body | An array of objects with values below. |
| software.packages.slug | string | body | The slug for a Fleet-maintained app |
| software.packages.hash_sha256 | string | body | SHA256 hash of the package. If provided, must be 64 lower-case hex characters. One or both of sha256 or url must be provided. |
| software.packages.url | string | body | URL to the software package (PKG, MSI, EXE or DEB). If sha256 is also provided and the installer isn't already uploaded with the same hash for that URL, call will fail if the downloaded installer doesn't match the hash. |
| software.packages.categories | string[] | body | An array of categories, as they are displayed in the UI, to assign to the package. |
| software.packages.install_script | string | body | Command that Fleet runs to install software. |
| software.packages.pre_install_query | string | body | Condition query that determines if the install will proceed. |
| software.packages.post_install_script | string | body | Script that runs after software install. |
| software.packages.uninstall_script | string | body | Command that Fleet runs to uninstall software. |
| software.packages.self_service | boolean | body | Specifies whether end users can install self-service. |
| software.packages.install_during_setup | boolean | body | Specifies whether the package is included in Setup experience. |
| software.packages.labels_include_any | array | body | Target hosts that have any label in the array. Only one of labels_include_any or labels_exclude_any can be included. If neither are included, all hosts are targeted. |
| software.packages.labels_exclude_any | array | body | Target hosts that don't have any labels in the array. Only one of labels_include_any or labels_exclude_any can be included. If neither are included, all hosts are targeted. |
hash_sha256 can be provided alongside or as a replacement for url. If provided alongside url, adding software only succeeds if the software downloaded matches the specified hash. If provided without a URL, software with that hash must exist (either on that team or globally, depending on what level of access the API client is authorized at) prior to the GitOps run, whether from a previous GitOps run or an upload at the Add package endpoint, at which point Fleet will ensure the software package exists on the selected team with the specified configuration without needing to retrieve it again.
Example
POST /api/v1/fleet/software/batch
Default response
Status: 202
{
"request_uuid": "ec23c7b6-c336-4109-b89d-6afd859659b4",
}
Get status of software batch-apply request
Available in Fleet Premium.
GET /api/v1/fleet/software/batch/:request_uuid
This endpoint allows querying the status of a batch-apply software request (POST /api/v1/fleet/software/batch).
Returns "status" field that can be one of "processing", "complete" or "failed".
If "status" is "completed" then the "packages" field contains the applied packages.
If "status" is "processing" then the operation is ongoing and the request should be retried.
If "status" is "failed" then the "message" field contains the error message.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| request_uuid | string | query | The request_uuid returned by the POST /api/v1/fleet/software/batch endpoint. |
| team_name | string | query | The name of the team to add the software package to. Omitting these parameters will add software to 'No Team'. |
| dry_run | bool | query | If true, will validate the provided software packages and return any validation errors, but will not apply the changes. |
Default responses
Status: 200
{
"status": "processing",
"message": "",
"packages": null
}
Status: 200
{
"status": "completed",
"message": "",
"packages": [
{
"team_id": 1,
"title_id": 2751,
"url": "https://ftp.mozilla.org/pub/firefox/releases/129.0.2/win64/en-US/Firefox%20Setup%20129.0.2.msi",
"hash_sha256": "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"icon_hash_sha256": "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"icon_filename": "firefox-custom-icon.png"
},
{
"team_id": 1,
"title_id": 3496,
"url": "https://work-desktop-assets.8x8.com/prod-publish/ga/work-arm64-dmg-v8.29.1-3.dmg",
"hash_sha256": "c6aa78d0911a0cb504a21bcf8421de703cc7dd07b7388903cf29227ca5955737",
"fleet_maintained_app_id": 150,
"fleet_maintained_app_slug": "8x8-work/darwin",
"icon_hash_sha256": "dad98c7c1b9a5654a45972f2cd7e5c3e536fe5312b0e615291ceb35234eaaa7f",
"icon_filename": "custom-icon.png"
}
]
}
Status: 200
{
"status": "failed",
"message": "validation failed: software.url Couldn't edit software. URL (\"https://foobar.does.not.exist.com\") returned \"Not Found\". Please make sure that URLs are reachable from your Fleet server.",
"packages": null
}
Batch-apply App Store apps
Available in Fleet Premium.
POST /api/latest/fleet/software/app_store_apps/batch
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| team_name | string | query | The name of the team to add the software package to. Omitting this parameter will add software to "No team". |
| dry_run | bool | query | If true, will validate the provided VPP apps and return any validation errors, but will not apply the changes. |
| app_store_apps | list | body | An array of objects. Each object contains app_store_id and self_service. |
| app_store_apps | list | body | An array of objects with . Each object contains app_store_id and self_service. |
| app_store_apps.categories | string[] | body | An array of categories, as they are displayed in the UI, to assign to the app. |
| app_store_apps.app_store_id | string | body | ID of the App Store app. |
| app_store_apps.self_service | boolean | body | Whether the VPP app is available for install via the My device UI on macOS hosts. |
| app_store_apps.install_during_setup | boolean | body | Specifies whether the VPP app is included in Setup experience. |
| app_store_apps.labels_include_any | array | body | App will only be available for install on hosts that have any of these labels. Only one of either labels_include_any or labels_exclude_any can be included in the request. |
| app_store_apps.labels_exclude_any | array | body | App will only be available for install on hosts that don't have any of these labels. Only one of either labels_include_any or labels_exclude_any can be included in the request. |
| app_store_apps.auto_update_enabled | boolean | body | Optional. Whether automatic updates are enabled for this iOS/iPadOS VPP app. |
| app_store_apps.auto_update_window_start | string | body | Optional. The start time (in HH:MM format, local time) of the window during which automatic updates can occur. Required if auto_update_enabled is true. |
| app_store_apps.auto_update_window_end | string | body | Optional. The end time (in HH:MM format, local time) of the window during which automatic updates can occur. Required if auto_update_enabled is true. |
Example
POST /api/latest/fleet/software/app_store_apps/batch
{
"team_name": "Foobar",
"app_store_apps": [
{
"app_store_id": "597799333",
"categories": ["Browsers"],
"self_service": false,
"install_during_setup": false,
"labels_include_any": [
"Engineering",
"Customer Support"
]
},
{
"app_store_id": "497799835",
"self_service": true,
"auto_update_enabled": true,
"auto_update_window_start": "01:00",
"auto_update_window_end": "05:00"
}
]
}
Default response
Status: 200
{
"app_store_apps": [
{
"team_id": 1,
"title_id": 123,
"app_store_id": "597799333",
"platform": "darwin",
"icon_hash_sha256": "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"icon_filename": "browser-custom-icon.png"
},
{
"team_id": 1,
"title_id": 124,
"app_store_id": "597799333",
"platform": "ios",
"icon_hash_sha256": "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"icon_filename": "browser-custom-icon.png"
},
{
"team_id": 1,
"title_id": 125,
"app_store_id": "597799333",
"platform": "ipados",
"icon_hash_sha256": "0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"icon_filename": "browser-custom-icon.png"
}
]
}
Get token to download package
Available in Fleet Premium.
POST /api/v1/fleet/software/titles/:software_title_id/package/token?alt=media
The returned token is a one-time use token that expires after 10 minutes.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| software_title_id | integer | path | Required. The ID of the software title for software package. |
| team_id | integer | query | Required. The team ID containing the software package. |
| alt | integer | query | Required. Must be specified and set to "media". |
Example
POST /api/v1/fleet/software/titles/123/package/token?alt=media&team_id=2
Default response
Status: 200
{
"token": "e905e33e-07fe-4f82-889c-4848ed7eecb7"
}
Download package using a token
Available in Fleet Premium.
GET /api/v1/fleet/software/titles/:software_title_id/package/token/:token?alt=media
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| software_title_id | integer | path | Required. The ID of the software title to download software package. |
| token | string | path | Required. The token to download the software package. |
Example
GET /api/v1/fleet/software/titles/123/package/token/e905e33e-07fe-4f82-889c-4848ed7eecb7
Default response
Status: 200
Status: 200
Content-Type: application/octet-stream
Content-Disposition: attachment
Content-Length: <length>
Body: <blob>
Certificates
Apply certificate templates
Available in Fleet Premium
POST /api/latest/fleet/spec/certificates
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| specs | array | body | Required. An array of objects with the certificate templates. Each item must contain name with the certificate template name, a team with a team name, certificate_authority_id with the certificate authority id, and subject_name with the certificate's subject name. |
Any existing certificate template that is not included in the list will be removed, and existing templates with the same name as the new template will be edited. Providing an empty list of certificate templates will remove existing scripts.
Example
POST /api/latest/fleet/spec/certificates
Request body
{
"specs": [
{
"name": "WIFI_CERTIFICATE",
"team": "workstations",
"certificate_authority_id": 1,
"subject_name": "/CN=$FLEET_VAR_HOST_END_USER_IDP_USERNAME/OU=$FLEET_VAR_HOST_UUID/ST=$FLEET_VAR_HOST_HARDWARE_SERIAL"
},
{
"name": "WIFI_CERTIFICATE_TEST",
"team": "workstations-canary",
"certificate_authority_id": 1,
"subject_name": "/CN=$FLEET_VAR_HOST_END_USER_IDP_USERNAME/OU=$FLEET_VAR_HOST_UUID/ST=$FLEET_VAR_HOST_HARDWARE_SERIAL"
}
]
}
Default response
Status: 200
Delete certificate templates
DELETE /api/latest/fleet/spec/certificates
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| ids | array | body | Required. An array of certificate template ids to be deleted |
| team_id | integer | body | Required. The team_id which the certificate templates you want to delete belong to |
Example
DELETE /api/latest/fleet/spec/certificates
{
"ids": [1, 2, 3, 4],
"team_id": 1
}
Default response
Status: 200
Users
Update user-specific UI settings
PATCH /api/v1/fleet/users/:id
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| settings | object | body | The updated user settings. |
Example
PATCH /api/v1/fleet/users/1
{
"hidden_host_columns": ["hostname"]
}
Default response
- Note that user settings are not included in this response. See below
GETs for how to get user settings.Status: 200
{
"user": {
"created_at": "2025-01-08T01:04:23Z",
"updated_at": "2025-01-09T00:08:19Z",
"id": 1,
"name": "Sum Bahdee",
"email": "sum@org.com",
"force_password_reset": false,
"gravatar_url": "",
"sso_enabled": false,
"mfa_enabled": false,
"global_role": "admin",
"api_only": false,
"teams": []
}
}
Include settings when getting a user
GET /api/v1/fleet/users/:id?include_ui_settings=true
Use of include_ui_settings=true is considered the contributor API functionality – without that
param, this endpoint is considered a documented REST API endpoint
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| include_ui_settings | bool | query | If true, will include the user's settings in the response. For now, this is a single ui setting. |
Example
GET /api/v1/fleet/users/2/?include_ui_settings=true
Default response
Status: 200
{
"user": {...},
"available_teams": {...}
"settings": {"hidden_host_columns": ["hostname"]},
}
Include settings when getting current user
GET /api/v1/fleet/me/?include_ui_settings=true
Use of include_ui_settings=true is considered the contributor API functionality – without that
param, this endpoint is considered a documented REST API endpoint
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| include_ui_settings | bool | query | If true, will include the user's settings in the response. For now, this is a single ui setting. |
Example
GET /api/v1/fleet/me?include_ui_settings=true
Default response
Status: 200
{
"user": {...},
"available_teams": {...}
"settings": {"hidden_host_columns": ["hostname"]},
}
Conditional access
Initiate Microsoft Entra conditional access
Kick off authentication with Microsoft Entra to configure conditional access.
POST /api/v1/conditional-access/microsoft
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| microsoft_tenant_id | string | body | Required. The Microsoft Entra tenant ID. |
Request body
{
"fleet_license_key": "<LICENSE KEY>",
"microsoft_tenant_id": "<TENANT ID>"
}
Default response
Status: 200
{
"microsoft_authentication_url": "https://login.microsoftonline.com/<TENANT ID>/adminconsent?client_id=<CLIENT ID>"
}
Confirm Microsoft Entra conditional access configuration
POST /api/v1/conditional-access/confirm
Confirm whether admin consent has been granted in Microsoft Entra.
Parameters
None.
Default response
Status: 200
{
"configuration_completed": false
}
Get Okta conditional access SAML IdP metadata
Note: This endpoint is unauthenticated and used by Okta to discover Fleet's SAML IdP configuration.
Returns SAML IdP metadata XML for Okta conditional access. This metadata is consumed by Okta to configure Fleet as a SAML identity provider.
GET /api/fleet/conditional_access/idp/metadata
Parameters
None.
Example
GET /api/fleet/conditional_access/idp/metadata
Default response
Status: 200
Returns SAML IdP metadata XML with Content-Type: application/xml.
Okta conditional access SAML SSO
Note: This endpoint requires mTLS authentication at the load balancer level. The regular Fleet load balancer should redirect requests to this endpoint to an mTLS-enabled load balancer that validates client certificates.
Handles SAML authentication requests from Okta for conditional access. This endpoint validates the device's client certificate (via the X-Client-Cert-Serial header set by the mTLS load balancer), checks device health policies, and returns a SAML response.
POST /api/fleet/conditional_access/idp/sso
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| X-Client-Cert-Serial | string | header | Required. The serial number of the client certificate (hex format). |
| SAMLRequest | string | body | The SAML authentication request from Okta (URL-encoded). |
Example
POST /api/fleet/conditional_access/idp/sso
Request header
X-Client-Cert-Serial: 1A
Default response
Status: 200
Returns a SAML response (HTML form auto-submit) or redirects to an error page if authentication fails.
Okta conditional access SCEP enrollment
Note: This endpoint implements the SCEP protocol for automatic certificate enrollment. SCEP certificate requests are authenticated using a challenge password, which is a global enroll secret.
Handles Simple Certificate Enrollment Protocol (SCEP) requests for Okta conditional access. Devices use this endpoint to automatically enroll and obtain client certificates.
GET /api/fleet/conditional_access/scep?operation={operation}
POST /api/fleet/conditional_access/scep?operation={operation}
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| operation | string | query | Required. The SCEP operation: GetCACaps, GetCACert, or PKIOperation. |
Example
Get CA capabilities:
GET /api/fleet/conditional_access/scep?operation=GetCACaps
Get CA certificate:
GET /api/fleet/conditional_access/scep?operation=GetCACert
Submit certificate signing request:
POST /api/fleet/conditional_access/scep?operation=PKIOperation
Default response
Status: 200
Response format varies by operation according to the SCEP protocol specification.
Android fleetdm.com proxy
The following endpoints are exposed on fleetdm.com to proxy Google Android Management API.
Create Android signup URL
POST https://fleetdm.com/api/android/v1/signupUrls
This endpoint is a proxy for the Google Android Management API to create a signup URL for Android Enterprise. The Origin header with the Fleet server URL is required.
See the Google documentation for signupUrls.create for more details.
Parameters
Refer to the Google Android Management API documentation for the request parameters.
Example
POST https://fleetdm.com/api/android/v1/signupUrls?alt=json&callbackUrl=https%3A%2F%2Fexample.com%2Fapi%2Fv1%2Ffleet%2Fandroid_enterprise%2Fconnect%2FLBe-7b1loXPyj-FAIa7dWQEAML4_oaW9d1glwMkaY_Q%3D&prettyPrint=false
Default response
Status: 200
{
"url": "https://enterprise.google.com/signup/android/email?origin=android&thirdPartyToken=B194BDC81C6B0DCDB",
"name": "signupUrls/C42b24423ab5589b"
}
Create Android enterprise
POST https://fleetdm.com/api/android/v1/enterprises
This endpoint is a proxy for the Google Android Management API to create an Android enterprise. In addition, it creates the PubSub topic and subscription for the enterprise.
The Origin header with the Fleet server URL is required.
See the Google documentation for enterprises.create for more details.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| enterpriseToken | string | body | Required. The enterprise token from signup. |
| signupUrlName | string | body | Required. The signup URL. |
| pubsubPushUrl | string | body | Required. The URL that will receive pubsub push notifications from Google. |
| fleetLicenseKey | string | body | The Fleet license key. |
| enterprise | json | body | Required. The enterprise to create. |
Unlike other proxy endpoints, this endpoint requires additional parameters in the body. Refer to the Google Android Management API documentation for the enterprise-specific parameters.
Example
POST https://fleetdm.com/api/android/v1/enterprises
{
"fleetLicenseKey": "",
"pubsubPushUrl": "https://example.com/api/v1/fleet/android_enterprise/pubsub?token=NjoLUtP7WWP6-UUr-7wlO1AaHbOpvPlodyaItT5SdDVy9vwF2DvwgOao8UcqHAlpefYeZ7MutERDAuBN0Hpr1w==",
"enterpriseToken": "EAEFb-jU8o9IssnEGGaXb1krM_qjWdYI1rieiWreqNd7nxaSM0R-YimMOriTFI5yJm2qk2sixijmdkCyDz6A6XdQxNHLdYraNk5dvzPb9H4o3bQEtRontGeI",
"signupUrlName": "signupUrls/Cd777504276d345a8",
"Enterprise": {
"enabledNotificationTypes": [
"ENROLLMENT",
"STATUS_REPORT",
"COMMAND",
"USAGE_LOGS"
]
}
}
Default response
Status: 200
{
"name": "enterprises/LC0487pz4e",
"fleetServerSecret": "9b37a4e5efa314b76199987994ba02"
}
Create Android enrollment token
POST https://fleetdm.com/api/android/v1/enterprises/:androidEnterpriseId/enrollmentTokens
This endpoint is a proxy for the Google Android Management API to create enrollment tokens for Android devices. Requires Authorization header with Bearer token.
See the Google documentation for enterprises.enrollmentTokens.create for more details.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| androidEnterpriseId | string | path | Required. The ID of the Android enterprise. |
Additional parameters should be provided in the request body as per the Google Android Management API documentation.
Example
POST https://fleetdm.com/api/android/v1/enterprises/LC01234567/enrollmentTokens
Default response
Status: 200
{
"name": "enterprises/LC0487pz4e/enrollmentTokens/eqkHZKfK3Vk3vrXKGWPmBaM1UseRDVRO2g0dMuz8noc",
"value": "KMQBSJSRUFHIQTAELHXP",
"expirationTimestamp": "2025-06-09T17:47:12.430901Z",
"additionalData": "ZnISqWWWZLcn2mjYHfOzbsz1YjYglf17",
"policyName": "enterprises/LC0487pz4e/policies/1",
"qrCode": "{\"android.app.extra.PROVISIONING_DEVICE_ADMIN_COMPONENT_NAME\":\"com.google.android.apps.work.clouddpc/.receivers.CloudDeviceAdminReceiver\",\"android.app.extra.PROVISIONING_DEVICE_ADMIN_SIGNATURE_CHECKSUM\":\"I5YvS0O5hXY46mb01BlRjq4oJJGs2kuUcHvVkAPEXlg\",\"android.app.extra.PROVISIONING_DEVICE_ADMIN_PACKAGE_DOWNLOAD_LOCATION\":\"https://play.google.com/managed/downloadManagingApp?identifier=setup\",\"android.app.extra.PROVISIONING_ADMIN_EXTRAS_BUNDLE\":{\"com.google.android.apps.work.clouddpc.EXTRA_ENROLLMENT_TOKEN\":\"KMQBSJSRUFHIQTAELHXP\"}}",
"oneTimeOnly": true,
"allowPersonalUsage": "PERSONAL_USAGE_ALLOWED"
}
Modify Android policies
PATCH https://fleetdm.com/api/android/v1/enterprises/:androidEnterpriseId/policies/:policyId
This endpoint is a proxy for the Google Android Management API to modify Android device policies. Requires Authorization header with Bearer token.
See the Google documentation for enterprises.policies.patch for more details.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| androidEnterpriseId | string | path | Required. The ID of the Android enterprise. |
| policyId | string | path | Required. The ID of the policy to create/modify. |
Additional parameters should be provided in the request body as per the Google Android Management API documentation.
Example
PATCH https://fleetdm.com/api/android/v1/enterprises/LC01234567/policies/policy1
{
"statusReportingSettings": {
"commonCriteriaModeEnabled": true,
"deviceSettingsEnabled": true,
"displayInfoEnabled": true,
"hardwareStatusEnabled": true,
"memoryInfoEnabled": true,
"networkInfoEnabled": true,
"powerManagementEventsEnabled": true,
"softwareInfoEnabled": true,
"systemPropertiesEnabled": true
}
}
Default response
Status: 200
{
"name": "enterprises/LC012iajk0/policies/1",
"version": "1"
}
Delete Android enterprise
DELETE https://fleetdm.com/api/android/v1/enterprises/:androidEnterpriseId
This endpoint is a proxy for the Google Android Management API to delete an Android enterprise. Requires Authorization header with Bearer token.
See the Google documentation for enterprises.delete for more details.
Parameters
| Name | Type | In | Description |
|---|---|---|---|
| androidEnterpriseId | string | path | Required. The ID of the Android enterprise to delete. |
Example
DELETE https://fleetdm.com/api/android/v1/enterprises/LC01234567
Default response
Status: 200
{}
Host identity
SCEP
/api/fleet/orbit/host_identity/scep
This endpoint is used to retrieve a host identity certificate. It uses the SCEP protocol.
Supported certificate algorithms are:
- ECC NIST P-384
- ECC NIST P-256
The common name (CN) of the certificate must be either the hardware UUID or osquery identity. Only one valid certificate can exist matching the host identifier.
The SCEP challenge password must be the enrollment secret.