feat: add tenant table/logic
This commit is contained in:
parent
a37a57b437
commit
81b4027737
3 changed files with 53 additions and 3 deletions
|
|
@ -14,7 +14,7 @@ export async function validateSession({ locals }: ServerLoadEvent) {
|
|||
return redirect(307, '/login');
|
||||
}
|
||||
|
||||
if (!locals.auth.orgId && locals.auth.sessionId) {
|
||||
if ((!locals.auth.orgId && locals.auth.sessionId) || !locals.auth.orgId) {
|
||||
// Sign out the user if they are not associated with an organization
|
||||
await clerkSessionClient.sessions.revokeSession(locals.auth.sessionId);
|
||||
return redirect(307, '/login');
|
||||
|
|
@ -22,9 +22,32 @@ export async function validateSession({ locals }: ServerLoadEvent) {
|
|||
|
||||
const clerkUser = await clerkClient.users.getUser(locals.auth.userId);
|
||||
|
||||
const tenantClerkId = locals.auth.orgId;
|
||||
|
||||
let tenant = await prisma.tenant.findUnique({
|
||||
where: {
|
||||
clerkId: tenantClerkId,
|
||||
},
|
||||
});
|
||||
|
||||
if (!tenant) {
|
||||
const organization = await clerkClient.organizations.getOrganization({
|
||||
organizationId: tenantClerkId,
|
||||
});
|
||||
|
||||
tenant = await prisma.tenant.create({
|
||||
data: {
|
||||
clerkId: tenantClerkId,
|
||||
name: organization.name,
|
||||
slug: organization.slug ?? `tenant-${tenantClerkId}`,
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
let user = await prisma.user.findFirst({
|
||||
where: {
|
||||
clerkId: clerkUser.id,
|
||||
tenantId: tenant.id,
|
||||
},
|
||||
});
|
||||
|
||||
|
|
@ -41,6 +64,7 @@ export async function validateSession({ locals }: ServerLoadEvent) {
|
|||
clerkId: clerkUser.id,
|
||||
email: clerkUser.emailAddresses[0].emailAddress,
|
||||
name: clerkUser.fullName ?? '',
|
||||
tenantId: tenant.id,
|
||||
},
|
||||
});
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue