From 292e67f428f802b91c3754a9c8c29b8ecabe532f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Niemier?= Date: Tue, 2 Jul 2024 00:20:08 +0200 Subject: [PATCH] ft: do not traverse whole state for actions handling --- lib/supavisor/client_handler.ex | 28 ++++++++++------------------ 1 file changed, 10 insertions(+), 18 deletions(-) diff --git a/lib/supavisor/client_handler.ex b/lib/supavisor/client_handler.ex index 146ca166..cb1b5a49 100644 --- a/lib/supavisor/client_handler.ex +++ b/lib/supavisor/client_handler.ex @@ -931,11 +931,6 @@ defmodule Supavisor.ClientHandler do def try_get_sni(_), do: nil - @spec timeout_check(atom, non_neg_integer) :: {:timeout, non_neg_integer, atom} - defp timeout_check(key, timeout) do - {:timeout, timeout, key} - end - defp db_pid_meta({_, {_, pid}} = _key) do rkey = Supavisor.Registry.PoolPids fnode = node(pid) @@ -976,18 +971,15 @@ defmodule Supavisor.ClientHandler do defp handle_prepared_statements(_, _, _), do: nil @spec handle_actions(map) :: [{:timeout, non_neg_integer, atom}] - defp handle_actions(data) do - Enum.flat_map(data, fn - {:heartbeat_interval, v} = t when v > 0 -> - Logger.debug("ClientHandler: Call timeout #{inspect(t)}") - [timeout_check(:heartbeat_check, v)] - - {:idle_timeout, v} = t when v > 0 -> - Logger.debug("ClientHandler: Call timeout #{inspect(t)}") - [timeout_check(:idle_terminate, v)] - - _ -> - [] - end) + defp handle_actions(%{} = data) do + heartbeat = + if data.heartbeat_interval > 0, + do: [{:timeout, data.heartbeat_interval, :heartbeat_check}], + else: [] + + idle = + if data.idle_timeout > 0, do: [{:timeout, data.idle_timeout, :idle_timeout}], else: [] + + idle ++ heartbeat end end