I hope nobody will mind me resurrecting old thread instead of creating another one for very similar problem.
Does anyone have any working example where the hostname is not known at compile time and simply matching by . is not possible? Example: dynamic ad-hoc PR envs with some hash in the domain name. myapp-{{random string}}.example.comI found a workaround with replacing “host” on conn and it matched the route, but LiveView fails match in phoenix_live_view/lib/phoenix_live_view/route.ex at main · phoenixframework/phoenix_live_view · GitHub and keeps reconnecting.
That sounds like a limitation, which could be lifted, but also could you use something like foo.<uuid>.…?
That doesn’t work if this is supposed to work with LV. Socket connections do not run on the plug pipeline, so their host value will differ to the one used on the static connection, making LiveViews call to Phoenix.Router.route_info/4 fail.
I understand when @hauleth said “before the router” it means the Plug would be referenced in the endpoint.ex file, and could be also before the socket definitions.
The socket definition is not a plug though. All it does runs before the endpoint enters it’s own plug pipeline. Feel free to take a look at more detail here:
I’d rather not change my established domain prefixes and how rest of the infrastructure and other apps work to just to get to “.uuid”. It’s one of many apps, with rest of the system already in place. I’ll probably raise a ticket to remove this limitation, I’m just worried that it could be a dangerous breaking change for other plug users. Plug support would be so much better…
Oh yeah, that’s right! I forgot. I remember coming across your PR from other threads, as usual you know what you’re talking about thanks!
In my app, I do host-to-X-header translation outside of the BEAM (for historical reasons), and use the X-header (through different code paths) for both regular routes and LiveView (plug pipeline on the relevant routes, on_mount callback on relevant LVs/live_session).