Deprecated RLS features
Last edited: 10/17/2025
The auth.role() function is now deprecated
The auth.role() function has been deprecated in favour of using the TO field, natively supported within Postgres:
12345678910111213-- DEPRECATEDcreate policy "Public profiles are viewable by everyone."on profiles for select using (  auth.role() = 'authenticated' or auth.role() = 'anon');-- RECOMMENDEDcreate policy "Public profiles are viewable by everyone."on profiles for selectto authenticated, anonusing (  true);The auth.email() function is now deprecated
The auth.email() function has been deprecated in favour a more generic function to return the full JWT:
1234567891011- DEPRECATEDcreate policy "User can view their profile."on profiles for select using (  auth.email() = email);-- RECOMMENDEDcreate policy "User can view their profile."on profiles for select using (  (auth.jwt() ->> 'email') = email);