working on db logic
Some checks failed
CI/CD Pipeline / build (push) Failing after 3s

This commit is contained in:
2026-03-12 15:01:33 -06:00
parent 399eb9f93f
commit 4dc4814b2f
21 changed files with 573 additions and 256 deletions

View File

@@ -1,5 +1,6 @@
defmodule ElixirAi.ClusterSingleton do
use GenServer
require Logger
@sync_delay_ms 200
@@ -7,25 +8,46 @@ defmodule ElixirAi.ClusterSingleton do
def start_link(opts), do: GenServer.start_link(__MODULE__, opts, name: __MODULE__)
@impl true
def init(_opts) do
Process.send_after(self(), :start_singletons, @sync_delay_ms)
{:ok, :pending}
end
@impl true
def handle_info(:start_singletons, state) do
def handle_info(:start_singletons, _state) do
for module <- @singletons do
case Horde.DynamicSupervisor.start_child(ElixirAi.ChatRunnerSupervisor, module) do
{:ok, _pid} -> :ok
{:error, {:already_started, _pid}} -> :ok
{:error, :already_present} -> :ok
{:error, reason} ->
require Logger
Logger.warning("ClusterSingleton: failed to start #{inspect(module)}: #{inspect(reason)}")
if singleton_exists?(module) do
Logger.debug(
"ClusterSingleton: singleton already exists, skipping start for #{inspect(module)}"
)
else
case Horde.DynamicSupervisor.start_child(ElixirAi.ChatRunnerSupervisor, module) do
{:ok, _pid} ->
:ok
{:error, {:already_started, _pid}} ->
:ok
{:error, :already_present} ->
:ok
{:error, reason} ->
Logger.warning(
"ClusterSingleton: failed to start #{inspect(module)}: #{inspect(reason)}"
)
end
end
end
{:noreply, :started}
end
defp singleton_exists?(module) do
case Horde.Registry.lookup(ElixirAi.ChatRegistry, module) do
[{pid, _metadata} | _] when is_pid(pid) ->
true
_ ->
false
end
end
end