-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathprofileFuncsAndTriggers.sql
51 lines (47 loc) · 1.57 KB
/
profileFuncsAndTriggers.sql
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
44
45
46
47
48
49
50
51
-- Trigger and function for new User
CREATE OR REPLACE FUNCTION handle_new_user()
RETURNS TRIGGER AS $$
DECLARE new_slug text := LOWER(UNACCENT(CONCAT(regexp_replace(new.raw_user_meta_data ->> 'name', '[^\w]+','','g'), ROUND(RANDOM()*9),ROUND(RANDOM()*9),ROUND(RANDOM()*9),ROUND(RANDOM()*9),ROUND(RANDOM()*9))));
BEGIN
INSERT INTO public.namespaces (id, slug) VALUES (uuid_generate_v4(), new_slug);
INSERT INTO public.users (
id,
email,
name,
namespace_id,
avatar
)
VALUES (
new.id,
new.email,
COALESCE(new.raw_user_meta_data ->> 'name', new.raw_user_meta_data ->> 'this_name'),
(select id from public.namespaces where slug = new_slug),
new.raw_user_meta_data ->> 'avatar'
);
RETURN NEW;
END;
$$
LANGUAGE plpgsql SECURITY DEFINER
SET search_path = extensions, public, pg_temp;
-- trigger the function every time a user is created
DROP TRIGGER IF EXISTS on_user_created on auth.users;
CREATE TRIGGER on_user_created
AFTER INSERT ON auth.users
FOR EACH ROW EXECUTE PROCEDURE handle_new_user();
-- Trigger and function for updated User
-- update a row in public."Users" when the email is updated
CREATE OR REPLACE FUNCTION handle_updated_user()
RETURNS TRIGGER AS $$
BEGIN
UPDATE public.users
SET email = new.email
WHERE id = new.id::text;
RETURN NEW;
END;
$$
LANGUAGE plpgsql SECURITY DEFINER;
-- trigger the function every time a user is updated
DROP TRIGGER IF EXISTS on_user_updated on auth.users;
CREATE TRIGGER on_user_updated
AFTER UPDATE ON auth.users
FOR EACH ROW EXECUTE PROCEDURE handle_updated_user();