Open device management
Find a file
Jordan Montgomery 227e94de5b
Some checks are pending
Build binaries / build-binaries (push) Waiting to run
Check automated documentation is up-to-date / check-doc-gen (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Deploy Fleet website / build (20.x) (push) Waiting to run
Apply latest configuration to dogfood with GitOps / fleet-gitops (push) Waiting to run
Test latest changes in fleetctl preview / test-preview (ubuntu-latest) (push) Waiting to run
golangci-lint / lint (push) Waiting to run
golangci-lint / lint-incremental (push) Waiting to run
Docker publish / publish (push) Waiting to run
Ingest maintained apps / build (push) Waiting to run
OSSF Scorecard / Validate Gradle wrapper (push) Waiting to run
OSSF Scorecard / Scorecard analysis (push) Waiting to run
Sync Maintained Apps Outputs to R2 / sync-to-r2 (push) Waiting to run
Test DB Changes / test-db-changes (push) Waiting to run
Run fleetd-chrome tests / test-fleetd-chrome (ubuntu-latest) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, integration-mdm) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, main) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, mysql) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, service) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, vuln) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, fleetctl) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, integration-core) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, integration-enterprise) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, integration-mdm) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, main) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, mysql) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, service) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.4.8, vuln) (push) Waiting to run
Go Tests / test-go-nanomdm (push) Waiting to run
Go Tests / test-go-no-db (fast) (push) Waiting to run
Go Tests / test-go-no-db (scripts) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, fleetctl) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, fleetctl) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, integration-core) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, integration-enterprise) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, integration-mdm) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, integration-core) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, main) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, mysql) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, service) (push) Waiting to run
Go Tests / test-go (mysql:8.0.44, vuln) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, fleetctl) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, integration-core) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, integration-enterprise) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, integration-mdm) (push) Waiting to run
Go Tests / test-go-extended-mysql (mysql:8.0.42, integration-enterprise) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, main) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, mysql) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, service) (push) Waiting to run
Go Tests / test-go (mysql:9.5.0, vuln) (push) Waiting to run
Go Tests / upload-coverage (push) Blocked by required conditions
Go Tests / aggregate-result (push) Blocked by required conditions
JavaScript Tests / test-js (ubuntu-latest) (push) Waiting to run
JavaScript Tests / lint-js (ubuntu-latest) (push) Waiting to run
Test Mock Changes / test-mock-changes (push) Waiting to run
Test native tooling packaging / test-packaging (local, ubuntu-latest) (push) Waiting to run
Test native tooling packaging / test-packaging (remote, ubuntu-latest) (push) Waiting to run
Test Puppet / test-puppet (push) Waiting to run
🤖 Chore: remove deprecated appendListOptionsWithCursorToSQL (#44385)
<!-- Add the related story/sub-task/bug number, like Resolves #123, or
remove if NA -->
**Related issue:** Resolves #44723

# Checklist for submitter

If some of the following don't apply, delete the relevant line.

- [x] Changes file added for user-visible changes in `changes/`,
`orbit/changes/` or `ee/fleetd-chrome/changes`.
See [Changes
files](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/guides/committing-changes.md#changes-files)
for more information.

- [x] Input data is properly validated, `SELECT *` is avoided, SQL
injection is prevented (using placeholders for values in statements), JS
inline code is prevented especially for url redirects, and untrusted
data interpolated into shell scripts/commands is validated against shell
metacharacters.
- [x] If paths of existing endpoints are modified without backwards
compatibility, checked the frontend/CLI for any necessary changes

## Testing

- [x] Added/updated automated tests
- [x] Where appropriate, [automated tests simulate multiple hosts and
test for host
isolation](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/reference/patterns-backend.md#unit-testing)
(updates to one hosts's records do not affect another)

- [ ] QA'd all new/changed functionality manually


<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->
## Summary by CodeRabbit

* **Bug Fixes**
* Strengthened validation of sorting/order parameters across many list
and cursor-based endpoints — unsupported sort keys now return explicit
errors and prevent unsafe queries.
* Labels listing: label-list pagination query name changed; ordering by
host_count is rejected when host counts are disabled (validated at
request parsing).

* **Tests**
* Added/expanded tests covering allowed order keys, rejection of unknown
keys, and pagination behavior for multiple listing APIs.
<!-- end of auto-generated comment: release notes by coderabbit.ai -->

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
Co-authored-by: Lucas Manuel Rodriguez <lucas@fleetdm.com>
2026-05-05 10:26:47 -04:00
.claude Openspec init (#44592) 2026-05-01 12:10:08 -06:00
.github Remove TODO in story template comments (#44686) 2026-05-05 13:10:55 +01:00
.kilocode Add protected-branches rule and cherry-pick note (#44317) 2026-04-28 13:49:47 -05:00
.storybook FE: Add dark mode view to storybook (#43469) 2026-04-14 15:31:07 -05:00
.vscode Update VSCode Typescript version setting (#43131) 2026-04-07 11:27:10 -05:00
android Android agent to always send the platform field on enrollment (#43809) 2026-04-20 19:23:13 -05:00
articles Reference docs: Multi-platform names for macos_setup and macos_settings (#43565) 2026-05-04 18:51:54 -04:00
assets Use Docker as default WiX runtime on macOS arm64 (#43715) 2026-04-21 10:53:46 -05:00
changes 🤖 Chore: remove deprecated appendListOptionsWithCursorToSQL (#44385) 2026-05-05 10:26:47 -04:00
charts adding redis and mysql subcharts instead of bitnami (#42442) 2026-05-04 15:39:56 -05:00
client Reopen SSO browser window if it hasn't been completed after an interval (#42645) 2026-04-22 17:07:14 -03:00
cmd Add ability to upload custom org logos (#44390) 2026-05-05 14:42:52 +02:00
docs Add supported versions of Redis to the FAQ (#44471) 2026-05-05 10:16:17 -03:00
ee Update Fleet-maintained apps (#44734) 2026-05-05 09:14:22 -05:00
frontend Clicking outside a modal should close the modal (excluding forms that have been interacted with) (#43734) 2026-05-05 09:27:24 -04:00
git-hooks Merge Android datastore into main Fleet datastore (#32233) 2025-08-25 11:41:28 -04:00
handbook Handbook: Add 'Why read every line of AI-generated work?' (#44712) 2026-05-05 08:03:11 -05:00
infrastructure Load test - Enable standard performance insights (#44694) 2026-05-04 16:23:38 -04:00
it-and-security Update policy that checks launch agent plist file presence (#44731) 2026-05-05 09:01:35 -05:00
openspec Openspec init (#44592) 2026-05-01 12:10:08 -06:00
orbit Update versions of fleetd components in Fleet's TUF [automated] (#44736) 2026-05-05 11:16:36 -03:00
pkg Validate label platform during gitops --dry-run (#42477) (#44594) 2026-05-04 07:18:07 -04:00
proposals Remove proposals (unused) (#26646) 2025-02-27 10:37:07 -06:00
schema Bump macadmins/osquery-extension to v1.4.1 and add network_quality ta… (#44214) 2026-04-27 14:52:27 -03:00
security Update security notes for v4.84.2 (#44577) 2026-05-01 10:44:32 -03:00
server 🤖 Chore: remove deprecated appendListOptionsWithCursorToSQL (#44385) 2026-05-05 10:26:47 -04:00
terraform Clean up "click here" and "here" link anchors - part 1 (#29731) 2025-06-04 13:54:34 -06:00
test/upgrade Bump supported MySQL versions (#40892) 2026-03-04 12:25:20 -06:00
third_party Bump pgx/v5 to v5.9.2 in goval-dictionary (CVE-2026-33816) (#44706) 2026-05-04 17:43:27 -04:00
tools Add ability to upload custom org logos (#44390) 2026-05-05 14:42:52 +02:00
website Website: remove /meetups and update routes (#44701) 2026-05-04 17:08:21 -05:00
.coderabbit.yaml Turn on CodeRabbit auto-review, exclude docs changes (#43304) 2026-04-09 14:12:54 -05:00
.custom-gcl.yml Add setboolcheck linter: flag map[T]bool used as sets (#42631) 2026-03-31 16:26:24 -05:00
.dockerignore Added support to read jwt and mysql password from a file (#141) 2021-01-04 07:58:43 -08:00
.eslintignore Allow ESCAPE in LIKE clauses to be valid SQL (#31222) 2025-07-25 10:13:55 -05:00
.eslintrc.js update storybook to 8.4.7 (#25451) 2025-01-20 16:17:33 +00:00
.gitattributes Windows friendly changes after walking through getting started guide (#1441) 2021-07-21 20:49:44 -04:00
.gitignore adding redis and mysql subcharts instead of bitnami (#42442) 2026-05-04 15:39:56 -05:00
.gitpod.yml Add gitpod yml (#2915) 2021-11-19 10:03:56 -03:00
.golangci-incremental.yml Claude, use math/rand/v2 instead of math/rand (#42861) 2026-04-02 13:20:43 -05:00
.golangci.yml Update golangci-lint from 2.7.1 to 2.11.3 (#42066) 2026-03-19 11:19:42 -05:00
.goreleaser-snapshot.yml Cleanup docker publish (#42693) 2026-04-03 10:40:56 -05:00
.goreleaser.yml Fix tagging of fleetdm/fleet and fleetdm/fleetctl when releasing (#28251) 2025-04-16 15:48:47 -03:00
.npmignore Move fleetdm.com into main Fleet repo (#83) 2020-12-02 14:48:03 -06:00
.pr_agent.toml Added Qodo configuration (#43668) 2026-04-16 11:31:05 -05:00
.pre-commit-config.yaml Update golangci-lint from 2.7.1 to 2.11.3 (#42066) 2026-03-19 11:19:42 -05:00
.prettierignore Allow ESCAPE in LIKE clauses to be valid SQL (#31222) 2025-07-25 10:13:55 -05:00
.prettierrc.json add prettier and have it format all fleet application code (#625) 2021-04-12 14:32:25 +01:00
.yarnrc New yarn configuration: Sets installing a dependency to a specific semantic versioning instead of latest stable (#17938) 2024-03-29 10:39:20 -04:00
43273-fix-policy-stats-wipe Fix issue with GitOps incorrectly wiping policy stats (#43282) 2026-04-08 17:03:08 -05:00
babel.config.json Fleet Frontend: Create integration tests QuerySidePanel.tests.tsx (#12179) 2023-06-07 12:01:59 -04:00
CHANGELOG.md Adding changes for Fleet v4.84.2 (#44590) 2026-05-04 10:57:04 -05:00
CODE_OF_CONDUCT.md Remove @fleetdm.com emails from fleetdm/fleet repo (#882) 2021-05-27 17:19:14 -04:00
codecov.yml Added dedicated Go test workflow for activity bounded context (#40653) 2026-02-27 07:53:57 -06:00
CODEOWNERS Update why-fleet.md (#44100) 2026-04-28 10:41:01 -05:00
docker-compose-redis-cluster.yml Set Redis explicitly to 6.2 for clarity (it was already aliased to latest 6.2) (#44501) 2026-04-30 11:29:05 -05:00
docker-compose.yml Set Redis explicitly to 6.2 for clarity (it was already aliased to latest 6.2) (#44501) 2026-04-30 11:29:05 -05:00
Dockerfile-desktop-linux Update go to 1.26.2 and update tooling to update it (#43771) 2026-04-20 13:40:57 -03:00
go.mod Redis-backed cache for host-by-key lookups (#43936) 2026-05-01 12:06:16 -05:00
go.sum Redis-backed cache for host-by-key lookups (#43936) 2026-05-01 12:06:16 -05:00
kilo.md Add kilo.md with AI agent coding guidelines (#42939) 2026-04-03 11:57:02 -05:00
LICENSE Update LICENSE (#10) 2020-11-04 19:57:51 -06:00
Makefile Allow concurrent make lint-go executions (#44724) 2026-05-05 09:10:07 -03:00
manifest.yml.cloudgov.example cloud.gov deployment (#7611) 2022-09-07 13:30:06 -05:00
osv-scanner.toml We have migrated from aws-sdk-go v1 to v2, remove scanner skip (#30469) 2025-07-02 13:33:31 -03:00
package.json Upgrade fork-ts-checker-webpack-plugin (#44304) 2026-04-28 13:16:32 -05:00
postcss.config.js Upgrade Bourbon to 5.1.0 and fix deprecation warnings (#1973) 2019-01-03 12:46:55 -08:00
README.md Removing run tests badge from README (#32131) 2025-08-20 12:54:48 -05:00
render.yaml Use Render Redis service (#23056) 2025-01-02 10:07:54 -06:00
SECURITY.md Update PGP key and fingerprint in SECURITY.md (#44221) 2026-04-27 11:40:15 -05:00
tsconfig.json Update to TypeScript 6.0 (#43141) 2026-04-09 08:28:59 -05:00
webpack.config.js Silence webpack warnings (#40756) 2026-03-10 12:29:11 -05:00
yarn.lock Upgrade fork-ts-checker-webpack-plugin (#44304) 2026-04-28 13:16:32 -05:00

Fleet logo, landscape, dark text, transparent background

News   ·   Report a bug   ·   Handbook   ·   Why open source?   ·   Art

Open-source platform for IT and security teams with thousands of computers. Designed for APIs, GitOps, webhooks, YAML, and humans.

A glass city in the clouds

What's it for?

Organizations like Fastly and Gusto use Fleet for vulnerability reporting, detection engineering, device management (MDM), device health monitoring, posture-based access control, managing unused software licenses, and more.

Explore data

To see what kind of data you can use Fleet to gather, check out the table reference documentation.

Out-of-the-box policies

Fleet includes out-of-the box support for all CIS benchmarks for macOS and Windows, as well as many simpler queries.

Take as much or as little as you need for your organization.

Supported platforms

Here are the platforms Fleet currently supports:

  • Linux (all distros)
  • macOS
  • Windows
  • Chromebooks
  • Amazon Web Services (AWS)
  • Google Cloud (GCP)
  • Azure (Microsoft cloud)
  • Data centers
  • Containers (kube, etc)
  • Linux-based IoT devices

Lighter than air

Fleet is lightweight and modular. You can use it for security without using it for MDM, and vice versa. You can turn off features you are not using.

Openness

Fleet is dedicated to flexibility, accessibility, and clarity. We think everyone can contribute and that tools should be as easy as possible for everyone to understand.

Good neighbors

Fleet has no ambition to replace all of your other tools. (Though it might replace some, if you want it to.) Ready-to-use, enterprise-friendly integrations exist for Snowflake, Splunk, GitHub Actions, Vanta, Elastic Jira, Zendesk, and more.

Fleet plays well with Munki, Chef, Puppet, and Ansible, as well as with security tools like Crowdstrike and SentinelOne. For example, you can use the free version of Fleet to quickly report on what hosts are actually running your EDR agent.

Free as in free

The free version of Fleet will always be free. Fleet is independently backed and actively maintained with the help of many amazing contributors.

Longevity

The company behind Fleet is founded (and majority-owned) by true believers in open source. The company's business model is influenced by GitLab (NYSE: GTLB), with great investors, happy customers, and the capacity to become profitable at any time.

In keeping with Fleet's value of openness, Fleet Device Management's company handbook is public and open source. You can read about the history of Fleet and osquery and our commitment to improving the product.

Is it any good?

Fleet is used in production by IT and security teams with thousands of laptops and servers. Many deployments support tens of thousands of hosts, and a few large organizations manage deployments as large as 400,000+ hosts.

Chat

Please join us in MacAdmins Slack or in osquery Slack.

The Fleet community is full of kind and helpful people. Whether or not you are a paying customer, if you need help, just ask.

Contributing   Go Report Card   CII Best Practices   Twitter Follow  

The landscape of cybersecurity and IT is too complex. Let's open it up.

Contributions are welcome, whether you answer questions on Slack / GitHub / StackOverflow / LinkedIn / Twitter, improve the documentation or website, write a tutorial, give a talk at a conference or local meetup, give an interview on a podcast, troubleshoot reported issues, or submit a patch. The Fleet code of conduct is on GitHub.

What's next?

To see what Fleet can do, head over to fleetdm.com and try it out for yourself, grab time with one of the maintainers to discuss, or visit the docs and roll it out to your organization.

Production deployment

Fleet is simple enough to spin up for yourself. Or you can have us host it for you. Premium features are available either way.

Documentation

Complete documentation for Fleet can be found at https://fleetdm.com/docs.

License

The free version of Fleet is available under the MIT license. The commercial license is also designed to allow contributions to paid features for users whose employment agreements allow them to contribute to open source projects. (See LICENSE.md for details.)

Fleet is built on osquery, nanoMDM, Nudge, and swiftDialog.