-
Notifications
You must be signed in to change notification settings - Fork 928
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
pip install --trusted-host
support
#1339
Comments
Hi! Thanks for your feedback. Could you explain why this is valuable to you? Not saying we shouldn't have it, just want to learn more about use-cases. |
Of course! I work on developing a PyPI-compatible repository that I'll occasionally run locally either without https or using self-signed certificates, in which case I need to supply the |
This is a need I have to use with an internal mirror/index. I would love to see this implemented. |
This is perhaps tangential to this exact issue, but we'd like to see better support for secure connections to registries with custom CAs too. Right now we see |
Thanks @edwardpeek-crown ! I think we'll need to expose something like we explored in #615 |
The method @edwardpeek-crown pointed to is the way we usually implement our local config, but trusted host would work for us. I would be happy to see either implementation to allow the use of an internal mirror/registry. |
Hello, I have a similar need here. We're using an internal devpi repo with a certificate signed by an internal root CA. Those are trusted by my workstation's Windows certificate store but I'm still getting an Thank you! |
Coming from #1535 where I originally had a request for both So, related to this request for |
Linking #1474 which solved a similar use case for us. |
+1 for uv to support |
+1. Waiting for this feature so we can use uv as the default in my work team. |
+1. Seems like a superb tool, but we can't use it in our team without trusted-host support. |
Please don't comment with +1s, just upvote the original post. We'd like to keep the issue focused on substantive discussion and updates on implementation for all those subscribed. The next step here is a prototype of how we would accomplish this, i.e. |
I'd also like to see examples of tools other than |
E.g. Docker has a similar feature called |
--insecure-skip-tls-verify on kubectl
…On Fri, Mar 29, 2024, 01:23 Zanie Blue ***@***.***> wrote:
I'd also like to see examples of tools other than pip that expose a flag
to allow invalid certificates.
—
Reply to this email directly, view it on GitHub
<#1339 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AEF5Z5E444MOIYQMYFWB5PDY2TUDVAVCNFSM6AAAAABDK6NKISVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDAMRWGYZDIOBUGY>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
Hashicorp vault apparently also supports this with the environment variable VAULT_SKIP_VERIFY |
Where I work, there is an internal Pypi mirror which is also used to uploading our internal pypi packages. Unfortunately, IT has configured these hosts with "HTTP", so I have been providing both of the following args to our pip install commands. "--trusted-host" and "--extra-index-url". Please add support for both, so that I can onboard to "uv". we are already using ruff, and it is blazing fast. I am very excited to use uv as well. |
I believe that with http, if you remove the trusted-host and keep the
extra-index-url, things should work fine. For me, the problem only arises
on https with self signed certificates, which is common behind a corporate
firewall.
…On Tue, Apr 2, 2024, 13:01 Jason ***@***.***> wrote:
Where I work, there is an internal Pypi mirror which is also used to
uploading our internal pypi packages. Unfortunately, IT has configured
these hosts with "HTTP", so I have been providing both of the following
args to our pip install commands. "--trusted-host" and "--extra-index-url".
Please add support for both, so that I can onboard to "uv". we are already
using ruff, and it is blazing fast. I am very excited to use uv as well.
—
Reply to this email directly, view it on GitHub
<#1339 (comment)>, or
unsubscribe
<https://github.com/notifications/unsubscribe-auth/AEF5Z5C6XONT44KWK7IN3SLY3LI45AVCNFSM6AAAAABDK6NKISVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDAMZSGQ2TCOBWGA>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
You can check if the host is the same passed via |
@inoa-jboliveira is there an API to do so per request? We use a shared client for all of the requests we make. |
This comment was marked as off-topic.
This comment was marked as off-topic.
Unfortunately, I also need this feature - I'll try to add this in a PR. |
This is also currently a blocking feature that we need at our company. We LOVE uv and use it for a ton of our docker builds, but we have private devpi servers that we launch for testing on CI and uv won't install from them sadly. I would happily submit a PR, but I don't know rust :( |
I'm working on it currently, but it might take another week before I can submit a reviewable PR because it's more effort than I originally thought, and I only have a bit of experience with Rust, but I'm trying my best 🙂. |
@fkapsahili Feel free to put up a draft early if you need help! |
Have you tried setting the environment variable |
If you have root certificates for your registry installed in your system the workaround could be putting next lines in your native-tls = true
[pip]
index-url = "REGISTRY PATH" After this all commands work well. |
+1 This would make it much easier to migrate existing build pipelines that currently use |
If the your CA isn't working even you generated CA by command like `update-ca-certificates', please check this issue and try adjusting the permissions. I resolved the certificate issue that persisted even after setting
then
|
Hi hi all, I could do with having this feature. I run a personal PyPI repo on my network but didn't want to bother with setting up TLS for it, so I need to pass |
@charliermarsh @zanieb Does the astral team have an ETA for this? It's a huge blocker for the adoption of |
#4944 was not an acceptable solution, unfortunately. If someone is willing to investigate the solution described in the discussion there, we'll review it. Otherwise, we'll get to this when we can — we have a lot on our plate. We generally don't provide ETAs for features. Please just 👍 the OP if you want this feature, don't ping everyone following the thread asking for an update. |
PR open here: #6591. Anyone able to test this, or have advice on how to test this on macOS? :) |
(Figured out a test workflow + found a few things to fix before merging.) |
@charliermarsh The tests are only running against If you also want to test against x86 based MacOS, you have to have to use a different image. Ideally as another Test Workflow.. See runner images docs here: https://github.com/actions/runner-images?tab=readme-ov-file#available-images These are x86 with MacOS-14: |
One clarification for anyone that's been waiting on this: IIUC, this isn't necessary for |
While the new changes work fine if I use a uv.toml, I keep getting errors locally as well as in CI docker containers, when I run something like: - >
uv pip install
--allow-insecure-host="${LOCAL_NETWORK_IP}"
--extra-index-url="https://__token__:${some_token}@${LOCAL_NETWORK_IP}/api/v4/.../package1_ID/.../simple"
--extra-index-url="https://__token__:${some_token}@${LOCAL_NETWORK_IP}/api/v4/.../package2_ID/.../simple"
package1 package2 I get this chain of errors: error: Failed to download `somepackage==someversion`
Caused by: Failed to unzip wheel: somepackage.whl
Caused by: an upstream reader returned an error: io error occurred: HTTP status client error (404 Not Found) for url (the wheel url and a sha appended)
Caused by: io error occurred: HTTP status client error (404 Not Found) for url (the wheel url and a sha appended)
Caused by: HTTP status client error (404 Not Found) for url (the wheel url and a sha appended) This does not happen if I install them one by one with only one extra index url provided at a time. Is the syntax when using multiple extra-index-url's in the command line different than when I do the same with vanilla pip or is this a bug resp. not yet a feature? |
@Zyantist did you try https://docs.astral.sh/uv/reference/settings/#index-strategy |
@zmeir Thank you very much! That works like a charm, at least locally where I just tried. I will test it in CI, too and report if issues occur. Update 1: First attempt in CI failed. There I installed a wheel with multiple extra index urls and I used the --pre flag and the --system flag as I do not require a venv in a docker container. I will post more information later, when I figured out what the breaking difference is between my local attempt and in CI |
Sorry for the delayed update. I took some hours today to test whatever could be tested. I finally was able to conclude the difference were the tokens I used. The reason my attempt on CI failed is that I use project-individual access tokens there, whereas I use a private token locally. Today I tried to use the access tokens locally and all attempts at installation fail except when I use an individual access token in a single extra index url of a package that does not depend on other private packages that also require extra index url. If I use my private token in both extra index urls, it works. My private token has at lot more privileges than my access tokens. However, pip can work with these individual tokens, in CI and locally. For some reason, uv seems to either require tokens with more access rights (in complex situations) or it cannot handle multiple tokens in one installation command. Maybe this example extract of a toml helps to describe my situation: # pyproject.toml of my-project-A
...
[project]
...
dependencies = [
"public-project",
"my-project-B"
]
[project.optional-dependencies]
frontend = [
"tkinter",
"my-project-B[frontend]", # nested tag, different token and different url
]
test = [
"my-project-A[frontend]", # recursive nested tag
"pytest",
] This is what my setups look like but even a simpler one without the optional-dependencies fails to work with uv and individual tokens/urls. Are you aware of this different behaviour? |
pip install
has thetrusted-host
flag:Seems like a nice-to-have for
uv pip install
to also support this flag.The text was updated successfully, but these errors were encountered: