Unofficial command-line interface for the Loxo recruiting ATS/CRM API
Project description
loxo-cli
A fast, ergonomic command-line interface for the Loxo recruiting
ATS/CRM REST API. It offers typed subcommands for the common resources (people, jobs,
companies, deals, candidates, activities, webhooks, reference data) plus a generic
loxo api escape hatch that can call any endpoint. Output is human-friendly tables on a
terminal and clean JSON when piped, so it fits both interactive use and scripts.
Unofficial — not affiliated with Loxo, Inc.
Install
uvx loxo-cli # run without installing
pipx install loxo-cli # or install as a user tool
Quickstart
loxo configure # set up a profile
loxo people list --query "engineer" # human table
loxo people list --json | jq '.' # JSON for scripts
loxo api GET jobs/123 # raw escape hatch
Configuration
Credentials resolve with the precedence flags > environment > config file.
Environment variables:
| Variable | Meaning |
|---|---|
LOXO_API_KEY |
API bearer token |
LOXO_API_SLUG |
Agency slug (the {slug} in every request URL) |
LOXO_BASE_URL |
API base URL (default https://app.loxo.co/api) |
LOXO_PROFILE |
Default profile name to use |
The config file lives at ~/.config/loxo/config.toml (or $XDG_CONFIG_HOME/loxo/config.toml)
and is written with 0600 permissions. Example:
default_profile = "prod"
[profile.prod]
slug = "acme"
base_url = "https://app.loxo.co/api"
api_key = "your-token"
[profile.staging]
slug = "acme-staging"
# Pull the key from a secrets manager instead of storing it in plaintext:
api_key_cmd = "op read op://Private/loxo-staging/credential"
api_key_cmd is run on demand and its stdout is used as the key, so the secret never has
to live in the file. Set it without hand-editing the file via
loxo configure --api-key-cmd "op read op://Private/loxo/credential". The key is never
printed by loxo configure list, logged, or shown in --verbose output.
Commands
| Group | What it does |
|---|---|
people |
List/search, get, create, update people |
jobs |
List, get, create, update jobs |
companies |
List/search, get, create, update companies |
deals |
List, get, create, update deals |
candidates |
List/get/add/update candidates under a job |
activities |
List and add person events (activities) |
webhooks |
Full CRUD for webhooks (with enum validation) |
ref |
Reference lookups: job/activity/source/person types, lists, custom fields, hierarchies |
api |
Generic escape hatch — call any endpoint directly |
configure |
Create and list credential profiles |
Custom (dynamic) fields are supported on writes via repeatable --field key=value
(use key[]=value to force a list, e.g. hierarchy fields). Discover valid keys with
loxo ref custom-fields.
Output
On a terminal, list and object results render as Rich tables. Pipe the command or pass
--json to get machine-readable JSON; --jq '<path>' applies a small built-in selector
(e.g. --jq '.[].id') without needing the jq binary.
Exit codes
| Code | Meaning |
|---|---|
| 0 | Success |
| 1 | Generic error |
| 2 | Usage error (bad flags/arguments) |
| 3 | Authentication/authorization failure (401/403) |
| 4 | Not found (404) |
| 5 | Rate limited (429) |
| 6 | Server error (5xx) |
| 7 | Timeout or network failure |
Pagination
Loxo paginates differently per endpoint: cursor (scroll_id), offset (page), and keyset
(after_id). loxo-cli detects and handles all three. List commands fetch a single page by
default; pass --all to transparently walk every page. The generic loxo api ... --all
auto-detects the scheme (or force it with --paginate scroll_id|page|after_id).
Contributing
uv sync # install dependencies
uv run pytest # run the test suite (HTTP is mocked; no live calls)
uv run ruff check src tests
uv run black --check src tests
uv run mypy
Commits follow Conventional Commits.
License
MIT. See LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file loxo_cli-0.2.1.tar.gz.
File metadata
- Download URL: loxo_cli-0.2.1.tar.gz
- Upload date:
- Size: 61.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c4c8a3fbd255270d53661acd8228f6546c460fcc5fded908e6fbf8b9a305bd5e
|
|
| MD5 |
a84a57591054534ee8878da55262ae8a
|
|
| BLAKE2b-256 |
b26844c225b6beab9d97c954a0fc8964d0df1a6c500fa872ecbceea247323732
|
Provenance
The following attestation bundles were made for loxo_cli-0.2.1.tar.gz:
Publisher:
publish.yml on alphaomegateam/loxo-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
loxo_cli-0.2.1.tar.gz -
Subject digest:
c4c8a3fbd255270d53661acd8228f6546c460fcc5fded908e6fbf8b9a305bd5e - Sigstore transparency entry: 1864742054
- Sigstore integration time:
-
Permalink:
alphaomegateam/loxo-cli@5d1d0a1a6952bcc3db969135ea12a945463bb042 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/alphaomegateam
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5d1d0a1a6952bcc3db969135ea12a945463bb042 -
Trigger Event:
push
-
Statement type:
File details
Details for the file loxo_cli-0.2.1-py3-none-any.whl.
File metadata
- Download URL: loxo_cli-0.2.1-py3-none-any.whl
- Upload date:
- Size: 27.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
caa1fcaf0b0ba79637de4965d8050a2a20bd196eb997f34be2d4f82cbeb310ec
|
|
| MD5 |
079a37e75b18cf2b6cfdbd5c6a293aa9
|
|
| BLAKE2b-256 |
fbcfc3fcc84addaa7a2628f4c600c76844de5a094a2f4da9c1d15acba7dfe422
|
Provenance
The following attestation bundles were made for loxo_cli-0.2.1-py3-none-any.whl:
Publisher:
publish.yml on alphaomegateam/loxo-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
loxo_cli-0.2.1-py3-none-any.whl -
Subject digest:
caa1fcaf0b0ba79637de4965d8050a2a20bd196eb997f34be2d4f82cbeb310ec - Sigstore transparency entry: 1864742065
- Sigstore integration time:
-
Permalink:
alphaomegateam/loxo-cli@5d1d0a1a6952bcc3db969135ea12a945463bb042 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/alphaomegateam
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5d1d0a1a6952bcc3db969135ea12a945463bb042 -
Trigger Event:
push
-
Statement type: