-
Notifications
You must be signed in to change notification settings - Fork 473
Enable WebChannel messages for custom FxA servers #6225
Comments
In a different (possibly out-of-band?) conversation, I recall @csadilek suggesting to make a couple of different copies of the fxa-webchannel support module - one that is used by default and hard-codes the prod FxA domain, one that can be used when configured to talk to stage, and perhaps one that has slightly different perf characteristics that can be used with any arbitrary domain. This sounds like a lot of potential for code duplication but perhaps we could avoid that with careful factoring. Another option is to disable webchannels for non-prod servers and fall back to the plain OAuth flow, at the cost of losing CWTS during signup. We probably shouldn't do this for stage (since it changes QA experience between stage and prod) but we could do it for self-hosters. |
FYIW I'd be fine with either making a version of the extension or even changing the behavior the current one to set itself up (with the |
This is accurate. |
Just be extra clear, this would change the current extension to be injected for all domains, while the Kotlin code would have to grow the capability to decide whether or not it wants to listen from a particular domain. (e.g. by comparing |
Other conversation was here: #6012. I think we can combine and close one of these tickets. Duplication can be minimal and would definitely address this concern: #6012 (comment) But other solutions welcome, of course :). |
Summary of the latest developments:
|
Renaming the ticket to acknowledge this ticket is about allowing arbitrary FxA servers to send WebChannel messages to Kotlin. #6012 is for Mozilla-owned non-prod servers. |
We've done part of this now - the origin-checking is now performed in |
Hello there. I'm working on self hosting fxa stack and i try to use @eoger 's second method to make fenix work with self hosting fxa.
However I cannot make this work. diff --git a/components/feature/accounts/src/main/assets/extensions/fxawebchannel/background.js b/components/feature/accounts/src/main/assets/extensions/fxawebchannel/background.js
new file mode 100644
index 000000000..b3ce7148e
--- /dev/null
+++ b/components/feature/accounts/src/main/assets/extensions/fxawebchannel/background.js
@@ -0,0 +1,18 @@
+/*
+Establish communication with native application.
+*/
+let port = browser.runtime.connectNative("mozacWebchannelBackground");
+/*
+Handle messages from native application, dispatch them to FxA via an event.
+*/
+port.onMessage.addListener( event => {
+ if(event.type == "overrideFxAServer"){
+ // TODO: unregister
+ browser.contentScripts.register({
+ "matches": [ event.url+"/*" ],
+ "js": [{file: "fxawebchannel.js"}],
+ "runAt": "document_start"
+ })
+ }
+});
+
diff --git a/components/feature/accounts/src/main/assets/extensions/fxawebchannel/manifest.json b/components/feature/accounts/src/main/assets/extensions/fxawebchannel/manifest.json
index 007b9bc1c..264179844 100644
--- a/components/feature/accounts/src/main/assets/extensions/fxawebchannel/manifest.json
+++ b/components/feature/accounts/src/main/assets/extensions/fxawebchannel/manifest.json
@@ -15,6 +15,9 @@
"run_at": "document_start"
}
],
+ "background": {
+ "scripts": ["background.js"]
+ },
"permissions": [
"mozillaAddons",
"geckoViewAddons",
diff --git a/components/feature/accounts/src/main/java/mozilla/components/feature/accounts/FxaWebChannelFeature.kt b/components/feature/accounts/src/main/java/mozilla/components/feature/accounts/FxaWebChannelFeature.kt
index 421f4fd1a..263d1bac6 100644
--- a/components/feature/accounts/src/main/java/mozilla/components/feature/accounts/FxaWebChannelFeature.kt
+++ b/components/feature/accounts/src/main/java/mozilla/components/feature/accounts/FxaWebChannelFeature.kt
@@ -73,7 +73,7 @@ class FxaWebChannelFeature(
override fun start() {
extensionController.install(runtime)
-
+ extensionController.registerBackgroundMessageHandler(WebChannelViewBackgroundMessageHandler(serverConfig),"mozacWebchannelBackground")
scope = store.flowScoped { flow ->
flow.mapNotNull { state -> state.findCustomTabOrSelectedTab(customTabSessionId) }
.ifChanged { it.engineState.engineSession }
@@ -161,6 +161,17 @@ class FxaWebChannelFeature(
extensionController.registerContentMessageHandler(engineSession, messageHandler)
}
+ private class WebChannelViewBackgroundMessageHandler(
+ private val serverConfig: ServerConfig
+ ) : MessageHandler {
+ @SuppressWarnings("ComplexMethod")
+ override fun onPortConnected(port: Port) {
+ logger.debug("in WebChannelViewBackgroundMessageHandler onPortConnected begin")
+ port.postMessage(JSONObject().put("type", "overrideFxAServer").put("url",serverConfig.contentUrl))
+ logger.debug("in WebChannelViewBackgroundMessageHandler onPortConnected done")
+ }
+ }
+
@VisibleForTesting
companion object {
private val logger = Logger("mozac-fxawebchannel") Any help would be appericated. Thanks. |
Using the Firefox Beta app, the custom account and sync server URLs can be displayed but even when correct self-hosted FXA/sync URLs are added (using @jackyzy823 's https://github.com/jackyzy823/fxa-selfhosting project), the login page just wouldn't load. Self-hosting FXA/sync is a good thing between desktop browsers but it would be great if it could work between desktop and mobile apps. I even started self-hosting it to be able to transfer links between desktop and mobile and continue reading on either devices. Why on Earth would the Beta app display the custom URL fields if it's useless because some other settings are hard-coded? 😀 The "old" Firefox app was working fine with the self-hosted FXA/sync stack, please allow Fenix to work with it, too. These are the settings we can set in Firefox Desktop about:config to make the self-hosted FXA/sync work:
These are the settings that we need in Firefox Android (Beta) about:config to make the self-hosted FXA/sync work:
https://www.fxa.local and https://token.fxa.local can be added to Firefox Android (Beta) with the debug settings enabled, but the webchannel whitelist is still missing. Please allow setting it in the Beta, too. |
@immanuelfodor's observation still applies for 87.0.0-rc.1
|
Are there any chance to get this merged? |
* Accounts: Make webchannel work with custom fxa server * Accounts: Send overrideFxAServer message only to custom fxa server * Accounts: make webchannel background message name constant Co-authored-by: Grisha Kruglov <gkruglov@mozilla.com>
#9827 merged (apologies to all for the delay there), so in theory, the next Fenix Nightly should work well with a |
…ozilla-mobile#9827) * Accounts: Make webchannel work with custom fxa server * Accounts: Send overrideFxAServer message only to custom fxa server * Accounts: make webchannel background message name constant Co-authored-by: Grisha Kruglov <gkruglov@mozilla.com>
So, Firefox Nightly is supposed to allow me to log in to a self-hosted FxA server now? |
still a problem in 102: setting a custom auth server in fenix does not work properly, the UI presented by the auth server cannot access the webchannel |
it looks like https://github.com/mozilla-mobile/android-components/blob/main/components/feature/accounts/src/main/assets/extensions/fxawebchannel/background.js#L15 is never triggered for the account server url (as set in the secet config menu). opening the account server page and sending a |
we've installed a fresh copy of firefox from the fenix github repository (103.2.0) to make sure we have an absolutely clean slate and the same happens, although running the full fragment does not seem to be required. just executing the one commonality we see among all those is that the first reply to a status query is always an error, if the actual reply is sent it is sent second. edit: after much more investigation i think we figured out what happened.
so this is not so much a bug that this feature isn't working, it's more that fenix always sends a channel error first, before the actual reply. |
Thanks @pennae for the summary, and glad to read you figured this out! The "No such channel" errors come from outdated functionality. I will close this ticket as completed. We have https://bugzilla.mozilla.org/show_bug.cgi?id=1616635 (which I will re-open). |
Right now setting up a different FxA server on Fenix will not work, because WebChannel messages can't get through. (
JavaScript Error: "account_updates error message. No Such Channel"
)This is caused by the
fxawebchannel.js
content script only getting injected on the prod server pages.What we could do is either:
FxaWebChannelFeature.kt
.@grigoryk @csadilek @vladikoff thoughts?
┆Issue is synchronized with this Jira Task
The text was updated successfully, but these errors were encountered: