2

您好我使用不同的域名来加载不同的数据集。我目前正在使用自定义插件根据主机名加载正确的域 ID。例如,在我endpoint.ex的路由器之前得到了这个:

plug WebApp.DomainCheck
socket "/live", Phoenix.LiveView.Socket, websocket: [connect_info: [session: @session_options]]
...
plug WebApp.Router

defmodule WebApp.DomainCheck do
  import Plug.Conn
  @behaviour Plug

  def init([]), do: []

  def call(conn, _options \\ []) do
    domains = Model.load_allowed_domains()
    case Map.get(domains, conn.host) do
      nil ->
        conn
        |> resp(401, "Domain not allowed")
        |> halt()

      domain_id ->
        conn
        |> assign(:domain_id, domain_id)
    end
  end
end

现在这适用于正常情况View,因为我domain_id在每个人中都有分​​配。但是我如何从插件中获取domain数据注入到我的 s 中呢?LiveView

目前,我已将相同的域检查代码复制到每个 LiveViews mount()页面:

defmodule WebApp.WelcomeLive do
  use WebApp, :live_view

  @impl true
  def mount(_args, _session, socket) do
    domains = Model.load_allowed_domains()
    host = socket.host_uri.host
    case Map.get(domains, host) do
      nil -> {:error, "Domain not allowed"}
      domain_id -> {:ok, assign(socket, :domain_id, domain_id)}
    end
  end

有什么方法可以使插件有效地将这些数据推送到实时视图,而无需向每个安装添加代码?

4

1 回答 1

4

我在我的应用程序中有一个类似的用例,我的插件将 auser结构放在上面,assigns并且我想将该数据保留在实时视图中而不重新加载所有内容。

我能做到这一点的唯一方法是使用通过 MFA的路由中的选项。 sessionlive

在路由器中,您将拥有类似的东西

live "/page", WebApp.SomeLiveView, :show, session: {WebAppp.Helpers, :keep_domain_id, []}

并且您WebApp.Helpers将拥有该功能,将您想要传递给实时视图的内容作为session.

defmodule WebApp.Helpers do
  def keep_domain_id(conn) do
    %{"domain_id" => conn.assigns.domain_id}
  end
end

然后在你mount的身上,你将拥有你的"domain_id"钥匙session

defmodule WebApp.WelcomeLive do
  use WebApp, :live_view

  @impl true
  def mount(_args, %{"domain_id" => domain} = _session, socket) do
    ...
  end
end
于 2020-12-18T14:56:44.267 回答