-
Notifications
You must be signed in to change notification settings - Fork 970
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enable user-level management of index credentials via uv (& keyring) #9920
base: main
Are you sure you want to change the base?
Conversation
It would be nice to add a |
@bschoenmaeckers, I think adding One part is implementing an The other part is providing a |
@stoney95 Thx for starting integration of kering-rs into uv! How to use credentials already defined in credential store? |
@zanieb, clippy is configured to not allow the usage of |
I was super curious whether it would be difficult to interact with keyring-rs directly, so I quickly implemented alternative Credential constructor (tests are necessary!), but it works with locally configured auth.toml and hand-crafted secret in keychain already.. I like what you tried to achieve, but I think it would be good to implement the configuration to be similar to poetry, so users don't have to think and be surprised. Have a look here: https://github.com/astral-sh/uv/compare/main...lejmr:uv:simple-poetry-like-version?expand=1 |
@lejmr, thanks for your suggestion. To clarify, I see two suggestions made from your end.
Do you agree with this summary? Personal opinion
|
Hey @stoney95 sorry I missed your ping! Reviewing this is on my queue but I'm working through that holiday backlog still. Regarding
We use |
@stoney95, let me write my grains of salt..
Add/Rm etc is bad naming to me because what really happens is upsert, so add is confusing.
Regards 2), I think your implementation is just more complicated than what is necessary. I took shortcut by implementing
|
@lejmr, thanks for explaining your suggestion in more details :) NamingI would opt for Keyring crate / Complicated implementationI am using If I understand your suggestion correctly we could modify So, we could make |
Keyring) if we modify ::from_url, so it loads username from auth.toml for the given URL, we don't need the from_keyring at all because the secret is loaded by middleware, https://github.com/stoney95/uv/blob/main/crates/uv-auth/src/middleware.rs#L203 - which is already existing code, so we won't create any duplicity. |
Summary
Currently reading credentials from
keyring
is only supported when a username is provided in the URL of the index. This prohibits to define indexes - in pyproject.toml - that are shared within a team. See these two issues for further details:In general this PR provides two things:
Setting credentials for an index via CLI
With this MR you can run
uv index credentials add --name <name-of-the-index> [--username <username>]
This will ask for the password of the user. A keyring entry will be made with the url of the index, the username and the password. The username and the index will be appended to "<uv_cache_dir>/auth.toml". "auth.toml" has the following structure
Using credentials
When reading the credentials in
uv_distribution_types::index::Index.credentials
it's now additionally checked if credentials have been configured via "<uv_cache_dir>/auth.toml" andkeyring
. The current implementation of reading the credentials from the environment variablesUV_INDEX_XXX
has priority overkeyring
authentication.Test Plan
I have added unit tests to the newly defined
uv_auth::keyring_config
which takes care of loading, storing and modifying the auth configuration.I also want to add a test for
uv_auth::credentials::Credentials.from_keyring
. But am currently struggling with mocking keyring and config file.I manually tested the new command
uv index credentials add --name <name-of-the-index>
as I could not find examples for testing commands.Further remarks
I am a noobie in this context
=> I am curious about your opinion and suggestions for improvements
Not completely ready
The current version of the PR is a draft. Especially in regards of error handling and logging. Also testing can be improved.
I open this PR to discuss the direction in which the implementation is heading. As I am new to rust & uv I would also like to receive your guideance upfront 🙂