From ce5d6267cce14e5df9f1c9f7415b3f015e3c18e7 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Thu, 23 Nov 2023 17:13:51 +0000 Subject: [PATCH 1/2] Move per creator utils into backend core, allow creators to create apps --- packages/backend-core/src/users/users.ts | 17 +++++++++++++++++ .../src/pages/builder/portal/apps/index.svelte | 2 +- packages/pro | 2 +- .../server/src/api/controllers/application.ts | 6 ++---- packages/shared-core/src/sdk/documents/users.ts | 4 ++++ 5 files changed, 25 insertions(+), 6 deletions(-) diff --git a/packages/backend-core/src/users/users.ts b/packages/backend-core/src/users/users.ts index 6aed45371a..bdc89f1a88 100644 --- a/packages/backend-core/src/users/users.ts +++ b/packages/backend-core/src/users/users.ts @@ -25,6 +25,7 @@ import { import { getGlobalDB } from "../context" import * as context from "../context" import { isCreator } from "./utils" +import { UserDB } from "./db" type GetOpts = { cleanup?: boolean } @@ -336,3 +337,19 @@ export function cleanseUserObject(user: User | ContextUser, base?: User) { } return user } + +export async function addAppBuilder(user: User, appId: string) { + const prodAppId = getProdAppID(appId) + user.builder ??= {} + user.builder.apps ??= [] + user.builder.apps.push(prodAppId) + await UserDB.save(user, { hashPassword: false }) +} + +export async function removeAppBuilder(user: User, appId: string) { + const prodAppId = getProdAppID(appId) + if (user.builder && user.builder.apps?.includes(prodAppId)) { + user.builder.apps = user.builder.apps.filter(id => id !== prodAppId) + } + await UserDB.save(user, { hashPassword: false }) +} diff --git a/packages/builder/src/pages/builder/portal/apps/index.svelte b/packages/builder/src/pages/builder/portal/apps/index.svelte index 59267f37e7..ad0d3658ea 100644 --- a/packages/builder/src/pages/builder/portal/apps/index.svelte +++ b/packages/builder/src/pages/builder/portal/apps/index.svelte @@ -237,7 +237,7 @@ {#if enrichedApps.length}
- {#if $auth.user && sdk.users.isGlobalBuilder($auth.user)} + {#if $auth.user && sdk.users.canCreateApps($auth.user)}