summary refs log tree commit diff
path: root/install.sql
blob: 38d4ea0ea7d4875893bb9444a47556172822e0d3 (plain) (blame)
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
42
43
-- -*- mode: sql; sql-product: postgres -*-

-- Create a login role for ambassador
CREATE USER ambassador;

-- Use this if your deployment uses passwords rather than peer authentication:
-- ALTER ROLE mastodon_ambassador WITH PASSWORD 'something secret, hopefully';
--
-- Note that PostgreSQL supports setting “encrypted” (hashed) passwords,
-- which is a better option if the password must be stored in some configuration
-- management tool.


-- Now, create the view that ambassador actually uses
DROP VIEW IF EXISTS public_toots;
CREATE VIEW public_toots AS
  SELECT 
   statuses.id, statuses.reblog_of_id, statuses.account_id,
   statuses.updated_at, status_stats.favourites_count
    FROM statuses
    LEFT OUTER JOIN status_stats
     ON statuses.id = status_stats.status_id
    LEFT OUTER JOIN accounts
     ON statuses.account_id = accounts.id
   WHERE statuses.visibility = 0
    AND statuses.updated_at > NOW() - INTERVAL '30 days'
    AND statuses.local IS TRUE
    AND (accounts.id = 13104 OR accounts.note NOT ILIKE '%#nobot%')
    AND NOT EXISTS (
     SELECT 1 FROM blocks
      WHERE statuses.account_id = blocks.account_id
      AND blocks.target_account_id = 13104  -- Change 13104 to your ambassador's account ID
     )
;

-- performance helper
CREATE INDEX index_status_stats_on_favourites_count ON status_stats (favourites_count);

-- Make sure the role doesn't have access to anything undesireable
REVOKE ALL FROM ambassador;

-- Let ambassador select from the view
GRANT SELECT ON public_toots TO ambassador;