Actions
Idea #22665
openGeneralize logic for getting cluster credentials
Start date:
Due date:
Story points:
-
Description
Following on the api_for_instance
logic in arv-copy, it would be nice to generalize this and use it in our other tools.
We want behavior like:
- If the target cluster can be inferred (e.g. there's an Arvados uuid in the input somewhere) then the tool can choose the right credentials by default (this is how arv-copy works currently).
- As an alternative to
ARVADOS_API_HOST
andARVADOS_API_TOKEN
the user would only have to set a single environment variableARVADOS_CLUSTER
(or ARVADOS_INSTANCE) which by convention is the cluster id - Getting credentials from workbench and saving them locally should be streamlined (e.g. #21847)
- It would convenient to have the default
settings.conf
symlink to the config file named by cluster id.
Also, it could be helpful to check token validity using api.api_client_authorizations().current() and providing a standardized error message instead of failing on first use.
We probably want to put this logic into the default constructor (e.g. arvados.api()) with a new optional parameter like cluster_id: str
as well as looking for ARVADOS_CLUSTER
in the environment. This would make the new functionality available for everyone, while the behavior of inferring the right cluster based on tool-specific arguments (e.g. --project-uuid
) can be phased in to individual tools.
Updated by Peter Amstutz 21 days ago
- Related to Feature #22602: arv-copy should recognize when default environment matches instance name added
Updated by Peter Amstutz 21 days ago
- Related to Idea #21847: "Get API Token" usability improvements added
Updated by Peter Amstutz 16 days ago
- Target version changed from Future to Development 2025-04-16
Updated by Peter Amstutz 1 day ago
- Target version changed from Development 2025-04-16 to Development 2025-04-30
Updated by Peter Amstutz 1 day ago
- Has duplicate Idea #21848: All CLI tools look for credentials from xyzzy.conf before settings.conf added
Actions