mirror of
https://github.com/thiloho/archtika.git
synced 2025-11-22 02:41:35 +01:00
Replace SQL wildcard selectors with explicit columns for better versioning
This commit is contained in:
@@ -8,55 +8,111 @@ FROM internal.user;
|
|||||||
CREATE VIEW api.website
|
CREATE VIEW api.website
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
id,
|
||||||
|
owner_id,
|
||||||
|
content_type,
|
||||||
|
title,
|
||||||
|
created_at,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.website;
|
FROM internal.website;
|
||||||
|
|
||||||
CREATE VIEW api.media
|
CREATE VIEW api.media
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
id,
|
||||||
|
website_id,
|
||||||
|
user_id,
|
||||||
|
original_name,
|
||||||
|
file_system_path,
|
||||||
|
created_at
|
||||||
FROM internal.media;
|
FROM internal.media;
|
||||||
|
|
||||||
CREATE VIEW api.settings
|
CREATE VIEW api.settings
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
accent_color_light_theme,
|
||||||
|
accent_color_dark_theme,
|
||||||
|
favicon_image,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.settings;
|
FROM internal.settings;
|
||||||
|
|
||||||
CREATE VIEW api.header
|
CREATE VIEW api.header
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
logo_type,
|
||||||
|
logo_text,
|
||||||
|
logo_image,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.header;
|
FROM internal.header;
|
||||||
|
|
||||||
CREATE view api.home
|
CREATE view api.home
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
main_content,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.home;
|
FROM internal.home;
|
||||||
|
|
||||||
CREATE VIEW api.article
|
CREATE VIEW api.article
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
id,
|
||||||
|
website_id,
|
||||||
|
title,
|
||||||
|
meta_description,
|
||||||
|
meta_author,
|
||||||
|
cover_image,
|
||||||
|
publication_date,
|
||||||
|
main_content,
|
||||||
|
created_at,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.article;
|
FROM internal.article;
|
||||||
|
|
||||||
CREATE VIEW api.footer
|
CREATE VIEW api.footer
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
additional_text,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.footer;
|
FROM internal.footer;
|
||||||
|
|
||||||
CREATE VIEW api.collab
|
CREATE VIEW api.collab
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
user_id,
|
||||||
|
permission_level,
|
||||||
|
added_at,
|
||||||
|
last_modified_at,
|
||||||
|
last_modified_by
|
||||||
FROM internal.collab;
|
FROM internal.collab;
|
||||||
|
|
||||||
CREATE VIEW api.change_log
|
CREATE VIEW api.change_log
|
||||||
WITH (security_invoker = on)
|
WITH (security_invoker = on)
|
||||||
AS
|
AS
|
||||||
SELECT *
|
SELECT
|
||||||
|
website_id,
|
||||||
|
user_id,
|
||||||
|
change_summary,
|
||||||
|
previous_value,
|
||||||
|
new_value,
|
||||||
|
timestamp
|
||||||
FROM internal.change_log;
|
FROM internal.change_log;
|
||||||
|
|
||||||
CREATE FUNCTION
|
CREATE FUNCTION
|
||||||
|
|||||||
@@ -0,0 +1,42 @@
|
|||||||
|
-- migrate:up
|
||||||
|
CREATE VIEW api.website_overview AS
|
||||||
|
SELECT
|
||||||
|
w.id,
|
||||||
|
w.owner_id,
|
||||||
|
w.content_type,
|
||||||
|
w.title,
|
||||||
|
s.accent_color_light_theme,
|
||||||
|
s.accent_color_dark_theme,
|
||||||
|
s.favicon_image,
|
||||||
|
h.logo_type,
|
||||||
|
h.logo_text,
|
||||||
|
h.logo_image,
|
||||||
|
ho.main_content,
|
||||||
|
f.additional_text,
|
||||||
|
(
|
||||||
|
SELECT json_agg(
|
||||||
|
json_build_object(
|
||||||
|
'title', a.title,
|
||||||
|
'meta_description', a.meta_description,
|
||||||
|
'meta_author', a.meta_author,
|
||||||
|
'cover_image', a.cover_image,
|
||||||
|
'publication_date', a.publication_date,
|
||||||
|
'main_content', a.main_content
|
||||||
|
)
|
||||||
|
)
|
||||||
|
FROM internal.article a
|
||||||
|
WHERE a.website_id = w.id
|
||||||
|
) AS articles
|
||||||
|
FROM
|
||||||
|
internal.website w
|
||||||
|
JOIN internal.settings s ON w.id = s.website_id
|
||||||
|
JOIN internal.header h ON w.id = h.website_id
|
||||||
|
JOIN internal.home ho ON w.id = ho.website_id
|
||||||
|
JOIN internal.footer f ON w.id = f.website_id;
|
||||||
|
|
||||||
|
GRANT SELECT ON api.website_overview TO authenticated_user;
|
||||||
|
|
||||||
|
-- migrate:down
|
||||||
|
REVOKE SELECT ON api.website_overview FROM authenticated_user;
|
||||||
|
|
||||||
|
DROP VIEW api.website_overview;
|
||||||
Reference in New Issue
Block a user