Additionally, even when I disable the `http2` feature, the server still handles HTTP/2 requests. I don't think it should behave this way.
TheAwiteb opened this issue · 10 comments
Additionally, even when I disable the `http2` feature, the server still handles HTTP/2 requests. I don't think it should behave this way.
Originally posted by @TheAwiteb in #851 (comment)
But have you enabled other features such as rustls openssl? These features may cause http2 to be automatically enabled.
rustls = ["http1", "http2", "dep:tokio-rustls", "dep:rustls-pemfile", "ring"]
native-tls = ["http1", "http2", "dep:tokio-native-tls", "dep:native-tls"]
openssl = ["http2", "dep:openssl", "dep:tokio-openssl"]
These features may cause http2 to be automatically enabled.
Yes I see, do you think changing this is better? because maybe I want my server only support one protocol.
We already emit a compile error if no one of those are enabled
salvo/crates/core/src/server.rs
Lines 7 to 10 in affa8cc
If all these protocols are disabled, what services are you providing?
If all these protocols are disabled, what services are you providing?
Not all, I only want http2 or only http3, or both together. Do you understand me? Meaning I don't want to support http1 for example, now the server owner is forced to support http1 while they doesn't want to.
This is a breaking change, so we can implement it in the stable release.
Your words confuse me. The code here means that as long as you have a feature enabled, there will be no compilation error.
#[cfg(not(any(feature = "http1", feature = "http2", feature = "quinn")))]
compile_error!(
"You have enabled `server` feature, it requires at least one of the following features: http1, http2, quinn."
);
I mean there is no fear of not enabling one of them. Now if I want to support only http2 I can't and I want to.
Why not? Please provide the code you have a problem with.
I have no problem with the issue, and there is no reason why I would not want to support a particular protocol. But surely there is someone who wants to support only http1 or only http2. If you do not see this as the case, you can close the issue.
What I mean is that you only need to make sure that one feature is turned on, and there will be no compilation errors. Compilation errors will only be reported when any protocol is not supported.
There is a misunderstanding here. Let's say I want my server to support http1 only, and I want rustls to support https. Can I do this now?
From what I see and what I have tried, no, because the rustls feature enables the http2 feature, do you understand me now?