This repository has been archived on 2025-01-04. You can view files and clone it, but cannot push or open issues or pull requests.
lwb6/legacyworlds-server-data/db-structure/parts/040-functions/002-sys.sql
Emmanuel BENOîT e50775ec76 Database definition & tests organisation
* The main loader script has been updated to generate the list of files
it needs to load automatically. As a consequence, files that contained
manually-maintained lists of scripts have been removed, and definition
directories have been renamed accordingly.

* PostgreSQL extension loading and configuration has been moved to a
separate script to be loaded automatically in the main transaction.

* Data and function definition scripts that had the -data or -functions
suffix have been renamed (the suffix is unnecessary).

* Unit tests have been reorganised to follow the definition's structure.

* Documentation has been improved
2012-01-06 11:19:19 +01:00

158 lines
3.2 KiB
PL/PgSQL

-- LegacyWorlds Beta 6
-- PostgreSQL database scripts
--
-- System management functions
--
-- Copyright(C) 2004-2010, DeepClone Development
-- --------------------------------------------------------
--
-- Gets the next tick's identifier
--
CREATE OR REPLACE FUNCTION sys.get_tick( )
RETURNS BIGINT
STRICT STABLE
SECURITY INVOKER
AS $$
SELECT next_tick FROM sys.status;
$$ LANGUAGE SQL;
--
-- Registers a new ticker task
--
CREATE OR REPLACE FUNCTION sys.register_ticker_task( t_name TEXT )
RETURNS INT
STRICT VOLATILE
SECURITY DEFINER
AS $$
INSERT INTO sys.ticker ( task_name , status )
VALUES ( $1 , 'RUNNING' )
RETURNING id;
$$ LANGUAGE SQL;
GRANT EXECUTE ON FUNCTION sys.register_ticker_task( TEXT ) TO :dbuser;
--
-- Indicates that a ticker task was started automatically
--
-- Parameters:
-- task_id Task identifier
--
CREATE OR REPLACE FUNCTION sys.set_task_started( task_id INT )
RETURNS VOID
STRICT VOLATILE
SECURITY DEFINER
AS $$
DECLARE
t_name TEXT;
BEGIN
SELECT INTO t_name task_name FROM sys.ticker
WHERE id = task_id AND status = 'AUTO' FOR UPDATE;
IF FOUND
THEN
UPDATE sys.ticker SET status = 'RUNNING' , auto_start = NULL
WHERE id = task_id;
PERFORM sys.write_sql_log( 'Ticker' , 'INFO'::log_level , 'Scheduled task ''' || t_name
|| ''' has been enabled' );
END IF;
END;
$$ LANGUAGE plpgsql;
GRANT EXECUTE ON FUNCTION sys.set_task_started( INT ) TO :dbuser;
--
-- Starts or stops a task
--
-- Parameters:
-- admin_id Administrator identifier
-- task_id Task identifier
-- running Whether the task should be started or stopped
--
CREATE OR REPLACE FUNCTION sys.set_task_running( admin_id INT , task_id INT , running BOOLEAN )
RETURNS VOID
STRICT VOLATILE
SECURITY DEFINER
AS $$
DECLARE
n_stat ticker_task_status;
t_name TEXT;
BEGIN
n_stat := ( CASE WHEN running THEN 'RUNNING' ELSE 'STOPPED' END );
SELECT INTO t_name task_name FROM sys.ticker
WHERE id = task_id AND status <> n_stat FOR UPDATE;
IF FOUND
THEN
UPDATE sys.ticker SET status = n_stat , auto_start = NULL
WHERE id = task_id;
PERFORM admin.write_log( admin_id , 'INFO'::log_level , 'Ticker task ''' || t_name
|| ''' changed to status ' || n_stat );
END IF;
END;
$$ LANGUAGE plpgsql;
GRANT EXECUTE ON FUNCTION sys.set_task_running( INT , INT , BOOLEAN ) TO :dbuser;
--
-- Schedules a task to start automatically at a later date
--
-- Parameters:
-- admin_id Administrator identifier
-- task_id Task identifier
-- delay Delay, in seconds, before the task starts
--
-- Returns:
-- start_at Time and date at which the task will start
--
CREATE OR REPLACE FUNCTION sys.schedule_task( admin_id INT , task_id INT , delay BIGINT , OUT start_at TIMESTAMP WITHOUT TIME ZONE )
STRICT VOLATILE
SECURITY DEFINER
AS $$
DECLARE
t_name TEXT;
BEGIN
start_at := now() + ( delay || 's' )::INTERVAL;
SELECT INTO t_name task_name FROM sys.ticker
WHERE id = task_id FOR UPDATE;
IF NOT FOUND
THEN
RETURN;
END IF;
UPDATE sys.ticker SET status = 'AUTO' , auto_start = start_at WHERE id = task_id;
PERFORM admin.write_log( admin_id , 'INFO'::log_level , 'Ticker task ''' || t_name
|| ''' scheduled to start ' || start_at );
END;
$$ LANGUAGE plpgsql;
GRANT EXECUTE ON FUNCTION sys.schedule_task( INT , INT , BIGINT ) TO :dbuser;