UNPKG

@syngrisi/syngrisi

Version:
113 lines (109 loc) 3.81 kB
// src/server/schemas/Logs.schema.ts import { z as z3 } from "zod"; // src/server/schemas/utils/commonValidations.ts import { z as z2 } from "zod"; import { extendZodWithOpenApi as extendZodWithOpenApi2 } from "@asteasolutions/zod-to-openapi"; // src/server/schemas/common/Version.schema.ts import { z } from "zod"; import { extendZodWithOpenApi } from "@asteasolutions/zod-to-openapi"; extendZodWithOpenApi(z); var VersionBaseSchema = z.string().regex(/^\d+\.\d+\.\d+$/, 'Version must be in the format "x.y.z"'); var VersionSchema = VersionBaseSchema.transform((value) => { const parts = value.split("."); return { major: parseInt(parts[0]), minor: parseInt(parts[1]), patch: parseInt(parts[2]) }; }); // src/server/schemas/utils/commonValidations.ts extendZodWithOpenApi2(z2); var mongooseIdRegex = /^[0-9a-fA-F]{24}$/; var id = z2.string().regex(mongooseIdRegex, { message: "Invalid Mongoose ObjectId format: /^[0-9a-fA-F]{24}$/" }).openapi({ description: "baseline ID", example: "6bbF35cAB3C59dA969edAe79" }); var commonValidations = { id, version: VersionBaseSchema.openapi({ example: "1.1.2" }), positiveNumberString: z2.string().refine((value) => { const num = Number(value); return Number.isInteger(num) && num >= 0; }, { message: "String must be a positive number or 0" }), password: z2.string().min(6).regex(/(?=.*[0-9])/, "Password must include a number").regex(/(?=.*[a-z])/, "Password must include a lowercase letter").regex(/(?=.*[A-Z])/, "Password must include an uppercase letter").refine((value) => { return /(?=.*[!@#$%^&*(),.?":{}|<>-])/.test(value); }, { message: "Password must include a special symbol" }).openapi({ example: "Aa1!IJASSNOJ" }), username: z2.string().min(1).openapi({ example: "john.doe@example.com" }), // TODO: workaround TBD date: z2.string().refine((val) => { const date = new Date(val); return !isNaN(date.getTime()); }, { message: "Invalid date format" }), paramsId: { params: z2.object({ id }) }, paramsTestId: { params: z2.object({ testid: id }) }, success: z2.object({ message: z2.literal("success") }) }; // src/server/schemas/Logs.schema.ts var LogGetSchema = z3.object({ _id: commonValidations.id, level: z3.enum(["error", "warn", "info", "verbose", "debug", "silly"]).openapi({ description: "Log level", example: "info" }), message: z3.string().min(1).openapi({ description: "Log message", example: "User logged in" }), timestamp: commonValidations.date.openapi({ description: "Timestamp of the log entry", example: "2024-05-26T10:49:19.896Z" }), meta: z3.object({}).optional().openapi({ description: "Additional metadata for the log entry", example: { userId: "66519e582c2c701cc438ce59" } }), id: commonValidations.id }); var LogCreateSchema = z3.object({ level: z3.enum(["error", "warn", "info", "verbose", "debug", "silly"]).openapi({ description: "Log level", example: "info" }).optional(), message: z3.string().min(1).openapi({ description: "Log message", example: "User logged in" }).optional(), meta: z3.object({}).optional().openapi({ description: "Additional metadata for the log entry", example: { userId: "66519e582c2c701cc438ce59" } }) }); var LogCreateRespSchema = commonValidations.success; var LogDistinctSchema = z3.object({ field: z3.string().min(1).openapi({ description: "Field name for distinct query", example: "level" }) }); var LogDistinctResponseSchema = z3.array(z3.string()).openapi({ description: "Array of distinct log levels", example: ["debug", "error", "info", "warn"] }); export { LogCreateRespSchema, LogCreateSchema, LogDistinctResponseSchema, LogDistinctSchema, LogGetSchema }; //# sourceMappingURL=Logs.schema.js.map