RLS doesn't work when managing policies with Drizzle?
This is taking to long to understand and I would be grateful for some help!!!
I have my schema distributed between a number of different files grouped by the table's functions/needs. All these files are in my
I am following @rphlmr โก 's
src/schemas
directory. One of these files is dedicated for policies. Nothing crazy. Something like image 1.
userProfiles
for example is correctly being imported โ
, drizzle-kit check passes with flying colors โ
, a push or a migrate call runs smoothly โ
and everything is being created in Supabase as expected โ
. Or so I think? ๐คI am following @rphlmr โก 's
createDrizzle
flow in his SupaSecureSlack example nearly exactly based on my app's needs. Here's whats done so far:
1. tables created with .enableRls()
2. policy is being added in the policies file similar to the example above.
3. new role for rls_client
was created and is being used for the client
connection
4. tables are seeded with dummy rows
5. using createDrizzle
to create a createDrizzleSupabaseClient()
function exactly like the example.
5. drizzle config looks like Image 2
The issue:
when running db.rls((tx)=> tx.select().from(userProfiles)
as an example, I get zero rows back. Running db.admin.select().from(useProfiles)
returns the right rows. So RLS is kinda working, but not really, because I definitely have the right policy. I can see it was created in Supabase. BUT, if I add a new policy directly inside of Supabase UI, exactly similar to the one already exists, then rls works. Can someone make it make sense? :nomore: ๐ฅนdata:image/s3,"s3://crabby-images/7a045/7a04503c99b02f0a767c8d872be6a1625a512350" alt="No description"
data:image/s3,"s3://crabby-images/f3deb/f3debd6775305bf6845466a3c00b8051a5b3903e" alt="No description"
3 Replies
Update: Saw that
using
and withCheck
clauses are migrating to null
in the database. Here's the relevant snippet generated from Drizzle Kit:
The attached image is a result from SELECT * FROM pg_policies WHERE tablename = 'user_profiles';
Note the only one with qual = true
is the one I created from Supabase. Anyone running into similar issues?
p.s.: no I am not using the rls_client creds for migration. I am using the admin one, on a non-pooled connection.data:image/s3,"s3://crabby-images/6571a/6571a51379881c19b5ea3595c78aa1ce5b9d56e0" alt="No description"
GitHub
[BUG]: RLS "using" rule not applied to supabase ยท Issue #4078 ยท dri...
Report hasn't been filed before. I have verified that the bug I'm about to report hasn't been filed before. What version of drizzle-orm are you using? 0.38.2 What version of drizzle-kit...
Thanks @rphlmr โก ! Btw, really appreciate your work, man.. You're a superstar!