dotfiles/app/lib/prymn_web/live/server_live/index.ex

73 lines
1.8 KiB
Elixir

defmodule PrymnWeb.ServerLive.Index do
require Logger
alias Prymn.{Servers, Agents}
use PrymnWeb, :live_view
@impl true
def mount(_params, _session, socket) do
servers = Servers.list_servers()
# pid = self()
for %Servers.Server{status: :registered, public_ip: ip} <- servers do
:ok = Phoenix.PubSub.subscribe(Prymn.PubSub, "agent:#{ip}")
Task.start_link(fn ->
case Agents.ensure_connection(ip) do
:ok -> IO.puts("Ok")
_ -> IO.puts("not ok")
end
end)
end
{:ok, assign(socket, :servers, servers)}
end
@impl true
def handle_params(params, _url, socket) do
{:noreply, apply_action(socket, socket.assigns.live_action, params)}
end
defp apply_action(socket, :new, _params) do
socket
|> assign(:page_title, "New Server")
end
defp apply_action(socket, :index, _params) do
socket
|> assign(:page_title, "Listing Servers")
end
@impl true
def handle_info({:connect, %Servers.Server{} = server}, socket) do
{:noreply,
socket
|> update(:servers, fn servers -> [server | servers] end)}
end
@impl true
def handle_info({:healthcheck, ip, _message}, socket) do
servers =
update_in(
socket.assigns.servers,
[Access.filter(&match?(%{public_ip: ^ip}, &1))],
&Map.merge(&1, %{connection_status: "Connected"})
)
{:noreply, assign(socket, :servers, servers)}
end
@impl true
def handle_info(msg, state) do
Logger.debug("received unexpected message #{inspect(msg)}")
{:noreply, state}
end
# @impl true
# def handle_event("delete", %{"id" => id}, socket) do
# server = Servers.get_server!(id)
# {:ok, _} = Servers.delete_server(server)
# {:noreply, stream_delete(socket, :servers, server)}
# end
end