Mercurial > libervia-pubsub
view db/sat_pubsub_update_2_3.sql @ 438:b5e1e8d93dd4
backend, pgsql: new `overwrite_policy` node setting:
/!\ pgsql schema needs to be updated /!\
this settings can be set currently to 2 values:
- `original_publisher` (default), when only original publisher of an item can overwrite it
(except node owner/admin)
- `any_publisher` when any entity with publishing right can overwrite any item.
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 27 Feb 2021 21:20:32 +0100 |
parents | 1dc606612405 |
children |
line wrap: on
line source
-- we check version of the database before doing anything -- and stop execution if not good \set ON_ERROR_STOP DO $$ DECLARE ver text; BEGIN SELECT value INTO ver FROM metadata WHERE key='version'; IF NOT FOUND OR ver!='2' THEN RAISE EXCEPTION 'This update file needs to be applied on database schema version 2, you use version %',ver; END IF; END$$; \unset ON_ERROR_STOP -- end of version check /* we add "presence" access model */ ALTER TABLE nodes DROP CONSTRAINT nodes_access_model_check; ALTER TABLE nodes ADD CHECK (access_model IN ('open', 'presence', 'publisher-roster', 'whitelist', 'publish-only', 'self-publisher')); /* and schema column */ ALTER TABLE nodes ADD COLUMN schema xml; /* we want xml types for items data too */ ALTER TABLE items ALTER data TYPE xml using data::xml; UPDATE metadata SET value='3' WHERE key='version';