From 0a1ad74691b32959fef62409f49cdef47c7099f2 Mon Sep 17 00:00:00 2001 From: Gao Sun Date: Fri, 1 Mar 2024 14:56:32 +0800 Subject: [PATCH] refactor(schemas): update schema to fit cloud --- packages/schemas/package.json | 2 +- packages/schemas/src/types/organization.ts | 14 +++++++++----- pnpm-lock.yaml | 14 ++++++++++++-- 3 files changed, 22 insertions(+), 8 deletions(-) diff --git a/packages/schemas/package.json b/packages/schemas/package.json index 3e56663ce..a962a0687 100644 --- a/packages/schemas/package.json +++ b/packages/schemas/package.json @@ -86,7 +86,7 @@ "@logto/phrases": "workspace:^1.9.0", "@logto/phrases-experience": "workspace:^1.6.0", "@logto/shared": "workspace:^3.1.0", - "@withtyped/server": "^0.12.9" + "@withtyped/server": "^0.13.1" }, "peerDependencies": { "zod": "^3.22.4" diff --git a/packages/schemas/src/types/organization.ts b/packages/schemas/src/types/organization.ts index 32d750eba..fdbefcd42 100644 --- a/packages/schemas/src/types/organization.ts +++ b/packages/schemas/src/types/organization.ts @@ -11,6 +11,10 @@ import { import { type UserInfo, type FeaturedUser, userInfoGuard } from './user.js'; +type ToZodObject = z.ZodObject<{ + [K in keyof T]: z.ZodType; +}>; + /** * The simplified organization scope entity that is returned for some endpoints. */ @@ -23,7 +27,7 @@ export type OrganizationRoleWithScopes = OrganizationRole & { scopes: OrganizationScopeEntity[]; }; -export const organizationRoleWithScopesGuard: z.ZodType = +export const organizationRoleWithScopesGuard: ToZodObject = OrganizationRoles.guard.extend({ scopes: z .object({ @@ -42,7 +46,7 @@ export type OrganizationRoleEntity = { name: string; }; -const organizationRoleEntityGuard: z.ZodType = z.object({ +const organizationRoleEntityGuard: ToZodObject = z.object({ id: z.string(), name: z.string(), }); @@ -56,7 +60,7 @@ export type OrganizationWithRoles = Organization & { organizationRoles: OrganizationRoleEntity[]; }; -export const organizationWithOrganizationRolesGuard: z.ZodType = +export const organizationWithOrganizationRolesGuard: ToZodObject = Organizations.guard.extend({ organizationRoles: organizationRoleEntityGuard.array(), }); @@ -70,7 +74,7 @@ export type UserWithOrganizationRoles = UserInfo & { organizationRoles: OrganizationRoleEntity[]; }; -export const userWithOrganizationRolesGuard: z.ZodType = +export const userWithOrganizationRolesGuard: ToZodObject = userInfoGuard.extend({ organizationRoles: organizationRoleEntityGuard.array(), }); @@ -93,7 +97,7 @@ export type OrganizationInvitationEntity = OrganizationInvitation & { organizationRoles: OrganizationRoleEntity[]; }; -export const organizationInvitationEntityGuard: z.ZodType = +export const organizationInvitationEntityGuard: ToZodObject = OrganizationInvitations.guard.extend({ organizationRoles: organizationRoleEntityGuard.array(), }); diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index fc47c7b4b..271428e74 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -3997,8 +3997,8 @@ importers: specifier: workspace:^3.1.0 version: link:../shared '@withtyped/server': - specifier: ^0.12.9 - version: 0.12.9(zod@3.22.4) + specifier: ^0.13.1 + version: 0.13.1(zod@3.22.4) zod: specifier: ^3.22.4 version: 3.22.4 @@ -10547,6 +10547,16 @@ packages: '@withtyped/shared': 0.2.2 zod: 3.22.4 + /@withtyped/server@0.13.1(zod@3.22.4): + resolution: {integrity: sha512-Fmmlw/7f3oidMS2tjgOx82BIkNEDBpHbFPj4oghXbyaZ8bgskLjKoLE0Qscbua6vhWUG4EgAmfR5ijSfg3bw2Q==} + peerDependencies: + zod: ^3.19.1 + dependencies: + '@silverhand/essentials': 2.9.0 + '@withtyped/shared': 0.2.2 + zod: 3.22.4 + dev: false + /@withtyped/shared@0.2.2: resolution: {integrity: sha512-Vpcj12NqaoZ8M5Z/1kffheI9FBZEm9goed0THmgTcMKXLHjXSRbMZMp0olVxovEgaTIAydshqJOQUXKZMctIZw==}