summaryrefslogtreecommitdiff
path: root/db/rest/post/api_post_delete.sql
diff options
context:
space:
mode:
authorFreya Murphy <freya@freyacat.org>2024-03-29 22:29:56 -0400
committerFreya Murphy <freya@freyacat.org>2024-03-29 22:29:56 -0400
commit944b6b0526032ad8c1b4a2612d6723bec75e0e4c (patch)
treed3da5584df33a7878c087622b4fc2ec2883cf880 /db/rest/post/api_post_delete.sql
downloadxssbook2-944b6b0526032ad8c1b4a2612d6723bec75e0e4c.tar.gz
xssbook2-944b6b0526032ad8c1b4a2612d6723bec75e0e4c.tar.bz2
xssbook2-944b6b0526032ad8c1b4a2612d6723bec75e0e4c.zip
start database (user and post), and initial barebones home page
Diffstat (limited to 'db/rest/post/api_post_delete.sql')
-rw-r--r--db/rest/post/api_post_delete.sql31
1 files changed, 31 insertions, 0 deletions
diff --git a/db/rest/post/api_post_delete.sql b/db/rest/post/api_post_delete.sql
new file mode 100644
index 0000000..e3dec55
--- /dev/null
+++ b/db/rest/post/api_post_delete.sql
@@ -0,0 +1,31 @@
+CREATE FUNCTION _api.post_delete()
+RETURNS TRIGGER
+LANGUAGE plpgsql VOLATILE
+AS $BODY$
+DECLARE
+ _user_id INTEGER;
+BEGIN
+ _user_id = _api.get_user_id();
+
+ IF OLD.user_id <> _user_id THEN
+ PERFORM _api.raise_deny();
+ END IF;
+
+ DELETE FROM admin.post
+ WHERE user_id = _user_id
+ AND id = OLD.id;
+END
+$BODY$;
+
+GRANT EXECUTE ON FUNCTION _api.post_delete()
+ TO rest_user;
+GRANT DELETE ON TABLE api.post
+ TO rest_user;
+GRANT DELETE ON TABLE admin.post
+ TO rest_user;
+
+CREATE TRIGGER api_post_delete_trgr
+ INSTEAD OF DELETE
+ ON api.post
+ FOR EACH ROW
+ EXECUTE PROCEDURE _api.post_delete();