-
-
Notifications
You must be signed in to change notification settings - Fork 3.7k
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
Add http
& https
asset sources
#16366
base: main
Are you sure you want to change the base?
Conversation
It looks like |
It's possible to add an exception for the licenses, but unmaintained and vulnerable is pretty bad. |
This could be done with something like |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yep this looks awesome to me! Also I wasn't aware of the surf
crate; I'll have to keep it in mind for any bevy dashboards I make in the future
@mnmaita actually that would be great, I've replaced // crates/bevy_asset/src/http_source.rs#134
let client = reqwest_middleware::ClientBuilder::new(Client::new())
.with(Cache(HttpCache {
mode: CacheMode::Default,
manager: CACacheManager::default(),
options: HttpCacheOptions::default(),
}))
.build();
let response = ContinuousPoll(client.get(str_path).send())
.await |
FWIW surf has a bug where any erroring http response >8kb stops every subsequent request from succeeding and is unlikely to ever be fixed which made me unable to use bevy_web_asset so I would personally appreciate a switch 😄. If you can't get reqwest to work perhaps hyper would suffice since it's already in the dep tree for BRP? Perhaps too low level for this. |
The council of bevy async wizards has spoken and we're going with A few notes:
|
You added a new example but didn't add metadata for it. Please update the root Cargo.toml file. |
Tested on Windows 11. The example prints a 404 error when the .meta file fails to load and doesn't show the sprite. If I configure AssetPlugin to AssetMetaCheck::Never, it runs correctly. I believe the asset is still supposed to load successfully even if the .meta file 404s so I think this is a bug? |
You can ignore that. It isn't a required check. Once those 2 small issues above are fixed, this should be in a pretty good state, I think. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Once there's a note or two about the license in the docs I'm happy to merge this.
I don't think it's worth it to merge this without https support Nowadays everything is https. hiding the license behind a not enabled feature is not a fix, because for pretty much all use cases it will need to be enabled and the license issue solved |
FWIW the situation here has improved since the linked discussions. Since v0.23.13 Rustls uses |
Thats very helpful. it increasingly looks like |
I made a PR in ureq that would allow it to be compiled without ring, and to pick any The only drawback is that rustls isn't semver 1.x, which means I can't make semver major version guarantees for ureq in this API. |
@mrchantey before we merge that PR, I just want to double check. We can't guarantee this API under semver for ureq, is that a blocker for you? I.e. hypothetically, if |
@algesten Thanks for clarifying, not a problem but good to keep in mind, I'll make a note of it in the Cargo.toml. |
Cool. Thanks! I merge! |
@algesten fyi im getting compile errors, not sure if i set the feature flags up correctly: ureq = { git = "https://github.com/algesten/ureq", rev = "fd82f2bef3c2b2a8eaeaac9aae7ea06ffe7449d3", optional = true, default-features = false, features = [
# "rustls", # compiles ok
"rustls-no-provider", # breaks compilation
"gzip",
"json",
] }
rustls = { version = "0.23", optional = true, default-features = false, features = [
"aws_lc_rs",
"logging",
"std",
"tls12",
] }
|
crates/bevy_asset/Cargo.toml
Outdated
"brotli", | ||
ureq = { git = "https://github.com/algesten/ureq", rev = "fd82f2bef3c2b2a8eaeaac9aae7ea06ffe7449d3", optional = true, default-features = false, features = [ | ||
# "rustls", # compiles ok | ||
"rustls-no-provider", # breaks compilation |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking at this now. I'll add it to the CI.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mrchantey thanks. Fixing it now. See algesten/ureq#935 Also adding the case to CI so it doesn't regress. |
@mrchantey try 423aa8f05b30799129080e1bbe821ef067b50ed2 |
@algesten awesome all working as expected 🙏 I'll leave the
|
@mrchantey We published This release reset the clock on having some "time of quiet" before going full out on 3.0.0, but there's nothing on the radar that needs fixing. |
Objective
bevy_web_asset
, allowing assets loaded viahttp
#16307Solution
http
&https
asset sourcesTesting
cargo run --example http_source
Showcase
Bevy now supports assets loaded via url!
Add the
http_source
and optionallyhttp_source_cache
features.