Emmanuel BENOîT
e50775ec76
* 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
158 lines
3.2 KiB
PL/PgSQL
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;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|