Project

General

Custom queries

Profile

Actions

Idea #22665

open

Generalize logic for getting cluster credentials

Added by Peter Amstutz 21 days ago. Updated 1 day ago.

Status:
New
Priority:
Normal
Assigned To:
-
Category:
SDKs
Target version:
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 and ARVADOS_API_TOKEN the user would only have to set a single environment variable ARVADOS_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.


Related issues 3 (1 open2 closed)

Related to Arvados - Feature #22602: arv-copy should recognize when default environment matches instance nameResolvedPeter AmstutzActions
Related to Arvados - Idea #21847: "Get API Token" usability improvementsNewActions
Has duplicate Arvados - Idea #21848: All CLI tools look for credentials from xyzzy.conf before settings.confDuplicateActions
#1

Updated by Peter Amstutz 21 days ago

  • Position changed from -944676 to -944664
#2

Updated by Peter Amstutz 21 days ago

  • Related to Feature #22602: arv-copy should recognize when default environment matches instance name added
#3

Updated by Peter Amstutz 21 days ago

  • Related to Idea #21847: "Get API Token" usability improvements added
#4

Updated by Peter Amstutz 21 days ago

  • Description updated (diff)
#5

Updated by Peter Amstutz 16 days ago

  • Target version changed from Future to Development 2025-04-16
#6

Updated by Peter Amstutz 1 day ago

  • Target version changed from Development 2025-04-16 to Development 2025-04-30
#7

Updated by Peter Amstutz 1 day ago

  • Description updated (diff)
#8

Updated by Peter Amstutz 1 day ago

  • Description updated (diff)
#9

Updated by Peter Amstutz 1 day ago

  • Description updated (diff)
#10

Updated by Peter Amstutz 1 day ago

  • Description updated (diff)
#11

Updated by Peter Amstutz 1 day ago

  • Tracker changed from Feature to Idea
#12

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

Also available in: Atom PDF