db/schema/0301_grp_usr.sql
Orion Kindel 38893b5861
Some checks failed
migrate-stage / migrate-stage (push) Successful in 6s
gen-migrations / gen-migrations (push) Failing after 12s
migrate-devel / migrate-devel (push) Failing after 4s
fix: do_grp_add_admins
2023-07-20 15:45:18 -05:00

60 lines
1.3 KiB
PL/PgSQL

create table public.grp_usr
( grp int not null references public.grp(id)
, usr int not null references public.usr(id)
, primary key (grp, usr)
);
create function public.grp_add_member(to_grp int, add_usr int)
returns void
volatile
language plpgsql
as $$
begin
insert into public.grp_usr (grp, usr) values (to_grp, add_usr);
end;
$$;
create function public.grp_add_members(to_grp int, add_usrs int[])
returns void
volatile
language plpgsql
as $$
begin
insert into public.grp_usr (grp, usr)
select grp, usr_id
from unnest(add_usrs) usr_id
left join public.grp_usr gu on gu.usr = usr_id and gu.grp = to_grp
where gu is null;
end;
$$;
create function public.grp_members(of_grp int)
returns setof public.usr
stable
language plpgsql
as $$
begin
return query select u.*
from public.grp_usr gu
inner join public.usr u on gu.usr = u.id
where gu.grp = of_grp;
end;
$$;
create function public.grp_members_admins()
returns setof public.usr
stable
language sql
as $$select * from public.grp_members((public.grp_admins()).id)$$;
create function public.grp_rm_member(from_grp int, rm_usr int)
returns void
volatile
language plpgsql
as $$
begin
delete from public.grp_usr gu
where gu.grp = from_grp and gu.usr = rm_usr;
end;
$$;