the CLI supports multiple authentication methods with the following precedence:
--api-keyflag (explicit key for single command)LINEAR_API_KEYenvironment variableapi_keyin project.linear.tomlconfig--workspace/-wflag → stored credentials lookup- project's
workspaceconfig → stored credentials lookup - default workspace from stored credentials
credentials are stored in ~/.config/linear/credentials.toml and support multiple workspaces.
linear auth login # add a workspace (prompts for API key)
linear auth login --key <key> # add with key directly (for scripts)
linear auth list # list configured workspaces
linear auth default # interactively set default workspace
linear auth default <slug> # set default workspace directly
linear auth logout <slug> # remove a workspace
linear auth logout <slug> -f # remove without confirmation
linear auth whoami # show current user and workspace
linear auth token # print the resolved API key# first workspace becomes the default
$ linear auth login
Enter your Linear API key: ***
Logged in to workspace: Acme Corp (acme)
User: Jane Developer <jane@acme.com>
Set as default workspace
# add additional workspaces
$ linear auth login
Enter your Linear API key: ***
Logged in to workspace: Side Project (side-project)
User: Jane Developer <jane@example.com>$ linear auth list
WORKSPACE ORG NAME USER
* acme Acme Corp Jane Developer <jane@acme.com>
side-project Side Project Jane Developer <jane@example.com>the * indicates the default workspace.
# set a new default
linear auth default side-project
# or use -w flag for a single command
linear -w side-project issue list
linear -w acme issue create --title "Bug fix"# ~/.config/linear/credentials.toml
default = "acme"
acme = "lin_api_xxx"
side-project = "lin_api_yyy"for simpler setups or CI environments, you can use an environment variable:
# bash/zsh
export LINEAR_API_KEY="lin_api_..."
# fish
set -Ux LINEAR_API_KEY "lin_api_..."this takes precedence over stored credentials. if you have LINEAR_API_KEY set and try to use linear auth login, you'll see a warning:
Warning: LINEAR_API_KEY environment variable is set.
It takes precedence over stored credentials.
Remove it from your shell config to use multi-workspace auth.
you can also set the API key in a project's .linear.toml:
api_key = "lin_api_..."
workspace = "acme"
team_id = "ENG"this is useful for project-specific credentials but less secure than stored credentials since it may be committed to version control.
when your project config has a workspace setting:
# .linear.toml
workspace = "acme"
team_id = "ENG"the CLI will automatically use the stored credentials for that workspace, even if a different workspace is your default. this lets you work on multiple projects with different workspaces without constantly switching.
- go to linear.app/settings/account/security
- scroll to "Personal API keys"
- click "Create key"
- give it a label (e.g., "CLI")
- copy the key (starts with
lin_api_)
note: creating an API key requires member access; it is not available for guest accounts.