Skip to content

Make system keyring discoverable (or default) for rsconnect login #791

Description

@nealrichardson

Problem

rsconnect login stores OAuth tokens in the system keyring only if the optional keyring package is installed, otherwise it falls back to a local chmod-600 file and prints:

Note: keyring not available; credentials stored in local file (chmod 600).

keyring is an optional extra (pyproject.toml: keyring = ["keyring>=23.0.0"]), added alongside the login/logout commands in #773. The reasoning for keeping it optional is sound: rsconnect-python frequently runs in headless/CI/container/server environments where there's no usable secret-service backend (especially on Linux, where keyring needs SecretService/dbus), and the file fallback works fine there.

But there's a discoverability gap: a workstation user who would benefit from the OS keychain has no way to learn that the feature exists or how to turn it on. The fallback message states that keyring is unavailable but not how to enable it. Most users will never find the [keyring] extra.

Proposals

In rough order of preference:

  1. Make the fallback message actionable. Tell the user how to opt in, e.g.:

    Note: keyring not available; credentials stored in local file (chmod 600).
    To store credentials in your system keychain instead, install the keyring extra:
        pip install 'rsconnect-python[keyring]'
    

    This is low-risk and directly answers "how would I know to use it?"

  2. Document it in the login/logout help text and the deploying/auth docs (the --help for login mentions the keyring but not the extra needed to enable it).

  3. Consider making keyring a default dependency. Modern keyring installs cleanly on all platforms without heavy system requirements; on a backend-less Linux host it simply has no usable backend, and the existing code already catches that (keyring_store_token returns False on any exception and falls back to the file). If install footprint is the only concern, the trade-off may now favor including it by default and letting the runtime fallback handle headless environments. Worth at least evaluating.

Acceptance

  • A workstation user can discover and enable system-keychain credential storage without prior knowledge of the [keyring] extra (at minimum via an actionable message and docs).

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type
    No fields configured for issues without a type.

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions