Skip to content

Latest commit

 

History

History
81 lines (64 loc) · 3.28 KB

README.md

File metadata and controls

81 lines (64 loc) · 3.28 KB

Multi-tenancy with RBAC for Supabase

This is a template, that enables Supabase users to quickly create multi-tenant application with role-based security access.

Rationale

I've started this project because I believe, that multi-tenancy is an important feature for small startups. It is very common to have a project where you want to host multiple tenants in the same database. And allowing them to have users, with different levels of access is another important feature.

The third reason for having this project is that I wanted to make sure that everything is covered with appropriate test cases.

Features

  • There are tenants
    • All tables must be referring the tenant table and set the appropriate RLS policy
  • The security implements a simple RBAC scheme
    • There is an enumerated type app_permissions:
      • all
      • tenant_members.assign
      • roles.edit
      • roles.assign
      • profiles.edit
    • Permissions are assigned to roles
    • Roles are assigned to groups
  • All permission must be scoped - within the current tenant
  • There are some special claims copied to auth.users.raw_app_meta_data
    • perms[] - an array of permissions
    • tenant_id - the tenant to which this user is assigned
    • tenant_access - controls access if the user can "read" or "write" the tenants table
  • All fields from user_profile are copied to auth.users.raw_user_meta_data
  • The public profile user_profiles is optional. If you don't need it, removed it from migrations.

Limitations

  • Users can be assigned to only one tenant.
  • You cannot assign tenant admin (tenant_access) normally. You have to use a database admin/superuser account for that.

Custom Claims

This project is based on the wonderful custom-claims work. As such it has the same drawback. One particular one, that you should be aware of is that permissions are set inside JWT claims. So the permission is removed the user will keep having the permission until the JWT claim expires.

One significant difference is that the roles and permissions are managed by a table, not by calling the set_claim function. Roles update is achieved through the usage of triggers.

The Demo

Go to demo folder.

  1. run npm install (only once)
  2. Configure your instance with the command below. Just make sure to change the key.
cat << EOF > .env.local
VITE_SUPABASE_URL=http://localhost:54321
VITE_SUPABASE_ANON_KEY=<your_key>
EOF
  1. run npm run dev
  2. run open http://localhost:5173/

References