Skip to content
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

fix(login): Deprecate CLI token #15057

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

fix(login): Deprecate CLI token #15057

wants to merge 1 commit into from

Conversation

epage
Copy link
Contributor

@epage epage commented Jan 13, 2025

What does this PR try to resolve?

This came up in #13623 to avoid putting tokens into shell history.

How should we test and review this PR?

The exact approach to deprecation can vary

  • Include <token> in at least some docs for discovery (most likely the man page)
  • Don't warn yet

etc

I also suspect we could reorganize cargo help login but wanted to decouple that from this change.

Additional information

This came up in rust-lang#13623 to avoid putting tokens into shell history.
@rustbot
Copy link
Collaborator

rustbot commented Jan 13, 2025

r? @weihanglo

rustbot has assigned @weihanglo.
They will have a look at your PR within the next two weeks and either review your PR or reassign to another reviewer.

Use r? to explicitly pick a reviewer

@rustbot rustbot added A-cli Area: Command-line interface, option parsing, etc. A-cli-help Area: built-in command-line help A-documenting-cargo-itself Area: Cargo's documentation Command-login S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Jan 13, 2025
@epage epage force-pushed the login branch 3 times, most recently from 47af6dc to 5f93571 Compare January 13, 2025 17:57
Copy link
Member

@weihanglo weihanglo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good to me. Have we had any consensus or FCP for this change?

@epage
Copy link
Contributor Author

epage commented Jan 13, 2025

Have we had any consensus or FCP for this change?

I do not believe we've discussed this as a team yet. Open to FCP or team meeting discussion.

@Turbo87
Copy link
Member

Turbo87 commented Jan 14, 2025

FWIW I've seen @woodruffw use https://developer.1password.com/docs/cli/reference/commands/read/ to use command line options like this in a seemingly safe way. I wonder if we really need to deprecate this option, or if a strong warning in the documentation/help text would be sufficient.

though to be fair, this is probably irrelevant for the cargo login case, since CI systems should probably use env vars to pass in the token instead of saving it via cargo login and regular users can use stdin and are unlikely to regularly call cargo login for this to matter much 😅

@weihanglo
Copy link
Member

I wonder if we really need to deprecate this option, or if a strong warning in the documentation/help text would be sufficient.

Do you suggest keeping doc/helptext for discoverable reasons? I am fine with that as well :)

@epage
Copy link
Contributor Author

epage commented Jan 14, 2025

I feel like cargo login -h help output would need to be carefully tweaked to avoid people seeing [TOKEN] and immediately thinking thats what they need. I'm not even sure thats possible as we've already anchored the users conversation with the help by the usage / argument placeholder column.

@woodruffw
Copy link

FWIW I've seen @woodruffw use developer.1password.com/docs/cli/reference/commands/read to use command line options like this in a seemingly safe way. I wonder if we really need to deprecate this option, or if a strong warning in the documentation/help text would be sufficient.

Yep, I frequently use that or similar (e.g. $(gh auth token) for GitHub)!

Ultimately, passing secrets between processes without an actual authenticated IPC channel/system secret manager is pretty difficult to do in a completely secure way 😅 -- even cargo login $(op read ...) can be sniffed by any other user-level process via /proc/<pid>/cmdline, as can any environment variable via /proc/<pid>/environ. Whether or not those are considered attacker-readable depends on the threat model.

IMO it'd be reasonable to nudge users towards providing tokens via stdin, while still allowing people to pass it via argv (perhaps with a loud warning about the risk of token exposure when passing a literal token rather than via a subshell?).

@weihanglo
Copy link
Member

weihanglo commented Jan 15, 2025

To clarify, because of the stability guarantee Cargo cannot remove the flag (see #13623 (comment)). Deprecation here means, well, a big warning 😆.

@woodruffw
Copy link

To clarify, because of the stability guarantee Cargo cannot remove the flag (see #13623 (comment)). Deprecation here means, well, a big warning 😆.

Ah, sorry for the confusion! I badly misread the diff as actually removing the positional, not merely hiding it 😅

@Turbo87
Copy link
Member

Turbo87 commented Jan 15, 2025

To clarify, because of the stability guarantee Cargo cannot remove the flag (see #13623 (comment)). Deprecation here means, well, a big warning 😆.

I wasn't aware either that the plan is not to remove the flag. The word "deprecated" to me means that it would go away in a future version.

I think I would personally prefer the second option mentioned in #13623 (comment):

help message mentioning stdin as an alternative for more secure operation

@epage epage force-pushed the login branch 2 times, most recently from 696a577 to 0e8578b Compare January 16, 2025 14:46
@weihanglo weihanglo added the T-cargo Team: Cargo label Jan 16, 2025
@weihanglo
Copy link
Member

@rfcbot fcp merge

This PR deprecates the optional <token> argument in cargo login, in the sense of:

  • Remove the mention of the <token> argument from cargo login help text and doc.
  • Give a warning when the <token> argument is used
    warn: cargo login <token>` is deprecated in favor of reading `<token>` from stdin`.
    

Folks, take your time to check in boxes. This is not an urgent FCP.

@rfcbot
Copy link
Collaborator

rfcbot commented Jan 16, 2025

Team member @weihanglo has proposed to merge this. The next step is review by the rest of the tagged team members:

No concerns currently listed.

Once a majority of reviewers approve (and at most 2 approvals are outstanding), this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up!

See this document for info about what commands tagged team members can give me.

@rfcbot rfcbot added proposed-final-comment-period An FCP proposal has started, but not yet signed off. disposition-merge FCP with intent to merge labels Jan 16, 2025
Copy link

@provrb provrb left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Useful change. LGTM

@rfcbot rfcbot added the final-comment-period FCP — a period for last comments before action is taken label Jan 22, 2025
@rfcbot
Copy link
Collaborator

rfcbot commented Jan 22, 2025

🔔 This is now entering its final comment period, as per the review above. 🔔

@rfcbot rfcbot removed the proposed-final-comment-period An FCP proposal has started, but not yet signed off. label Jan 22, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-cli Area: Command-line interface, option parsing, etc. A-cli-help Area: built-in command-line help A-documenting-cargo-itself Area: Cargo's documentation Command-login disposition-merge FCP with intent to merge final-comment-period FCP — a period for last comments before action is taken S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. T-cargo Team: Cargo
Projects
Status: FCP merge
Development

Successfully merging this pull request may close these issues.

8 participants