Files
omnivore/packages/db/migrations/0011.do.article_saving_request.sql
2022-02-11 09:24:33 -08:00

41 lines
1.5 KiB
PL/PgSQL
Executable File

-- Type: DO
-- Name: article_saving_request
-- Description: Creates article saving request table
BEGIN;
CREATE TABLE omnivore.article_saving_request (
id uuid PRIMARY KEY DEFAULT uuid_generate_v1mc(),
user_id uuid NOT NULL REFERENCES omnivore.user ON DELETE CASCADE,
article_id uuid REFERENCES omnivore.article ON DELETE CASCADE,
status text DEFAULT 'PROCESSING',
error_code text,
created_at timestamptz NOT NULL DEFAULT current_timestamp,
updated_at timestamptz NOT NULL DEFAULT current_timestamp
);
CREATE TRIGGER update_article_saving_request_modtime BEFORE UPDATE ON omnivore.article_saving_request FOR EACH ROW EXECUTE PROCEDURE update_updated_at_column();
ALTER TABLE omnivore.article_saving_request ENABLE ROW LEVEL SECURITY;
-- Enabling reading policy for everybody to reduce trx amount and in case we would need any analytics on this
CREATE POLICY read_article_saving_request on omnivore.article_saving_request
FOR SELECT TO omnivore_user
USING (true);
CREATE POLICY create_article_saving_request on omnivore.article_saving_request
FOR INSERT TO omnivore_user
WITH CHECK (true);
CREATE POLICY update_article_saving_request on omnivore.article_saving_request
FOR UPDATE TO omnivore_user
USING (user_id = omnivore.get_current_user_id());
CREATE POLICY delete_article_saving_request on omnivore.article_saving_request
FOR DELETE TO omnivore_user
USING (user_id = omnivore.get_current_user_id());
GRANT SELECT, INSERT, UPDATE, DELETE ON omnivore.article_saving_request TO omnivore_user;
COMMIT;