I realize this is pushing the boundaries of tested space for this library, but I’ve got two Auth resources (Admin and User, one is global the other schema-based both with their own token tables) and I’m trying to figure out how to use the generate UI with them, but have them be separated. The default when you do that is this fun UI:
== Compilation error in file lib/app_web/router.ex ==
** (ArgumentError) AshAuthentication.Phoenix.StrategyRouter has already been forwarded to. A module can only be forwarded a single time
(phoenix 1.7.18) lib/phoenix/router/scope.ex:87: Phoenix.Router.Scope.register_forwards/3
(phoenix 1.7.18) lib/phoenix/router/scope.ex:58: Phoenix.Router.Scope.route/8
lib/app_web/router.ex:74: (module)
A module can only be forwarded to a single time??? This is news to me
Looking into it there are certain kinds of workarounds that could be done:
but honestly nothing I can think of that is something that you could apply yourself in this situation. I would first really like to understand why you can’t forward to the same plug multiple times from different routes??
I’ve pushed something up to main that you can try.
First define a plug that wraps AshAuthentication.Phoenix.StrategyRouter like so:
defmodule MyPlugThatShouldNotBeNecessary do
defdelegate init(opts), to: AshAuthentication.Phoenix.StrategyRouter
defdelegate call(conn, opts), to: AshAuthentication.Phoenix.StrategyRouter
end
then in your second call to auth_routes add strategy_router_plug: MyPlugThatShouldNotBeNecessary
This seems like a very strange limitation, but this should get you around it. If you wouldn’t mind, a PR with docs for this or an issue reminding us to add some docs around it would be great.