@open-mercato/shared 0.4.2-canary-c02407ff85
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build.mjs +101 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +7 -0
- package/dist/lib/api/crud.js +47 -0
- package/dist/lib/api/crud.js.map +7 -0
- package/dist/lib/api/scoped.js +140 -0
- package/dist/lib/api/scoped.js.map +7 -0
- package/dist/lib/auth/jwt.js +34 -0
- package/dist/lib/auth/jwt.js.map +7 -0
- package/dist/lib/auth/server.js +157 -0
- package/dist/lib/auth/server.js.map +7 -0
- package/dist/lib/boolean.js +22 -0
- package/dist/lib/boolean.js.map +7 -0
- package/dist/lib/bootstrap/appResolver.js +43 -0
- package/dist/lib/bootstrap/appResolver.js.map +7 -0
- package/dist/lib/bootstrap/dynamicLoader.js +108 -0
- package/dist/lib/bootstrap/dynamicLoader.js.map +7 -0
- package/dist/lib/bootstrap/factory.js +59 -0
- package/dist/lib/bootstrap/factory.js.map +7 -0
- package/dist/lib/bootstrap/index.js +11 -0
- package/dist/lib/bootstrap/index.js.map +7 -0
- package/dist/lib/bootstrap/types.js +1 -0
- package/dist/lib/bootstrap/types.js.map +7 -0
- package/dist/lib/cache/segments.js +36 -0
- package/dist/lib/cache/segments.js.map +7 -0
- package/dist/lib/cli/progress.js +46 -0
- package/dist/lib/cli/progress.js.map +7 -0
- package/dist/lib/commands/command-bus.js +285 -0
- package/dist/lib/commands/command-bus.js.map +7 -0
- package/dist/lib/commands/customFieldSnapshots.js +66 -0
- package/dist/lib/commands/customFieldSnapshots.js.map +7 -0
- package/dist/lib/commands/helpers.js +98 -0
- package/dist/lib/commands/helpers.js.map +7 -0
- package/dist/lib/commands/index.js +8 -0
- package/dist/lib/commands/index.js.map +7 -0
- package/dist/lib/commands/operationMetadata.js +32 -0
- package/dist/lib/commands/operationMetadata.js.map +7 -0
- package/dist/lib/commands/registry.js +43 -0
- package/dist/lib/commands/registry.js.map +7 -0
- package/dist/lib/commands/scope.js +44 -0
- package/dist/lib/commands/scope.js.map +7 -0
- package/dist/lib/commands/types.js +8 -0
- package/dist/lib/commands/types.js.map +7 -0
- package/dist/lib/crud/cache-stats.js +98 -0
- package/dist/lib/crud/cache-stats.js.map +7 -0
- package/dist/lib/crud/cache.js +175 -0
- package/dist/lib/crud/cache.js.map +7 -0
- package/dist/lib/crud/custom-fields-client.js +52 -0
- package/dist/lib/crud/custom-fields-client.js.map +7 -0
- package/dist/lib/crud/custom-fields.js +467 -0
- package/dist/lib/crud/custom-fields.js.map +7 -0
- package/dist/lib/crud/errors.js +24 -0
- package/dist/lib/crud/errors.js.map +7 -0
- package/dist/lib/crud/exporters.js +154 -0
- package/dist/lib/crud/exporters.js.map +7 -0
- package/dist/lib/crud/factory.js +1311 -0
- package/dist/lib/crud/factory.js.map +7 -0
- package/dist/lib/crud/types.js +1 -0
- package/dist/lib/crud/types.js.map +7 -0
- package/dist/lib/custom-fields/normalize.js +36 -0
- package/dist/lib/custom-fields/normalize.js.map +7 -0
- package/dist/lib/data/engine.js +396 -0
- package/dist/lib/data/engine.js.map +7 -0
- package/dist/lib/db/escapeLikePattern.js +5 -0
- package/dist/lib/db/escapeLikePattern.js.map +7 -0
- package/dist/lib/db/mikro.js +82 -0
- package/dist/lib/db/mikro.js.map +7 -0
- package/dist/lib/di/container.js +94 -0
- package/dist/lib/di/container.js.map +7 -0
- package/dist/lib/email/send.js +12 -0
- package/dist/lib/email/send.js.map +7 -0
- package/dist/lib/encryption/aes.js +58 -0
- package/dist/lib/encryption/aes.js.map +7 -0
- package/dist/lib/encryption/customFieldValues.js +49 -0
- package/dist/lib/encryption/customFieldValues.js.map +7 -0
- package/dist/lib/encryption/entityFields.js +26 -0
- package/dist/lib/encryption/entityFields.js.map +7 -0
- package/dist/lib/encryption/entityIds.js +80 -0
- package/dist/lib/encryption/entityIds.js.map +7 -0
- package/dist/lib/encryption/find.js +45 -0
- package/dist/lib/encryption/find.js.map +7 -0
- package/dist/lib/encryption/indexDoc.js +69 -0
- package/dist/lib/encryption/indexDoc.js.map +7 -0
- package/dist/lib/encryption/kms.js +282 -0
- package/dist/lib/encryption/kms.js.map +7 -0
- package/dist/lib/encryption/subscriber.js +330 -0
- package/dist/lib/encryption/subscriber.js.map +7 -0
- package/dist/lib/encryption/tenantDataEncryptionService.js +252 -0
- package/dist/lib/encryption/tenantDataEncryptionService.js.map +7 -0
- package/dist/lib/encryption/toggles.js +18 -0
- package/dist/lib/encryption/toggles.js.map +7 -0
- package/dist/lib/entities/naming.js +9 -0
- package/dist/lib/entities/naming.js.map +7 -0
- package/dist/lib/entities/system-entities.js +43 -0
- package/dist/lib/entities/system-entities.js.map +7 -0
- package/dist/lib/frontend/organizationEvents.js +41 -0
- package/dist/lib/frontend/organizationEvents.js.map +7 -0
- package/dist/lib/frontend/useOrganizationScope.js +32 -0
- package/dist/lib/frontend/useOrganizationScope.js.map +7 -0
- package/dist/lib/hotkeys/index.js +128 -0
- package/dist/lib/hotkeys/index.js.map +7 -0
- package/dist/lib/i18n/app-dictionaries.js +17 -0
- package/dist/lib/i18n/app-dictionaries.js.map +7 -0
- package/dist/lib/i18n/config.js +7 -0
- package/dist/lib/i18n/config.js.map +7 -0
- package/dist/lib/i18n/context.js +50 -0
- package/dist/lib/i18n/context.js.map +7 -0
- package/dist/lib/i18n/server.js +68 -0
- package/dist/lib/i18n/server.js.map +7 -0
- package/dist/lib/i18n/translate.js +45 -0
- package/dist/lib/i18n/translate.js.map +7 -0
- package/dist/lib/indexers/error-log.js +82 -0
- package/dist/lib/indexers/error-log.js.map +7 -0
- package/dist/lib/indexers/status-log.js +80 -0
- package/dist/lib/indexers/status-log.js.map +7 -0
- package/dist/lib/lib/auth/jwt.js +34 -0
- package/dist/lib/lib/auth/jwt.js.map +7 -0
- package/dist/lib/lib/auth/server.js +77 -0
- package/dist/lib/lib/auth/server.js.map +7 -0
- package/dist/lib/lib/email/send.js +12 -0
- package/dist/lib/lib/email/send.js.map +7 -0
- package/dist/lib/lib/i18n/config.js +7 -0
- package/dist/lib/lib/i18n/config.js.map +7 -0
- package/dist/lib/lib/i18n/context.js +31 -0
- package/dist/lib/lib/i18n/context.js.map +7 -0
- package/dist/lib/lib/utils.js +9 -0
- package/dist/lib/lib/utils.js.map +7 -0
- package/dist/lib/location/countries.js +68 -0
- package/dist/lib/location/countries.js.map +7 -0
- package/dist/lib/modules/index.js +6 -0
- package/dist/lib/modules/index.js.map +7 -0
- package/dist/lib/modules/registry.js +18 -0
- package/dist/lib/modules/registry.js.map +7 -0
- package/dist/lib/openapi/crud.js +137 -0
- package/dist/lib/openapi/crud.js.map +7 -0
- package/dist/lib/openapi/generator.js +1131 -0
- package/dist/lib/openapi/generator.js.map +7 -0
- package/dist/lib/openapi/index.js +10 -0
- package/dist/lib/openapi/index.js.map +7 -0
- package/dist/lib/openapi/sanitize.js +110 -0
- package/dist/lib/openapi/sanitize.js.map +7 -0
- package/dist/lib/openapi/types.js +1 -0
- package/dist/lib/openapi/types.js.map +7 -0
- package/dist/lib/profiler/index.js +258 -0
- package/dist/lib/profiler/index.js.map +7 -0
- package/dist/lib/query/engine.js +729 -0
- package/dist/lib/query/engine.js.map +7 -0
- package/dist/lib/query/join-utils.js +195 -0
- package/dist/lib/query/join-utils.js.map +7 -0
- package/dist/lib/query/types.js +9 -0
- package/dist/lib/query/types.js.map +7 -0
- package/dist/lib/search/config.js +32 -0
- package/dist/lib/search/config.js.map +7 -0
- package/dist/lib/search/tokenize.js +34 -0
- package/dist/lib/search/tokenize.js.map +7 -0
- package/dist/lib/slugify.js +24 -0
- package/dist/lib/slugify.js.map +7 -0
- package/dist/lib/testing/bootstrap.js +51 -0
- package/dist/lib/testing/bootstrap.js.map +7 -0
- package/dist/lib/testing/index.js +17 -0
- package/dist/lib/testing/index.js.map +7 -0
- package/dist/lib/testing/renderWithProviders.js +15 -0
- package/dist/lib/testing/renderWithProviders.js.map +7 -0
- package/dist/lib/url.js +12 -0
- package/dist/lib/url.js.map +7 -0
- package/dist/lib/utils.js +13 -0
- package/dist/lib/utils.js.map +7 -0
- package/dist/lib/version.js +7 -0
- package/dist/lib/version.js.map +7 -0
- package/dist/modules/dashboard/widgets.js +1 -0
- package/dist/modules/dashboard/widgets.js.map +7 -0
- package/dist/modules/dsl.js +30 -0
- package/dist/modules/dsl.js.map +7 -0
- package/dist/modules/entities/kinds.js +22 -0
- package/dist/modules/entities/kinds.js.map +7 -0
- package/dist/modules/entities/options.js +26 -0
- package/dist/modules/entities/options.js.map +7 -0
- package/dist/modules/entities/validation.js +102 -0
- package/dist/modules/entities/validation.js.map +7 -0
- package/dist/modules/entities/validators.js +88 -0
- package/dist/modules/entities/validators.js.map +7 -0
- package/dist/modules/entities.js +1 -0
- package/dist/modules/entities.js.map +7 -0
- package/dist/modules/navigation/sidebarPreferences.js +50 -0
- package/dist/modules/navigation/sidebarPreferences.js.map +7 -0
- package/dist/modules/perspectives/types.js +1 -0
- package/dist/modules/perspectives/types.js.map +7 -0
- package/dist/modules/registry.js +96 -0
- package/dist/modules/registry.js.map +7 -0
- package/dist/modules/search.js +15 -0
- package/dist/modules/search.js.map +7 -0
- package/dist/modules/vector.js +1 -0
- package/dist/modules/vector.js.map +7 -0
- package/dist/modules/widgets/injection-loader.js +180 -0
- package/dist/modules/widgets/injection-loader.js.map +7 -0
- package/dist/modules/widgets/injection.js +1 -0
- package/dist/modules/widgets/injection.js.map +7 -0
- package/dist/security/features.js +23 -0
- package/dist/security/features.js.map +7 -0
- package/dist/types/pg.d.js +1 -0
- package/dist/types/pg.d.js.map +7 -0
- package/dist/types/react-email.d.js +1 -0
- package/dist/types/react-email.d.js.map +7 -0
- package/dist/types/resend.d.js +1 -0
- package/dist/types/resend.d.js.map +7 -0
- package/jest.config.cjs +22 -0
- package/package.json +88 -0
- package/src/index.ts +0 -0
- package/src/lib/api/__tests__/scoped.test.ts +38 -0
- package/src/lib/api/crud.ts +59 -0
- package/src/lib/api/scoped.ts +239 -0
- package/src/lib/auth/jwt.ts +39 -0
- package/src/lib/auth/server.ts +199 -0
- package/src/lib/boolean.ts +17 -0
- package/src/lib/bootstrap/appResolver.ts +85 -0
- package/src/lib/bootstrap/dynamicLoader.ts +177 -0
- package/src/lib/bootstrap/factory.ts +108 -0
- package/src/lib/bootstrap/index.ts +23 -0
- package/src/lib/bootstrap/types.ts +31 -0
- package/src/lib/cache/segments.ts +56 -0
- package/src/lib/cli/progress.ts +55 -0
- package/src/lib/commands/__tests__/command-bus.test.ts +84 -0
- package/src/lib/commands/__tests__/helpers.test.ts +42 -0
- package/src/lib/commands/command-bus.ts +349 -0
- package/src/lib/commands/customFieldSnapshots.ts +86 -0
- package/src/lib/commands/helpers.ts +143 -0
- package/src/lib/commands/index.ts +4 -0
- package/src/lib/commands/operationMetadata.ts +40 -0
- package/src/lib/commands/registry.ts +46 -0
- package/src/lib/commands/scope.ts +59 -0
- package/src/lib/commands/types.ts +63 -0
- package/src/lib/crud/__tests__/crud-factory.test.ts +333 -0
- package/src/lib/crud/__tests__/custom-fields.test.ts +150 -0
- package/src/lib/crud/cache-stats.ts +127 -0
- package/src/lib/crud/cache.ts +205 -0
- package/src/lib/crud/custom-fields-client.ts +54 -0
- package/src/lib/crud/custom-fields.ts +607 -0
- package/src/lib/crud/errors.ts +23 -0
- package/src/lib/crud/exporters.ts +188 -0
- package/src/lib/crud/factory.ts +1622 -0
- package/src/lib/crud/types.ts +29 -0
- package/src/lib/custom-fields/normalize.ts +45 -0
- package/src/lib/data/engine.ts +562 -0
- package/src/lib/db/escapeLikePattern.ts +2 -0
- package/src/lib/db/mikro.ts +100 -0
- package/src/lib/di/container.ts +105 -0
- package/src/lib/email/send.ts +18 -0
- package/src/lib/encryption/__tests__/customFieldValues.test.ts +63 -0
- package/src/lib/encryption/__tests__/indexDoc.test.ts +115 -0
- package/src/lib/encryption/aes.ts +64 -0
- package/src/lib/encryption/customFieldValues.ts +67 -0
- package/src/lib/encryption/entityFields.ts +39 -0
- package/src/lib/encryption/entityIds.ts +107 -0
- package/src/lib/encryption/find.ts +81 -0
- package/src/lib/encryption/indexDoc.ts +104 -0
- package/src/lib/encryption/kms.ts +337 -0
- package/src/lib/encryption/subscriber.ts +416 -0
- package/src/lib/encryption/tenantDataEncryptionService.ts +313 -0
- package/src/lib/encryption/toggles.ts +15 -0
- package/src/lib/entities/naming.ts +6 -0
- package/src/lib/entities/system-entities.ts +43 -0
- package/src/lib/frontend/organizationEvents.ts +55 -0
- package/src/lib/frontend/useOrganizationScope.ts +30 -0
- package/src/lib/hotkeys/index.ts +168 -0
- package/src/lib/i18n/app-dictionaries.ts +18 -0
- package/src/lib/i18n/config.ts +4 -0
- package/src/lib/i18n/context.tsx +66 -0
- package/src/lib/i18n/server.ts +74 -0
- package/src/lib/i18n/translate.ts +54 -0
- package/src/lib/indexers/error-log.ts +106 -0
- package/src/lib/indexers/status-log.ts +119 -0
- package/src/lib/lib/auth/jwt.ts +39 -0
- package/src/lib/lib/auth/server.ts +94 -0
- package/src/lib/lib/email/send.ts +18 -0
- package/src/lib/lib/i18n/config.ts +4 -0
- package/src/lib/lib/i18n/context.tsx +38 -0
- package/src/lib/lib/utils.ts +6 -0
- package/src/lib/location/countries.ts +97 -0
- package/src/lib/modules/index.ts +1 -0
- package/src/lib/modules/registry.ts +18 -0
- package/src/lib/openapi/crud.ts +218 -0
- package/src/lib/openapi/generator.ts +1311 -0
- package/src/lib/openapi/index.ts +4 -0
- package/src/lib/openapi/sanitize.ts +137 -0
- package/src/lib/openapi/types.ts +79 -0
- package/src/lib/profiler/index.ts +371 -0
- package/src/lib/query/__tests__/engine.test.ts +274 -0
- package/src/lib/query/engine.ts +837 -0
- package/src/lib/query/join-utils.ts +238 -0
- package/src/lib/query/types.ts +121 -0
- package/src/lib/search/config.ts +49 -0
- package/src/lib/search/tokenize.ts +45 -0
- package/src/lib/slugify.ts +28 -0
- package/src/lib/testing/bootstrap.ts +124 -0
- package/src/lib/testing/index.ts +15 -0
- package/src/lib/testing/renderWithProviders.tsx +31 -0
- package/src/lib/url.ts +12 -0
- package/src/lib/utils.ts +17 -0
- package/src/lib/version.ts +5 -0
- package/src/modules/__tests__/dsl.test.ts +35 -0
- package/src/modules/__tests__/registry.test.ts +300 -0
- package/src/modules/dashboard/widgets.ts +57 -0
- package/src/modules/dsl.ts +32 -0
- package/src/modules/entities/__tests__/validation.test.ts +52 -0
- package/src/modules/entities/kinds.ts +20 -0
- package/src/modules/entities/options.ts +36 -0
- package/src/modules/entities/validation.ts +118 -0
- package/src/modules/entities/validators.ts +93 -0
- package/src/modules/entities.ts +102 -0
- package/src/modules/navigation/sidebarPreferences.ts +62 -0
- package/src/modules/perspectives/types.ts +40 -0
- package/src/modules/registry.ts +249 -0
- package/src/modules/search.ts +325 -0
- package/src/modules/vector.ts +122 -0
- package/src/modules/widgets/__tests__/injection.test.ts +48 -0
- package/src/modules/widgets/injection-loader.ts +235 -0
- package/src/modules/widgets/injection.ts +120 -0
- package/src/security/features.ts +22 -0
- package/src/types/pg.d.ts +2 -0
- package/src/types/react-email.d.ts +2 -0
- package/src/types/resend.d.ts +2 -0
- package/tsconfig.build.json +11 -0
- package/tsconfig.json +9 -0
- package/watch.mjs +6 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/lib/openapi/generator.ts"],
|
|
4
|
+
"sourcesContent": ["import { z, type ZodTypeAny } from 'zod'\nimport type { Module, ModuleApi, ModuleApiLegacy, ModuleApiRouteFile, HttpMethod } from '@open-mercato/shared/modules/registry'\nimport type {\n OpenApiDocument,\n OpenApiDocumentOptions,\n OpenApiMethodDoc,\n OpenApiRequestBodyDoc,\n OpenApiResponseDoc,\n OpenApiRouteDoc,\n} from './types'\n\ntype PathParamInfo = {\n name: string\n catchAll?: boolean\n optional?: boolean\n}\n\ntype ParameterLocation = 'query' | 'path' | 'header'\n\ntype JsonSchema = Record<string, unknown>\n\ntype SchemaConversionContext = {\n memo: WeakMap<ZodTypeAny, JsonSchema>\n}\n\ntype ExampleGenerationContext = {\n stack: WeakSet<ZodTypeAny>\n}\n\ntype ExampleMap = {\n query?: unknown\n body?: unknown\n path?: Record<string, unknown>\n headers?: Record<string, unknown>\n}\n\nconst HTTP_METHODS: HttpMethod[] = ['GET', 'POST', 'PUT', 'PATCH', 'DELETE']\n\nfunction resolveType(def: any): string | undefined {\n if (!def) return undefined\n if (typeof def.typeName === 'string' && def.typeName.length) return def.typeName\n if (typeof def.type === 'string' && def.type.length) return def.type\n return undefined\n}\n\nfunction getShape(def: any): Record<string, ZodTypeAny> {\n if (!def) return {}\n const shape = typeof def.shape === 'function' ? def.shape() : def.shape\n if (shape && typeof shape === 'object') return shape as Record<string, ZodTypeAny>\n return {}\n}\n\nfunction normalizeChecks(checks: any[] | undefined): Array<{ kind?: string; value?: unknown; extra?: Record<string, unknown> }> {\n if (!Array.isArray(checks)) return []\n return checks.map((check) => {\n if (!check) return {}\n const base = (check as any)?._zod?.def ?? (check as any)?.def ?? check\n const kind = typeof (check as any)?.kind === 'string'\n ? (check as any).kind\n : typeof base?.check === 'string'\n ? base.check\n : undefined\n const value =\n base?.value ??\n base?.minimum ??\n base?.maximum ??\n base?.exact ??\n base?.length ??\n base?.limit ??\n base?.includes ??\n base?.min ??\n base?.max\n return { kind, value, extra: base && typeof base === 'object' ? base : undefined }\n })\n}\n\nconst DEFAULT_EXAMPLE_VALUES = {\n string: 'string',\n number: 1,\n integer: 1,\n boolean: true,\n uuid: '00000000-0000-4000-8000-000000000000',\n email: 'user@example.com',\n url: 'https://example.com/resource',\n datetime: new Date('2025-01-01T00:00:00.000Z').toISOString(),\n}\n\nfunction toTitle(str: string): string {\n if (!str) return ''\n return str\n .split(/[_\\-\\s]+/)\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1))\n .join(' ')\n}\n\nfunction normalizePath(path: string): { path: string; params: PathParamInfo[] } {\n const segments = path.split('/').filter((seg) => seg.length > 0)\n const params: PathParamInfo[] = []\n const normalized = segments\n .map((seg) => {\n const catchAll = seg.match(/^\\[\\.\\.\\.(.+)\\]$/)\n if (catchAll) {\n params.push({ name: catchAll[1], catchAll: true })\n return `{${catchAll[1]}}`\n }\n const optCatchAll = seg.match(/^\\[\\[\\.\\.\\.(.+)\\]\\]$/)\n if (optCatchAll) {\n params.push({ name: optCatchAll[1], catchAll: true, optional: true })\n return `{${optCatchAll[1]}}`\n }\n const dyn = seg.match(/^\\[(.+)\\]$/)\n if (dyn) {\n params.push({ name: dyn[1] })\n return `{${dyn[1]}}`\n }\n return seg\n })\n .join('/')\n return { path: '/' + normalized, params }\n}\n\nfunction unwrap(schema?: ZodTypeAny): {\n schema: ZodTypeAny | undefined\n optional: boolean\n nullable: boolean\n defaultValue?: unknown\n} {\n if (!schema) {\n return { schema: undefined, optional: true, nullable: false }\n }\n\n let current: ZodTypeAny = schema\n let optional = false\n let nullable = false\n let defaultValue: unknown\n // eslint-disable-next-line no-constant-condition\n while (true) {\n const def = (current as any)?._def\n if (!def) {\n return { schema: current, optional, nullable, defaultValue }\n }\n const typeName = resolveType(def)\n if (typeName === 'ZodOptional' || typeName === 'optional') {\n optional = true\n current = (current as any)._def.innerType\n continue\n }\n if (typeName === 'ZodNullable' || typeName === 'nullable') {\n nullable = true\n current = (current as any)._def.innerType\n continue\n }\n if (typeName === 'ZodDefault' || typeName === 'default') {\n optional = true\n const rawDefault = (current as any)._def.defaultValue\n defaultValue = typeof rawDefault === 'function' ? rawDefault() : rawDefault\n current = (current as any)._def.innerType\n continue\n }\n if (typeName === 'ZodPipeline' || typeName === 'pipe') {\n current = (current as any)._def.out ?? (current as any)._def.innerType ?? (current as any)._def.schema\n continue\n }\n if (typeName === 'transformer') {\n current = (current as any)._def.output\n continue\n }\n if (typeName === 'ZodLazy' || typeName === 'lazy') {\n const getter = (current as any)._def.getter\n current = typeof getter === 'function' ? getter() : current\n if (current === schema) break\n continue\n }\n if (typeName === 'ZodPromise' || typeName === 'promise') {\n current = (current as any)._def.type\n continue\n }\n if (typeName === 'ZodCatch' || typeName === 'catch') {\n current = (current as any)._def.innerType\n continue\n }\n if (typeName === 'ZodReadonly' || typeName === 'readonly') {\n current = (current as any)._def.innerType\n continue\n }\n if (typeName === 'ZodBranded' || typeName === 'branded') {\n current = (current as any)._def.type\n continue\n }\n break\n }\n return { schema: current, optional, nullable, defaultValue }\n}\n\nfunction zodToJsonSchema(schema?: ZodTypeAny, ctx?: SchemaConversionContext): JsonSchema | undefined {\n if (!schema) return undefined\n const context: SchemaConversionContext = ctx ?? { memo: new WeakMap<ZodTypeAny, JsonSchema>() }\n\n const cached = context.memo.get(schema)\n if (cached) return cached\n\n const placeholder: JsonSchema = {}\n context.memo.set(schema, placeholder)\n\n const { schema: inner, nullable } = unwrap(schema)\n if (!inner) {\n if (nullable) placeholder.nullable = true\n return placeholder\n }\n\n if (inner !== schema && typeof inner === 'object') {\n if (!context.memo.has(inner as ZodTypeAny)) {\n context.memo.set(inner as ZodTypeAny, placeholder)\n }\n }\n\n const def = (inner as any)._def\n if (!def) return placeholder\n const typeName = resolveType(def) as string | undefined\n\n const result = placeholder\n\n switch (typeName) {\n case 'ZodString':\n case 'string': {\n result.type = 'string'\n const checks = normalizeChecks(def.checks)\n for (const check of checks) {\n if (!check.kind) continue\n if (check.kind === 'uuid' || check.extra?.format === 'uuid') {\n result.format = 'uuid'\n } else if (check.kind === 'email' || check.extra?.format === 'email') {\n result.format = 'email'\n } else if (check.kind === 'url' || check.extra?.format === 'uri' || check.extra?.format === 'url') {\n result.format = 'uri'\n } else if (check.kind === 'regex' && check.extra?.pattern instanceof RegExp) {\n result.pattern = check.extra.pattern.source\n } else if (check.kind === 'string_format' && typeof check.extra?.format === 'string') {\n result.format = check.extra.format\n } else if (check.kind === 'datetime' || check.extra?.format === 'date-time') {\n result.format = 'date-time'\n } else if (['length', 'len', 'exact_length'].includes(check.kind ?? '')) {\n if (typeof check.value === 'number') {\n result.minLength = check.value\n result.maxLength = check.value\n }\n } else if (check.kind === 'min' || check.kind === 'min_length') {\n if (typeof check.value === 'number') result.minLength = check.value\n } else if (check.kind === 'max' || check.kind === 'max_length') {\n if (typeof check.value === 'number') result.maxLength = check.value\n }\n }\n break\n }\n case 'ZodNumber':\n case 'number': {\n result.type = 'number'\n const checks = normalizeChecks(def.checks)\n for (const check of checks) {\n if (!check.kind) continue\n if (check.kind === 'int' || check.kind === 'isInteger') result.type = 'integer'\n if ((check.kind === 'min' || check.kind === 'gte') && typeof check.value === 'number') result.minimum = check.value\n if ((check.kind === 'max' || check.kind === 'lte') && typeof check.value === 'number') result.maximum = check.value\n if (check.kind === 'multipleOf' && typeof check.value === 'number') result.multipleOf = check.value\n }\n break\n }\n case 'ZodBigInt':\n case 'bigint':\n result.type = 'integer'\n result.format = 'int64'\n break\n case 'ZodBoolean':\n case 'boolean':\n result.type = 'boolean'\n break\n case 'ZodLiteral':\n case 'literal': {\n const value = def.value ?? (Array.isArray(def.values) ? def.values[0] : undefined)\n result.type = typeof value\n result.enum = [value]\n break\n }\n case 'ZodEnum':\n case 'enum': {\n const entries = def.values ?? def.entries\n const values = Array.isArray(entries) ? entries : entries ? Object.values(entries) : []\n const enumerators = values.filter((v: unknown) => typeof v === 'string' || typeof v === 'number')\n const allString = enumerators.every((v: unknown) => typeof v === 'string')\n result.type = allString ? 'string' : 'number'\n result.enum = enumerators\n break\n }\n case 'ZodNativeEnum': {\n const values = Object.values(def.values).filter((v) => typeof v === 'string' || typeof v === 'number')\n const allString = values.every((v) => typeof v === 'string')\n result.type = allString ? 'string' : 'number'\n result.enum = values\n break\n }\n case 'ZodUnion':\n case 'union': {\n const options = def.options || []\n result.oneOf = options.map((option: ZodTypeAny) => zodToJsonSchema(option, context) ?? {})\n break\n }\n case 'ZodIntersection':\n case 'intersection': {\n result.allOf = [\n zodToJsonSchema(def.left, context) ?? {},\n zodToJsonSchema(def.right, context) ?? {},\n ]\n break\n }\n case 'ZodPipeline':\n case 'pipe': {\n const resolved = zodToJsonSchema(def.out ?? def.innerType ?? def.schema, context) ?? {}\n Object.assign(result, resolved)\n break\n }\n case 'ZodLazy':\n case 'lazy': {\n const next = typeof def.getter === 'function' ? def.getter() : undefined\n const resolved = next ? zodToJsonSchema(next, context) : undefined\n if (resolved) Object.assign(result, resolved)\n break\n }\n case 'ZodPromise':\n case 'promise': {\n const resolved = zodToJsonSchema(def.type, context)\n if (resolved) Object.assign(result, resolved)\n break\n }\n case 'ZodCatch':\n case 'catch': {\n const resolved = zodToJsonSchema(def.innerType ?? def.type, context)\n if (resolved) Object.assign(result, resolved)\n break\n }\n case 'ZodReadonly':\n case 'readonly': {\n const resolved = zodToJsonSchema(def.innerType ?? def.type, context)\n if (resolved) Object.assign(result, resolved)\n break\n }\n case 'ZodArray':\n case 'array': {\n const elementSchema =\n def.type && typeof def.type === 'object'\n ? def.type\n : (def.element && typeof def.element === 'object' ? def.element : undefined)\n result.type = 'array'\n result.items = zodToJsonSchema(elementSchema as ZodTypeAny, context) ?? {}\n if (typeof def.minLength === 'number') result.minItems = def.minLength\n if (typeof def.maxLength === 'number') result.maxItems = def.maxLength\n const checks = normalizeChecks(def.checks)\n for (const check of checks) {\n if (check.kind === 'min_length' && typeof check.value === 'number') result.minItems = check.value\n if (check.kind === 'max_length' && typeof check.value === 'number') result.maxItems = check.value\n if (check.kind === 'length' && typeof check.value === 'number') {\n result.minItems = check.value\n result.maxItems = check.value\n }\n }\n break\n }\n case 'ZodTuple':\n case 'tuple': {\n const items = def.items || []\n result.type = 'array'\n result.prefixItems = items.map((item: ZodTypeAny) => zodToJsonSchema(item, context) ?? {})\n result.minItems = items.length\n result.maxItems = items.length\n break\n }\n case 'ZodRecord':\n case 'record': {\n result.type = 'object'\n result.additionalProperties = zodToJsonSchema(def.valueType ?? def.value, context) ?? {}\n break\n }\n case 'ZodObject':\n case 'object': {\n result.type = 'object'\n const shape = getShape(def)\n const properties: Record<string, JsonSchema> = {}\n const required: string[] = []\n for (const [key, rawSchema] of Object.entries(shape)) {\n const unwrapped = unwrap(rawSchema as ZodTypeAny)\n const childSchema = zodToJsonSchema(unwrapped.schema, context)\n if (!childSchema) continue\n const baseSchema = childSchema\n let propertySchema: JsonSchema = baseSchema\n if (unwrapped.nullable) {\n propertySchema = {\n anyOf: [{ type: 'null' }, propertySchema],\n }\n }\n if (unwrapped.defaultValue !== undefined) {\n if (propertySchema === baseSchema) {\n propertySchema = { allOf: [baseSchema], default: unwrapped.defaultValue }\n } else {\n propertySchema = { ...propertySchema, default: unwrapped.defaultValue }\n }\n }\n properties[key] = propertySchema\n if (!unwrapped.optional) required.push(key)\n }\n result.properties = properties\n if (required.length > 0) result.required = required\n if (def.unknownKeys === 'passthrough') {\n result.additionalProperties = true\n } else if (def.catchall && resolveType(def.catchall._def) !== 'ZodNever' && resolveType(def.catchall._def) !== 'never') {\n result.additionalProperties = zodToJsonSchema(def.catchall, context) ?? true\n } else {\n result.additionalProperties = false\n }\n break\n }\n case 'ZodDate':\n case 'date':\n result.type = 'string'\n result.format = 'date-time'\n break\n case 'ZodNull':\n case 'null':\n result.type = 'null'\n break\n case 'ZodVoid':\n case 'void':\n case 'ZodNever':\n case 'never':\n break\n case 'ZodAny':\n case 'any':\n case 'ZodUnknown':\n case 'unknown':\n case 'ZodNaN':\n case 'nan':\n default:\n break\n }\n\n if (nullable) {\n if (result.type && result.type !== 'null') {\n result.nullable = true\n } else if (!result.type) {\n const clone = { ...result }\n result.anyOf = [{ type: 'null' }, clone]\n }\n }\n\n return result\n}\n\nfunction generateExample(schema?: ZodTypeAny, ctx?: ExampleGenerationContext): unknown {\n if (!schema) return undefined\n if ((typeof schema !== 'object' || schema === null) && typeof schema !== 'function') return undefined\n const trackable = schema as object\n const context: ExampleGenerationContext = ctx ?? { stack: new WeakSet<ZodTypeAny>() }\n if (context.stack.has(trackable as ZodTypeAny)) return undefined\n context.stack.add(trackable as ZodTypeAny)\n\n try {\n const { schema: inner, optional, nullable, defaultValue } = unwrap(schema)\n if (!inner) {\n if (defaultValue !== undefined) return defaultValue\n if (nullable) return null\n if (optional) return undefined\n return undefined\n }\n const def = (inner as any)._def\n const typeName = resolveType(def) as string | undefined\n if (defaultValue !== undefined) return defaultValue\n\n if (nullable) return null\n if (optional) return undefined\n\n switch (typeName) {\n case 'ZodString':\n case 'string': {\n const checks = normalizeChecks(def?.checks)\n for (const check of checks) {\n if (!check.kind && !check.extra?.format) continue\n if (check.kind === 'uuid' || check.extra?.format === 'uuid') return DEFAULT_EXAMPLE_VALUES.uuid\n if (check.kind === 'email' || check.extra?.format === 'email') return DEFAULT_EXAMPLE_VALUES.email\n if (check.kind === 'url' || check.extra?.format === 'url' || check.extra?.format === 'uri') return DEFAULT_EXAMPLE_VALUES.url\n if (check.kind === 'datetime' || check.extra?.format === 'date-time') return DEFAULT_EXAMPLE_VALUES.datetime\n }\n return DEFAULT_EXAMPLE_VALUES.string\n }\n case 'ZodNumber':\n case 'number': {\n const checks = normalizeChecks(def?.checks)\n const isInt = checks.some((check) => check.kind === 'int' || check.kind === 'isInteger')\n return isInt ? DEFAULT_EXAMPLE_VALUES.integer : DEFAULT_EXAMPLE_VALUES.number\n }\n case 'ZodBigInt':\n case 'bigint':\n return BigInt(1)\n case 'ZodBoolean':\n case 'boolean':\n return DEFAULT_EXAMPLE_VALUES.boolean\n case 'ZodEnum':\n case 'enum': {\n const entries = def?.values ?? def?.entries\n const values = Array.isArray(entries) ? entries : entries ? Object.values(entries) : []\n return values[0]\n }\n case 'ZodNativeEnum': {\n const values = Object.values(def?.values || [])\n return values[0]\n }\n case 'ZodLiteral':\n case 'literal':\n return def?.value ?? (Array.isArray(def?.values) ? def.values[0] : undefined)\n case 'ZodArray':\n case 'array': {\n const elementSchema =\n def?.type && typeof def.type === 'object'\n ? def.type\n : (def?.element && typeof def.element === 'object' ? def.element : undefined)\n const child = generateExample(elementSchema, context)\n return child === undefined ? [] : [child]\n }\n case 'ZodTuple':\n case 'tuple': {\n const items = def?.items || []\n return items.map((item: ZodTypeAny) => generateExample(item, context))\n }\n case 'ZodObject':\n case 'object': {\n const shape = getShape(def)\n const obj: Record<string, unknown> = {}\n for (const [key, value] of Object.entries(shape)) {\n const example = generateExample(value as ZodTypeAny, context)\n if (example !== undefined) obj[key] = example\n }\n return obj\n }\n case 'ZodRecord':\n case 'record': {\n const valueExample = generateExample(def?.valueType ?? def?.value, context)\n return valueExample === undefined ? {} : { key: valueExample }\n }\n case 'ZodUnion':\n case 'union': {\n const options = def?.options || []\n return options.length ? generateExample(options[0], context) : undefined\n }\n case 'ZodPipeline':\n case 'pipe':\n return generateExample(def?.out ?? def?.innerType ?? def?.schema, context)\n case 'ZodLazy':\n case 'lazy': {\n const next = typeof def?.getter === 'function' ? def.getter() : undefined\n return next ? generateExample(next, context) : undefined\n }\n case 'ZodPromise':\n case 'promise':\n return generateExample(def?.type, context)\n case 'ZodCatch':\n case 'catch':\n return generateExample(def?.innerType ?? def?.type, context)\n case 'ZodReadonly':\n case 'readonly':\n return generateExample(def?.innerType ?? def?.type, context)\n case 'ZodIntersection':\n case 'intersection': {\n const left = generateExample(def?.left, context)\n const right = generateExample(def?.right, context)\n if (typeof left === 'object' && left && typeof right === 'object' && right) {\n return { ...(left as object), ...(right as object) }\n }\n return left ?? right\n }\n case 'ZodDate':\n case 'date':\n return DEFAULT_EXAMPLE_VALUES.datetime\n default:\n return undefined\n }\n } finally {\n context.stack.delete(trackable as ZodTypeAny)\n }\n}\n\nfunction buildParameters(\n schema: ZodTypeAny | undefined,\n location: ParameterLocation,\n pathParamNames?: PathParamInfo[]\n): Array<Record<string, unknown>> {\n if (!schema && location !== 'path') return []\n\n const params: Array<Record<string, unknown>> = []\n\n if (location === 'path' && pathParamNames && pathParamNames.length) {\n const merged = mergePathParamSchemas(schema, pathParamNames)\n for (const { name, schema: paramSchema, optional } of merged) {\n const jsonSchema = zodToJsonSchema(paramSchema)\n const example = generateExample(paramSchema)\n params.push({\n name,\n in: 'path',\n required: !optional,\n schema: jsonSchema ?? { type: 'string' },\n example,\n })\n }\n return params\n }\n\n if (!schema) return params\n\n const { schema: unwrapped } = unwrap(schema)\n if (!unwrapped) return params\n const def = (unwrapped as any)._def\n const typeName = resolveType(def) as string | undefined\n if (typeName === 'ZodObject' || typeName === 'object') {\n const shape = getShape(def)\n for (const [key, raw] of Object.entries(shape)) {\n const details = unwrap(raw as ZodTypeAny)\n if (!details.schema) continue\n const jsonSchema = zodToJsonSchema(details.schema)\n const example = generateExample(details.schema)\n params.push({\n name: key,\n in: location,\n required: location === 'path' ? true : !details.optional,\n schema: jsonSchema ?? {},\n example,\n })\n }\n } else {\n const jsonSchema = zodToJsonSchema(unwrapped)\n const example = generateExample(unwrapped)\n params.push({\n name: location === 'header' ? 'X-Custom-Header' : 'value',\n in: location,\n required: location === 'path',\n schema: jsonSchema ?? {},\n example,\n })\n }\n\n return params\n}\n\nfunction mergePathParamSchemas(schema: ZodTypeAny | undefined, params: PathParamInfo[]) {\n const merged: Array<{ name: string; schema: ZodTypeAny | undefined; optional: boolean }> = []\n const map: Record<string, ZodTypeAny> = {}\n if (schema) {\n const { schema: unwrapped } = unwrap(schema)\n if (unwrapped && (unwrapped as any)._def && (resolveType((unwrapped as any)._def) === 'ZodObject' || resolveType((unwrapped as any)._def) === 'object')) {\n const shape = getShape((unwrapped as any)._def)\n for (const [key, value] of Object.entries(shape)) {\n map[key] = value as ZodTypeAny\n }\n }\n }\n for (const param of params) {\n merged.push({\n name: param.name,\n schema: map[param.name],\n optional: !!param.optional,\n })\n }\n return merged\n}\n\nfunction buildRequestBody(request?: OpenApiRequestBodyDoc): Record<string, unknown> | undefined {\n if (!request) return undefined\n const schema = zodToJsonSchema(request.schema)\n const example = request.example ?? generateExample(request.schema)\n const contentType = request.contentType ?? 'application/json'\n return {\n required: true,\n content: {\n [contentType]: {\n schema: schema ?? {},\n example,\n },\n },\n description: request.description,\n }\n}\n\nfunction buildResponses(\n method: HttpMethod,\n responses?: OpenApiResponseDoc[],\n errors?: OpenApiResponseDoc[],\n metadata?: any\n): Record<string, unknown> {\n const entries: Record<string, unknown> = {}\n const list = [...(responses ?? [])]\n const errorList = [...(errors ?? [])]\n if (metadata?.requireAuth) {\n errorList.push({\n status: 401,\n description: 'Unauthorized',\n schema: z.object({ error: z.string() }),\n xAutoGenerated: true,\n })\n }\n if (Array.isArray(metadata?.requireFeatures) && metadata.requireFeatures.length) {\n errorList.push({\n status: 403,\n description: 'Forbidden \u2013 missing required features',\n schema: z.object({ error: z.string() }),\n xAutoGenerated: true,\n })\n }\n if (!list.some((res) => res.status >= 200 && res.status < 300)) {\n const fallbackStatus = method === 'POST' ? 201 : method === 'DELETE' ? 204 : 200\n list.push({\n status: fallbackStatus,\n description: fallbackStatus === 204 ? 'Success' : 'Success response',\n })\n }\n for (const res of [...list, ...errorList]) {\n const status = String(res.status || 200)\n const mediaType = res.mediaType ?? 'application/json'\n const schema = res.schema ? zodToJsonSchema(res.schema) : undefined\n const example = res.schema ? res.example ?? generateExample(res.schema) : res.example\n const isNoContent = res.status === 204\n entries[status] = {\n description: res.description ?? '',\n ...(isNoContent\n ? {}\n : {\n content: {\n [mediaType]: {\n schema: schema ?? { type: 'object' },\n ...(example !== undefined ? { example } : {}),\n },\n },\n }),\n ...(res.xAutoGenerated ? { 'x-autoGenerated': true } : {}),\n }\n }\n return entries\n}\n\nfunction buildSecurity(metadata: any, methodDoc?: OpenApiMethodDoc, defaults?: string[]) {\n const securitySchemes = new Set<string>()\n if (Array.isArray(methodDoc?.security)) methodDoc.security.forEach((s) => securitySchemes.add(s))\n if (metadata?.requireAuth) securitySchemes.add('bearerAuth')\n if (defaults) defaults.forEach((s) => securitySchemes.add(s))\n if (securitySchemes.size === 0) return undefined\n return Array.from(securitySchemes.values()).map((scheme) => ({ [scheme]: [] }))\n}\n\nfunction collectExamples(\n querySchema?: ZodTypeAny,\n bodySchema?: ZodTypeAny,\n pathSchema?: ZodTypeAny,\n headerSchema?: ZodTypeAny,\n metadata?: any\n): ExampleMap {\n const examples: ExampleMap = {}\n const queryExample = querySchema ? generateExample(querySchema) : undefined\n if (queryExample && typeof queryExample === 'object') examples.query = queryExample\n const bodyExample = bodySchema ? generateExample(bodySchema) : undefined\n if (bodyExample !== undefined) examples.body = bodyExample\n const pathExample = pathSchema ? generateExample(pathSchema) : undefined\n if (pathExample && typeof pathExample === 'object') examples.path = pathExample as Record<string, unknown>\n const headerExample = headerSchema ? generateExample(headerSchema) : undefined\n if (headerExample && typeof headerExample === 'object') examples.headers = headerExample as Record<string, unknown>\n if (metadata?.requireAuth) {\n if (!examples.headers) examples.headers = {}\n if (typeof examples.headers.authorization !== 'string') {\n examples.headers.authorization = 'Bearer <token>'\n }\n }\n return examples\n}\n\nfunction toFormUrlEncoded(value: unknown): string {\n if (!value || typeof value !== 'object') return ''\n const params = new URLSearchParams()\n for (const [key, raw] of Object.entries(value as Record<string, unknown>)) {\n if (raw === undefined) continue\n params.append(key, raw === null ? '' : String(raw))\n }\n return params.toString()\n}\n\nfunction stringifyBodyExample(value: unknown, mediaType?: string): string {\n if (value === undefined) return ''\n if (mediaType === 'application/x-www-form-urlencoded') {\n return toFormUrlEncoded(value)\n }\n if (!mediaType || mediaType === 'application/json') {\n try {\n return JSON.stringify(value, null, 2)\n } catch {\n return ''\n }\n }\n if (typeof value === 'string') return value\n try {\n return JSON.stringify(value, null, 2)\n } catch {\n return String(value)\n }\n}\n\nfunction buildQueryString(example: unknown): string {\n if (!example || typeof example !== 'object') return ''\n const parts: string[] = []\n for (const [key, value] of Object.entries(example as Record<string, unknown>)) {\n if (value === undefined || value === null) continue\n const encoded = encodeURIComponent(String(value))\n parts.push(`${encodeURIComponent(key)}=${encoded}`)\n }\n return parts.length ? `?${parts.join('&')}` : ''\n}\n\nfunction injectPathExamples(path: string, params: PathParamInfo[], examples?: Record<string, unknown>): string {\n if (!params.length) return path\n let result = path\n for (const param of params) {\n const placeholder = `{${param.name}}`\n const example = examples && examples[param.name] !== undefined ? examples[param.name] : `:${param.name}`\n result = result.replace(placeholder, String(example))\n }\n return result\n}\n\nfunction buildCurlSample(\n method: HttpMethod,\n path: string,\n params: PathParamInfo[],\n examples: ExampleMap,\n baseUrl: string,\n metadata: any,\n requestBody?: OpenApiRequestBodyDoc\n): string {\n const lines: string[] = []\n const pathWithExamples = injectPathExamples(path, params, examples.path)\n const query = buildQueryString(examples.query)\n const url = baseUrl.replace(/\\/$/, '') + pathWithExamples + query\n lines.push(`curl -X ${method} \"${url}\"`)\n\n lines.push(' -H \"Accept: application/json\"')\n\n const headers: Record<string, unknown> = { ...(examples.headers ?? {}) }\n if (metadata?.requireAuth && !headers.Authorization && !headers.authorization) {\n headers.Authorization = 'Bearer <token>'\n }\n for (const [key, value] of Object.entries(headers)) {\n lines.push(` -H \"${key.replace(/\"/g, '')}: ${String(value).replace(/\"/g, '')}\"`)\n }\n\n const bodyExample = examples.body ?? requestBody?.example\n const requestContentType = requestBody?.contentType ?? 'application/json'\n if (bodyExample !== undefined) {\n lines.push(` -H \"Content-Type: ${requestContentType}\"`)\n const serialized = stringifyBodyExample(bodyExample, requestContentType)\n if (serialized) {\n const escapedSerialized = escapeShellDoubleQuotes(serialized)\n lines.push(` -d \"${escapedSerialized}\"`)\n }\n }\n\n return lines.join(' \\\\\\n')\n}\n\nfunction escapeShellDoubleQuotes(value: string): string {\n return value.replace(/[\\\\`\"$]/g, '\\\\$&')\n}\n\nfunction ensureSecurityComponents(doc: OpenApiDocument) {\n if (!doc.components) doc.components = {}\n if (!doc.components.securitySchemes) doc.components.securitySchemes = {}\n if (!doc.components.securitySchemes.bearerAuth) {\n doc.components.securitySchemes.bearerAuth = {\n type: 'http',\n scheme: 'bearer',\n bearerFormat: 'JWT',\n description: 'Send an `Authorization: Bearer <token>` header with a valid API token.',\n }\n }\n}\n\nfunction resolveOperationId(moduleId: string, path: string, method: HttpMethod): string {\n const cleaned = normalizeOperationIdSegment(path)\n return [moduleId, method.toLowerCase(), cleaned].filter(Boolean).join('_')\n}\n\nfunction normalizeOperationIdSegment(input: string): string {\n let output = ''\n let previousUnderscore = false\n\n for (const character of input) {\n const codePoint = character.charCodeAt(0)\n const isLower = codePoint >= 97 && codePoint <= 122\n const isUpper = codePoint >= 65 && codePoint <= 90\n const isNumber = codePoint >= 48 && codePoint <= 57\n const isAlphaNumeric = isLower || isUpper || isNumber\n\n if (isAlphaNumeric) {\n output += character\n previousUnderscore = false\n continue\n }\n\n if (!previousUnderscore) {\n output += '_'\n previousUnderscore = true\n }\n }\n\n while (output.startsWith('_')) output = output.slice(1)\n while (output.endsWith('_')) output = output.slice(0, -1)\n\n return output\n}\n\nfunction collectRouteDoc(api: ModuleApi, moduleId: string): OpenApiRouteDoc | undefined {\n if ('handlers' in api) {\n const route = api as ModuleApiRouteFile & { docs?: OpenApiRouteDoc }\n if (route.docs) return route.docs\n const maybe = (route.handlers as any)?.openApi\n if (maybe && typeof maybe === 'object') return maybe as OpenApiRouteDoc\n } else {\n const legacy = api as ModuleApiLegacy & { docs?: OpenApiMethodDoc }\n if (legacy.docs) {\n return {\n methods: { [legacy.method]: legacy.docs },\n }\n }\n const maybe = (legacy.handler as any)?.openApi\n if (maybe && typeof maybe === 'object') {\n return {\n methods: { [legacy.method]: maybe as OpenApiMethodDoc },\n }\n }\n }\n return undefined\n}\n\nexport function buildOpenApiDocument(modules: Module[], options: OpenApiDocumentOptions = {}): OpenApiDocument {\n const doc: OpenApiDocument = {\n openapi: '3.1.0',\n info: {\n title: options.title ?? 'Open Mercato API',\n version: options.version ?? '1.0.0',\n description: options.description,\n },\n servers: options.servers,\n paths: {},\n }\n\n ensureSecurityComponents(doc)\n\n const tags = new Map<string, string | undefined>()\n\n for (const moduleEntry of modules) {\n const defaultTag = moduleEntry.info?.title ?? toTitle(moduleEntry.id)\n if (defaultTag) tags.set(defaultTag, moduleEntry.info?.description)\n\n const apis = moduleEntry.apis ?? []\n for (const api of apis) {\n const routeDoc = collectRouteDoc(api, moduleEntry.id)\n const moduleTag = routeDoc?.tag ?? defaultTag\n const normalized = normalizePath((api as any).path ?? (api as any).path ?? '')\n const pathKey = normalized.path\n if (!doc.paths[pathKey]) doc.paths[pathKey] = {}\n const availableMethods: HttpMethod[] =\n 'handlers' in api\n ? HTTP_METHODS.filter((method) => typeof (api as ModuleApiRouteFile).handlers?.[method] === 'function')\n : [api.method as HttpMethod]\n\n for (const method of availableMethods) {\n const methodLower = method.toLowerCase() as Lowercase<HttpMethod>\n const existing = doc.paths[pathKey][methodLower]\n if (existing) continue\n\n const metadata = 'handlers' in api ? (api as ModuleApiRouteFile).metadata?.[method] : undefined\n const methodDoc = routeDoc?.methods?.[method]\n const summary = methodDoc?.summary ?? routeDoc?.summary ?? `${method} ${pathKey}`\n const baseDescription = methodDoc?.description ?? routeDoc?.description\n const meta = metadata && typeof metadata === 'object' ? (metadata as Record<string, unknown>) : undefined\n const requireFeatures = Array.isArray(meta?.['requireFeatures'])\n ? (meta!['requireFeatures'] as string[])\n : undefined\n const requireRoles = Array.isArray(meta?.['requireRoles'])\n ? (meta!['requireRoles'] as string[])\n : undefined\n const requireAuth = meta?.['requireAuth'] === true\n const descriptionParts: string[] = []\n if (baseDescription) descriptionParts.push(baseDescription)\n if (Array.isArray(requireFeatures) && requireFeatures.length) {\n descriptionParts.push(`Requires features: ${requireFeatures.join(', ')}`)\n }\n if (Array.isArray(requireRoles) && requireRoles.length) {\n descriptionParts.push(`Requires roles: ${requireRoles.join(', ')}`)\n }\n\n const querySchema = methodDoc?.query\n const pathSchema = methodDoc?.pathParams ?? routeDoc?.pathParams\n const headerSchema = methodDoc?.headers\n const requestBody = methodDoc?.requestBody\n const examples = collectExamples(querySchema, requestBody?.schema, pathSchema, headerSchema, metadata)\n const curlSample = buildCurlSample(\n method,\n pathKey,\n normalized.params,\n examples,\n options.baseUrlForExamples ?? 'https://api.open-mercato.local',\n metadata,\n requestBody\n )\n\n doc.paths[pathKey][methodLower] = {\n operationId: methodDoc?.operationId ?? resolveOperationId(moduleEntry.id, pathKey, method),\n summary,\n description: descriptionParts.length ? descriptionParts.join('\\n\\n') : undefined,\n tags: methodDoc?.tags ?? (moduleTag ? [moduleTag] : undefined),\n deprecated: methodDoc?.deprecated,\n externalDocs: methodDoc?.externalDocs,\n parameters: [\n ...buildParameters(pathSchema, 'path', normalized.params),\n ...buildParameters(querySchema, 'query'),\n ...buildParameters(headerSchema, 'header'),\n ].filter(Boolean),\n requestBody: buildRequestBody(requestBody),\n responses: buildResponses(method, methodDoc?.responses, methodDoc?.errors, metadata),\n security: buildSecurity(metadata, methodDoc, options.defaultSecurity),\n 'x-codeSamples': methodDoc?.codeSamples ?? [\n {\n lang: 'curl',\n label: 'cURL',\n source: curlSample,\n },\n ],\n ...(Array.isArray(requireFeatures) && requireFeatures.length ? { 'x-require-features': requireFeatures } : {}),\n ...(Array.isArray(requireRoles) && requireRoles.length ? { 'x-require-roles': requireRoles } : {}),\n ...(requireAuth ? { 'x-require-auth': true } : {}),\n ...(methodDoc?.extensions ?? {}),\n }\n }\n }\n }\n\n doc.tags = Array.from(tags.entries()).map(([name, description]) => ({\n name,\n description: description ?? undefined,\n }))\n\n return doc\n}\n\nfunction formatMarkdownTable(rows: Array<[string, string, string, string]>): string {\n if (!rows.length) return ''\n const header = ['Name', 'Location', 'Type', 'Description']\n const align = ['---', '---', '---', '---']\n const lines = [\n `| ${header.join(' | ')} |`,\n `| ${align.join(' | ')} |`,\n ...rows.map((row) => `| ${row.join(' | ')} |`),\n ]\n return lines.join('\\n')\n}\n\nfunction schemaTypeLabel(schema: any): string {\n if (!schema) return 'any'\n if (schema.type) return schema.type\n if (schema.oneOf) return schema.oneOf.map(schemaTypeLabel).join(' | ')\n if (schema.allOf) return schema.allOf.map(schemaTypeLabel).join(' & ')\n return 'any'\n}\n\nfunction schemaHasDetails(schema: unknown): boolean {\n if (!schema || typeof schema !== 'object') return false\n const schemaObj = schema as Record<string, unknown>\n if (Array.isArray(schemaObj.enum) && schemaObj.enum.length) return true\n if (schemaObj.const !== undefined) return true\n if (typeof schemaObj.format === 'string') return true\n if (Array.isArray(schemaObj.oneOf) && schemaObj.oneOf.some((s: unknown) => schemaHasDetails(s))) return true\n if (Array.isArray(schemaObj.anyOf) && schemaObj.anyOf.some((s: unknown) => schemaHasDetails(s))) return true\n if (Array.isArray(schemaObj.allOf) && schemaObj.allOf.some((s: unknown) => schemaHasDetails(s))) return true\n if (schemaObj.items && schemaHasDetails(schemaObj.items)) return true\n if (schemaObj.properties && Object.keys(schemaObj.properties as Record<string, unknown>).length) return true\n if (Array.isArray(schemaObj.prefixItems) && schemaObj.prefixItems.some((s: unknown) => schemaHasDetails(s))) return true\n if (schemaObj.type && schemaObj.type !== 'object') return true\n return false\n}\n\ntype ContentSelection = {\n mediaType: string\n entry: any\n}\n\ntype DisplaySnippet = {\n value: string\n language: string\n}\n\nfunction selectContentVariant(content?: Record<string, any>): ContentSelection | undefined {\n if (!content) return undefined\n const entries = Object.entries(content)\n if (!entries.length) return undefined\n const preferred = [\n 'application/json',\n 'application/x-www-form-urlencoded',\n 'multipart/form-data',\n 'text/plain',\n ]\n for (const mediaType of preferred) {\n const match = entries.find(([type]) => type === mediaType)\n if (match) {\n const [selectedType, entry] = match\n return { mediaType: selectedType, entry }\n }\n }\n const [mediaType, entry] = entries[0]\n return { mediaType, entry }\n}\n\nfunction formatExampleForDisplay(example: unknown, mediaType?: string): DisplaySnippet | null {\n if (example === undefined) return null\n if (mediaType === 'application/x-www-form-urlencoded') {\n const encoded = toFormUrlEncoded(example)\n if (!encoded) return null\n return { value: encoded, language: 'text' }\n }\n if (mediaType === 'multipart/form-data') {\n if (example && typeof example === 'object') {\n const lines = Object.entries(example as Record<string, unknown>).map(([key, value]) => {\n const rendered = value === undefined || value === null ? '' : String(value)\n return `${key}=${rendered}`\n })\n if (lines.length) {\n return { value: lines.join('\\n'), language: 'text' }\n }\n }\n if (typeof example === 'string') {\n return { value: example, language: 'text' }\n }\n }\n if (!mediaType || mediaType === 'application/json') {\n try {\n return { value: JSON.stringify(example, null, 2), language: 'json' }\n } catch {\n return null\n }\n }\n if (typeof example === 'string') {\n return { value: example, language: 'text' }\n }\n try {\n return { value: JSON.stringify(example, null, 2), language: 'json' }\n } catch {\n return { value: String(example), language: 'text' }\n }\n}\n\nfunction formatSchemaForDisplay(schema: any): DisplaySnippet | null {\n if (!schema) return null\n try {\n return { value: JSON.stringify(schema, null, 2), language: 'json' }\n } catch {\n return null\n }\n}\n\nexport function generateMarkdownFromOpenApi(doc: OpenApiDocument): string {\n const lines: string[] = []\n lines.push(`# ${doc.info.title}`)\n lines.push('')\n lines.push(`Version: ${doc.info.version}`)\n if (doc.info.description) {\n lines.push('')\n lines.push(doc.info.description)\n }\n if (doc.servers && doc.servers.length) {\n lines.push('')\n lines.push('## Servers')\n for (const server of doc.servers) {\n lines.push(`- ${server.url}${server.description ? ` \u2013 ${server.description}` : ''}`)\n }\n }\n\n const sortedPaths = Object.keys(doc.paths).sort()\n for (const path of sortedPaths) {\n const operations = doc.paths[path]\n const methods = Object.keys(operations).sort()\n for (const method of methods) {\n const op: any = operations[method]\n lines.push('')\n lines.push(`## ${method.toUpperCase()} \\`${path}\\``)\n if (op.summary) {\n lines.push('')\n lines.push(op.summary)\n }\n if (op.description) {\n lines.push('')\n lines.push(op.description)\n }\n if (op.tags && op.tags.length) {\n lines.push('')\n lines.push(`**Tags:** ${op.tags.join(', ')}`)\n }\n if (op['x-require-auth']) {\n lines.push('')\n lines.push(`**Requires authentication.**`)\n }\n if (op['x-require-features']) {\n lines.push('')\n lines.push(`**Features:** ${(op['x-require-features'] as string[]).join(', ')}`)\n }\n if (op['x-require-roles']) {\n lines.push('')\n lines.push(`**Roles:** ${(op['x-require-roles'] as string[]).join(', ')}`)\n }\n\n const parameters = (op.parameters as any[]) ?? []\n if (parameters.length) {\n lines.push('')\n lines.push('### Parameters')\n const rows: Array<[string, string, string, string]> = parameters.map((p) => [\n p.name,\n p.in,\n schemaTypeLabel(p.schema),\n p.required ? 'Required' : 'Optional',\n ])\n lines.push(formatMarkdownTable(rows))\n }\n\n if (op.requestBody) {\n const selection = selectContentVariant(op.requestBody.content)\n if (selection) {\n const { mediaType, entry } = selection\n const example = entry?.example ?? entry?.examples?.default?.value\n const formatted = formatExampleForDisplay(example, mediaType)\n const schemaFormatted =\n entry?.schema && schemaHasDetails(entry.schema) ? formatSchemaForDisplay(entry.schema) : null\n lines.push('')\n lines.push('### Request Body')\n lines.push('')\n lines.push(`Content-Type: \\`${mediaType}\\``)\n if (formatted) {\n lines.push('')\n lines.push(`\\`\\`\\`${formatted.language}`)\n lines.push(formatted.value)\n lines.push('```')\n } else if (schemaFormatted) {\n lines.push('')\n lines.push(`\\`\\`\\`${schemaFormatted.language}`)\n lines.push(schemaFormatted.value)\n lines.push('```')\n } else {\n lines.push('')\n lines.push('No example available for this content type.')\n }\n }\n }\n\n const responses = op.responses ?? {}\n const responseStatuses = Object.keys(responses).sort()\n if (responseStatuses.length) {\n lines.push('')\n lines.push('### Responses')\n for (const status of responseStatuses) {\n const response = responses[status]\n if (response?.['x-autoGenerated']) continue\n lines.push('')\n lines.push(`**${status}** \u2013 ${response.description || 'Response'}`)\n const selection = selectContentVariant(response.content)\n if (selection) {\n const { mediaType, entry } = selection\n const example = entry?.example ?? entry?.examples?.default?.value\n const formatted = formatExampleForDisplay(example, mediaType)\n const schemaFormatted =\n entry?.schema && schemaHasDetails(entry.schema) ? formatSchemaForDisplay(entry.schema) : null\n lines.push('')\n lines.push(`Content-Type: \\`${mediaType}\\``)\n if (formatted) {\n lines.push('')\n lines.push(`\\`\\`\\`${formatted.language}`)\n lines.push(formatted.value)\n lines.push('```')\n } else if (schemaFormatted) {\n lines.push('')\n lines.push(`\\`\\`\\`${schemaFormatted.language}`)\n lines.push(schemaFormatted.value)\n lines.push('```')\n }\n }\n }\n }\n\n const samples = op['x-codeSamples'] as any[] | undefined\n if (samples && samples.length) {\n const curl = samples.find((sample) => String(sample.lang).toLowerCase() === 'curl') ?? samples[0]\n if (curl?.source) {\n lines.push('')\n lines.push('### Example')\n lines.push('')\n lines.push('```bash')\n lines.push(curl.source)\n lines.push('```')\n }\n }\n }\n }\n\n return lines.join('\\n')\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["mediaType", "entry"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from "./types.js";
|
|
2
|
+
import { buildOpenApiDocument, generateMarkdownFromOpenApi } from "./generator.js";
|
|
3
|
+
export * from "./crud.js";
|
|
4
|
+
import { sanitizeOpenApiDocument } from "./sanitize.js";
|
|
5
|
+
export {
|
|
6
|
+
buildOpenApiDocument,
|
|
7
|
+
generateMarkdownFromOpenApi,
|
|
8
|
+
sanitizeOpenApiDocument
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/lib/openapi/index.ts"],
|
|
4
|
+
"sourcesContent": ["export * from './types'\nexport { buildOpenApiDocument, generateMarkdownFromOpenApi } from './generator'\nexport * from './crud'\nexport { sanitizeOpenApiDocument } from './sanitize'\n"],
|
|
5
|
+
"mappings": "AAAA,cAAc;AACd,SAAS,sBAAsB,mCAAmC;AAClE,cAAc;AACd,SAAS,+BAA+B;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
function isPlainObject(value) {
|
|
2
|
+
return typeof value === "object" && value !== null && Object.getPrototypeOf(value) === Object.prototype;
|
|
3
|
+
}
|
|
4
|
+
function toComponentName(hint, fallbackIndex) {
|
|
5
|
+
const cleaned = hint.split(/[^a-zA-Z0-9]+/).filter(Boolean).map((segment) => segment.charAt(0).toUpperCase() + segment.slice(1)).join("");
|
|
6
|
+
return cleaned.length ? cleaned : `Schema${fallbackIndex}`;
|
|
7
|
+
}
|
|
8
|
+
const SCHEMA_KEYS = /* @__PURE__ */ new Set([
|
|
9
|
+
"type",
|
|
10
|
+
"properties",
|
|
11
|
+
"items",
|
|
12
|
+
"anyOf",
|
|
13
|
+
"oneOf",
|
|
14
|
+
"allOf",
|
|
15
|
+
"$ref",
|
|
16
|
+
"enum",
|
|
17
|
+
"format",
|
|
18
|
+
"not",
|
|
19
|
+
"additionalProperties",
|
|
20
|
+
"required",
|
|
21
|
+
"pattern",
|
|
22
|
+
"minimum",
|
|
23
|
+
"maximum"
|
|
24
|
+
]);
|
|
25
|
+
function looksLikeSchema(value) {
|
|
26
|
+
if (typeof value.$ref === "string") return true;
|
|
27
|
+
for (const key of Object.keys(value)) {
|
|
28
|
+
if (SCHEMA_KEYS.has(key)) return true;
|
|
29
|
+
}
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
function sanitizeOpenApiDocument(doc) {
|
|
33
|
+
const target = doc;
|
|
34
|
+
const schemaNameMap = /* @__PURE__ */ new Map();
|
|
35
|
+
const schemas = target.components?.schemas ?? {};
|
|
36
|
+
if (!target.components) target.components = {};
|
|
37
|
+
target.components.schemas = schemas;
|
|
38
|
+
let counter = Object.keys(schemas).length;
|
|
39
|
+
const cloneContainer = (source, hint, mode) => {
|
|
40
|
+
const clone = {};
|
|
41
|
+
for (const [key, value] of Object.entries(source)) {
|
|
42
|
+
const forceSchema = mode === "properties" || mode === "patternProperties";
|
|
43
|
+
clone[key] = cloneSchemaValue(value, `${hint}_${key}`, key, forceSchema);
|
|
44
|
+
}
|
|
45
|
+
return clone;
|
|
46
|
+
};
|
|
47
|
+
const serializeSchema = (schema, hint) => {
|
|
48
|
+
if (schemaNameMap.has(schema)) {
|
|
49
|
+
const name2 = schemaNameMap.get(schema);
|
|
50
|
+
return { $ref: `#/components/schemas/${name2}` };
|
|
51
|
+
}
|
|
52
|
+
counter += 1;
|
|
53
|
+
const tentativeName = toComponentName(hint, counter);
|
|
54
|
+
let name = tentativeName;
|
|
55
|
+
let suffix = 1;
|
|
56
|
+
while (schemas[name]) {
|
|
57
|
+
name = `${tentativeName}${suffix++}`;
|
|
58
|
+
}
|
|
59
|
+
schemaNameMap.set(schema, name);
|
|
60
|
+
schemas[name] = cloneContainer(schema, hint);
|
|
61
|
+
return { $ref: `#/components/schemas/${name}` };
|
|
62
|
+
};
|
|
63
|
+
const cloneSchemaValue = (value, hint, parentKey, forceSchema = false) => {
|
|
64
|
+
if (Array.isArray(value)) {
|
|
65
|
+
return value.map((entry, idx) => cloneSchemaValue(entry, `${hint}_${idx}`, parentKey, forceSchema));
|
|
66
|
+
}
|
|
67
|
+
if (isPlainObject(value)) {
|
|
68
|
+
if (typeof value.$ref === "string") return value;
|
|
69
|
+
if (parentKey === "properties" || parentKey === "patternProperties") {
|
|
70
|
+
return cloneContainer(value, hint, parentKey);
|
|
71
|
+
}
|
|
72
|
+
if (parentKey === "additionalProperties" && Object.keys(value).length) {
|
|
73
|
+
return serializeSchema(value, hint);
|
|
74
|
+
}
|
|
75
|
+
if (forceSchema || looksLikeSchema(value)) {
|
|
76
|
+
return serializeSchema(value, hint);
|
|
77
|
+
}
|
|
78
|
+
return cloneContainer(value, hint);
|
|
79
|
+
}
|
|
80
|
+
if (typeof value === "bigint") {
|
|
81
|
+
return value.toString();
|
|
82
|
+
}
|
|
83
|
+
return value;
|
|
84
|
+
};
|
|
85
|
+
const traverse = (value, hint) => {
|
|
86
|
+
if (Array.isArray(value)) {
|
|
87
|
+
return value.map((entry, idx) => traverse(entry, `${hint}_${idx}`));
|
|
88
|
+
}
|
|
89
|
+
if (!isPlainObject(value)) {
|
|
90
|
+
if (typeof value === "bigint") {
|
|
91
|
+
return value.toString();
|
|
92
|
+
}
|
|
93
|
+
return value;
|
|
94
|
+
}
|
|
95
|
+
const result = { ...value };
|
|
96
|
+
for (const [key, child] of Object.entries(result)) {
|
|
97
|
+
if (key === "schema" && child && typeof child === "object") {
|
|
98
|
+
result[key] = cloneSchemaValue(child, `${hint}_${key}`, key);
|
|
99
|
+
} else {
|
|
100
|
+
result[key] = traverse(child, `${hint}_${key}`);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return result;
|
|
104
|
+
};
|
|
105
|
+
return traverse(target, "doc");
|
|
106
|
+
}
|
|
107
|
+
export {
|
|
108
|
+
sanitizeOpenApiDocument
|
|
109
|
+
};
|
|
110
|
+
//# sourceMappingURL=sanitize.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/lib/openapi/sanitize.ts"],
|
|
4
|
+
"sourcesContent": ["type JsonValue = string | number | boolean | null | JsonValue[] | { [key: string]: JsonValue }\ntype MutableOpenApiDoc = Record<string, any> & {\n components?: {\n schemas?: Record<string, JsonValue>\n }\n}\n\nfunction isPlainObject(value: unknown): value is Record<string, any> {\n return typeof value === 'object' && value !== null && Object.getPrototypeOf(value) === Object.prototype\n}\n\nfunction toComponentName(hint: string, fallbackIndex: number): string {\n const cleaned = hint\n .split(/[^a-zA-Z0-9]+/)\n .filter(Boolean)\n .map((segment) => segment.charAt(0).toUpperCase() + segment.slice(1))\n .join('')\n return cleaned.length ? cleaned : `Schema${fallbackIndex}`\n}\n\nconst SCHEMA_KEYS = new Set([\n 'type',\n 'properties',\n 'items',\n 'anyOf',\n 'oneOf',\n 'allOf',\n '$ref',\n 'enum',\n 'format',\n 'not',\n 'additionalProperties',\n 'required',\n 'pattern',\n 'minimum',\n 'maximum',\n])\n\nfunction looksLikeSchema(value: Record<string, unknown>): boolean {\n if (typeof value.$ref === 'string') return true\n for (const key of Object.keys(value)) {\n if (SCHEMA_KEYS.has(key)) return true\n }\n return false\n}\n\nexport function sanitizeOpenApiDocument<T extends Record<string, any>>(doc: T): T {\n const target = doc as T & MutableOpenApiDoc\n const schemaNameMap = new Map<object, string>()\n const schemas: Record<string, JsonValue> = target.components?.schemas ?? {}\n if (!target.components) target.components = {}\n target.components.schemas = schemas\n let counter = Object.keys(schemas).length\n\n const cloneContainer = (\n source: Record<string, any>,\n hint: string,\n mode?: 'properties' | 'patternProperties'\n ): JsonValue => {\n const clone: Record<string, JsonValue> = {}\n for (const [key, value] of Object.entries(source)) {\n const forceSchema = mode === 'properties' || mode === 'patternProperties'\n clone[key] = cloneSchemaValue(value, `${hint}_${key}`, key, forceSchema)\n }\n return clone\n }\n\n const serializeSchema = (schema: Record<string, any>, hint: string): JsonValue => {\n if (schemaNameMap.has(schema)) {\n const name = schemaNameMap.get(schema)!\n return { $ref: `#/components/schemas/${name}` }\n }\n counter += 1\n const tentativeName = toComponentName(hint, counter)\n let name = tentativeName\n let suffix = 1\n while (schemas[name]) {\n name = `${tentativeName}${suffix++}`\n }\n schemaNameMap.set(schema, name)\n schemas[name] = cloneContainer(schema, hint)\n return { $ref: `#/components/schemas/${name}` }\n }\n\n const cloneSchemaValue = (\n value: any,\n hint: string,\n parentKey?: string,\n forceSchema = false\n ): JsonValue => {\n if (Array.isArray(value)) {\n return value.map((entry, idx) => cloneSchemaValue(entry, `${hint}_${idx}`, parentKey, forceSchema)) as JsonValue\n }\n if (isPlainObject(value)) {\n if (typeof value.$ref === 'string') return value\n if (parentKey === 'properties' || parentKey === 'patternProperties') {\n return cloneContainer(value, hint, parentKey)\n }\n if (parentKey === 'additionalProperties' && Object.keys(value).length) {\n return serializeSchema(value, hint)\n }\n if (forceSchema || looksLikeSchema(value)) {\n return serializeSchema(value, hint)\n }\n return cloneContainer(value, hint)\n }\n // Convert BigInt to string for JSON serialization\n if (typeof value === 'bigint') {\n return value.toString()\n }\n return value as JsonValue\n }\n\n const traverse = (value: any, hint: string): any => {\n if (Array.isArray(value)) {\n return value.map((entry, idx) => traverse(entry, `${hint}_${idx}`))\n }\n if (!isPlainObject(value)) {\n // Convert BigInt to string for JSON serialization\n if (typeof value === 'bigint') {\n return value.toString()\n }\n return value\n }\n const result: Record<string, unknown> = { ...value }\n for (const [key, child] of Object.entries(result)) {\n if (key === 'schema' && child && typeof child === 'object') {\n result[key] = cloneSchemaValue(child, `${hint}_${key}`, key)\n } else {\n result[key] = traverse(child, `${hint}_${key}`)\n }\n }\n return result\n }\n\n return traverse(target, 'doc') as T\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["name"]
|
|
7
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
import { parseBooleanToken } from "../boolean.js";
|
|
2
|
+
const ROUND_PRECISION = 1e3;
|
|
3
|
+
const NS_PER_MS = BigInt(1e6);
|
|
4
|
+
const BIGINT_ZERO = BigInt(0);
|
|
5
|
+
function now() {
|
|
6
|
+
return process.hrtime.bigint();
|
|
7
|
+
}
|
|
8
|
+
function roundDuration(ns) {
|
|
9
|
+
if (ns <= BIGINT_ZERO) return 0;
|
|
10
|
+
const ms = Number(ns) / Number(NS_PER_MS);
|
|
11
|
+
return Math.round(ms * ROUND_PRECISION) / ROUND_PRECISION;
|
|
12
|
+
}
|
|
13
|
+
function mergeExtra(base, extra) {
|
|
14
|
+
if (!base && !extra) return void 0;
|
|
15
|
+
if (!base) return extra ? { ...extra } : void 0;
|
|
16
|
+
if (!extra) return base ? { ...base } : void 0;
|
|
17
|
+
return { ...base, ...extra };
|
|
18
|
+
}
|
|
19
|
+
function serializeNode(node) {
|
|
20
|
+
const base = {
|
|
21
|
+
label: node.label,
|
|
22
|
+
durationMs: roundDuration(node.durationNs)
|
|
23
|
+
};
|
|
24
|
+
if (node.extra && Object.keys(node.extra).length > 0) {
|
|
25
|
+
base.extra = node.extra;
|
|
26
|
+
}
|
|
27
|
+
base.type = node.type;
|
|
28
|
+
if (node.type === "span" && node.children.length > 0) {
|
|
29
|
+
base.children = node.children.map(serializeNode);
|
|
30
|
+
}
|
|
31
|
+
return base;
|
|
32
|
+
}
|
|
33
|
+
class ProfilerImpl {
|
|
34
|
+
constructor(options) {
|
|
35
|
+
this.closed = false;
|
|
36
|
+
this.root = options.root;
|
|
37
|
+
this.span = options.span;
|
|
38
|
+
this.parent = options.parent;
|
|
39
|
+
this.lastTimestamp = options.span ? options.span.lastTimestamp : options.root.lastTimestamp;
|
|
40
|
+
}
|
|
41
|
+
get enabled() {
|
|
42
|
+
return this.root.enabled;
|
|
43
|
+
}
|
|
44
|
+
mark(label, extra) {
|
|
45
|
+
if (!this.enabled || this.closed) return;
|
|
46
|
+
const timestamp = now();
|
|
47
|
+
const duration = timestamp - this.lastTimestamp;
|
|
48
|
+
const node = {
|
|
49
|
+
type: "mark",
|
|
50
|
+
label,
|
|
51
|
+
start: timestamp,
|
|
52
|
+
durationNs: duration >= BIGINT_ZERO ? duration : BIGINT_ZERO,
|
|
53
|
+
extra: extra ? { ...extra } : void 0
|
|
54
|
+
};
|
|
55
|
+
this.appendNode(node);
|
|
56
|
+
this.updateTimestamps(timestamp);
|
|
57
|
+
}
|
|
58
|
+
section(label, extra) {
|
|
59
|
+
if (!this.enabled || this.closed) {
|
|
60
|
+
return disabledSection;
|
|
61
|
+
}
|
|
62
|
+
const child = this.child(label, extra);
|
|
63
|
+
return {
|
|
64
|
+
end: (childExtra) => child.end(childExtra)
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
async measure(label, fn, extra) {
|
|
68
|
+
if (!this.enabled || this.closed) {
|
|
69
|
+
return Promise.resolve(fn());
|
|
70
|
+
}
|
|
71
|
+
const child = this.child(label);
|
|
72
|
+
try {
|
|
73
|
+
const result = await Promise.resolve(fn());
|
|
74
|
+
const payload = typeof extra === "function" ? extra(result) : extra;
|
|
75
|
+
child.end(payload);
|
|
76
|
+
return result;
|
|
77
|
+
} catch (err) {
|
|
78
|
+
child.end({ error: err instanceof Error ? err.message : String(err) });
|
|
79
|
+
throw err;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
record(label, durationMs, extra) {
|
|
83
|
+
if (!this.enabled || this.closed) return;
|
|
84
|
+
const safeDurationMs = Number.isFinite(durationMs) && durationMs > 0 ? durationMs : 0;
|
|
85
|
+
const durationNs = BigInt(Math.round(safeDurationMs * Number(NS_PER_MS)));
|
|
86
|
+
const node = {
|
|
87
|
+
type: "record",
|
|
88
|
+
label,
|
|
89
|
+
start: this.lastTimestamp,
|
|
90
|
+
durationNs: durationNs >= BIGINT_ZERO ? durationNs : BIGINT_ZERO,
|
|
91
|
+
extra: extra ? { ...extra } : void 0
|
|
92
|
+
};
|
|
93
|
+
this.appendNode(node);
|
|
94
|
+
this.updateTimestamps(this.lastTimestamp + node.durationNs);
|
|
95
|
+
}
|
|
96
|
+
child(label, extra) {
|
|
97
|
+
if (!this.enabled || this.closed) return disabledProfiler;
|
|
98
|
+
const timestamp = now();
|
|
99
|
+
const span = {
|
|
100
|
+
type: "span",
|
|
101
|
+
label,
|
|
102
|
+
start: timestamp,
|
|
103
|
+
durationNs: BIGINT_ZERO,
|
|
104
|
+
extra: extra ? { ...extra } : void 0,
|
|
105
|
+
children: [],
|
|
106
|
+
lastTimestamp: timestamp,
|
|
107
|
+
closed: false
|
|
108
|
+
};
|
|
109
|
+
this.appendNode(span);
|
|
110
|
+
this.updateTimestamps(timestamp);
|
|
111
|
+
return new ProfilerImpl({ root: this.root, span, parent: this });
|
|
112
|
+
}
|
|
113
|
+
end(extra) {
|
|
114
|
+
if (!this.enabled || this.closed) return;
|
|
115
|
+
const current = now();
|
|
116
|
+
if (this.span) {
|
|
117
|
+
this.closeSpan(current, extra);
|
|
118
|
+
} else {
|
|
119
|
+
this.closeRoot(current, extra);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
appendNode(node) {
|
|
123
|
+
if (this.span) {
|
|
124
|
+
this.span.children.push(node);
|
|
125
|
+
this.span.lastTimestamp = node.start;
|
|
126
|
+
} else {
|
|
127
|
+
this.root.nodes.push(node);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
updateTimestamps(newTimestamp) {
|
|
131
|
+
if (this.span) {
|
|
132
|
+
this.span.lastTimestamp = newTimestamp;
|
|
133
|
+
} else {
|
|
134
|
+
this.root.lastTimestamp = newTimestamp;
|
|
135
|
+
}
|
|
136
|
+
this.lastTimestamp = newTimestamp;
|
|
137
|
+
}
|
|
138
|
+
closeSpan(closedAt, extra) {
|
|
139
|
+
if (!this.span || this.span.closed) return;
|
|
140
|
+
const effectiveEnd = closedAt >= this.span.start ? closedAt : this.span.start;
|
|
141
|
+
this.span.durationNs = effectiveEnd - this.span.start;
|
|
142
|
+
this.span.extra = mergeExtra(this.span.extra, extra);
|
|
143
|
+
this.span.closed = true;
|
|
144
|
+
this.closed = true;
|
|
145
|
+
this.updateTimestamps(effectiveEnd);
|
|
146
|
+
if (this.parent) {
|
|
147
|
+
this.parent.updateTimestamps(effectiveEnd);
|
|
148
|
+
} else {
|
|
149
|
+
this.root.lastTimestamp = effectiveEnd;
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
closeRoot(closedAt, extra) {
|
|
153
|
+
if (this.root.closed) return;
|
|
154
|
+
const endTime = closedAt >= this.root.startedAt ? closedAt : this.root.startedAt;
|
|
155
|
+
this.root.lastTimestamp = endTime;
|
|
156
|
+
this.root.meta = mergeExtra(this.root.meta, extra);
|
|
157
|
+
this.root.closed = true;
|
|
158
|
+
this.closed = true;
|
|
159
|
+
const totalNs = endTime - this.root.startedAt;
|
|
160
|
+
const snapshot = {
|
|
161
|
+
scope: this.root.scope,
|
|
162
|
+
target: this.root.target,
|
|
163
|
+
totalMs: roundDuration(totalNs),
|
|
164
|
+
tree: this.root.nodes.map(serializeNode)
|
|
165
|
+
};
|
|
166
|
+
if (this.root.meta && Object.keys(this.root.meta).length > 0) {
|
|
167
|
+
snapshot.meta = this.root.meta;
|
|
168
|
+
}
|
|
169
|
+
const serialized = JSON.stringify(snapshot, null, 2);
|
|
170
|
+
try {
|
|
171
|
+
console.info(this.root.loggerLabel, serialized);
|
|
172
|
+
} catch {
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
const disabledSection = { end: () => {
|
|
177
|
+
} };
|
|
178
|
+
const disabledProfiler = {
|
|
179
|
+
get enabled() {
|
|
180
|
+
return false;
|
|
181
|
+
},
|
|
182
|
+
mark: () => {
|
|
183
|
+
},
|
|
184
|
+
section: () => disabledSection,
|
|
185
|
+
measure: async (_label, fn) => Promise.resolve(fn()),
|
|
186
|
+
record: () => {
|
|
187
|
+
},
|
|
188
|
+
child: () => disabledProfiler,
|
|
189
|
+
end: () => {
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
function createProfiler(options) {
|
|
193
|
+
if (options.enabled === false) return disabledProfiler;
|
|
194
|
+
const startedAt = now();
|
|
195
|
+
const enabledFlag = options.enabled !== void 0 ? options.enabled : true;
|
|
196
|
+
const root = {
|
|
197
|
+
scope: options.scope,
|
|
198
|
+
target: options.target,
|
|
199
|
+
label: options.label ?? options.scope,
|
|
200
|
+
loggerLabel: options.loggerLabel ?? "[profile]",
|
|
201
|
+
enabled: enabledFlag,
|
|
202
|
+
startedAt,
|
|
203
|
+
lastTimestamp: startedAt,
|
|
204
|
+
nodes: [],
|
|
205
|
+
closed: false,
|
|
206
|
+
meta: options.meta ? { ...options.meta } : void 0
|
|
207
|
+
};
|
|
208
|
+
return new ProfilerImpl({ root });
|
|
209
|
+
}
|
|
210
|
+
function normalizeProfilerTokens(input) {
|
|
211
|
+
if (!input) return [];
|
|
212
|
+
return input.split(",").map((token) => token.trim().toLowerCase()).filter((token) => token.length > 0);
|
|
213
|
+
}
|
|
214
|
+
function profilerMatches(target, tokens) {
|
|
215
|
+
if (!tokens.length) return false;
|
|
216
|
+
const lower = target.toLowerCase();
|
|
217
|
+
return tokens.some((token) => {
|
|
218
|
+
if (token === "*" || token === "all" || parseBooleanToken(token) === true) return true;
|
|
219
|
+
if (token.endsWith("*")) {
|
|
220
|
+
const prefix = token.slice(0, -1);
|
|
221
|
+
return prefix.length === 0 ? true : lower.startsWith(prefix);
|
|
222
|
+
}
|
|
223
|
+
return token === lower;
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
const DEFAULT_ENV_KEYS = [
|
|
227
|
+
"OM_PROFILE",
|
|
228
|
+
"NEXT_PUBLIC_OM_PROFILE",
|
|
229
|
+
"OM_CRUD_PROFILE",
|
|
230
|
+
"NEXT_PUBLIC_OM_CRUD_PROFILE",
|
|
231
|
+
"OM_QE_PROFILE",
|
|
232
|
+
"NEXT_PUBLIC_OM_QE_PROFILE"
|
|
233
|
+
];
|
|
234
|
+
function resolveProfilerTokens(envKeys = DEFAULT_ENV_KEYS) {
|
|
235
|
+
const tokens = [];
|
|
236
|
+
envKeys.forEach((key) => {
|
|
237
|
+
const raw = process.env[key];
|
|
238
|
+
if (!raw) return;
|
|
239
|
+
const parsed = normalizeProfilerTokens(raw);
|
|
240
|
+
if (parsed.length) tokens.push(...parsed);
|
|
241
|
+
});
|
|
242
|
+
return Array.from(new Set(tokens));
|
|
243
|
+
}
|
|
244
|
+
function shouldEnableProfiler(target, options) {
|
|
245
|
+
const tokens = options?.tokens ?? resolveProfilerTokens(options?.envKeys);
|
|
246
|
+
if (!tokens.length) return false;
|
|
247
|
+
return profilerMatches(target, tokens);
|
|
248
|
+
}
|
|
249
|
+
const disabledProfilerInstance = disabledProfiler;
|
|
250
|
+
export {
|
|
251
|
+
createProfiler,
|
|
252
|
+
disabledProfilerInstance,
|
|
253
|
+
normalizeProfilerTokens,
|
|
254
|
+
profilerMatches,
|
|
255
|
+
resolveProfilerTokens,
|
|
256
|
+
shouldEnableProfiler
|
|
257
|
+
};
|
|
258
|
+
//# sourceMappingURL=index.js.map
|