From 3342e940390e33d62800562d254c842143fd6d57 Mon Sep 17 00:00:00 2001 From: Dustin Do Date: Sun, 22 Sep 2024 10:47:52 +0700 Subject: [PATCH] feat(api): restrict budget creation based on entitlement --- apps/api/v1/services/budget.service.ts | 17 +++++++++++------ apps/api/v1/services/user.service.ts | 8 ++++++++ 2 files changed, 19 insertions(+), 6 deletions(-) diff --git a/apps/api/v1/services/budget.service.ts b/apps/api/v1/services/budget.service.ts index c7f81d9f..6ba37eac 100644 --- a/apps/api/v1/services/budget.service.ts +++ b/apps/api/v1/services/budget.service.ts @@ -1,4 +1,7 @@ -import { calculateBudgetPeriodStartEndDates } from '@6pm/utilities' +import { + calculateBudgetPeriodStartEndDates, + getPlanConfig, +} from '@6pm/utilities' import type { CreateBudget, UpdateBudget } from '@6pm/validation' import { type Budget, @@ -9,6 +12,7 @@ import { } from '@prisma/client' import prisma from '../../lib/prisma' import { inviteUserToBudget } from './budget-invitation.service' +import { getUserPlan } from './user.service' const BUDGET_INCLUDE: Prisma.BudgetInclude = { periodConfigs: true, @@ -19,12 +23,13 @@ type BudgetPopulated = Budget & { } export async function canUserCreateBudget({ - // biome-ignore lint/correctness/noUnusedVariables: user, -}: { - user: User -}): Promise { - return true +}: { user: User }): Promise { + const userBudgets = await findBudgetsOfUser({ user }) + const userPlan = getUserPlan(user) + const maxBudgets = getPlanConfig(userPlan, 'maxBudgets') + + return maxBudgets !== null && userBudgets.length < maxBudgets } export async function canUserReadBudget({ diff --git a/apps/api/v1/services/user.service.ts b/apps/api/v1/services/user.service.ts index 09a4dd00..9b068a0d 100644 --- a/apps/api/v1/services/user.service.ts +++ b/apps/api/v1/services/user.service.ts @@ -1,3 +1,4 @@ +import type { UserEntitlement } from '@6pm/utilities' import type { CreateUser } from '@6pm/validation' import type { User } from '@prisma/client' import { getLogger } from '../../lib/log' @@ -99,3 +100,10 @@ export async function syncAllUsersSubscription() { failed, } } + +/** @alias getUserEntitlement */ +export const getUserPlan = (user: User): UserEntitlement => { + return (user.entitlement as UserEntitlement) ?? 'saver' +} +/** @alias getUserPlan */ +export const getUserEntitlement = getUserPlan