-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
Crates can easily be published to crates.io accidentally when using alternative registries #6123
Comments
@sfackler & @withoutboats, as you are both also interested in alternative registries, is this something you have put any thought into, or have a view? |
Yeah, it is something I've wondered about. In practice any accidental publishes to crates.io for us at least will fail since we don't set the license field for internal crates, which crates.io requires. It does seem like a more robust solution would be to be able to set the default publish registry in the manifest though. |
I like the idea of global configuration in |
I just realised that the registry was missing in option 3 from publish (due to not escaping it), I presume that is what you were agreeing with. |
Indeed yeah! For now I'm thinking we can start off with something like: [cargo-new]
default-publish = [] and we could expand from there |
After having a think about this overnight, I think I would prefer to add --registry as an option to new (and init) which adds the registry to publish, then in command_prelude.rs/registry() add a check for the registry, if none was provided, go to the default from config (which can also then pick up from an environment variable for free). This would then mean that all commands which take --registry would work with the default. I worry that adding default-publish in cargo-new would then introduce multiple commands which perform the same role (assuming that in time a default registry config option is added) and then we will need to document what order they are checked. |
Makes sense to me! |
Any preference on the field name in the config file for the default registry? Happy for it to be something like this?:
Or for an alternative registry we could have a new field to specify that it is the default (and only allow one to be set as default).
Personally I think that it would be better with the first option, but happy with either (or would welcome an alternative suggestion). For when a default is specified and someone wants to use crates.io, does the user just provide |
Either way's fine by me, i wouldn't have much of an opinion |
I've read the discussion but I'm not completely sure what's being proposed. I think what's being proposed is adding a |
No, it is setting the publish field in Cargo.toml based on if you pass --registry. There is also the option of adding a default registry in cargo/config files (in all the normal scopes) to allow setting where you want the default registry to be (thus not requiring passing --registry all the time if you default is an alternative registry). |
That sounds fine to me also. |
Perhaps this belongs in a separate issue, but wouldn't it be sensible to have My guess is that most people who intend to publish (on crates.io or elsewhere) will have several things they want to configure before doing so (like setting a license file), so adding another configuration tweak isn't a problem. Meanwhile, it should almost completely remove accidental publishings, like this. |
I agree that defaulting to disabled would make more sense to me, but I think that may be a more controversial change and would be better as a separate issue. |
Yes disabling publishing by default is something that shouldn't happen here, a change like that would want its own dedicated thread. |
@alexcrichton @cswindle No problem: #6153 |
Add support for a default registry for cargo commands This adds two things: - --registry support for new and init - adds default registry configuration to cargo The main reason for these changes is to reduce the risk of closed-source software ending up accidentally on crates.io. This fixes #6123.
Currently when cargo new is run it requires that users remember to set the registry that the crate can be published to, if that is not done it can lead to closed-source software being uploaded to crates.io accidentally.
For enterprises to be able to safely use alternative registries I think there should be a mechanism which allows blocking publishing by default.
A couple of options I have thought of are:
The third of these has the advantage that it could also be used in place of having —registry on every command run.
The text was updated successfully, but these errors were encountered: