2023-01-28 19:26:29 +08:00
|
|
|
/* init_order = 0.5 */
|
|
|
|
|
2024-03-20 13:16:23 +08:00
|
|
|
/** A function to set the tenant_id column based on the current user. */
|
2023-01-28 19:26:29 +08:00
|
|
|
create function set_tenant_id() returns trigger as
|
|
|
|
$$ begin
|
2023-02-10 13:06:52 +08:00
|
|
|
if new.tenant_id is not null then
|
|
|
|
return new;
|
2023-01-28 19:26:29 +08:00
|
|
|
end if;
|
|
|
|
|
2023-02-10 13:06:52 +08:00
|
|
|
select tenants.id into new.tenant_id
|
|
|
|
from tenants
|
|
|
|
where tenants.db_user = current_user;
|
|
|
|
|
2023-01-28 19:26:29 +08:00
|
|
|
return new;
|
|
|
|
end; $$ language plpgsql;
|
2023-02-08 18:58:45 +08:00
|
|
|
|
2024-03-21 23:10:24 +08:00
|
|
|
/** A function to set the `updated_at` column to the current time. */
|
2024-03-20 13:16:23 +08:00
|
|
|
create function set_updated_at() returns trigger as
|
|
|
|
$$ begin
|
|
|
|
new.updated_at = now();
|
|
|
|
return new;
|
|
|
|
end; $$ language plpgsql;
|
|
|
|
|
2023-02-08 18:58:45 +08:00
|
|
|
/* no_after_each */
|