-
Notifications
You must be signed in to change notification settings - Fork 396
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
Please discourage custom schemes #484
Comments
People using custom schemes on android do it for matching the iOS scheme. Sadly on iOS, Apple doesn’t allow to intercept or use http nor https for serving local files. We can add a note to encourage people, but I think the Android webview should fix the issue and set the proper origin |
Ah, I see. I agree that's very inconvenient. Does iOS restrict any other schemes? We originally considered supporting a custom scheme for intercepted content, but ultimately decided the AssetLoader design would be simpler (and would have better device coverage). The issue is that the notion of an origin is only well defined for http(s) URLs. As I understand, the spec actually requires we treat custom schemes as origin-less. So it's not that it's something for us to "fix," but rather changing behavior would violate the spec. My colleague's response on this bug probably explains things more clearly: https://bugs.chromium.org/p/chromium/issues/detail?id=1029487#c4 |
It restricts to any scheme handled by the webview, don’t give specifics, but some of them are https, http, file and data. |
Exactly that's what I am trying to find a solution for. The "Access-Control-Allow-Origin" header is now set to I must agree that setting the app to run on As I already discussed in the Chromium bug, I still think WebView could change the behavior according to the spec. RFC6454 is kind of vague with custom schemes and in my interpretation would allow hostnames to be part of the origin on custom schemes the app implements with |
@NiklasMerz it sounds like your complaint is about setting up the "Access-Control-Allow-Origin" header. But even if you hosted your Android app on
I posted a response on crbug/1029487, since this Github probably isn't the best spot to discuss Android WebView APIs. |
Running Android on
Thank you for the reponse. This makes it clear why it is like that. |
I thought If your app connects with servers on multiple different domains, would it help for cordova-plugin-ionic-webview to give an API to set the domain during startup (this is how the AssetLoader API is designed) rather than statically in |
what difference does it make if you do it with an API or with a preference? In the end you can only have a domain and if you connect with servers on multiple domains the problem will still be there |
'ourdomain.com' is a placeholder for one domain we would choose to run our app on. Our app is designed to always do CORS requests. It's a Web App with the UI and does requests to the server configured in the app by the user.
I don't know if it's possible to allow the plugin to change the origin at runtime and make same origin requests. I would need to look further and I am not that familiar with Android APIs.
Am 6. Dez. 2019, 22:30, um 22:30, Nate Fischer <[email protected]> schrieb:
…I thought `https://ourdomain.com` was a placeholder for whatever domain
is serving the content. My understanding is you **don't** need special
CORS headers for that case, because it wouldn't be considered "cross
origin." The intention of AssetLoader (and the original
WebViewLocalServer which cordova-plugin-ionic-webview has forked) is
you would choose a domain which will give your content the same origin
as your real web server.
If your app connects with servers on multiple different domains, would
it help for cordova-plugin-ionic-webview to give an API to set the
domain during startup (this is how the AssetLoader API is designed)
rather than statically in `config.xml`? I haven't looked closely at the
plugin's implementation, so I'm not sure if this is something it could
support even if it migrated to AssetLoader. Just trying to understand
at which layer we're hitting the problem.
--
You are receiving this because you were mentioned.
Reply to this email directly or view it on GitHub:
#484 (comment)
|
I think the difference is that @NiklasMerz's app only knows which server it will connect to at runtime, they won't know at compile time. The
I'm not sure you actually need to load content on multiple origins for this use case (you only need the right origin), but we support registering an arbitrary number of AssetLoaders, each of which can load content on their own origin. Here's some example code.
I see. Our team intends AssetLoader as a way to avoid CORS requests. From the sound of it, AssetLoader itself should be sufficient for this in native apps (you would just register the AssetLoader when the user inputs their origin, which you must already know prior to loading content in the web page anyway), and the only issue is this does't integrate well with this plugin's static preferences. If it's possible, it might be nice if cordova-plugin-ionic-webview supported dynamically configuring the origin, to avoid CORS in cases like this. But I would hope most apps only need to connect to a predetermined list of origins, so they could host their content on those origins (this is what we recommend for AssetLoader/WebViewLocalServer, and it might be good to pass along the same recommendation in this repo's docs for scheme/domain). |
Since cordova apps load the app content since the beginning the hostname have to be configured before loading the app, so can’t be done with an API since plugins won’t work until the app code is loaded. Unless the API reloads the code with webview.reload/webview.loadUrl after changing the hostname |
That means I could extend the plugin to set the hostname dynamically, but that would reload the whole app app, correct? That would be feasible for us as a workaround. I don't know much about the If that's possible, I will try that out on Monday and report back. @nfischer Another option we considered would be to intercept all requests and do them natively to avoid CORS checks. But the intercept method does not allow access to POST data. Do you see any chance for https://crbug.com/155250 to be fixed. It is untriaged for some time but was discussed extensively. |
In that case, this sounds out of scope for cordova-plugin-ionic-webview. I suspect this is a very limited use case, at which point I think a native app is probably a better path forward.
Even if you If you're going that far, I think you should just register your own AssetLoader (hooked up to your WebView's
It's on our team's radar, but not currently prioritized. |
Nevermind, I was just thinking out loud ways to move http requests to native code where CORS is not a concern. But now I think we will go the "same origin route" or require server side changes. I can report, I found a way to switch the hostname at runtime. My first attempt here: I am now able to let the app run on the same originn like the server let's say Regarding the original title of this issue, we could add a note that custom schemes may not be the best option for apps requiring CORS requests. Others should not walk down a wrong path like I did :-). See also #485 |
@nfischer thanks for reaching out, we really appreciate you guys communicating w/ us. Are there any deprecations or things we should keep in mind here? i.e. is there some urgency in us finding a different solution? Feel free to email me directly as well max AT ionic DOT io |
Yeah, I think that's a good way to frame it.
We haven't finalized any deprecations yet, but non-standard schemes have historically been fragile, and we recognize there's latency from updating docs discouraging this until all the apps in the wild migrate off it. Another chromium team is working on a major rewrite of the CORS implementation (I forget the exact timeline, but should release in the next few months). There's a decent risk it won't be 100% backwards compatible, and apps using non-standard schemes are at a greater risk of seeing any incompatibilities. We would almost certainly fix such regressions as we discover them, but these sorts of bugs are often only discovered after they're released into the wild, so those fixes might take up to 6 weeks to go out. Ideally we catch this in our prerelease channels, but stuff often sneaks through due to small user population in those channels. |
I created a PR for switching the origin at runtime #486 . Going same origin this way was way better than the custom scheme for me. I hope this is the most future proof solution as well. Let me know in the PR if I could change it to get it merged. |
I'm an engineer on the Android WebView team. Custom schemes are poorly defined in web platform standards, and Android WebView generally struggles to maintain backwards compatibility for these. #348 and https://issuetracker.google.com/issues/140057007 are just a couple examples of this fragile use case breaking.
I see https://github.com/ionic-team/cordova-plugin-ionic-webview#scheme documents support for changing the scheme of content. While we encourage changing the scheme to
https://
(and would even encourage making this the default, for improved web security), we strongly discourage any other scheme (data:
,file:///
,blob:
, custom scheme, etc.). I would advise your docs to show the same recommendation.If the app wants to distinguish injected content from real web content, they should host it on a unique domain rather than a unique scheme. This is the intended use case for https://developer.android.com/reference/androidx/webkit/WebViewAssetLoader.Builder.html#setDomain(java.lang.String).
CC @HazemSamir (the author of WebViewAssetLoader).
The text was updated successfully, but these errors were encountered: