2020-10-28 16:10:24 +03:00
|
|
|
/* We define our own uuid generator function that uses gen_random_uuid() underneath.
|
|
|
|
Since the column default is not directly referencing gen_random_uuid(),
|
|
|
|
it prevents the column default to be dropped when pgcrypto or public schema is dropped unwittingly.
|
|
|
|
|
|
|
|
See https://github.com/hasura/graphql-engine/issues/4217
|
|
|
|
*/
|
|
|
|
CREATE FUNCTION hdb_catalog.gen_hasura_uuid() RETURNS uuid AS
|
|
|
|
-- We assume gen_random_uuid() is available in the search_path.
|
|
|
|
-- This may not be true but we can't do much till https://github.com/hasura/graphql-engine/issues/3657
|
|
|
|
'select gen_random_uuid()' LANGUAGE SQL;
|
|
|
|
|
2018-06-27 16:11:32 +03:00
|
|
|
CREATE TABLE hdb_catalog.hdb_version (
|
2020-10-28 16:10:24 +03:00
|
|
|
hasura_uuid UUID PRIMARY KEY DEFAULT hdb_catalog.gen_hasura_uuid(),
|
2018-06-27 16:11:32 +03:00
|
|
|
version TEXT NOT NULL,
|
2019-01-28 16:55:28 +03:00
|
|
|
upgraded_on TIMESTAMPTZ NOT NULL,
|
|
|
|
cli_state JSONB NOT NULL DEFAULT '{}'::jsonb,
|
|
|
|
console_state JSONB NOT NULL DEFAULT '{}'::jsonb
|
2018-06-27 16:11:32 +03:00
|
|
|
);
|
|
|
|
|
|
|
|
CREATE UNIQUE INDEX hdb_version_one_row
|
|
|
|
ON hdb_catalog.hdb_version((version IS NOT NULL));
|
|
|
|
|
2020-12-08 17:22:31 +03:00
|
|
|
-- Create table which stores metadata JSON blob
|
|
|
|
CREATE TABLE hdb_catalog.hdb_metadata
|
2018-06-27 16:11:32 +03:00
|
|
|
(
|
2020-12-08 17:22:31 +03:00
|
|
|
id INTEGER PRIMARY KEY,
|
|
|
|
metadata JSON NOT NULL
|
2018-06-27 16:11:32 +03:00
|
|
|
);
|
|
|
|
|
2018-09-05 14:26:46 +03:00
|
|
|
CREATE TABLE hdb_catalog.event_log
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2018-09-05 14:26:46 +03:00
|
|
|
schema_name TEXT NOT NULL,
|
|
|
|
table_name TEXT NOT NULL,
|
|
|
|
trigger_name TEXT NOT NULL,
|
|
|
|
payload JSONB NOT NULL,
|
|
|
|
delivered BOOLEAN NOT NULL DEFAULT FALSE,
|
|
|
|
error BOOLEAN NOT NULL DEFAULT FALSE,
|
|
|
|
tries INTEGER NOT NULL DEFAULT 0,
|
|
|
|
created_at TIMESTAMP DEFAULT NOW(),
|
2020-07-29 02:11:51 +03:00
|
|
|
/* when locked IS NULL the event is unlocked and can be processed */
|
2020-07-30 00:08:27 +03:00
|
|
|
locked TIMESTAMPTZ,
|
2019-11-13 10:29:19 +03:00
|
|
|
next_retry_at TIMESTAMP,
|
|
|
|
archived BOOLEAN NOT NULL DEFAULT FALSE
|
2018-09-05 14:26:46 +03:00
|
|
|
);
|
|
|
|
|
2019-03-25 20:10:52 +03:00
|
|
|
CREATE INDEX ON hdb_catalog.event_log (trigger_name);
|
2019-08-27 03:41:38 +03:00
|
|
|
CREATE INDEX ON hdb_catalog.event_log (locked);
|
2019-11-13 10:29:19 +03:00
|
|
|
CREATE INDEX ON hdb_catalog.event_log (delivered);
|
2020-03-27 07:50:45 +03:00
|
|
|
CREATE INDEX ON hdb_catalog.event_log (created_at);
|
2018-09-24 14:50:11 +03:00
|
|
|
|
2018-09-05 14:26:46 +03:00
|
|
|
CREATE TABLE hdb_catalog.event_invocation_logs
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2018-09-05 14:26:46 +03:00
|
|
|
event_id TEXT,
|
|
|
|
status INTEGER,
|
|
|
|
request JSON,
|
|
|
|
response JSON,
|
|
|
|
created_at TIMESTAMP DEFAULT NOW(),
|
|
|
|
|
|
|
|
FOREIGN KEY (event_id) REFERENCES hdb_catalog.event_log (id)
|
|
|
|
);
|
2018-09-24 14:50:11 +03:00
|
|
|
|
|
|
|
CREATE INDEX ON hdb_catalog.event_invocation_logs (event_id);
|
2018-11-23 16:02:46 +03:00
|
|
|
|
2019-05-13 12:41:07 +03:00
|
|
|
CREATE OR REPLACE FUNCTION
|
|
|
|
hdb_catalog.insert_event_log(schema_name text, table_name text, trigger_name text, op text, row_data json)
|
|
|
|
RETURNS text AS $$
|
|
|
|
DECLARE
|
|
|
|
id text;
|
|
|
|
payload json;
|
|
|
|
session_variables json;
|
|
|
|
server_version_num int;
|
2020-07-23 23:39:26 +03:00
|
|
|
trace_context json;
|
2019-05-13 12:41:07 +03:00
|
|
|
BEGIN
|
|
|
|
id := gen_random_uuid();
|
|
|
|
server_version_num := current_setting('server_version_num');
|
|
|
|
IF server_version_num >= 90600 THEN
|
|
|
|
session_variables := current_setting('hasura.user', 't');
|
2020-07-23 23:39:26 +03:00
|
|
|
trace_context := current_setting('hasura.tracecontext', 't');
|
2019-05-13 12:41:07 +03:00
|
|
|
ELSE
|
|
|
|
BEGIN
|
|
|
|
session_variables := current_setting('hasura.user');
|
|
|
|
EXCEPTION WHEN OTHERS THEN
|
|
|
|
session_variables := NULL;
|
|
|
|
END;
|
2020-07-23 23:39:26 +03:00
|
|
|
BEGIN
|
|
|
|
trace_context := current_setting('hasura.tracecontext');
|
|
|
|
EXCEPTION WHEN OTHERS THEN
|
|
|
|
trace_context := NULL;
|
|
|
|
END;
|
2019-05-13 12:41:07 +03:00
|
|
|
END IF;
|
|
|
|
payload := json_build_object(
|
|
|
|
'op', op,
|
|
|
|
'data', row_data,
|
2020-07-23 23:39:26 +03:00
|
|
|
'session_variables', session_variables,
|
|
|
|
'trace_context', trace_context
|
2019-05-13 12:41:07 +03:00
|
|
|
);
|
|
|
|
INSERT INTO hdb_catalog.event_log
|
|
|
|
(id, schema_name, table_name, trigger_name, payload)
|
|
|
|
VALUES
|
|
|
|
(id, schema_name, table_name, trigger_name, payload);
|
|
|
|
RETURN id;
|
|
|
|
END;
|
|
|
|
$$ LANGUAGE plpgsql;
|
2019-05-16 09:13:25 +03:00
|
|
|
|
2020-02-13 20:38:23 +03:00
|
|
|
CREATE TABLE hdb_catalog.hdb_action_log
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id UUID PRIMARY KEY DEFAULT hdb_catalog.gen_hasura_uuid(),
|
2020-02-13 20:38:23 +03:00
|
|
|
-- we deliberately do not reference the action name
|
|
|
|
-- because sometimes we may want to retain history
|
|
|
|
-- after dropping the action
|
|
|
|
action_name TEXT,
|
|
|
|
input_payload JSONB NOT NULL,
|
|
|
|
request_headers JSONB NOT NULL,
|
|
|
|
session_variables JSONB NOT NULL,
|
|
|
|
response_payload JSONB NULL,
|
|
|
|
errors JSONB NULL,
|
|
|
|
created_at timestamptz NOT NULL default now(),
|
|
|
|
response_received_at timestamptz NULL,
|
|
|
|
status text NOT NULL,
|
|
|
|
CHECK (status IN ('created', 'processing', 'completed', 'error'))
|
|
|
|
);
|
|
|
|
|
2020-05-13 15:33:16 +03:00
|
|
|
CREATE TABLE hdb_catalog.hdb_cron_events
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2020-05-13 15:33:16 +03:00
|
|
|
trigger_name TEXT NOT NULL,
|
|
|
|
scheduled_time TIMESTAMPTZ NOT NULL,
|
|
|
|
status TEXT NOT NULL DEFAULT 'scheduled',
|
|
|
|
tries INTEGER NOT NULL DEFAULT 0,
|
2020-09-04 20:14:54 +03:00
|
|
|
created_at TIMESTAMPTZ DEFAULT NOW(),
|
2020-05-13 15:33:16 +03:00
|
|
|
next_retry_at TIMESTAMPTZ,
|
|
|
|
|
|
|
|
CONSTRAINT valid_status CHECK (status IN ('scheduled','locked','delivered','error','dead'))
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE INDEX hdb_cron_event_status ON hdb_catalog.hdb_cron_events (status);
|
|
|
|
|
|
|
|
CREATE TABLE hdb_catalog.hdb_cron_event_invocation_logs
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2020-05-13 15:33:16 +03:00
|
|
|
event_id TEXT,
|
|
|
|
status INTEGER,
|
|
|
|
request JSON,
|
|
|
|
response JSON,
|
2020-09-04 20:14:54 +03:00
|
|
|
created_at TIMESTAMPTZ DEFAULT NOW(),
|
2020-05-13 15:33:16 +03:00
|
|
|
|
|
|
|
FOREIGN KEY (event_id) REFERENCES hdb_catalog.hdb_cron_events (id)
|
|
|
|
ON UPDATE CASCADE ON DELETE CASCADE
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE hdb_catalog.hdb_scheduled_events
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2020-05-13 15:33:16 +03:00
|
|
|
webhook_conf JSON NOT NULL,
|
|
|
|
scheduled_time TIMESTAMPTZ NOT NULL,
|
|
|
|
retry_conf JSON,
|
|
|
|
payload JSON,
|
|
|
|
header_conf JSON,
|
|
|
|
status TEXT NOT NULL DEFAULT 'scheduled',
|
|
|
|
tries INTEGER NOT NULL DEFAULT 0,
|
2020-09-04 20:14:54 +03:00
|
|
|
created_at TIMESTAMPTZ DEFAULT NOW(),
|
2020-05-13 15:33:16 +03:00
|
|
|
next_retry_at TIMESTAMPTZ,
|
|
|
|
comment TEXT,
|
|
|
|
CONSTRAINT valid_status CHECK (status IN ('scheduled','locked','delivered','error','dead'))
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE INDEX hdb_scheduled_event_status ON hdb_catalog.hdb_scheduled_events (status);
|
|
|
|
|
|
|
|
CREATE TABLE hdb_catalog.hdb_scheduled_event_invocation_logs
|
|
|
|
(
|
2020-10-28 16:10:24 +03:00
|
|
|
id TEXT DEFAULT hdb_catalog.gen_hasura_uuid() PRIMARY KEY,
|
2020-05-13 15:33:16 +03:00
|
|
|
event_id TEXT,
|
|
|
|
status INTEGER,
|
|
|
|
request JSON,
|
|
|
|
response JSON,
|
2020-09-04 20:14:54 +03:00
|
|
|
created_at TIMESTAMPTZ DEFAULT NOW(),
|
2020-05-13 15:33:16 +03:00
|
|
|
|
|
|
|
FOREIGN KEY (event_id) REFERENCES hdb_catalog.hdb_scheduled_events (id)
|
|
|
|
ON DELETE CASCADE ON UPDATE CASCADE
|
|
|
|
);
|