Back to Uv

The `uv auth` CLI

docs/concepts/authentication/cli.md

0.11.143.7 KB
Original Source

The uv auth CLI

uv provides a high-level interface for storing and retrieving credentials from services.

Logging in to a service

To add credentials for service, use the uv auth login command:

console
$ uv auth login example.com

This will prompt for the credentials.

The credentials can also be provided using the --username and --password options, or the --token option for services which use a __token__ or arbitrary username.

!!! note

We recommend providing the secret via stdin. Use `-` to indicate the value should be read from
stdin, e.g., for `--password`:

```console
$ echo 'my-password' | uv auth login example.com --password -
```

The same pattern can be used with `--token`.

Once credentials are added, uv will use them for packaging operations that require fetching content from the given service. At this time, only HTTPS Basic authentication is supported. The credentials will not yet be used for Git requests.

!!! note

The credentials will not be validated, i.e., incorrect credentials will not fail.

Logging out of a service

To remove credentials, use the uv auth logout command:

console
$ uv auth logout example.com

!!! note

The credentials will not be invalidated with the remote server, i.e., they will only be removed
from local storage not rendered unusable.

Showing credentials for a service

To show the credential stored for a given URL, use the uv auth token command:

console
$ uv auth token example.com

If a username was used to log in, it will need to be provided as well, e.g.:

console
$ uv auth token --username foo example.com

Using credentials with external tools

uv auth helper allows tools that support credential helpers to request HTTP credentials from uv. At this time, uv supports the Bazel credential helper protocol.

The command is intended to be invoked by external tools. It reads a JSON request from stdin and writes a JSON response to stdout. When matching credentials are available, the response includes the Authorization header:

console
$ echo '{"uri": "https://example.com/path"}' | uv --preview-features auth-helper auth helper --protocol=bazel get
{"headers":{"Authorization":["Basic ..."]}}

If no credentials are found, uv will return an empty set of headers:

json
{ "headers": {} }

!!! note

`uv auth helper` is experimental. Use `--preview-features auth-helper` or
`UV_PREVIEW_FEATURES=auth-helper` to disable the warning.

Bazel

Bazel 7 and newer supports credential helpers via the --credential_helper option. First, authenticate uv with the service that hosts the files Bazel needs to fetch:

console
$ uv auth login https://packages.example.com

Then, configure Bazel to invoke uv for matching hosts:

text
common --credential_helper=packages.example.com=%workspace%/bazel/uv-auth-helper
common --credential_helper=files.example.com=%workspace%/bazel/uv-auth-helper

Replace the host patterns with the hosts that serve the index and files Bazel will fetch.

Finally, add the wrapper script referenced by .bazelrc:

bash
#!/usr/bin/env bash
exec uv --preview-features auth-helper auth helper --protocol=bazel "$@"

The script must be executable:

console
$ chmod +x bazel/uv-auth-helper

Configuring the storage backend

Credentials are persisted to the uv credentials store.

By default, credentials are written to a plaintext file. An encrypted system-native storage backend can be enabled with UV_PREVIEW_FEATURES=native-auth.