- After importing a backup, run prisma migrate deploy so any schema migrations the backup is missing are applied automatically. This prevents pages from failing due to missing tables/columns when the backup was taken on an older version of the app. - Force logout and redirect to login after a successful restore so the JWT is refreshed against the restored database (prevents userId mismatch causing user-scoped queries to return empty results). - Fix getTotalPatientCount() in /status route to pass userId so it counts only the current user's patients instead of all patients. - Add prisma.$connect() after $disconnect() to ensure a clean reconnect. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
68 lines
4.1 KiB
TypeScript
68 lines
4.1 KiB
TypeScript
import type { Prisma } from '../../generated/prisma';
|
|
import * as z from 'zod';
|
|
import { UserIncludeObjectSchema as UserIncludeObjectSchema } from './objects/UserInclude.schema';
|
|
import { UserOrderByWithRelationInputObjectSchema as UserOrderByWithRelationInputObjectSchema } from './objects/UserOrderByWithRelationInput.schema';
|
|
import { UserWhereInputObjectSchema as UserWhereInputObjectSchema } from './objects/UserWhereInput.schema';
|
|
import { UserWhereUniqueInputObjectSchema as UserWhereUniqueInputObjectSchema } from './objects/UserWhereUniqueInput.schema';
|
|
import { UserScalarFieldEnumSchema } from './enums/UserScalarFieldEnum.schema';
|
|
|
|
// Select schema needs to be in file to prevent circular imports
|
|
//------------------------------------------------------
|
|
|
|
export const UserFindFirstOrThrowSelectSchema: z.ZodType<Prisma.UserSelect> = z.object({
|
|
id: z.boolean().optional(),
|
|
username: z.boolean().optional(),
|
|
password: z.boolean().optional(),
|
|
autoBackupEnabled: z.boolean().optional(),
|
|
usbBackupEnabled: z.boolean().optional(),
|
|
patients: z.boolean().optional(),
|
|
appointments: z.boolean().optional(),
|
|
staff: z.boolean().optional(),
|
|
npiProviders: z.boolean().optional(),
|
|
claims: z.boolean().optional(),
|
|
insuranceCredentials: z.boolean().optional(),
|
|
updatedPayments: z.boolean().optional(),
|
|
backups: z.boolean().optional(),
|
|
backupDestinations: z.boolean().optional(),
|
|
notifications: z.boolean().optional(),
|
|
cloudFolders: z.boolean().optional(),
|
|
cloudFiles: z.boolean().optional(),
|
|
communications: z.boolean().optional(),
|
|
twilioSettings: z.boolean().optional(),
|
|
aiSettings: z.boolean().optional(),
|
|
officeHours: z.boolean().optional(),
|
|
officeContact: z.boolean().optional(),
|
|
procedureTimeslot: z.boolean().optional(),
|
|
_count: z.boolean().optional()
|
|
}).strict() as unknown as z.ZodType<Prisma.UserSelect>;
|
|
|
|
export const UserFindFirstOrThrowSelectZodSchema = z.object({
|
|
id: z.boolean().optional(),
|
|
username: z.boolean().optional(),
|
|
password: z.boolean().optional(),
|
|
autoBackupEnabled: z.boolean().optional(),
|
|
usbBackupEnabled: z.boolean().optional(),
|
|
patients: z.boolean().optional(),
|
|
appointments: z.boolean().optional(),
|
|
staff: z.boolean().optional(),
|
|
npiProviders: z.boolean().optional(),
|
|
claims: z.boolean().optional(),
|
|
insuranceCredentials: z.boolean().optional(),
|
|
updatedPayments: z.boolean().optional(),
|
|
backups: z.boolean().optional(),
|
|
backupDestinations: z.boolean().optional(),
|
|
notifications: z.boolean().optional(),
|
|
cloudFolders: z.boolean().optional(),
|
|
cloudFiles: z.boolean().optional(),
|
|
communications: z.boolean().optional(),
|
|
twilioSettings: z.boolean().optional(),
|
|
aiSettings: z.boolean().optional(),
|
|
officeHours: z.boolean().optional(),
|
|
officeContact: z.boolean().optional(),
|
|
procedureTimeslot: z.boolean().optional(),
|
|
_count: z.boolean().optional()
|
|
}).strict();
|
|
|
|
export const UserFindFirstOrThrowSchema: z.ZodType<Prisma.UserFindFirstOrThrowArgs> = z.object({ select: UserFindFirstOrThrowSelectSchema.optional(), include: z.lazy(() => UserIncludeObjectSchema.optional()), orderBy: z.union([UserOrderByWithRelationInputObjectSchema, UserOrderByWithRelationInputObjectSchema.array()]).optional(), where: UserWhereInputObjectSchema.optional(), cursor: UserWhereUniqueInputObjectSchema.optional(), take: z.number().optional(), skip: z.number().optional(), distinct: z.union([UserScalarFieldEnumSchema, UserScalarFieldEnumSchema.array()]).optional() }).strict() as unknown as z.ZodType<Prisma.UserFindFirstOrThrowArgs>;
|
|
|
|
export const UserFindFirstOrThrowZodSchema = z.object({ select: UserFindFirstOrThrowSelectSchema.optional(), include: z.lazy(() => UserIncludeObjectSchema.optional()), orderBy: z.union([UserOrderByWithRelationInputObjectSchema, UserOrderByWithRelationInputObjectSchema.array()]).optional(), where: UserWhereInputObjectSchema.optional(), cursor: UserWhereUniqueInputObjectSchema.optional(), take: z.number().optional(), skip: z.number().optional(), distinct: z.union([UserScalarFieldEnumSchema, UserScalarFieldEnumSchema.array()]).optional() }).strict(); |