fix 500
This commit is contained in:
@@ -142,27 +142,3 @@ $$;
|
||||
COMMENT ON FUNCTION ems.fn_expire_modes() IS
|
||||
'Zkontroluje všechny lokality s dočasným režimem (valid_until IS NOT NULL) a přepne zpět ty s prosahlým časem.
|
||||
Volat každou minutu jako scheduled task. Vrátí řádky (site_id, site_code, old_mode, new_mode) pro každé provedené přepnutí — backend z toho pošle Discord notifikace.';
|
||||
|
||||
-- ============================================================
|
||||
|
||||
CREATE OR REPLACE FUNCTION ems.fn_update_heartbeat(
|
||||
p_site_id INT,
|
||||
p_status TEXT DEFAULT 'ok',
|
||||
p_ems_version TEXT DEFAULT NULL
|
||||
)
|
||||
RETURNS VOID
|
||||
LANGUAGE sql
|
||||
AS $$
|
||||
INSERT INTO ems.site_heartbeat (site_id, last_seen, status, ems_version)
|
||||
VALUES (p_site_id, now(), p_status, p_ems_version)
|
||||
ON CONFLICT (site_id) DO UPDATE SET
|
||||
last_seen = now(),
|
||||
status = EXCLUDED.status,
|
||||
ems_version = COALESCE(EXCLUDED.ems_version, ems.site_heartbeat.ems_version);
|
||||
$$;
|
||||
|
||||
COMMENT ON FUNCTION ems.fn_update_heartbeat(INT, TEXT, TEXT) IS
|
||||
'Aktualizuje informační heartbeat záznam EMS pro danou lokalitu.
|
||||
Volat každou minutu z backend service po úspěšném odeslání pulzu do Loxone.
|
||||
Slouží pouze pro EMS dashboard – Loxone watchdog nezávisí na této tabulce,
|
||||
sleduje HTTP pulzy přímo a nezávisle na dostupnosti DB.';
|
||||
|
||||
22
db/routines/R__077_fn_update_heartbeat.sql
Normal file
22
db/routines/R__077_fn_update_heartbeat.sql
Normal file
@@ -0,0 +1,22 @@
|
||||
create or replace function ems.fn_update_heartbeat(
|
||||
p_site_id int,
|
||||
p_status text default 'ok',
|
||||
p_ems_version text default null
|
||||
)
|
||||
returns void
|
||||
language sql
|
||||
as $$
|
||||
insert into ems.site_heartbeat (site_id, last_seen, status, ems_version)
|
||||
values (p_site_id, now(), p_status, p_ems_version)
|
||||
on conflict (site_id) do update set
|
||||
last_seen = now(),
|
||||
status = excluded.status,
|
||||
ems_version = coalesce(excluded.ems_version, ems.site_heartbeat.ems_version);
|
||||
$$;
|
||||
|
||||
comment on function ems.fn_update_heartbeat(int, text, text) is
|
||||
'Aktualizuje informační heartbeat záznam EMS pro danou lokalitu.
|
||||
Volat každou minutu z backend service po úspěšném odeslání pulzu do Loxone.
|
||||
Slouží pouze pro EMS dashboard – Loxone watchdog nezávisí na této tabulce,
|
||||
sleduje HTTP pulzy přímo a nezávisle na dostupnosti DB.';
|
||||
|
||||
Reference in New Issue
Block a user