Adding Admin users | Next.js Supabase Lite Kit
A quick guide to set the correct permissions to add new admin users
To access the Super Admin, your users need to be updated with the correct Custom Claims. We use custom claims to verify they can access the super admin.
We do so by setting the role
property to super-admin
.
{ "role": "super-admin"}
You can provide more roles for your super admin users - but we only use super-admin
by default, which is equipped with all permissions.
If you're using the emulator, the user test@makerkit.dev
is set up with super admin permissions by default.
Setting your user as Super Admin
To set a user's custom claims against a production environment, we need to run an SQL query from the Supabase dashboard and set the correct claims for your user.
- Navigate to the SQL Query runner: From the Supabase dashboard, navigate to the SQL Query page - where we can run arbitrary commands against our Postgres Database.
- Grab the ID of your user: Now, copy this code below in a text editor and replace
<user_id>
with your real user's ID.
UPDATE auth.users SET raw_app_meta_data = raw_app_meta_data || '{"role": "super-admin"}' WHERE id='<user_id>';
Once copied the full query with your correct user ID, run the query in the Supabase query runner. Your user is now a super-admin and can access the Super Admin panel in your app.
Your user may need to log out and log in again to see the changes.
Please test this in a staging environment before running this in production.
Enforce MFA
For added security, you can enforce the admin to be signed out using MFA by toggling the constant ENFORCE_MFA
to from false
to true
.
const ENFORCE_MFA = true;