Skip to main content

Command-line client for the Public.com Trading API

Project description

publicdotcom-cli

Command-line client for the Public.com Trading API.

Use public to authenticate, inspect accounts, retrieve portfolio and market data, run preflight checks, and submit order-related requests from your terminal.

Install

The recommended installation method for command-line Python tools is pipx:

pipx install publicdotcom-cli

You can also install with uv:

uv tool install publicdotcom-cli

Confirm the CLI is available:

public --help

Quick Start

Generate a personal secret from your Public.com settings, then authenticate:

public auth login
public accounts list
public accounts set-default ACCOUNT_ID
public portfolio show
public market quotes AAPL MSFT

Most account-scoped commands use the configured default account. You can override it with --account-id ACCOUNT_ID or PUBLIC_ACCOUNT_ID=ACCOUNT_ID.

Important Disclosures

This CLI is a developer tool for interacting with the Public API. It is not investment, financial, legal, tax, accounting, or trading advice, and it does not recommend any security, strategy, account type, order type, or transaction.

Trading involves risk, including the possible loss of principal. You are responsible for reviewing all request payloads, account IDs, symbols, quantities, prices, order sides, time-in-force values, and other order instructions before submitting a trading command.

Order placement, replacement, and cancellation requests may be asynchronous. A successful API response confirms submission to the API, not execution, cancellation, fill price, availability, or final order state. Always verify order status after submitting, replacing, or cancelling an order.

Market data, quotes, option chains, greeks, account data, and preflight calculations are provided for informational and operational use through the API. They may be incomplete, delayed, unavailable, or different from final execution values.

You are responsible for complying with all applicable laws, regulations, exchange rules, API terms, account agreements, and internal policies that apply to your use of this CLI. Do not use this tool unless you are authorized to access the relevant account and API credentials.

Personal secrets and access tokens can authorize account access and trading activity. Keep them private, do not commit them to source control, and rotate or revoke them if you believe they were exposed.

Authenticate

Generate a personal secret from Public, then run:

public auth login

The access token is stored with your OS keychain when available. If no keychain backend is available, the CLI falls back to a user-only config file.

Access tokens are short-lived. To let the CLI refresh them automatically, opt in to storing your personal secret:

public auth login --store-secret

Because the personal secret is long-lived, this is optional. The CLI stores it in your OS keychain when available, otherwise it falls back to a user-only config file.

After that, secured commands automatically mint a fresh access token before the current token expires or after a 401 Unauthorized response. You can also refresh manually:

public auth refresh

You can also bypass stored credentials for automation:

PUBLIC_ACCESS_TOKEN=ey... public accounts list
PUBLIC_PERSONAL_SECRET=... public accounts list

Remove stored credentials with:

public auth logout
public auth logout --all

Default Account

Most API operations require the accountId returned by public accounts list. You can store a default account once:

public accounts set-default ACCOUNT_ID
public accounts get-default

Then omit --account-id from account-scoped commands:

public portfolio show
public market quotes AAPL MSFT
public order get ORDER_ID

You can override the default at any time:

public portfolio show --account-id ACCOUNT_ID
PUBLIC_ACCOUNT_ID=ACCOUNT_ID public portfolio show
public accounts clear-default

Example Commands

public accounts list
public accounts set-default ACCOUNT_ID
public portfolio show
public history list --page-size 25
public instruments get AAPL EQUITY
public market quotes AAPL MSFT --type EQUITY
public market option-expirations AAPL
public market option-chain AAPL 2026-05-15
public options greeks "AAPL  260515C00200000"
public historicdata bars EQUITY AAPL YEAR
public historicdata bars EQUITY AAPL DAY --aggregation FIVE_MINUTES
public historicdata bars EQUITY AAPL SINCE_PURCHASE --purchase-date 2024-01-15

Historic Bar Data

Fetch OHLCV bar data for a symbol over a given time period. The first argument is the instrument type (EQUITY, CRYPTO, OPTION, or INDEX):

public historicdata bars EQUITY AAPL YEAR
public historicdata bars CRYPTO BTC-USD WEEK

Available periods: DAY, WEEK, MONTH, QUARTER, HALF_YEAR, YEAR, FIVE_YEARS, YTD, SINCE_PURCHASE.

Override the default bar aggregation with --aggregation:

public historicdata bars EQUITY AAPL DAY --aggregation FIVE_MINUTES
public historicdata bars EQUITY AAPL MONTH --aggregation ONE_HOUR

Available aggregations: ONE_MINUTE, FIVE_MINUTES, TEN_MINUTES, FIFTEEN_MINUTES, THIRTY_MINUTES, ONE_HOUR, ONE_DAY, ONE_WEEK, ONE_MONTH, THREE_MONTHS, SIX_MONTHS, ONE_YEAR.

When using the SINCE_PURCHASE period, supply the purchase date:

public historicdata bars EQUITY AAPL SINCE_PURCHASE --purchase-date 2024-01-15

Trading requests use JSON files so the exact payload is visible before submission:

public order preflight-single --file examples/order.single-leg.market-buy.json
public order place --file examples/order.single-leg.market-buy.json
public order get ORDER_ID
public order cancel ORDER_ID

Trading commands prompt before submitting order placement, replacement, or cancellation requests. Use --yes only when your automation has already performed equivalent validation and approval.

Order payloads accept optional fields beyond the basics shown above. For example, useMargin controls buying power on order place and order place-multileg: set it to false to evaluate the order against cash-only buying power instead of margin. When omitted it defaults to true (margin applied where the account allows). See examples/order.single-leg.cash-only.json for a sample.

JSON Output

Use --json before the command group to print raw JSON:

public --json accounts list
public --json market quotes AAPL MSFT

Configuration

The CLI supports these environment variables:

PUBLIC_ACCESS_TOKEN=...
PUBLIC_PERSONAL_SECRET=...
PUBLIC_ACCOUNT_ID=...
PUBLIC_API_BASE_URL=https://api.public.com
PUBLIC_AUTO_REFRESH=true

PUBLIC_API_BASE_URL is optional and defaults to https://api.public.com.

Upgrade

pipx upgrade publicdotcom-cli
# or
uv tool upgrade publicdotcom-cli

Development

For local development from a checkout:

uv sync --extra dev
uv run public --help
uv run pytest

Regenerate The OpenAPI Client

The package ships with a generated API client. Contributors who need to regenerate it must place the local OpenAPI spec at the repository root as spec.yaml, then run:

uv run python scripts/generate_client.py

The raw spec uses */* for many JSON responses, which some Python generators do not parse as JSON. The regeneration script normalizes those response content types before running openapi-python-client. This requires network access the first time because it uses uvx openapi-python-client.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

publicdotcom_cli-1.2.1.tar.gz (97.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

publicdotcom_cli-1.2.1-py3-none-any.whl (172.1 kB view details)

Uploaded Python 3

File details

Details for the file publicdotcom_cli-1.2.1.tar.gz.

File metadata

  • Download URL: publicdotcom_cli-1.2.1.tar.gz
  • Upload date:
  • Size: 97.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for publicdotcom_cli-1.2.1.tar.gz
Algorithm Hash digest
SHA256 84bf1ddef51852f22d2fa66fae9927b966f3a0077ba2c0a7e1004334c599852e
MD5 1c970bb7dfe47ecb74da1f2ee365926b
BLAKE2b-256 b6030984e679300378509710f4a67da9ad72b5d762e5674c2d6d1299060b5c1c

See more details on using hashes here.

File details

Details for the file publicdotcom_cli-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: publicdotcom_cli-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 172.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for publicdotcom_cli-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6fb9270b0fb68f58f7674520948bd0b5257aef68cf5ed624d7147f21038058de
MD5 76635122956f19beddb156370e76efa6
BLAKE2b-256 fd215747db808f3abe8c9dee6a5070a0a841e54fcd9f6b76d763891872042b72

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page