summaryrefslogtreecommitdiff
path: root/src/db/rest/util/_api_serve_media.sql
blob: c2e213a7e3bb296b57ec31b975d55fdee76c8082 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
CREATE FUNCTION _api.serve_media(
	_media_id INTEGER
)
RETURNS sys."*/*"
LANGUAGE plpgsql VOLATILE
AS $BODY$
DECLARE
	_headers TEXT;
	_data BYTEA;
BEGIN

	SELECT FORMAT(
      '[{"Content-Type": "%s"},'
       '{"Content-Disposition": "inline; filename=\"%s\""},'
       '{"Cache-Control": "max-age=259200"}]'
      ,	m.type, m.name)
	FROM admin.media m
	WHERE m.id = _media_id INTO _headers;

	PERFORM SET_CONFIG('response.headers', _headers, true);

	SELECT m.content
	FROM admin.media m
	WHERE m.id = _media_id
	INTO _data;

	IF FOUND THEN
		RETURN(_data);
	ELSE
		PERFORM _api.raise(
			_msg => 'api_not_found',
			_err => 404
		);
	END IF;
END
$BODY$;

GRANT EXECUTE ON FUNCTION _api.serve_media(INTEGER)
	TO rest_anon, rest_user;
GRANT SELECT ON TABLE admin.media
	TO rest_anon, rest_user;