sonamu 0.8.13 → 0.8.14
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/dist/api/sonamu.d.ts.map +1 -1
- package/dist/api/sonamu.js +2 -3
- package/dist/auth/auth-generator.d.ts +8 -0
- package/dist/auth/auth-generator.d.ts.map +1 -1
- package/dist/auth/auth-generator.js +33 -1
- package/dist/auth/better-auth-entities.d.ts.map +1 -1
- package/dist/auth/better-auth-entities.js +12 -2
- package/dist/bin/cli.js +18 -3
- package/dist/cone/cone-generator.js +10 -4
- package/dist/database/knex.d.ts.map +1 -1
- package/dist/database/knex.js +64 -2
- package/dist/database/puri.d.ts +9 -1
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +42 -1
- package/dist/database/puri.types.d.ts +2 -0
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +6 -2
- package/dist/entity/entity-manager.d.ts +149 -1
- package/dist/entity/entity-manager.d.ts.map +1 -1
- package/dist/entity/entity-manager.js +68 -4
- package/dist/migration/__tests__/code-generation.search-text.test.js +435 -0
- package/dist/migration/code-generation.d.ts.map +1 -1
- package/dist/migration/code-generation.js +696 -32
- package/dist/migration/migration-set.js +3 -1
- package/dist/migration/postgresql-schema-reader.d.ts +16 -2
- package/dist/migration/postgresql-schema-reader.d.ts.map +1 -1
- package/dist/migration/postgresql-schema-reader.js +281 -7
- package/dist/stream/sse.js +5 -3
- package/dist/template/__tests__/generated.template.search-text.test.js +99 -0
- package/dist/template/generated.template.test-d.js +24 -0
- package/dist/template/implementations/generated.template.d.ts.map +1 -1
- package/dist/template/implementations/generated.template.js +2 -2
- package/dist/template/implementations/init_types.template.d.ts.map +1 -1
- package/dist/template/implementations/init_types.template.js +11 -3
- package/dist/template/zod-converter.d.ts.map +1 -1
- package/dist/template/zod-converter.js +6 -2
- package/dist/testing/dev-test-routes.d.ts.map +1 -1
- package/dist/testing/dev-test-routes.js +5 -3
- package/dist/testing/fixture-generator.d.ts +13 -0
- package/dist/testing/fixture-generator.d.ts.map +1 -1
- package/dist/testing/fixture-generator.js +105 -8
- package/dist/testing/fixture-manager.d.ts.map +1 -1
- package/dist/testing/fixture-manager.js +19 -2
- package/dist/types/__tests__/entity-json-schema-search-text.test.js +256 -0
- package/dist/types/types.d.ts +494 -1
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/types.js +117 -13
- package/dist/ui/api.d.ts.map +1 -1
- package/dist/ui/api.js +14 -2
- package/dist/ui/cdd-service.d.ts +16 -14
- package/dist/ui/cdd-service.d.ts.map +1 -1
- package/dist/ui/cdd-service.js +145 -37
- package/dist/ui/cdd-types.d.ts +60 -0
- package/dist/ui/cdd-types.d.ts.map +1 -0
- package/dist/ui/cdd-types.js +3 -0
- package/dist/ui-web/assets/index-D4XFBV-f.css +1 -0
- package/dist/ui-web/assets/{index-CQ_S40bD.js → index-D_19-Pi4.js} +87 -87
- package/dist/ui-web/index.html +2 -2
- package/package.json +7 -3
- package/src/api/sonamu.ts +1 -2
- package/src/auth/auth-generator.ts +38 -0
- package/src/auth/better-auth-entities.ts +18 -1
- package/src/bin/cli.ts +15 -1
- package/src/cone/cone-generator.ts +9 -3
- package/src/database/knex.ts +62 -4
- package/src/database/puri.ts +71 -0
- package/src/database/puri.types.ts +2 -0
- package/src/entity/entity-manager.ts +95 -3
- package/src/migration/__tests__/code-generation.search-text.test.ts +390 -0
- package/src/migration/code-generation.ts +848 -34
- package/src/migration/migration-set.ts +2 -0
- package/src/migration/postgresql-schema-reader.ts +366 -9
- package/src/skills/sonamu/auth-migration.md +80 -0
- package/src/skills/sonamu/cdd.md +148 -28
- package/src/skills/sonamu/cone.md +16 -0
- package/src/skills/sonamu/entity-relations.md +1 -1
- package/src/skills/sonamu/fixture-cli.md +4 -0
- package/src/skills/sonamu/frontend.md +65 -0
- package/src/skills/sonamu/migration.md +3 -1
- package/src/skills/sonamu/model.md +28 -0
- package/src/skills/sonamu/workflow.md +12 -5
- package/src/stream/sse.ts +4 -2
- package/src/template/__tests__/generated.template.search-text.test.ts +89 -0
- package/src/template/generated.template.test-d.ts +46 -0
- package/src/template/implementations/generated.template.ts +4 -1
- package/src/template/implementations/init_types.template.ts +20 -5
- package/src/template/zod-converter.ts +5 -0
- package/src/testing/dev-test-routes.ts +4 -2
- package/src/testing/fixture-generator.ts +157 -9
- package/src/testing/fixture-manager.ts +15 -1
- package/src/types/__tests__/entity-json-schema-search-text.test.ts +179 -0
- package/src/types/types.ts +168 -12
- package/src/ui/api.ts +24 -1
- package/src/ui/cdd-service.ts +195 -55
- package/src/ui/cdd-types.ts +73 -0
- package/dist/ui-web/assets/index-egkMxKos.css +0 -1
package/dist/types/types.js
CHANGED
|
@@ -65,6 +65,16 @@ export const SonamuFileArraySchema = z.array(SonamuFileSchema).describe("SonamuF
|
|
|
65
65
|
"SonamuFile",
|
|
66
66
|
"SonamuFile[]"
|
|
67
67
|
];
|
|
68
|
+
export const KnownOpclassValues = [
|
|
69
|
+
"gin_trgm_ops",
|
|
70
|
+
"gist_trgm_ops",
|
|
71
|
+
"gin_bigm_ops",
|
|
72
|
+
"vector_cosine_ops",
|
|
73
|
+
"vector_ip_ops",
|
|
74
|
+
"vector_l2_ops",
|
|
75
|
+
"pgroonga_varchar_full_text_search_ops_v2",
|
|
76
|
+
"pgroonga_jsonb_full_text_search_ops_v2"
|
|
77
|
+
];
|
|
68
78
|
export function normalizeSubsetField(f) {
|
|
69
79
|
return typeof f === "string" ? f : f.field;
|
|
70
80
|
}
|
|
@@ -177,6 +187,9 @@ export function isUuidProp(p) {
|
|
|
177
187
|
export function isJsonProp(p) {
|
|
178
188
|
return p?.type === "json";
|
|
179
189
|
}
|
|
190
|
+
export function isSearchTextProp(p) {
|
|
191
|
+
return p?.type === "searchText";
|
|
192
|
+
}
|
|
180
193
|
export function isVirtualProp(p) {
|
|
181
194
|
return p?.type === "virtual";
|
|
182
195
|
}
|
|
@@ -331,6 +344,11 @@ const GeneratedColumnSchema = z.object({
|
|
|
331
344
|
]),
|
|
332
345
|
expression: z.string()
|
|
333
346
|
});
|
|
347
|
+
const FixtureCompanionSchema = z.object({
|
|
348
|
+
entity: z.string(),
|
|
349
|
+
overrides: z.record(z.string(), z.unknown()).optional(),
|
|
350
|
+
count: z.number().int().positive().optional()
|
|
351
|
+
});
|
|
334
352
|
/**
|
|
335
353
|
* Cone 스키마 검증
|
|
336
354
|
*
|
|
@@ -341,6 +359,7 @@ const GeneratedColumnSchema = z.object({
|
|
|
341
359
|
fixtureGenerator: z.string().optional(),
|
|
342
360
|
fixtureDefault: z.unknown().optional(),
|
|
343
361
|
fixtureStrategy: z.literal("sequence").optional(),
|
|
362
|
+
fixtureCompanions: z.array(FixtureCompanionSchema).optional(),
|
|
344
363
|
dataSource: z.object({
|
|
345
364
|
strategy: z.enum([
|
|
346
365
|
"sample",
|
|
@@ -455,6 +474,15 @@ const JsonPropSchema = z.object({
|
|
|
455
474
|
type: z.literal("json"),
|
|
456
475
|
id: z.string()
|
|
457
476
|
}).strict();
|
|
477
|
+
const SearchTextSourceColumnSchema = z.object({
|
|
478
|
+
name: z.string(),
|
|
479
|
+
caseInsensitive: z.boolean().optional()
|
|
480
|
+
}).strict();
|
|
481
|
+
const SearchTextPropSchema = z.object({
|
|
482
|
+
...BasePropFields,
|
|
483
|
+
type: z.literal("searchText"),
|
|
484
|
+
sourceColumns: z.array(SearchTextSourceColumnSchema).min(1)
|
|
485
|
+
}).strict();
|
|
458
486
|
const VirtualPropSchema = z.object({
|
|
459
487
|
...BasePropFields,
|
|
460
488
|
type: z.literal("virtual"),
|
|
@@ -552,6 +580,7 @@ const NormalPropTypes = [
|
|
|
552
580
|
"uuid",
|
|
553
581
|
"uuid[]",
|
|
554
582
|
"json",
|
|
583
|
+
"searchText",
|
|
555
584
|
"virtual",
|
|
556
585
|
"vector",
|
|
557
586
|
"vector[]",
|
|
@@ -585,6 +614,7 @@ export const NormalPropSchema = z.discriminatedUnion("type", [
|
|
|
585
614
|
NumericPropSchema,
|
|
586
615
|
NumericArrayPropSchema,
|
|
587
616
|
JsonPropSchema,
|
|
617
|
+
SearchTextPropSchema,
|
|
588
618
|
VirtualPropSchema,
|
|
589
619
|
VectorPropSchema,
|
|
590
620
|
VectorArrayPropSchema
|
|
@@ -650,6 +680,10 @@ const EntityIndexColumnSchema = z.object({
|
|
|
650
680
|
"vector_cosine_ops",
|
|
651
681
|
"vector_ip_ops",
|
|
652
682
|
"vector_l2_ops"
|
|
683
|
+
]).optional(),
|
|
684
|
+
opclass: z.union([
|
|
685
|
+
z.enum(KnownOpclassValues),
|
|
686
|
+
z.string().min(1)
|
|
653
687
|
]).optional()
|
|
654
688
|
});
|
|
655
689
|
// EntityIndex 스키마 정의
|
|
@@ -712,7 +746,68 @@ const EntityIndexSchema = z.object({
|
|
|
712
746
|
cone: ConeSchema.optional()
|
|
713
747
|
})
|
|
714
748
|
]);
|
|
715
|
-
|
|
749
|
+
function unwrapSearchTextJsonSourceType(zodType) {
|
|
750
|
+
let current = zodType;
|
|
751
|
+
while(current instanceof z.ZodOptional || current instanceof z.ZodNullable){
|
|
752
|
+
current = current.unwrap();
|
|
753
|
+
}
|
|
754
|
+
return current;
|
|
755
|
+
}
|
|
756
|
+
export function isSearchTextJsonSourceZodType(zodType) {
|
|
757
|
+
const baseType = unwrapSearchTextJsonSourceType(zodType);
|
|
758
|
+
if (!(baseType instanceof z.ZodArray)) {
|
|
759
|
+
return false;
|
|
760
|
+
}
|
|
761
|
+
const elementType = baseType.def.element;
|
|
762
|
+
return elementType instanceof z.ZodString;
|
|
763
|
+
}
|
|
764
|
+
function validateSearchTextSources(props, ctx, propsPath = [
|
|
765
|
+
"props"
|
|
766
|
+
]) {
|
|
767
|
+
const propsByName = new Map(props.map((prop)=>{
|
|
768
|
+
return [
|
|
769
|
+
prop.name,
|
|
770
|
+
prop
|
|
771
|
+
];
|
|
772
|
+
}));
|
|
773
|
+
props.forEach((prop, propIndex)=>{
|
|
774
|
+
if (prop.type !== "searchText") {
|
|
775
|
+
return;
|
|
776
|
+
}
|
|
777
|
+
prop.sourceColumns.forEach((source, sourceIndex)=>{
|
|
778
|
+
const sourceProp = propsByName.get(source.name);
|
|
779
|
+
const sourcePath = [
|
|
780
|
+
...propsPath,
|
|
781
|
+
propIndex,
|
|
782
|
+
"sourceColumns",
|
|
783
|
+
sourceIndex,
|
|
784
|
+
"name"
|
|
785
|
+
];
|
|
786
|
+
if (!sourceProp) {
|
|
787
|
+
ctx.addIssue({
|
|
788
|
+
code: "custom",
|
|
789
|
+
message: `searchText source column "${source.name}"을(를) 찾을 수 없습니다.`,
|
|
790
|
+
path: sourcePath
|
|
791
|
+
});
|
|
792
|
+
return;
|
|
793
|
+
}
|
|
794
|
+
if (sourceProp.type === "string" || sourceProp.type === "string[]") {
|
|
795
|
+
return;
|
|
796
|
+
}
|
|
797
|
+
if (sourceProp.type === "json") {
|
|
798
|
+
// json source의 최종 타입 유효성은 EntityManager.register() 단계에서
|
|
799
|
+
// 실제 Zod 타입을 해석하여 구조적으로 검증합니다.
|
|
800
|
+
return;
|
|
801
|
+
}
|
|
802
|
+
ctx.addIssue({
|
|
803
|
+
code: "custom",
|
|
804
|
+
message: `searchText source column "${source.name}"의 타입 "${sourceProp.type}"은(는) 지원되지 않습니다.`,
|
|
805
|
+
path: sourcePath
|
|
806
|
+
});
|
|
807
|
+
});
|
|
808
|
+
});
|
|
809
|
+
}
|
|
810
|
+
const EntityJsonBaseSchema = z.object({
|
|
716
811
|
id: z.string().describe("PascalCase로 된 Entity ID"),
|
|
717
812
|
title: z.string().describe("Entity 이름"),
|
|
718
813
|
table: z.string().describe("snake_case로 된 테이블명"),
|
|
@@ -723,18 +818,27 @@ export const EntityJsonSchema = z.object({
|
|
|
723
818
|
subsets: z.record(z.string(), SubsetDefSchema),
|
|
724
819
|
enums: z.record(z.string(), EnumDefSchema)
|
|
725
820
|
}).strict();
|
|
821
|
+
export const EntityJsonSchema = EntityJsonBaseSchema.superRefine((entity, ctx)=>{
|
|
822
|
+
validateSearchTextSources(entity.props, ctx);
|
|
823
|
+
});
|
|
824
|
+
const TemplateEntitySchema = EntityJsonBaseSchema.omit({
|
|
825
|
+
id: true
|
|
826
|
+
}).extend({
|
|
827
|
+
entityId: z.string()
|
|
828
|
+
}).partial({
|
|
829
|
+
table: true,
|
|
830
|
+
props: true,
|
|
831
|
+
indexes: true,
|
|
832
|
+
subsets: true,
|
|
833
|
+
enums: true
|
|
834
|
+
}).superRefine((entity, ctx)=>{
|
|
835
|
+
if (!entity.props) {
|
|
836
|
+
return;
|
|
837
|
+
}
|
|
838
|
+
validateSearchTextSources(entity.props, ctx);
|
|
839
|
+
});
|
|
726
840
|
export const TemplateOptions = z.object({
|
|
727
|
-
entity:
|
|
728
|
-
id: true
|
|
729
|
-
}).extend({
|
|
730
|
-
entityId: z.string()
|
|
731
|
-
}).partial({
|
|
732
|
-
table: true,
|
|
733
|
-
props: true,
|
|
734
|
-
indexes: true,
|
|
735
|
-
subsets: true,
|
|
736
|
-
enums: true
|
|
737
|
-
}),
|
|
841
|
+
entity: TemplateEntitySchema,
|
|
738
842
|
init_types: z.object({
|
|
739
843
|
entityId: z.string()
|
|
740
844
|
}),
|
|
@@ -820,4 +924,4 @@ export const PathAndCode = z.object({
|
|
|
820
924
|
});
|
|
821
925
|
export var ApiParamType;
|
|
822
926
|
|
|
823
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types/types.ts"],"sourcesContent":["import type { FastifyReply, FastifyRequest } from \"fastify\";\nimport { z } from \"zod\";\nimport type { ApiDecoratorOptions, Context } from \"../api\";\nimport type { GuardKey } from \"./../api/decorators\";\nimport type { CacheControlHandler } from \"../cache-control/types\";\n\n/*\n  Utility Types\n*/\nexport function zArrayable<T extends z.ZodTypeAny>(shape: T): z.ZodUnion<[T, z.ZodArray<T>]> {\n  return z.union([shape, shape.array()]);\n}\n// biome-ignore lint/suspicious/noExplicitAny: any is used to make the type distributive\nexport type DistributiveOmit<T, K extends keyof any> = T extends any ? Omit<T, K> : never;\n\n/*\n  Model-Definition\n*/\n\n/**\n * cone: 범용 메타데이터 시스템\n *\n * Entity, Prop, Enum, Subset에 \"솔방울을 단다\"는 개념으로 붙이는 단일 서술 메타데이터입니다.\n * note 하나로 비즈니스 의미와 fixture 생성 힌트를 함께 기술합니다.\n */\nexport type Cone = {\n  note?: string; // 이 대상이 무엇인지 설명 (비즈니스 의미 + fixture 힌트 통합)\n  tags?: string[]; // 분류/검색용 태그\n\n  // Fixture 생성 관련\n  fixtureGenerator?: string; // Faker.js 코드 또는 커스텀 함수\n  fixtureDefault?: unknown; // 기본값\n  fixtureStrategy?: \"sequence\"; // string 타입이지만 DB sequence로 관리되는 PK (better-auth 등)\n\n  // 참조 데이터 관련\n  dataSource?: {\n    strategy: \"sample\" | \"ids\" | \"query\" | \"file\" | \"recent\" | \"random\";\n    config?: unknown; // 전략별 설정\n  };\n\n  // 확장성\n  [key: string]: unknown; // 사용자 정의 메타데이터\n};\n\nexport type GeneratedColumnType = \"STORED\" | \"VIRTUAL\";\nexport type GeneratedColumn = {\n  type: GeneratedColumnType;\n  expression: string;\n};\nexport type CommonProp = {\n  name: string;\n  nullable?: boolean;\n  toFilter?: true;\n  desc?: string;\n  dbDefault?: string;\n  generated?: GeneratedColumn;\n  cone?: Cone; // cone 메타데이터\n};\n\n/**\n * prop의 설명을 반환합니다.\n *\n * cone.note가 있으면 우선 사용하고, 없으면 prop.desc를 사용합니다.\n */\nexport function getDescription(item: { desc?: string; cone?: Cone }): string | undefined {\n  return item.cone?.note || item.desc;\n}\nexport type IntegerProp = CommonProp & {\n  type: \"integer\";\n}; // PG: integer / TS: number / JSON: number\nexport type IntegerArrayProp = CommonProp & {\n  type: \"integer[]\";\n}; // PG: integer[] / TS: number[] / JSON: number[]\nexport type BigIntegerProp = CommonProp & {\n  type: \"bigInteger\";\n}; // PG: bigint / TS: bigint / JSON: bigint\nexport type BigIntegerArrayProp = CommonProp & {\n  type: \"bigInteger[]\";\n}; // PG: bigint[] / TS: bigint[] / JSON: bigint[]\n\n/**\n * Zod 4 String Format 타입\n * entity.json에서 string 타입의 prop에 zodFormat 옵션을 지정하여\n * BaseSchema 생성 시 Zod의 string format validation을 적용합니다.\n */\nexport const ZodStringFormat = z.enum([\n  // 기본 포맷\n  \"email\",\n  \"uuid\",\n  \"url\",\n  \"httpUrl\",\n  \"hostname\",\n  \"emoji\",\n  \"base64\",\n  \"base64url\",\n  \"hex\",\n  \"jwt\",\n  \"nanoid\",\n  \"cuid\",\n  \"cuid2\",\n  \"ulid\",\n  \"ipv4\",\n  \"ipv6\",\n  \"mac\",\n  \"cidrv4\",\n  \"cidrv6\",\n  // hash 포맷 (알고리즘별)\n  \"hashMd5\",\n  \"hashSha1\",\n  \"hashSha256\",\n  \"hashSha384\",\n  \"hashSha512\",\n  // ISO 포맷\n  \"isoDate\",\n  \"isoTime\",\n  \"isoDatetime\",\n  \"isoDuration\",\n]);\nexport type ZodStringFormat = z.infer<typeof ZodStringFormat>;\n\nexport type StringProp = CommonProp & {\n  type: \"string\";\n  length?: number; // PG: varchar(n), text / TS: string / JSON: string\n  zodFormat?: ZodStringFormat;\n}; // PG: text / TS: string / JSON: string\nexport type StringArrayProp = CommonProp & {\n  type: \"string[]\";\n  length?: number; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\n  zodFormat?: ZodStringFormat;\n}; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\nexport type EnumProp = CommonProp & {\n  type: \"enum\";\n  id: string;\n  length?: number;\n}; // PG: text / TS: string / JSON: string\nexport type EnumArrayProp = CommonProp & {\n  type: \"enum[]\";\n  id: string;\n}; // PG: text[] / TS: string[] / JSON: string[]\nexport type NumberProp = CommonProp & {\n  type: \"number\";\n  precision?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  scale?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s) / TS: number / JSON: number\nexport type NumberArrayProp = CommonProp & {\n  type: \"number[]\";\n  precision?: number;\n  scale?: number;\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s)[] / TS: number[] / JSON: number[]\nexport type NumericProp = CommonProp & {\n  type: \"numeric\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s) / TS: string / JSON: string\nexport type NumericArrayProp = CommonProp & {\n  type: \"numeric[]\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s)[] / TS: string[] / JSON: string[]\nexport type BooleanProp = CommonProp & {\n  type: \"boolean\";\n}; // PG: boolean / TS: boolean / JSON: boolean\nexport type BooleanArrayProp = CommonProp & {\n  type: \"boolean[]\";\n}; // PG: boolean[] / TS: boolean[] / JSON: boolean[]\nexport type DateProp = CommonProp & {\n  type: \"date\";\n  // 기본값은 3, microseconds를 쓰려면 6을 써야함 (0 ~ 6)\n  precision?: number;\n}; // PG: timestampz / TS: Date / JSON: string(ISOString)\nexport type DateArrayProp = CommonProp & {\n  type: \"date[]\";\n  // 기본값은 3, microseconds를 쓰려면 6을 써야함 (0 ~ 6)\n  precision?: number;\n}; // PG: timestamptz[] / TS: Date[] / JSON: string[]\nexport type JsonProp = CommonProp & {\n  type: \"json\";\n  id: string;\n}; // PG: json / TS: any(id) / JSON: any\nexport type UuidProp = CommonProp & {\n  type: \"uuid\";\n}; // PG: uuid / TS: string / JSON: string\nexport type UuidArrayProp = CommonProp & {\n  type: \"uuid[]\";\n}; // PG: uuid[] / TS: string[] / JSON: string[]\nexport type VirtualProp = CommonProp & {\n  type: \"virtual\";\n  id: string;\n  virtualType?: \"query\" | \"code\"; // default: \"code\"\n}; // PG: none / TS: any(id) / JSON: any\nexport type VectorProp = CommonProp & {\n  type: \"vector\";\n  dimensions: number;\n};\nexport type VectorArrayProp = CommonProp & {\n  type: \"vector[]\";\n  dimensions: number;\n};\nexport type TsVectorProp = CommonProp & {\n  type: \"tsvector\";\n};\nexport type RelationType = \"HasMany\" | \"BelongsToOne\" | \"ManyToMany\" | \"OneToOne\";\nexport type RelationOn = \"CASCADE\" | \"SET NULL\" | \"NO ACTION\" | \"SET DEFAULT\" | \"RESTRICT\";\ntype _RelationProp = {\n  type: \"relation\";\n  name: string;\n  with: string;\n  nullable?: boolean; // DEFAULT: false\n  toFilter?: true; // DEFAULT: false\n  desc?: string;\n  cone?: Cone; // cone 메타데이터\n};\nexport type OneToOneRelationProp = _RelationProp & {\n  relationType: \"OneToOne\";\n  customJoinClause?: string;\n} & (\n    | {\n        hasJoinColumn: true;\n        useConstraint?: boolean; // DEFAULT: true\n        onUpdate?: RelationOn; // DEFAULT: RESTRICT\n        onDelete?: RelationOn; // DEFAULT: RESTRICT\n      }\n    | {\n        hasJoinColumn: false;\n      }\n  );\nexport type BelongsToOneRelationProp = _RelationProp & {\n  relationType: \"BelongsToOne\";\n  customJoinClause?: string;\n  useConstraint?: boolean; // DEFAULT: true\n  onUpdate?: RelationOn; // DEFAULT: RESTRICT\n  onDelete?: RelationOn; // DEFAULT: RESTRICT\n};\nexport type HasManyRelationProp = _RelationProp & {\n  relationType: \"HasMany\";\n  joinColumn: string;\n  fromColumn?: string;\n};\nexport type ManyToManyRelationProp = _RelationProp & {\n  relationType: \"ManyToMany\";\n  joinTable: `${string}__${string}`;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type RelationProp =\n  | OneToOneRelationProp\n  | BelongsToOneRelationProp\n  | HasManyRelationProp\n  | ManyToManyRelationProp;\n\nexport type EntityProp =\n  | IntegerProp\n  | IntegerArrayProp\n  | BigIntegerProp\n  | BigIntegerArrayProp\n  | StringProp\n  | StringArrayProp\n  | EnumProp\n  | EnumArrayProp\n  | NumberProp\n  | NumberArrayProp\n  | NumericProp\n  | NumericArrayProp\n  | NumericProp\n  | BooleanProp\n  | BooleanArrayProp\n  | DateProp\n  | DateArrayProp\n  | UuidProp\n  | UuidArrayProp\n  | JsonProp\n  | VirtualProp\n  | VectorProp\n  | VectorArrayProp\n  | TsVectorProp\n  | RelationProp;\n\n/**\n * SonamuFile Types\n *\n * 파일 업로드를 위한 JSON 타입입니다.\n * Entity의 json 속성에서 id로 \"SonamuFile\" 또는 \"SonamuFile[]\"을 지정하여 사용합니다.\n */\nexport interface SonamuFile {\n  name: string;\n  url: string;\n  mime_type: string;\n  size: number;\n}\n\nexport const SonamuFileSchema = z\n  .object({\n    name: z.string(),\n    url: z.string(),\n    mime_type: z.string(),\n    size: z.number(),\n  })\n  .describe(\"SonamuFile\");\n\nexport const SonamuFileArraySchema = z.array(SonamuFileSchema).describe(\"SonamuFile[]\");\n\n/**\n * Sonamu 코어에서 제공하는 내장 JSON 타입 ID 목록\n * 새로운 내장 타입 추가 시 이 배열에 추가하면 자동으로 UI에 노출됩니다.\n */\nexport const BUILT_IN_TYPE_IDS = [\"SonamuFile\", \"SonamuFile[]\"] as const;\nexport type BuiltInTypeId = (typeof BUILT_IN_TYPE_IDS)[number];\n\n/**\n * pgvector 거리 연산자 클래스\n *\n * @description\n * - `vector_cosine_ops`: 코사인 거리 (Cosine Distance) - 권장\n *   - SQL 연산자: `<=>`\n *   - 벡터의 방향만 비교 (크기 무시), 1 - cosine_similarity\n *   - 텍스트 임베딩, 시맨틱 검색에 가장 일반적으로 사용\n *   - 사용 예: OpenAI, Voyage 등 대부분의 임베딩 모델에 권장\n *\n * - `vector_ip_ops`: 내적 (Inner Product)\n *   - SQL 연산자: `<#>`\n *   - 두 벡터의 내적을 계산 (sum(a[i] * b[i]))\n *   - 정규화된 벡터에서 코사인 유사도와 동일한 결과\n *   - 값이 클수록 유사 (음수 연산자이므로 ORDER BY에서 주의)\n *   - 사용 예: 이미 정규화된 임베딩에서 가장 빠른 성능\n *\n * - `vector_l2_ops`: 유클리드 거리 (L2 Distance)\n *   - SQL 연산자: `<->`\n *   - 두 벡터 간의 직선 거리를 계산 (sqrt(sum((a[i] - b[i])^2)))\n *   - 벡터의 크기(magnitude)가 중요할 때 사용\n *   - 사용 예: 이미지 유사도, 절대적 거리 측정이 필요한 경우\n */\nexport type VectorOps = \"vector_cosine_ops\" | \"vector_ip_ops\" | \"vector_l2_ops\";\n\ntype EntityIndexColumn = {\n  name: string;\n  nullsFirst?: boolean;\n  sortOrder?: \"ASC\" | \"DESC\";\n  /** pgvector 인덱스에서 사용할 거리 연산자 (vector 컬럼에만 적용) */\n  vectorOps?: VectorOps;\n};\nexport type EntityIndex = {\n  type: \"index\" | \"unique\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\" | \"pgroonga\";\n  nullsNotDistinct?: boolean; // unique index only\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 각 노드의 최대 연결 수\n   *\n   * @description\n   * 그래프에서 각 노드가 가질 수 있는 최대 연결 수입니다.\n   * HNSW는 빠른 검색 속도와 높은 정확도를 제공하므로 권장됩니다.\n   * - 기본값: 16\n   * - 범위: 2 ~ 100\n   * - 높을수록: 정확도↑, 빌드 시간↑, 메모리↑\n   * - 권장: 빠른 빌드(8), 균형(16), 높은 정확도(32), 최고 정확도(64)\n   */\n  m?: number;\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 구성 시 탐색 범위\n   *\n   * @description\n   * 인덱스 구성 시 각 노드에서 탐색할 범위입니다.\n   * - 기본값: 64\n   * - 범위: 4 ~ 1000\n   * - 높을수록: 정확도↑, 빌드 시간↑\n   * - 권장: 빠른 빌드(32), 균형(64), 높은 정확도(128), 최고 정확도(256)\n   */\n  efConstruction?: number;\n  /**\n   * IVFFlat (Inverted File with Flat Compression) 인덱스: 클러스터링 리스트 수\n   *\n   * @description\n   * 벡터를 클러스터링할 버킷 수를 지정합니다.\n   * IVFFlat은 빠른 빌드와 낮은 메모리 사용이 필요할 때 사용합니다.\n   * - 권장값: sqrt(row_count) ~ row_count / 1000\n   * - 예시: 10,000행 → 100, 100,000행 → 300, 1,000,000행 → 1000\n   * - 많을수록 정확도↑, 검색 속도↓\n   */\n  lists?: number;\n};\n\n// SubsetField 타입: string 또는 internal 옵션이 있는 객체\nexport type SubsetField = string | { field: string; internal?: boolean };\n\nexport function normalizeSubsetField(f: SubsetField): string {\n  return typeof f === \"string\" ? f : f.field;\n}\nexport function isInternalSubsetField(f: SubsetField): boolean {\n  return typeof f !== \"string\" && f.internal === true;\n}\n\n/**\n * SubsetDef: Subset 정의\n *\n * 하위 호환성을 위해 SubsetField[] 배열 형태도 지원합니다.\n */\nexport type SubsetDef =\n  | SubsetField[] // 기존 배열 형태\n  | {\n      // 새로운 객체 형태\n      fields: SubsetField[];\n      cone?: Cone;\n    };\n\n/**\n * EnumDef: Enum 정의\n *\n * 하위 호환성을 위해 Record<string, string> 형태도 지원합니다.\n */\nexport type EnumDef =\n  | Record<string, string> // 기존 Record 형태\n  | {\n      // 새로운 객체 형태\n      values: Record<string, string>;\n      cone?: Cone;\n    };\n\n/**\n * SubsetDef가 새로운 객체 형태인지 확인\n */\nexport function isSubsetDefWithCone(def: SubsetDef): def is { fields: SubsetField[]; cone?: Cone } {\n  return !Array.isArray(def) && \"fields\" in def;\n}\n\n/**\n * EnumDef가 새로운 객체 형태인지 확인\n */\nexport function isEnumDefWithCone(\n  def: EnumDef,\n): def is { values: Record<string, string>; cone?: Cone } {\n  return (\n    \"values\" in def && !(\"cone\" in def && def.cone === undefined && Object.keys(def).length > 1)\n  );\n}\n\n/**\n * SubsetDef에서 fields 추출\n */\nexport function getSubsetFields(def: SubsetDef): SubsetField[] {\n  return Array.isArray(def) ? def : def.fields;\n}\n\n/**\n * EnumDef에서 values 추출\n */\nexport function getEnumDefValues(def: EnumDef): Record<string, string> {\n  return isEnumDefWithCone(def) ? def.values : def;\n}\n\nexport type EntityJson = {\n  id: string;\n  parentId?: string;\n  table: string;\n  title?: string;\n  cone?: Cone; // cone 메타데이터\n  props: EntityProp[];\n  indexes: EntityIndex[];\n  subsets: {\n    [subset: string]: SubsetDef;\n  };\n  enums: {\n    [enumId: string]: EnumDef;\n  };\n};\nexport type EntitySubsetRow = {\n  field: string;\n  has: {\n    [key: string]: boolean;\n  };\n  isInternal: {\n    [key: string]: boolean;\n  };\n  children: EntitySubsetRow[];\n  prefixes: string[];\n  relationEntity?: string;\n  isOpen?: boolean;\n};\nexport type FlattenSubsetRow = Omit<EntitySubsetRow, \"children\">;\n\n/*\n  PropNode\n*/\n\n/**\n * 엔티티의 필드 구조를 트리 형태로 표현하는 중간 노드입니다.\n *\n * **목적**: Entity의 subset 필드 표현식(예: \"id\", \"user.name\", \"tags[]\")을\n * 재귀적인 트리 구조로 파싱하여 Zod 스키마 생성의 중간 단계로 사용합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode (트리 구조) → Zod 스키마 → RenderingNode (UI용)\n *\n * **nodeType**:\n * - \"plain\": 단일 필드 (예: \"id\", \"name\")\n * - \"object\": 중첩 객체 (예: \"user.name\" → user 객체)\n * - \"array\": 배열 (예: \"tags[]\" → tags 배열)\n *\n * **사용 위치**: entity-converter.ts의 propNodeToZodType()\n */\nexport type EntityPropNode =\n  | {\n      nodeType: \"plain\";\n      prop: EntityProp;\n    }\n  | {\n      nodeType: \"object\" | \"array\";\n      prop?: EntityProp;\n      children: EntityPropNode[];\n    };\n\n/*\n  Prop Type Guards\n*/\nexport function isIntegerSingleProp(p: unknown): p is IntegerProp {\n  return (p as IntegerProp)?.type === \"integer\";\n}\nexport function isIntegerArrayProp(p: unknown): p is IntegerArrayProp {\n  return (p as IntegerArrayProp)?.type === \"integer[]\";\n}\nexport function isIntegerProp(p: unknown): p is IntegerProp | IntegerArrayProp {\n  return isIntegerSingleProp(p) || isIntegerArrayProp(p);\n}\nexport function isBigIntegerSingleProp(p: unknown): p is BigIntegerProp {\n  return (p as BigIntegerProp)?.type === \"bigInteger\";\n}\nexport function isBigIntegerArrayProp(p: unknown): p is BigIntegerArrayProp {\n  return (p as BigIntegerArrayProp)?.type === \"bigInteger[]\";\n}\nexport function isBigIntegerProp(p: unknown): p is BigIntegerProp | BigIntegerArrayProp {\n  return isBigIntegerSingleProp(p) || isBigIntegerArrayProp(p);\n}\nexport function isStringSingleProp(p: unknown): p is StringProp {\n  return (p as StringProp)?.type === \"string\";\n}\nexport function isStringArrayProp(p: unknown): p is StringArrayProp {\n  return (p as StringArrayProp)?.type === \"string[]\";\n}\nexport function isStringProp(p: unknown): p is StringProp | StringArrayProp {\n  return isStringSingleProp(p) || isStringArrayProp(p);\n}\nexport function isEnumSingleProp(p: unknown): p is EnumProp {\n  return (p as EnumProp)?.type === \"enum\";\n}\nexport function isEnumArrayProp(p: unknown): p is EnumArrayProp {\n  return (p as EnumArrayProp)?.type === \"enum[]\";\n}\nexport function isEnumProp(p: unknown): p is EnumProp | EnumArrayProp {\n  return isEnumSingleProp(p) || isEnumArrayProp(p);\n}\nexport function isNumberSingleProp(p: unknown): p is NumberProp {\n  return (p as NumberProp)?.type === \"number\";\n}\nexport function isNumberArrayProp(p: unknown): p is NumberArrayProp {\n  return (p as NumberArrayProp)?.type === \"number[]\";\n}\nexport function isNumberProp(p: unknown): p is NumberProp | NumberArrayProp {\n  return isNumberSingleProp(p) || isNumberArrayProp(p);\n}\nexport function isNumericSingleProp(p: unknown): p is NumericProp {\n  return (p as NumericProp)?.type === \"numeric\";\n}\nexport function isNumericArrayProp(p: unknown): p is NumericArrayProp {\n  return (p as NumericArrayProp)?.type === \"numeric[]\";\n}\nexport function isNumericProp(p: unknown): p is NumericProp | NumericArrayProp {\n  return isNumericSingleProp(p) || isNumericArrayProp(p);\n}\nexport function isBooleanSingleProp(p: unknown): p is BooleanProp {\n  return (p as BooleanProp)?.type === \"boolean\";\n}\nexport function isBooleanArrayProp(p: unknown): p is BooleanArrayProp {\n  return (p as BooleanArrayProp)?.type === \"boolean[]\";\n}\nexport function isBooleanProp(p: unknown): p is BooleanProp | BooleanArrayProp {\n  return isBooleanSingleProp(p) || isBooleanArrayProp(p);\n}\nexport function isDateSingleProp(p: unknown): p is DateProp {\n  return (p as DateProp)?.type === \"date\";\n}\nexport function isDateArrayProp(p: unknown): p is DateArrayProp {\n  return (p as DateArrayProp)?.type === \"date[]\";\n}\nexport function isDateProp(p: unknown): p is DateProp | DateArrayProp {\n  return isDateSingleProp(p) || isDateArrayProp(p);\n}\nexport function isUuidSingleProp(p: unknown): p is UuidProp {\n  return (p as UuidProp)?.type === \"uuid\";\n}\nexport function isUuidArrayProp(p: unknown): p is UuidArrayProp {\n  return (p as UuidArrayProp)?.type === \"uuid[]\";\n}\nexport function isUuidProp(p: unknown): p is UuidProp | UuidArrayProp {\n  return isUuidSingleProp(p) || isUuidArrayProp(p);\n}\nexport function isJsonProp(p: unknown): p is JsonProp {\n  return (p as JsonProp)?.type === \"json\";\n}\nexport function isVirtualProp(p: unknown): p is VirtualProp {\n  return (p as VirtualProp)?.type === \"virtual\";\n}\nexport function isVirtualCodeProp(p: unknown): p is VirtualProp {\n  if (!isVirtualProp(p)) return false;\n  return p.virtualType !== \"query\"; // undefined도 \"code\"로 취급\n}\nexport function isVirtualQueryProp(p: unknown): p is VirtualProp {\n  if (!isVirtualProp(p)) return false;\n  return p.virtualType === \"query\";\n}\nexport function isVectorSingleProp(p: unknown): p is VectorProp {\n  return (p as VectorProp)?.type === \"vector\";\n}\nexport function isVectorArrayProp(p: unknown): p is VectorArrayProp {\n  return (p as VectorArrayProp)?.type === \"vector[]\";\n}\nexport function isVectorProp(p: unknown): p is VectorProp | VectorArrayProp {\n  return isVectorSingleProp(p) || isVectorArrayProp(p);\n}\nexport function isTsVectorProp(p: unknown): p is TsVectorProp {\n  return (p as TsVectorProp)?.type === \"tsvector\";\n}\nexport function isRelationProp(p: unknown): p is RelationProp {\n  return (p as RelationProp)?.type === \"relation\";\n}\nexport function isOneToOneRelationProp(p: unknown): p is OneToOneRelationProp {\n  return (p as OneToOneRelationProp)?.relationType === \"OneToOne\";\n}\nexport function isBelongsToOneRelationProp(p: unknown): p is BelongsToOneRelationProp {\n  return (p as BelongsToOneRelationProp)?.relationType === \"BelongsToOne\";\n}\nexport function isHasManyRelationProp(p: unknown): p is HasManyRelationProp {\n  return (p as HasManyRelationProp)?.relationType === \"HasMany\";\n}\nexport function isManyToManyRelationProp(p: unknown): p is ManyToManyRelationProp {\n  return (p as ManyToManyRelationProp)?.relationType === \"ManyToMany\";\n}\n\ntype JoinClause =\n  | {\n      from: string;\n      to: string;\n    }\n  | {\n      custom: string;\n    };\nexport function isCustomJoinClause(p: unknown): p is { custom: string } {\n  return !!(p as { custom: string })?.custom;\n}\n\ntype SubsetLoader = {\n  as: string;\n  table: string;\n  manyJoin: {\n    fromTable: string;\n    fromCol: string;\n    idField: string;\n    toTable: string;\n    toCol: string;\n    through?: {\n      table: string;\n      fromCol: string;\n      toCol: string;\n    };\n  };\n  oneJoins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  select: string[];\n  loaders?: SubsetLoader[];\n};\n\nexport type SubsetQuery = {\n  select: string[];\n  virtual: string[];\n  joins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  loaders: SubsetLoader[];\n};\n\n/* BaseModel */\nexport const SonamuQueryMode = z.enum([\"both\", \"list\", \"count\"]);\nexport type SonamuQueryMode = z.infer<typeof SonamuQueryMode>;\n\n/* Semantic Query */\nexport const SonamuSemanticParams = z.object({\n  semanticQuery: z.object({\n    embedding: z.array(z.number()).min(1024).max(1024),\n    threshold: z.number().optional(),\n    method: z.enum([\"cosine\", \"l2\", \"inner_product\"]).optional(),\n  }),\n});\nexport type SonamuSemanticParams = z.infer<typeof SonamuSemanticParams>;\n\n/* Knex Migration */\nexport type KnexError = {\n  code: string;\n  errno: number;\n  sql: string;\n  sqlMessage: string;\n  sqlState: string;\n};\nexport function isKnexError(e: unknown): e is KnexError {\n  return !!(e as KnexError)?.code && !!(e as KnexError)?.sqlMessage && !!(e as KnexError)?.sqlState;\n}\n\nexport type KnexColumnType =\n  | \"string\"\n  | \"text\"\n  | \"smalltext\"\n  | \"mediumtext\"\n  | \"longtext\"\n  | \"integer\"\n  | \"bigInteger\"\n  | \"decimal\"\n  | \"timestamp\"\n  | \"boolean\"\n  | \"foreign\"\n  | \"uuid\"\n  | \"json\"\n  | \"float\"\n  | \"date\"\n  | \"time\"\n  | \"datetime\";\nexport type MigrationColumnType =\n  | \"string\"\n  | \"string[]\"\n  | \"integer\"\n  | \"integer[]\"\n  | \"bigInteger\"\n  | \"bigInteger[]\"\n  | \"numberOrNumeric\"\n  | \"numberOrNumeric[]\"\n  | \"boolean\"\n  | \"boolean[]\"\n  | \"date\"\n  | \"date[]\"\n  | \"uuid\"\n  | \"uuid[]\"\n  | \"json\"\n  | \"vector\"\n  | \"vector[]\"\n  | \"tsvector\";\nexport type MigrationColumn = {\n  name: string;\n  type: MigrationColumnType;\n  nullable: boolean;\n  numberType?: \"real\" | \"double precision\" | \"numeric\";\n  length?: number;\n  defaultTo?: string;\n  precision?: number;\n  scale?: number;\n  dimensions?: number;\n  generated?: GeneratedColumn;\n};\nexport type MigrationIndex = {\n  type: \"unique\" | \"index\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\" | \"pgroonga\";\n  nullsNotDistinct?: boolean;\n  /** HNSW (Hierarchical Navigable Small World): 각 노드의 최대 연결 수 */\n  m?: number;\n  /** HNSW (Hierarchical Navigable Small World): 구성 시 탐색 범위 */\n  efConstruction?: number;\n  /** IVFFlat (Inverted File with Flat Compression): 클러스터링 리스트 수 */\n  lists?: number;\n};\nexport type MigrationForeign = {\n  columns: string[];\n  to: string;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type MigrationJoinTable = {\n  table: string;\n  indexes: MigrationIndex[];\n  columns: MigrationColumn[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSet = {\n  table: string;\n  columns: MigrationColumn[];\n  indexes: MigrationIndex[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSetAndJoinTable = MigrationSet & {\n  joinTables: MigrationJoinTable[];\n};\nexport type GenMigrationCode = {\n  title: string;\n  table: string;\n  type: \"normal\" | \"foreign\";\n  formatted: string | null;\n};\n\n/* Api */\nexport type ApiParam = {\n  name: string;\n  type: ApiParamType;\n  optional: boolean;\n  defaultDef?: string;\n};\nexport namespace ApiParamType {\n  export type Function = {\n    t: \"function\";\n    parameters: ApiParam[];\n    returnType: ApiParamType;\n  };\n  export type Object = {\n    t: \"object\";\n    props: ApiParam[];\n  };\n  export type Union = {\n    t: \"union\";\n    types: ApiParamType[];\n  };\n  export type Intersection = {\n    t: \"intersection\";\n    types: ApiParamType[];\n  };\n  export type StringLiteral = {\n    t: \"string-literal\";\n    value: string;\n  };\n  export type NumericLiteral = {\n    t: \"numeric-literal\";\n    value: number;\n  };\n  export type Array = {\n    t: \"array\";\n    elementsType: ApiParamType;\n  };\n  export type Ref = {\n    t: \"ref\";\n    id: string;\n    args?: ApiParamType[];\n  };\n  export type IndexedAccess = {\n    t: \"indexed-access\";\n    object: ApiParamType;\n    index: ApiParamType;\n  };\n  export type TupleType = {\n    t: \"tuple-type\";\n    elements: ApiParamType[];\n  };\n  export type Pick = Ref & {\n    t: \"ref\";\n    id: \"Pick\";\n  };\n  export type Omit = Ref & {\n    t: \"ref\";\n    id: \"Omit\";\n  };\n  export type Partial = Ref & {\n    t: \"ref\";\n    id: \"Partial\";\n  };\n  export type Promise = Ref & {\n    t: \"ref\";\n    id: \"Promise\";\n  };\n  export type Context = Ref & {\n    t: \"ref\";\n    id: \"Context\";\n  };\n  export type TypeParam = {\n    t: \"type-param\";\n    id: string;\n    constraint?: ApiParamType;\n  };\n\n  export function isObject(v: unknown): v is ApiParamType.Object {\n    return (v as ApiParamType.Object)?.t === \"object\";\n  }\n  export function isUnion(v: unknown): v is ApiParamType.Union {\n    return (v as ApiParamType.Union)?.t === \"union\";\n  }\n  export function isIntersection(v: unknown): v is ApiParamType.Intersection {\n    return (v as ApiParamType.Intersection)?.t === \"intersection\";\n  }\n  export function isStringLiteral(v: unknown): v is ApiParamType.StringLiteral {\n    return (v as ApiParamType.StringLiteral)?.t === \"string-literal\";\n  }\n  export function isNumericLiteral(v: unknown): v is ApiParamType.NumericLiteral {\n    return (v as ApiParamType.NumericLiteral)?.t === \"numeric-literal\";\n  }\n  export function isArray(v: unknown): v is ApiParamType.Array {\n    return (v as ApiParamType.Array)?.t === \"array\";\n  }\n  export function isRef(v: unknown): v is ApiParamType.Ref {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"ref\";\n  }\n  export function isIndexedAccess(v: unknown): v is ApiParamType.IndexedAccess {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"indexed-access\";\n  }\n  export function isTupleType(v: unknown): v is ApiParamType.TupleType {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"tuple-type\";\n  }\n  export function isPick(v: unknown): v is ApiParamType.Pick {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Pick\"\n    );\n  }\n  export function isOmit(v: unknown): v is ApiParamType.Omit {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Omit\"\n    );\n  }\n  export function isPartial(v: unknown): v is ApiParamType.Partial {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Partial\"\n    );\n  }\n  export function isPromise(v: unknown): v is ApiParamType.Promise {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Promise\"\n    );\n  }\n  export function isContext(v: unknown): v is ApiParamType.Context {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Context\"\n    );\n  }\n  export function isRefKnex(v: unknown): v is ApiParamType.Ref {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Knex\"\n    );\n  }\n  export function isTypeParam(v: unknown): v is ApiParamType.TypeParam {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"type-param\";\n  }\n}\nexport type ApiParamType =\n  | \"string\"\n  | \"number\"\n  | \"boolean\"\n  | \"null\"\n  | \"undefined\"\n  | \"void\"\n  | \"any\"\n  | \"unknown\"\n  | \"true\"\n  | \"false\"\n  | ApiParamType.StringLiteral\n  | ApiParamType.NumericLiteral\n  | ApiParamType.Object\n  | ApiParamType.Union\n  | ApiParamType.Intersection\n  | ApiParamType.Array\n  | ApiParamType.Ref\n  | ApiParamType.IndexedAccess\n  | ApiParamType.TypeParam\n  | ApiParamType.TupleType\n  | ApiParamType.Function;\n\n/* Template */\n/**\n * UI 컴포넌트 렌더링을 위한 메타데이터 노드입니다.\n *\n * **목적**: Zod 스키마로부터 프론트엔드 UI 컴포넌트를 자동 생성하기 위한\n * 렌더링 정보를 담은 트리 구조입니다. 각 필드가 어떤 UI 컴포넌트로\n * 표현되어야 하는지(텍스트, 이미지, 날짜, Enum 선택 등)를 명시합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode → Zod 스키마 → RenderingNode (UI용) → React 컴포넌트 코드 생성\n *\n * **주요 필드**:\n * - `renderType`: UI 컴포넌트 유형 (string-plain, number-fk_id, enums, array 등)\n * - `zodType`: 원본 Zod 스키마 (validation 용)\n * - `children`: 중첩된 객체 필드들 (object일 때)\n * - `element`: 배열 요소 타입 (array일 때)\n *\n * **사용 위치**:\n * - zod-converter.ts의 zodTypeToRenderingNode()에서 생성\n * - view_form.template.ts, view_list.template.ts 등에서 React 컴포넌트 코드 생성에 사용\n */\n// 셀프 참조 타입이므로 Zod 생략하고 직접 정의\nexport const RenderingNode = z.any();\nexport type RenderingNode = {\n  name: string;\n  label: string;\n  renderType:\n    | \"string-plain\"\n    | \"string-image\"\n    | \"string-datetime\"\n    | \"string-date\"\n    | \"string-id\"\n    | \"string-fk_id\"\n    | \"datetime\"\n    | \"number-plain\"\n    | \"number-id\"\n    | \"number-fk_id\"\n    | \"boolean\"\n    | \"enums\"\n    | \"array\"\n    | \"array-images\"\n    | \"json-sonamufile\"\n    | \"json-sonamufile-array\"\n    | \"object\"\n    | \"object-pick\"\n    | \"record\"\n    | \"vector\";\n  zodType: z.ZodTypeAny;\n  element?: RenderingNode;\n  children?: RenderingNode[];\n  config?: {\n    picked: string;\n  };\n  optional?: boolean;\n  nullable?: boolean;\n};\n\nconst GeneratedColumnSchema = z.object({\n  type: z.enum([\"STORED\", \"VIRTUAL\"]),\n  expression: z.string(),\n});\n\n/**\n * Cone 스키마 검증\n *\n * cone 메타데이터의 유효성을 검증합니다.\n */\nconst ConeSchema = z\n  .object({\n    note: z.string().optional(),\n    tags: z.array(z.string()).optional(),\n    fixtureGenerator: z.string().optional(),\n    fixtureDefault: z.unknown().optional(),\n    fixtureStrategy: z.literal(\"sequence\").optional(),\n    dataSource: z\n      .object({\n        strategy: z.enum([\"sample\", \"ids\", \"query\", \"file\", \"recent\", \"random\"]),\n        config: z.unknown().optional(),\n      })\n      .optional(),\n  })\n  .catchall(z.unknown()); // 사용자 정의 메타데이터 허용\n\nconst BasePropFields = {\n  name: z.string(),\n  desc: z.string().optional(),\n  nullable: z.boolean().optional(),\n  toFilter: z.boolean().default(false).optional(),\n  dbDefault: z.union([z.string(), z.number(), z.boolean()]).optional(),\n  generated: GeneratedColumnSchema.optional(),\n  cone: ConeSchema.optional(),\n};\n\n// 부가 필드가 필요없는 prop\nconst BasePropFieldsWithoutAdditional = z\n  .object({\n    ...BasePropFields,\n    type: z.union([\n      z.literal(\"integer\"),\n      z.literal(\"integer[]\"),\n      z.literal(\"bigInteger\"),\n      z.literal(\"bigInteger[]\"),\n      z.literal(\"boolean\"),\n      z.literal(\"boolean[]\"),\n      z.literal(\"uuid\"),\n      z.literal(\"uuid[]\"),\n      z.literal(\"tsvector\"),\n    ]),\n  })\n  .strict();\n\n// precision/scale 필드\nconst PrecisionScaleFields = {\n  precision: z.number().optional(),\n  scale: z.number().optional(),\n};\n\n// 각 타입별 스키마 정의\n\nconst StringPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string\"),\n    length: z.number().optional(),\n    zodFormat: ZodStringFormat.optional(),\n  })\n  .strict();\nconst StringArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string[]\"),\n    length: z.number().optional(),\n    zodFormat: ZodStringFormat.optional(),\n  })\n  .strict();\n\nconst EnumPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum\"),\n    id: z.string(),\n    length: z.number().optional(),\n  })\n  .strict();\nconst EnumArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum[]\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst NumberPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\nconst NumberArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number[]\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\n\nconst DatePropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"date\"),\n    precision: z.number().optional(),\n  })\n  .strict();\nconst DateArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"date[]\"),\n    precision: z.number().optional(),\n  })\n  .strict();\n\nconst NumericPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\nconst NumericArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric[]\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\n\nconst JsonPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"json\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst VirtualPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"virtual\"),\n    id: z.string(),\n    virtualType: z.enum([\"query\", \"code\"]).optional(),\n  })\n  .strict();\n\nconst VectorPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector\"),\n    dimensions: z.number(),\n  })\n  .strict();\nconst VectorArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector[]\"),\n    dimensions: z.number(),\n  })\n  .strict();\n\n// Relation 타입은 relationType에 따라 세분화\nconst BaseRelationFields = {\n  ...BasePropFields,\n  type: z.literal(\"relation\"),\n  with: z.string(),\n};\n\n// RelationOn 타입\nconst RelationOnSchema = z.enum([\"CASCADE\", \"SET NULL\", \"NO ACTION\", \"SET DEFAULT\", \"RESTRICT\"]);\n\nconst BelongsToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"BelongsToOne\"),\n    customJoinClause: z.string().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst HasManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"HasMany\"),\n    joinColumn: z.string(),\n    fromColumn: z.string().optional(),\n  })\n  .strict();\n\nconst ManyToManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"ManyToMany\"),\n    joinTable: z.string(),\n    onUpdate: RelationOnSchema,\n    onDelete: RelationOnSchema,\n  })\n  .strict();\n\nconst OneToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"OneToOne\"),\n    customJoinClause: z.string().optional(),\n    hasJoinColumn: z.boolean().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst RelationTypes = [\"BelongsToOne\", \"HasMany\", \"ManyToMany\", \"OneToOne\"] as const;\nexport const RelationPropSchema = z.discriminatedUnion(\n  \"relationType\",\n  [\n    BelongsToOneRelationPropSchema,\n    HasManyRelationPropSchema,\n    ManyToManyRelationPropSchema,\n    OneToOneRelationPropSchema,\n  ],\n  {\n    error: (iss) =>\n      `relationType은 ${RelationTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.relationType}\"`,\n  },\n);\n\nconst NormalPropTypes = [\n  \"integer\",\n  \"integer[]\",\n  \"bigInteger\",\n  \"bigInteger[]\",\n  \"string\",\n  \"string[]\",\n  \"enum\",\n  \"enum[]\",\n  \"number\",\n  \"number[]\",\n  \"numeric\",\n  \"numeric[]\",\n  \"boolean\",\n  \"boolean[]\",\n  \"date\",\n  \"date[]\",\n  \"uuid\",\n  \"uuid[]\",\n  \"json\",\n  \"virtual\",\n  \"vector\",\n  \"vector[]\",\n  \"tsvector\",\n] as const;\n\n// VIRTUAL Generated Column에서 사용 불가능한 타입들\nconst VirtualGeneratedDisallowedTypes = [\n  \"json\",\n  \"vector\",\n  \"vector[]\",\n  \"string[]\",\n  \"integer[]\",\n  \"bigInteger[]\",\n  \"boolean[]\",\n  \"date[]\",\n  \"uuid[]\",\n  \"number[]\",\n  \"numeric[]\",\n  \"enum[]\",\n] as const;\n\nexport const NormalPropSchema = z\n  .discriminatedUnion(\n    \"type\",\n    [\n      BasePropFieldsWithoutAdditional,\n      StringPropSchema,\n      StringArrayPropSchema,\n      EnumPropSchema,\n      EnumArrayPropSchema,\n      NumberPropSchema,\n      NumberArrayPropSchema,\n      DatePropSchema,\n      DateArrayPropSchema,\n      NumericPropSchema,\n      NumericArrayPropSchema,\n      JsonPropSchema,\n      VirtualPropSchema,\n      VectorPropSchema,\n      VectorArrayPropSchema,\n    ],\n    {\n      error: (iss) =>\n        `type은 ${NormalPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n    },\n  )\n  .superRefine((data, ctx) => {\n    if (!data.generated) {\n      return;\n    }\n\n    // dbDefault와 generated 동시 사용 불가\n    if (data.dbDefault !== undefined) {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"dbDefault와 generated는 함께 사용할 수 없습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // virtual 타입은 generated 불가\n    if (data.type === \"virtual\") {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"virtual 타입은 generated column을 지원하지 않습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // VIRTUAL Generated Column 타입 제한 검증\n    if (data.generated.type === \"VIRTUAL\") {\n      if ((VirtualGeneratedDisallowedTypes as readonly string[]).includes(data.type)) {\n        ctx.addIssue({\n          code: \"custom\",\n          message: `VIRTUAL generated column은 ${data.type} 타입을 지원하지 않습니다. STORED를 사용하세요.`,\n          path: [\"generated\", \"type\"],\n          fatal: true,\n        });\n      }\n    }\n  });\n\nconst AllPropTypes = [...NormalPropTypes, \"relation\"] as const;\nconst EntityPropSchema = z.discriminatedUnion(\"type\", [NormalPropSchema, RelationPropSchema], {\n  error: (iss) =>\n    `type은 ${AllPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n});\n\nconst EntityIndexColumnSchema = z.object({\n  name: z.string(),\n  nullsFirst: z.boolean().optional(),\n  sortOrder: z.enum([\"ASC\", \"DESC\"]).optional(),\n  vectorOps: z.enum([\"vector_cosine_ops\", \"vector_ip_ops\", \"vector_l2_ops\"]).optional(),\n});\n\n// EntityIndex 스키마 정의\nconst EntityIndexSchema = z\n  .object({\n    type: z.enum([\"index\", \"unique\", \"hnsw\", \"ivfflat\"]),\n    columns: z.array(EntityIndexColumnSchema),\n    name: z.string().min(1).max(63),\n    using: z.enum([\"btree\", \"hash\", \"gin\", \"gist\", \"pgroonga\"]).optional(),\n    nullsNotDistinct: z.boolean().optional(),\n    m: z.number().optional(),\n    efConstruction: z.number().optional(),\n    lists: z.number().optional(),\n  })\n  .strict();\n\n/**\n * SubsetDef 스키마\n *\n * 하위 호환성을 위해 배열 형태와 객체 형태 둘 다 지원합니다.\n */\nconst SubsetDefSchema = z.union([\n  // 기존 배열 형태\n  z.array(z.union([z.string(), z.object({ field: z.string(), internal: z.boolean().optional() })])),\n  // 새로운 객체 형태\n  z.object({\n    fields: z.array(\n      z.union([z.string(), z.object({ field: z.string(), internal: z.boolean().optional() })]),\n    ),\n    cone: ConeSchema.optional(),\n  }),\n]);\n\n/**\n * EnumDef 스키마\n *\n * 하위 호환성을 위해 Record 형태와 객체 형태 둘 다 지원합니다.\n */\nconst EnumDefSchema = z.union([\n  // 기존 Record 형태\n  z.record(z.string(), z.string()),\n  // 새로운 객체 형태\n  z.object({\n    values: z.record(z.string(), z.string()),\n    cone: ConeSchema.optional(),\n  }),\n]);\n\nexport const EntityJsonSchema = z\n  .object({\n    id: z.string().describe(\"PascalCase로 된 Entity ID\"),\n    title: z.string().describe(\"Entity 이름\"),\n    table: z.string().describe(\"snake_case로 된 테이블명\"),\n    parentId: z.string().optional().describe(\"부모 Entity ID\"),\n    cone: ConeSchema.optional(),\n    props: z.array(EntityPropSchema),\n    indexes: z.array(EntityIndexSchema),\n    subsets: z.record(z.string(), SubsetDefSchema),\n    enums: z.record(z.string(), EnumDefSchema),\n  })\n  .strict();\n\nexport const TemplateOptions = z.object({\n  entity: EntityJsonSchema.omit({ id: true })\n    .extend({\n      entityId: z.string(),\n    })\n    .partial({\n      table: true,\n      props: true,\n      indexes: true,\n      subsets: true,\n      enums: true,\n    }),\n  init_types: z.object({\n    entityId: z.string(),\n  }),\n  generated: z.object({}),\n  generated_sso: z.object({}),\n  generated_http: z.object({\n    entityId: z.string(),\n  }),\n  model: z.object({\n    entityId: z.string(),\n    defaultSearchField: z.string().optional(),\n    defaultOrderBy: z.string().optional(),\n  }),\n  model_test: z.object({\n    entityId: z.string(),\n  }),\n  bridge: z.object({\n    entityId: z.string(),\n  }),\n  services: z.object({}),\n  view_list: z.object({\n    entityId: z.string(),\n    extra: z.unknown(),\n  }),\n  view_list_columns: z.object({\n    entityId: z.string(),\n    columns: z\n      .object({\n        name: z.string(),\n        label: z.string(),\n        tc: z.string(),\n      })\n      .array(),\n    columnImports: z.string(),\n  }),\n  view_search_input: z.object({\n    entityId: z.string(),\n  }),\n  view_form: z.object({\n    entityId: z.string(),\n  }),\n  view_id_all_select: z.object({\n    entityId: z.string(),\n  }),\n  view_enums_buttonset: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  queries: z.object({}),\n  entry_server: z.object({}),\n  sd: z.object({\n    target: z.enum([\"api\", \"web\", \"app\"]),\n  }),\n});\nexport type TemplateOptions = z.infer<typeof TemplateOptions>;\n\nexport const TemplateKey = z.enum([\n  \"entity\",\n  \"init_types\",\n  \"generated\",\n  \"generated_sso\",\n  \"generated_http\",\n  \"model\",\n  \"model_test\",\n  \"bridge\",\n  \"services\",\n  \"view_list\",\n  \"view_list_columns\",\n  \"view_search_input\",\n  \"view_form\",\n  \"view_id_all_select\",\n  \"view_enums_buttonset\",\n  \"queries\",\n  \"entry_server\",\n  \"sd\",\n]);\nexport type TemplateKey = z.infer<typeof TemplateKey>;\n\nexport const GenerateOptions = z.object({\n  overwrite: z.boolean().optional(),\n});\nexport type GenerateOptions = z.infer<typeof GenerateOptions>;\n\nexport const PathAndCode = z.object({\n  path: z.string(),\n  code: z.string(),\n});\nexport type PathAndCode = z.infer<typeof PathAndCode>;\n\nexport type FixtureSearchOptions = {\n  entityId: string;\n  field: string;\n  value: string;\n  searchType: \"equals\" | \"like\";\n};\n\ntype ColumnValue = string | number | boolean | Date | null;\nexport type FixtureRecord = {\n  fixtureId: string;\n  entityId: string;\n  id: number | string;\n  columns: {\n    [key: string]: {\n      prop: EntityProp;\n      value: ColumnValue | ColumnValue[];\n    };\n  };\n  fetchedRecords: string[];\n  belongsRecords: string[];\n  target?: FixtureRecord; // Import 대상 DB 레코드(id가 같은)\n  unique?: FixtureRecord; // Import 대상 DB 레코드(unique key가 같은)\n  override?: boolean;\n};\n\nexport type FixtureImportResult = {\n  entityId: string;\n  data: {\n    [key: string]: ColumnValue;\n  };\n};\n\nexport type RelationNode = {\n  fixtureId: string;\n  entityId: string;\n  related: Set<string>;\n};\n\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseSchemaExtend {}\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseForeignKeys {}\nexport type ManyToManyBaseSchema<\n  FromIdKey extends string,\n  ToIdKey extends string,\n  FromPkType = number,\n  ToPkType = number,\n> = {\n  id: number;\n} & {\n  [K in `${FromIdKey}_id`]: FromPkType;\n} & {\n  [K in `${ToIdKey}_id`]: ToPkType;\n};\n\n// 객체, 함수, 비동기 함수를 모두 포괄하는 타입\nexport type Executable<T> = T | Promise<T> | (() => T) | (() => Promise<T>);\n\nexport type SonamuFastifyConfig = {\n  contextProvider: (\n    defaultContext: Pick<\n      Context,\n      \"request\" | \"reply\" | \"headers\" | \"createSSE\" | \"naiteStore\" | \"locale\" | \"user\" | \"session\"\n    >,\n    request: FastifyRequest,\n    reply: FastifyReply,\n  ) => Context | Promise<Context>;\n  guardHandler: (\n    guard: GuardKey,\n    request: FastifyRequest,\n    api: {\n      typeParameters: ApiParamType.TypeParam[];\n      parameters: ApiParam[];\n      returnType: ApiParamType;\n      modelName: string;\n      methodName: string;\n      path: string;\n      options: ApiDecoratorOptions;\n    },\n  ) => void;\n  /**\n   * 전역 Cache-Control 핸들러입니다.\n   * 요청 타입(api, assets, ssr, csr)에 따라 Cache-Control 설정을 반환합니다.\n   * undefined를 반환하면 타입별 기본값이 적용됩니다.\n   */\n  cacheControlHandler?: CacheControlHandler;\n};\n"],"names":["z","zArrayable","shape","union","array","getDescription","item","cone","note","desc","ZodStringFormat","enum","SonamuFileSchema","object","name","string","url","mime_type","size","number","describe","SonamuFileArraySchema","BUILT_IN_TYPE_IDS","normalizeSubsetField","f","field","isInternalSubsetField","internal","isSubsetDefWithCone","def","Array","isArray","isEnumDefWithCone","undefined","Object","keys","length","getSubsetFields","fields","getEnumDefValues","values","isIntegerSingleProp","p","type","isIntegerArrayProp","isIntegerProp","isBigIntegerSingleProp","isBigIntegerArrayProp","isBigIntegerProp","isStringSingleProp","isStringArrayProp","isStringProp","isEnumSingleProp","isEnumArrayProp","isEnumProp","isNumberSingleProp","isNumberArrayProp","isNumberProp","isNumericSingleProp","isNumericArrayProp","isNumericProp","isBooleanSingleProp","isBooleanArrayProp","isBooleanProp","isDateSingleProp","isDateArrayProp","isDateProp","isUuidSingleProp","isUuidArrayProp","isUuidProp","isJsonProp","isVirtualProp","isVirtualCodeProp","virtualType","isVirtualQueryProp","isVectorSingleProp","isVectorArrayProp","isVectorProp","isTsVectorProp","isRelationProp","isOneToOneRelationProp","relationType","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isCustomJoinClause","custom","SonamuQueryMode","SonamuSemanticParams","semanticQuery","embedding","min","max","threshold","optional","method","isKnexError","e","code","sqlMessage","sqlState","ApiParamType","isObject","v","t","isUnion","isIntersection","isStringLiteral","isNumericLiteral","isRef","isIndexedAccess","isTupleType","isPick","id","isOmit","isPartial","isPromise","isContext","isRefKnex","isTypeParam","RenderingNode","any","GeneratedColumnSchema","expression","ConeSchema","tags","fixtureGenerator","fixtureDefault","unknown","fixtureStrategy","literal","dataSource","strategy","config","catchall","BasePropFields","nullable","boolean","toFilter","default","dbDefault","generated","BasePropFieldsWithoutAdditional","strict","PrecisionScaleFields","precision","scale","StringPropSchema","zodFormat","StringArrayPropSchema","EnumPropSchema","EnumArrayPropSchema","NumberPropSchema","numberType","NumberArrayPropSchema","DatePropSchema","DateArrayPropSchema","NumericPropSchema","NumericArrayPropSchema","JsonPropSchema","VirtualPropSchema","VectorPropSchema","dimensions","VectorArrayPropSchema","BaseRelationFields","with","RelationOnSchema","BelongsToOneRelationPropSchema","customJoinClause","useConstraint","onUpdate","onDelete","HasManyRelationPropSchema","joinColumn","fromColumn","ManyToManyRelationPropSchema","joinTable","OneToOneRelationPropSchema","hasJoinColumn","RelationTypes","RelationPropSchema","discriminatedUnion","error","iss","map","join","input","NormalPropTypes","VirtualGeneratedDisallowedTypes","NormalPropSchema","superRefine","data","ctx","addIssue","message","path","includes","fatal","AllPropTypes","EntityPropSchema","EntityIndexColumnSchema","nullsFirst","sortOrder","vectorOps","EntityIndexSchema","columns","using","nullsNotDistinct","m","efConstruction","lists","SubsetDefSchema","EnumDefSchema","record","EntityJsonSchema","title","table","parentId","props","indexes","subsets","enums","TemplateOptions","entity","omit","extend","entityId","partial","init_types","generated_sso","generated_http","model","defaultSearchField","defaultOrderBy","model_test","bridge","services","view_list","extra","view_list_columns","label","tc","columnImports","view_search_input","view_form","view_id_all_select","view_enums_buttonset","enumId","queries","entry_server","sd","target","TemplateKey","GenerateOptions","overwrite","PathAndCode"],"mappings":"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"}
|
|
927
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/types/types.ts"],"sourcesContent":["import type { FastifyReply, FastifyRequest } from \"fastify\";\nimport { z } from \"zod\";\nimport type { ApiDecoratorOptions, Context } from \"../api\";\nimport type { GuardKey } from \"./../api/decorators\";\nimport type { CacheControlHandler } from \"../cache-control/types\";\n\n/*\n  Utility Types\n*/\nexport function zArrayable<T extends z.ZodTypeAny>(shape: T): z.ZodUnion<[T, z.ZodArray<T>]> {\n  return z.union([shape, shape.array()]);\n}\n// biome-ignore lint/suspicious/noExplicitAny: any is used to make the type distributive\nexport type DistributiveOmit<T, K extends keyof any> = T extends any ? Omit<T, K> : never;\n\n/*\n  Model-Definition\n*/\n\n/**\n * 부모 Entity fixture 생성 시 함께 생성할 companion Entity 설정\n *\n * 예: User fixture 생성 시 credentials Account를 함께 생성\n */\nexport type FixtureCompanion = {\n  /** 함께 생성할 Entity 이름 */\n  entity: string;\n\n  /**\n   * 고정 오버라이드 값.\n   * \"{{fieldName}}\" 형식으로 부모 fixture의 필드 값을 참조할 수 있다.\n   * 예: { \"account_id\": \"{{email}}\" } → 부모 User의 email 값 사용\n   */\n  overrides?: Record<string, unknown>;\n\n  /**\n   * 부모 1개당 생성할 companion 개수. 기본값 1.\n   * 예: count: 2 → User 1개당 companion 2개 생성\n   */\n  count?: number;\n};\n\n/**\n * cone: 범용 메타데이터 시스템\n *\n * Entity, Prop, Enum, Subset에 \"솔방울을 단다\"는 개념으로 붙이는 단일 서술 메타데이터입니다.\n * note 하나로 비즈니스 의미와 fixture 생성 힌트를 함께 기술합니다.\n */\nexport type Cone = {\n  note?: string; // 이 대상이 무엇인지 설명 (비즈니스 의미 + fixture 힌트 통합)\n  tags?: string[]; // 분류/검색용 태그\n\n  // Fixture 생성 관련\n  fixtureGenerator?: string; // Faker.js 코드 또는 커스텀 함수\n  fixtureDefault?: unknown; // 기본값\n  fixtureStrategy?: \"sequence\"; // string 타입이지만 DB sequence로 관리되는 PK (better-auth 등)\n  fixtureCompanions?: FixtureCompanion[]; // 부모 fixture 생성 시 함께 생성할 companion Entity 목록\n\n  // 참조 데이터 관련\n  dataSource?: {\n    strategy: \"sample\" | \"ids\" | \"query\" | \"file\" | \"recent\" | \"random\";\n    config?: unknown; // 전략별 설정\n  };\n\n  // 확장성\n  [key: string]: unknown; // 사용자 정의 메타데이터\n};\n\nexport type GeneratedColumnType = \"STORED\" | \"VIRTUAL\";\nexport type GeneratedColumn = {\n  type: GeneratedColumnType;\n  expression: string;\n};\nexport type CommonProp = {\n  name: string;\n  nullable?: boolean;\n  toFilter?: true;\n  desc?: string;\n  dbDefault?: string;\n  generated?: GeneratedColumn;\n  cone?: Cone; // cone 메타데이터\n};\n\n/**\n * prop의 설명을 반환합니다.\n *\n * cone.note가 있으면 우선 사용하고, 없으면 prop.desc를 사용합니다.\n */\nexport function getDescription(item: { desc?: string; cone?: Cone }): string | undefined {\n  return item.cone?.note || item.desc;\n}\nexport type IntegerProp = CommonProp & {\n  type: \"integer\";\n}; // PG: integer / TS: number / JSON: number\nexport type IntegerArrayProp = CommonProp & {\n  type: \"integer[]\";\n}; // PG: integer[] / TS: number[] / JSON: number[]\nexport type BigIntegerProp = CommonProp & {\n  type: \"bigInteger\";\n}; // PG: bigint / TS: bigint / JSON: bigint\nexport type BigIntegerArrayProp = CommonProp & {\n  type: \"bigInteger[]\";\n}; // PG: bigint[] / TS: bigint[] / JSON: bigint[]\n\n/**\n * Zod 4 String Format 타입\n * entity.json에서 string 타입의 prop에 zodFormat 옵션을 지정하여\n * BaseSchema 생성 시 Zod의 string format validation을 적용합니다.\n */\nexport const ZodStringFormat = z.enum([\n  // 기본 포맷\n  \"email\",\n  \"uuid\",\n  \"url\",\n  \"httpUrl\",\n  \"hostname\",\n  \"emoji\",\n  \"base64\",\n  \"base64url\",\n  \"hex\",\n  \"jwt\",\n  \"nanoid\",\n  \"cuid\",\n  \"cuid2\",\n  \"ulid\",\n  \"ipv4\",\n  \"ipv6\",\n  \"mac\",\n  \"cidrv4\",\n  \"cidrv6\",\n  // hash 포맷 (알고리즘별)\n  \"hashMd5\",\n  \"hashSha1\",\n  \"hashSha256\",\n  \"hashSha384\",\n  \"hashSha512\",\n  // ISO 포맷\n  \"isoDate\",\n  \"isoTime\",\n  \"isoDatetime\",\n  \"isoDuration\",\n]);\nexport type ZodStringFormat = z.infer<typeof ZodStringFormat>;\n\nexport type StringProp = CommonProp & {\n  type: \"string\";\n  length?: number; // PG: varchar(n), text / TS: string / JSON: string\n  zodFormat?: ZodStringFormat;\n}; // PG: text / TS: string / JSON: string\nexport type StringArrayProp = CommonProp & {\n  type: \"string[]\";\n  length?: number; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\n  zodFormat?: ZodStringFormat;\n}; // PG: varchar(n)[], text[] / TS: string[] / JSON: string[]\nexport type EnumProp = CommonProp & {\n  type: \"enum\";\n  id: string;\n  length?: number;\n}; // PG: text / TS: string / JSON: string\nexport type EnumArrayProp = CommonProp & {\n  type: \"enum[]\";\n  id: string;\n}; // PG: text[] / TS: string[] / JSON: string[]\nexport type NumberProp = CommonProp & {\n  type: \"number\";\n  precision?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  scale?: number; // PG: numeric(p, s) / TS: number / JSON: number\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s) / TS: number / JSON: number\nexport type NumberArrayProp = CommonProp & {\n  type: \"number[]\";\n  precision?: number;\n  scale?: number;\n  numberType?: \"real\" | \"double precision\" | \"numeric\"; // 기본값: numeric\n}; // PG: numeric(p, s)[] / TS: number[] / JSON: number[]\nexport type NumericProp = CommonProp & {\n  type: \"numeric\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s) / TS: string / JSON: string\nexport type NumericArrayProp = CommonProp & {\n  type: \"numeric[]\";\n  precision?: number;\n  scale?: number;\n}; // PG: numeric(p, s)[] / TS: string[] / JSON: string[]\nexport type BooleanProp = CommonProp & {\n  type: \"boolean\";\n}; // PG: boolean / TS: boolean / JSON: boolean\nexport type BooleanArrayProp = CommonProp & {\n  type: \"boolean[]\";\n}; // PG: boolean[] / TS: boolean[] / JSON: boolean[]\nexport type DateProp = CommonProp & {\n  type: \"date\";\n  // 기본값은 3, microseconds를 쓰려면 6을 써야함 (0 ~ 6)\n  precision?: number;\n}; // PG: timestampz / TS: Date / JSON: string(ISOString)\nexport type DateArrayProp = CommonProp & {\n  type: \"date[]\";\n  // 기본값은 3, microseconds를 쓰려면 6을 써야함 (0 ~ 6)\n  precision?: number;\n}; // PG: timestamptz[] / TS: Date[] / JSON: string[]\nexport type JsonProp = CommonProp & {\n  type: \"json\";\n  id: string;\n}; // PG: json / TS: any(id) / JSON: any\nexport type SearchTextSourceColumn = {\n  name: string;\n  caseInsensitive?: boolean;\n};\nexport type SearchTextProp = CommonProp & {\n  type: \"searchText\";\n  sourceColumns: SearchTextSourceColumn[];\n}; // PG: text (generated) / TS: string / JSON: string\nexport type UuidProp = CommonProp & {\n  type: \"uuid\";\n}; // PG: uuid / TS: string / JSON: string\nexport type UuidArrayProp = CommonProp & {\n  type: \"uuid[]\";\n}; // PG: uuid[] / TS: string[] / JSON: string[]\nexport type VirtualProp = CommonProp & {\n  type: \"virtual\";\n  id: string;\n  virtualType?: \"query\" | \"code\"; // default: \"code\"\n}; // PG: none / TS: any(id) / JSON: any\nexport type VectorProp = CommonProp & {\n  type: \"vector\";\n  dimensions: number;\n};\nexport type VectorArrayProp = CommonProp & {\n  type: \"vector[]\";\n  dimensions: number;\n};\nexport type TsVectorProp = CommonProp & {\n  type: \"tsvector\";\n};\nexport type RelationType = \"HasMany\" | \"BelongsToOne\" | \"ManyToMany\" | \"OneToOne\";\nexport type RelationOn = \"CASCADE\" | \"SET NULL\" | \"NO ACTION\" | \"SET DEFAULT\" | \"RESTRICT\";\ntype _RelationProp = {\n  type: \"relation\";\n  name: string;\n  with: string;\n  nullable?: boolean; // DEFAULT: false\n  toFilter?: true; // DEFAULT: false\n  desc?: string;\n  cone?: Cone; // cone 메타데이터\n};\nexport type OneToOneRelationProp = _RelationProp & {\n  relationType: \"OneToOne\";\n  customJoinClause?: string;\n} & (\n    | {\n        hasJoinColumn: true;\n        useConstraint?: boolean; // DEFAULT: true\n        onUpdate?: RelationOn; // DEFAULT: RESTRICT\n        onDelete?: RelationOn; // DEFAULT: RESTRICT\n      }\n    | {\n        hasJoinColumn: false;\n      }\n  );\nexport type BelongsToOneRelationProp = _RelationProp & {\n  relationType: \"BelongsToOne\";\n  customJoinClause?: string;\n  useConstraint?: boolean; // DEFAULT: true\n  onUpdate?: RelationOn; // DEFAULT: RESTRICT\n  onDelete?: RelationOn; // DEFAULT: RESTRICT\n};\nexport type HasManyRelationProp = _RelationProp & {\n  relationType: \"HasMany\";\n  joinColumn: string;\n  fromColumn?: string;\n};\nexport type ManyToManyRelationProp = _RelationProp & {\n  relationType: \"ManyToMany\";\n  joinTable: `${string}__${string}`;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type RelationProp =\n  | OneToOneRelationProp\n  | BelongsToOneRelationProp\n  | HasManyRelationProp\n  | ManyToManyRelationProp;\n\nexport type EntityProp =\n  | IntegerProp\n  | IntegerArrayProp\n  | BigIntegerProp\n  | BigIntegerArrayProp\n  | StringProp\n  | StringArrayProp\n  | EnumProp\n  | EnumArrayProp\n  | NumberProp\n  | NumberArrayProp\n  | NumericProp\n  | NumericArrayProp\n  | NumericProp\n  | BooleanProp\n  | BooleanArrayProp\n  | DateProp\n  | DateArrayProp\n  | UuidProp\n  | UuidArrayProp\n  | JsonProp\n  | SearchTextProp\n  | VirtualProp\n  | VectorProp\n  | VectorArrayProp\n  | TsVectorProp\n  | RelationProp;\n\n/**\n * SonamuFile Types\n *\n * 파일 업로드를 위한 JSON 타입입니다.\n * Entity의 json 속성에서 id로 \"SonamuFile\" 또는 \"SonamuFile[]\"을 지정하여 사용합니다.\n */\nexport interface SonamuFile {\n  name: string;\n  url: string;\n  mime_type: string;\n  size: number;\n}\n\nexport const SonamuFileSchema = z\n  .object({\n    name: z.string(),\n    url: z.string(),\n    mime_type: z.string(),\n    size: z.number(),\n  })\n  .describe(\"SonamuFile\");\n\nexport const SonamuFileArraySchema = z.array(SonamuFileSchema).describe(\"SonamuFile[]\");\n\n/**\n * Sonamu 코어에서 제공하는 내장 JSON 타입 ID 목록\n * 새로운 내장 타입 추가 시 이 배열에 추가하면 자동으로 UI에 노출됩니다.\n */\nexport const BUILT_IN_TYPE_IDS = [\"SonamuFile\", \"SonamuFile[]\"] as const;\nexport type BuiltInTypeId = (typeof BUILT_IN_TYPE_IDS)[number];\n\n/**\n * pgvector 거리 연산자 클래스\n *\n * @description\n * - `vector_cosine_ops`: 코사인 거리 (Cosine Distance) - 권장\n *   - SQL 연산자: `<=>`\n *   - 벡터의 방향만 비교 (크기 무시), 1 - cosine_similarity\n *   - 텍스트 임베딩, 시맨틱 검색에 가장 일반적으로 사용\n *   - 사용 예: OpenAI, Voyage 등 대부분의 임베딩 모델에 권장\n *\n * - `vector_ip_ops`: 내적 (Inner Product)\n *   - SQL 연산자: `<#>`\n *   - 두 벡터의 내적을 계산 (sum(a[i] * b[i]))\n *   - 정규화된 벡터에서 코사인 유사도와 동일한 결과\n *   - 값이 클수록 유사 (음수 연산자이므로 ORDER BY에서 주의)\n *   - 사용 예: 이미 정규화된 임베딩에서 가장 빠른 성능\n *\n * - `vector_l2_ops`: 유클리드 거리 (L2 Distance)\n *   - SQL 연산자: `<->`\n *   - 두 벡터 간의 직선 거리를 계산 (sqrt(sum((a[i] - b[i])^2)))\n *   - 벡터의 크기(magnitude)가 중요할 때 사용\n *   - 사용 예: 이미지 유사도, 절대적 거리 측정이 필요한 경우\n */\nexport type VectorOps = \"vector_cosine_ops\" | \"vector_ip_ops\" | \"vector_l2_ops\";\n\nexport const KnownOpclassValues = [\n  \"gin_trgm_ops\",\n  \"gist_trgm_ops\",\n  \"gin_bigm_ops\",\n  \"vector_cosine_ops\",\n  \"vector_ip_ops\",\n  \"vector_l2_ops\",\n  \"pgroonga_varchar_full_text_search_ops_v2\",\n  \"pgroonga_jsonb_full_text_search_ops_v2\",\n] as const;\nexport type KnownOpclass = (typeof KnownOpclassValues)[number];\n\ntype EntityIndexColumn = {\n  name: string;\n  nullsFirst?: boolean;\n  sortOrder?: \"ASC\" | \"DESC\";\n  /** pgvector 인덱스에서 사용할 거리 연산자 (vector 컬럼에만 적용) */\n  vectorOps?: VectorOps;\n  /** generic 인덱스 opclass (vectorOps는 하위호환 목적으로 유지) */\n  opclass?: KnownOpclass | string;\n};\nexport type EntityIndex = {\n  type: \"index\" | \"unique\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\" | \"pgroonga\";\n  nullsNotDistinct?: boolean; // unique index only\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 각 노드의 최대 연결 수\n   *\n   * @description\n   * 그래프에서 각 노드가 가질 수 있는 최대 연결 수입니다.\n   * HNSW는 빠른 검색 속도와 높은 정확도를 제공하므로 권장됩니다.\n   * - 기본값: 16\n   * - 범위: 2 ~ 100\n   * - 높을수록: 정확도↑, 빌드 시간↑, 메모리↑\n   * - 권장: 빠른 빌드(8), 균형(16), 높은 정확도(32), 최고 정확도(64)\n   */\n  m?: number;\n  /**\n   * HNSW (Hierarchical Navigable Small World) 인덱스: 구성 시 탐색 범위\n   *\n   * @description\n   * 인덱스 구성 시 각 노드에서 탐색할 범위입니다.\n   * - 기본값: 64\n   * - 범위: 4 ~ 1000\n   * - 높을수록: 정확도↑, 빌드 시간↑\n   * - 권장: 빠른 빌드(32), 균형(64), 높은 정확도(128), 최고 정확도(256)\n   */\n  efConstruction?: number;\n  /**\n   * IVFFlat (Inverted File with Flat Compression) 인덱스: 클러스터링 리스트 수\n   *\n   * @description\n   * 벡터를 클러스터링할 버킷 수를 지정합니다.\n   * IVFFlat은 빠른 빌드와 낮은 메모리 사용이 필요할 때 사용합니다.\n   * - 권장값: sqrt(row_count) ~ row_count / 1000\n   * - 예시: 10,000행 → 100, 100,000행 → 300, 1,000,000행 → 1000\n   * - 많을수록 정확도↑, 검색 속도↓\n   */\n  lists?: number;\n};\n\n// SubsetField 타입: string 또는 internal 옵션이 있는 객체\nexport type SubsetField = string | { field: string; internal?: boolean };\n\nexport function normalizeSubsetField(f: SubsetField): string {\n  return typeof f === \"string\" ? f : f.field;\n}\nexport function isInternalSubsetField(f: SubsetField): boolean {\n  return typeof f !== \"string\" && f.internal === true;\n}\n\n/**\n * SubsetDef: Subset 정의\n *\n * 하위 호환성을 위해 SubsetField[] 배열 형태도 지원합니다.\n */\nexport type SubsetDef =\n  | SubsetField[] // 기존 배열 형태\n  | {\n      // 새로운 객체 형태\n      fields: SubsetField[];\n      cone?: Cone;\n    };\n\n/**\n * EnumDef: Enum 정의\n *\n * 하위 호환성을 위해 Record<string, string> 형태도 지원합니다.\n */\nexport type EnumDef =\n  | Record<string, string> // 기존 Record 형태\n  | {\n      // 새로운 객체 형태\n      values: Record<string, string>;\n      cone?: Cone;\n    };\n\n/**\n * SubsetDef가 새로운 객체 형태인지 확인\n */\nexport function isSubsetDefWithCone(def: SubsetDef): def is { fields: SubsetField[]; cone?: Cone } {\n  return !Array.isArray(def) && \"fields\" in def;\n}\n\n/**\n * EnumDef가 새로운 객체 형태인지 확인\n */\nexport function isEnumDefWithCone(\n  def: EnumDef,\n): def is { values: Record<string, string>; cone?: Cone } {\n  return (\n    \"values\" in def && !(\"cone\" in def && def.cone === undefined && Object.keys(def).length > 1)\n  );\n}\n\n/**\n * SubsetDef에서 fields 추출\n */\nexport function getSubsetFields(def: SubsetDef): SubsetField[] {\n  return Array.isArray(def) ? def : def.fields;\n}\n\n/**\n * EnumDef에서 values 추출\n */\nexport function getEnumDefValues(def: EnumDef): Record<string, string> {\n  return isEnumDefWithCone(def) ? def.values : def;\n}\n\nexport type EntityJson = {\n  id: string;\n  parentId?: string;\n  table: string;\n  title?: string;\n  cone?: Cone; // cone 메타데이터\n  props: EntityProp[];\n  indexes: EntityIndex[];\n  subsets: {\n    [subset: string]: SubsetDef;\n  };\n  enums: {\n    [enumId: string]: EnumDef;\n  };\n};\nexport type EntitySubsetRow = {\n  field: string;\n  has: {\n    [key: string]: boolean;\n  };\n  isInternal: {\n    [key: string]: boolean;\n  };\n  children: EntitySubsetRow[];\n  prefixes: string[];\n  relationEntity?: string;\n  isOpen?: boolean;\n};\nexport type FlattenSubsetRow = Omit<EntitySubsetRow, \"children\">;\n\n/*\n  PropNode\n*/\n\n/**\n * 엔티티의 필드 구조를 트리 형태로 표현하는 중간 노드입니다.\n *\n * **목적**: Entity의 subset 필드 표현식(예: \"id\", \"user.name\", \"tags[]\")을\n * 재귀적인 트리 구조로 파싱하여 Zod 스키마 생성의 중간 단계로 사용합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode (트리 구조) → Zod 스키마 → RenderingNode (UI용)\n *\n * **nodeType**:\n * - \"plain\": 단일 필드 (예: \"id\", \"name\")\n * - \"object\": 중첩 객체 (예: \"user.name\" → user 객체)\n * - \"array\": 배열 (예: \"tags[]\" → tags 배열)\n *\n * **사용 위치**: entity-converter.ts의 propNodeToZodType()\n */\nexport type EntityPropNode =\n  | {\n      nodeType: \"plain\";\n      prop: EntityProp;\n    }\n  | {\n      nodeType: \"object\" | \"array\";\n      prop?: EntityProp;\n      children: EntityPropNode[];\n    };\n\n/*\n  Prop Type Guards\n*/\nexport function isIntegerSingleProp(p: unknown): p is IntegerProp {\n  return (p as IntegerProp)?.type === \"integer\";\n}\nexport function isIntegerArrayProp(p: unknown): p is IntegerArrayProp {\n  return (p as IntegerArrayProp)?.type === \"integer[]\";\n}\nexport function isIntegerProp(p: unknown): p is IntegerProp | IntegerArrayProp {\n  return isIntegerSingleProp(p) || isIntegerArrayProp(p);\n}\nexport function isBigIntegerSingleProp(p: unknown): p is BigIntegerProp {\n  return (p as BigIntegerProp)?.type === \"bigInteger\";\n}\nexport function isBigIntegerArrayProp(p: unknown): p is BigIntegerArrayProp {\n  return (p as BigIntegerArrayProp)?.type === \"bigInteger[]\";\n}\nexport function isBigIntegerProp(p: unknown): p is BigIntegerProp | BigIntegerArrayProp {\n  return isBigIntegerSingleProp(p) || isBigIntegerArrayProp(p);\n}\nexport function isStringSingleProp(p: unknown): p is StringProp {\n  return (p as StringProp)?.type === \"string\";\n}\nexport function isStringArrayProp(p: unknown): p is StringArrayProp {\n  return (p as StringArrayProp)?.type === \"string[]\";\n}\nexport function isStringProp(p: unknown): p is StringProp | StringArrayProp {\n  return isStringSingleProp(p) || isStringArrayProp(p);\n}\nexport function isEnumSingleProp(p: unknown): p is EnumProp {\n  return (p as EnumProp)?.type === \"enum\";\n}\nexport function isEnumArrayProp(p: unknown): p is EnumArrayProp {\n  return (p as EnumArrayProp)?.type === \"enum[]\";\n}\nexport function isEnumProp(p: unknown): p is EnumProp | EnumArrayProp {\n  return isEnumSingleProp(p) || isEnumArrayProp(p);\n}\nexport function isNumberSingleProp(p: unknown): p is NumberProp {\n  return (p as NumberProp)?.type === \"number\";\n}\nexport function isNumberArrayProp(p: unknown): p is NumberArrayProp {\n  return (p as NumberArrayProp)?.type === \"number[]\";\n}\nexport function isNumberProp(p: unknown): p is NumberProp | NumberArrayProp {\n  return isNumberSingleProp(p) || isNumberArrayProp(p);\n}\nexport function isNumericSingleProp(p: unknown): p is NumericProp {\n  return (p as NumericProp)?.type === \"numeric\";\n}\nexport function isNumericArrayProp(p: unknown): p is NumericArrayProp {\n  return (p as NumericArrayProp)?.type === \"numeric[]\";\n}\nexport function isNumericProp(p: unknown): p is NumericProp | NumericArrayProp {\n  return isNumericSingleProp(p) || isNumericArrayProp(p);\n}\nexport function isBooleanSingleProp(p: unknown): p is BooleanProp {\n  return (p as BooleanProp)?.type === \"boolean\";\n}\nexport function isBooleanArrayProp(p: unknown): p is BooleanArrayProp {\n  return (p as BooleanArrayProp)?.type === \"boolean[]\";\n}\nexport function isBooleanProp(p: unknown): p is BooleanProp | BooleanArrayProp {\n  return isBooleanSingleProp(p) || isBooleanArrayProp(p);\n}\nexport function isDateSingleProp(p: unknown): p is DateProp {\n  return (p as DateProp)?.type === \"date\";\n}\nexport function isDateArrayProp(p: unknown): p is DateArrayProp {\n  return (p as DateArrayProp)?.type === \"date[]\";\n}\nexport function isDateProp(p: unknown): p is DateProp | DateArrayProp {\n  return isDateSingleProp(p) || isDateArrayProp(p);\n}\nexport function isUuidSingleProp(p: unknown): p is UuidProp {\n  return (p as UuidProp)?.type === \"uuid\";\n}\nexport function isUuidArrayProp(p: unknown): p is UuidArrayProp {\n  return (p as UuidArrayProp)?.type === \"uuid[]\";\n}\nexport function isUuidProp(p: unknown): p is UuidProp | UuidArrayProp {\n  return isUuidSingleProp(p) || isUuidArrayProp(p);\n}\nexport function isJsonProp(p: unknown): p is JsonProp {\n  return (p as JsonProp)?.type === \"json\";\n}\nexport function isSearchTextProp(p: unknown): p is SearchTextProp {\n  return (p as SearchTextProp)?.type === \"searchText\";\n}\nexport function isVirtualProp(p: unknown): p is VirtualProp {\n  return (p as VirtualProp)?.type === \"virtual\";\n}\nexport function isVirtualCodeProp(p: unknown): p is VirtualProp {\n  if (!isVirtualProp(p)) return false;\n  return p.virtualType !== \"query\"; // undefined도 \"code\"로 취급\n}\nexport function isVirtualQueryProp(p: unknown): p is VirtualProp {\n  if (!isVirtualProp(p)) return false;\n  return p.virtualType === \"query\";\n}\nexport function isVectorSingleProp(p: unknown): p is VectorProp {\n  return (p as VectorProp)?.type === \"vector\";\n}\nexport function isVectorArrayProp(p: unknown): p is VectorArrayProp {\n  return (p as VectorArrayProp)?.type === \"vector[]\";\n}\nexport function isVectorProp(p: unknown): p is VectorProp | VectorArrayProp {\n  return isVectorSingleProp(p) || isVectorArrayProp(p);\n}\nexport function isTsVectorProp(p: unknown): p is TsVectorProp {\n  return (p as TsVectorProp)?.type === \"tsvector\";\n}\nexport function isRelationProp(p: unknown): p is RelationProp {\n  return (p as RelationProp)?.type === \"relation\";\n}\nexport function isOneToOneRelationProp(p: unknown): p is OneToOneRelationProp {\n  return (p as OneToOneRelationProp)?.relationType === \"OneToOne\";\n}\nexport function isBelongsToOneRelationProp(p: unknown): p is BelongsToOneRelationProp {\n  return (p as BelongsToOneRelationProp)?.relationType === \"BelongsToOne\";\n}\nexport function isHasManyRelationProp(p: unknown): p is HasManyRelationProp {\n  return (p as HasManyRelationProp)?.relationType === \"HasMany\";\n}\nexport function isManyToManyRelationProp(p: unknown): p is ManyToManyRelationProp {\n  return (p as ManyToManyRelationProp)?.relationType === \"ManyToMany\";\n}\n\ntype JoinClause =\n  | {\n      from: string;\n      to: string;\n    }\n  | {\n      custom: string;\n    };\nexport function isCustomJoinClause(p: unknown): p is { custom: string } {\n  return !!(p as { custom: string })?.custom;\n}\n\ntype SubsetLoader = {\n  as: string;\n  table: string;\n  manyJoin: {\n    fromTable: string;\n    fromCol: string;\n    idField: string;\n    toTable: string;\n    toCol: string;\n    through?: {\n      table: string;\n      fromCol: string;\n      toCol: string;\n    };\n  };\n  oneJoins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  select: string[];\n  loaders?: SubsetLoader[];\n};\n\nexport type SubsetQuery = {\n  select: string[];\n  virtual: string[];\n  joins: ({\n    as: string;\n    join: \"inner\" | \"outer\";\n    table: string;\n  } & JoinClause)[];\n  loaders: SubsetLoader[];\n};\n\n/* BaseModel */\nexport const SonamuQueryMode = z.enum([\"both\", \"list\", \"count\"]);\nexport type SonamuQueryMode = z.infer<typeof SonamuQueryMode>;\n\n/* Semantic Query */\nexport const SonamuSemanticParams = z.object({\n  semanticQuery: z.object({\n    embedding: z.array(z.number()).min(1024).max(1024),\n    threshold: z.number().optional(),\n    method: z.enum([\"cosine\", \"l2\", \"inner_product\"]).optional(),\n  }),\n});\nexport type SonamuSemanticParams = z.infer<typeof SonamuSemanticParams>;\n\n/* Knex Migration */\nexport type KnexError = {\n  code: string;\n  errno: number;\n  sql: string;\n  sqlMessage: string;\n  sqlState: string;\n};\nexport function isKnexError(e: unknown): e is KnexError {\n  return !!(e as KnexError)?.code && !!(e as KnexError)?.sqlMessage && !!(e as KnexError)?.sqlState;\n}\n\nexport type KnexColumnType =\n  | \"string\"\n  | \"text\"\n  | \"smalltext\"\n  | \"mediumtext\"\n  | \"longtext\"\n  | \"integer\"\n  | \"bigInteger\"\n  | \"decimal\"\n  | \"timestamp\"\n  | \"boolean\"\n  | \"foreign\"\n  | \"uuid\"\n  | \"json\"\n  | \"float\"\n  | \"date\"\n  | \"time\"\n  | \"datetime\";\nexport type MigrationColumnType =\n  | \"string\"\n  | \"string[]\"\n  | \"integer\"\n  | \"integer[]\"\n  | \"bigInteger\"\n  | \"bigInteger[]\"\n  | \"numberOrNumeric\"\n  | \"numberOrNumeric[]\"\n  | \"boolean\"\n  | \"boolean[]\"\n  | \"date\"\n  | \"date[]\"\n  | \"uuid\"\n  | \"uuid[]\"\n  | \"json\"\n  | \"vector\"\n  | \"vector[]\"\n  | \"tsvector\";\nexport type MigrationColumn = {\n  name: string;\n  type: MigrationColumnType;\n  nullable: boolean;\n  numberType?: \"real\" | \"double precision\" | \"numeric\";\n  length?: number;\n  defaultTo?: string;\n  precision?: number;\n  scale?: number;\n  dimensions?: number;\n  generated?: GeneratedColumn;\n};\nexport type MigrationIndex = {\n  type: \"unique\" | \"index\" | \"hnsw\" | \"ivfflat\";\n  columns: EntityIndexColumn[];\n  name: string;\n  using?: \"btree\" | \"hash\" | \"gin\" | \"gist\" | \"pgroonga\";\n  nullsNotDistinct?: boolean;\n  /** HNSW (Hierarchical Navigable Small World): 각 노드의 최대 연결 수 */\n  m?: number;\n  /** HNSW (Hierarchical Navigable Small World): 구성 시 탐색 범위 */\n  efConstruction?: number;\n  /** IVFFlat (Inverted File with Flat Compression): 클러스터링 리스트 수 */\n  lists?: number;\n};\nexport type MigrationForeign = {\n  columns: string[];\n  to: string;\n  onUpdate: RelationOn;\n  onDelete: RelationOn;\n};\nexport type MigrationJoinTable = {\n  table: string;\n  indexes: MigrationIndex[];\n  columns: MigrationColumn[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSet = {\n  table: string;\n  columns: MigrationColumn[];\n  indexes: MigrationIndex[];\n  foreigns: MigrationForeign[];\n};\nexport type MigrationSetAndJoinTable = MigrationSet & {\n  joinTables: MigrationJoinTable[];\n};\nexport type GenMigrationCode = {\n  title: string;\n  table: string;\n  type: \"normal\" | \"foreign\";\n  formatted: string | null;\n};\n\n/* Api */\nexport type ApiParam = {\n  name: string;\n  type: ApiParamType;\n  optional: boolean;\n  defaultDef?: string;\n};\nexport namespace ApiParamType {\n  export type Function = {\n    t: \"function\";\n    parameters: ApiParam[];\n    returnType: ApiParamType;\n  };\n  export type Object = {\n    t: \"object\";\n    props: ApiParam[];\n  };\n  export type Union = {\n    t: \"union\";\n    types: ApiParamType[];\n  };\n  export type Intersection = {\n    t: \"intersection\";\n    types: ApiParamType[];\n  };\n  export type StringLiteral = {\n    t: \"string-literal\";\n    value: string;\n  };\n  export type NumericLiteral = {\n    t: \"numeric-literal\";\n    value: number;\n  };\n  export type Array = {\n    t: \"array\";\n    elementsType: ApiParamType;\n  };\n  export type Ref = {\n    t: \"ref\";\n    id: string;\n    args?: ApiParamType[];\n  };\n  export type IndexedAccess = {\n    t: \"indexed-access\";\n    object: ApiParamType;\n    index: ApiParamType;\n  };\n  export type TupleType = {\n    t: \"tuple-type\";\n    elements: ApiParamType[];\n  };\n  export type Pick = Ref & {\n    t: \"ref\";\n    id: \"Pick\";\n  };\n  export type Omit = Ref & {\n    t: \"ref\";\n    id: \"Omit\";\n  };\n  export type Partial = Ref & {\n    t: \"ref\";\n    id: \"Partial\";\n  };\n  export type Promise = Ref & {\n    t: \"ref\";\n    id: \"Promise\";\n  };\n  export type Context = Ref & {\n    t: \"ref\";\n    id: \"Context\";\n  };\n  export type TypeParam = {\n    t: \"type-param\";\n    id: string;\n    constraint?: ApiParamType;\n  };\n\n  export function isObject(v: unknown): v is ApiParamType.Object {\n    return (v as ApiParamType.Object)?.t === \"object\";\n  }\n  export function isUnion(v: unknown): v is ApiParamType.Union {\n    return (v as ApiParamType.Union)?.t === \"union\";\n  }\n  export function isIntersection(v: unknown): v is ApiParamType.Intersection {\n    return (v as ApiParamType.Intersection)?.t === \"intersection\";\n  }\n  export function isStringLiteral(v: unknown): v is ApiParamType.StringLiteral {\n    return (v as ApiParamType.StringLiteral)?.t === \"string-literal\";\n  }\n  export function isNumericLiteral(v: unknown): v is ApiParamType.NumericLiteral {\n    return (v as ApiParamType.NumericLiteral)?.t === \"numeric-literal\";\n  }\n  export function isArray(v: unknown): v is ApiParamType.Array {\n    return (v as ApiParamType.Array)?.t === \"array\";\n  }\n  export function isRef(v: unknown): v is ApiParamType.Ref {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"ref\";\n  }\n  export function isIndexedAccess(v: unknown): v is ApiParamType.IndexedAccess {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"indexed-access\";\n  }\n  export function isTupleType(v: unknown): v is ApiParamType.TupleType {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"tuple-type\";\n  }\n  export function isPick(v: unknown): v is ApiParamType.Pick {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Pick\"\n    );\n  }\n  export function isOmit(v: unknown): v is ApiParamType.Omit {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Omit\"\n    );\n  }\n  export function isPartial(v: unknown): v is ApiParamType.Partial {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Partial\"\n    );\n  }\n  export function isPromise(v: unknown): v is ApiParamType.Promise {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Promise\"\n    );\n  }\n  export function isContext(v: unknown): v is ApiParamType.Context {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Context\"\n    );\n  }\n  export function isRefKnex(v: unknown): v is ApiParamType.Ref {\n    return (\n      typeof v === \"object\" &&\n      v !== null &&\n      (v as { t?: unknown }).t === \"ref\" &&\n      (v as { id?: unknown }).id === \"Knex\"\n    );\n  }\n  export function isTypeParam(v: unknown): v is ApiParamType.TypeParam {\n    return typeof v === \"object\" && v !== null && (v as { t?: unknown }).t === \"type-param\";\n  }\n}\nexport type ApiParamType =\n  | \"string\"\n  | \"number\"\n  | \"boolean\"\n  | \"null\"\n  | \"undefined\"\n  | \"void\"\n  | \"any\"\n  | \"unknown\"\n  | \"true\"\n  | \"false\"\n  | ApiParamType.StringLiteral\n  | ApiParamType.NumericLiteral\n  | ApiParamType.Object\n  | ApiParamType.Union\n  | ApiParamType.Intersection\n  | ApiParamType.Array\n  | ApiParamType.Ref\n  | ApiParamType.IndexedAccess\n  | ApiParamType.TypeParam\n  | ApiParamType.TupleType\n  | ApiParamType.Function;\n\n/* Template */\n/**\n * UI 컴포넌트 렌더링을 위한 메타데이터 노드입니다.\n *\n * **목적**: Zod 스키마로부터 프론트엔드 UI 컴포넌트를 자동 생성하기 위한\n * 렌더링 정보를 담은 트리 구조입니다. 각 필드가 어떤 UI 컴포넌트로\n * 표현되어야 하는지(텍스트, 이미지, 날짜, Enum 선택 등)를 명시합니다.\n *\n * **변환 흐름**:\n * Entity subset → EntityPropNode → Zod 스키마 → RenderingNode (UI용) → React 컴포넌트 코드 생성\n *\n * **주요 필드**:\n * - `renderType`: UI 컴포넌트 유형 (string-plain, number-fk_id, enums, array 등)\n * - `zodType`: 원본 Zod 스키마 (validation 용)\n * - `children`: 중첩된 객체 필드들 (object일 때)\n * - `element`: 배열 요소 타입 (array일 때)\n *\n * **사용 위치**:\n * - zod-converter.ts의 zodTypeToRenderingNode()에서 생성\n * - view_form.template.ts, view_list.template.ts 등에서 React 컴포넌트 코드 생성에 사용\n */\n// 셀프 참조 타입이므로 Zod 생략하고 직접 정의\nexport const RenderingNode = z.any();\nexport type RenderingNode = {\n  name: string;\n  label: string;\n  renderType:\n    | \"string-plain\"\n    | \"string-image\"\n    | \"string-datetime\"\n    | \"string-date\"\n    | \"string-id\"\n    | \"string-fk_id\"\n    | \"datetime\"\n    | \"number-plain\"\n    | \"number-id\"\n    | \"number-fk_id\"\n    | \"boolean\"\n    | \"enums\"\n    | \"array\"\n    | \"array-images\"\n    | \"json-sonamufile\"\n    | \"json-sonamufile-array\"\n    | \"object\"\n    | \"object-pick\"\n    | \"record\"\n    | \"vector\";\n  zodType: z.ZodTypeAny;\n  element?: RenderingNode;\n  children?: RenderingNode[];\n  config?: {\n    picked: string;\n  };\n  optional?: boolean;\n  nullable?: boolean;\n};\n\nconst GeneratedColumnSchema = z.object({\n  type: z.enum([\"STORED\", \"VIRTUAL\"]),\n  expression: z.string(),\n});\n\nconst FixtureCompanionSchema = z.object({\n  entity: z.string(),\n  overrides: z.record(z.string(), z.unknown()).optional(),\n  count: z.number().int().positive().optional(),\n});\n\n/**\n * Cone 스키마 검증\n *\n * cone 메타데이터의 유효성을 검증합니다.\n */\nconst ConeSchema = z\n  .object({\n    note: z.string().optional(),\n    tags: z.array(z.string()).optional(),\n    fixtureGenerator: z.string().optional(),\n    fixtureDefault: z.unknown().optional(),\n    fixtureStrategy: z.literal(\"sequence\").optional(),\n    fixtureCompanions: z.array(FixtureCompanionSchema).optional(),\n    dataSource: z\n      .object({\n        strategy: z.enum([\"sample\", \"ids\", \"query\", \"file\", \"recent\", \"random\"]),\n        config: z.unknown().optional(),\n      })\n      .optional(),\n  })\n  .catchall(z.unknown()); // 사용자 정의 메타데이터 허용\n\nconst BasePropFields = {\n  name: z.string(),\n  desc: z.string().optional(),\n  nullable: z.boolean().optional(),\n  toFilter: z.boolean().default(false).optional(),\n  dbDefault: z.union([z.string(), z.number(), z.boolean()]).optional(),\n  generated: GeneratedColumnSchema.optional(),\n  cone: ConeSchema.optional(),\n};\n\n// 부가 필드가 필요없는 prop\nconst BasePropFieldsWithoutAdditional = z\n  .object({\n    ...BasePropFields,\n    type: z.union([\n      z.literal(\"integer\"),\n      z.literal(\"integer[]\"),\n      z.literal(\"bigInteger\"),\n      z.literal(\"bigInteger[]\"),\n      z.literal(\"boolean\"),\n      z.literal(\"boolean[]\"),\n      z.literal(\"uuid\"),\n      z.literal(\"uuid[]\"),\n      z.literal(\"tsvector\"),\n    ]),\n  })\n  .strict();\n\n// precision/scale 필드\nconst PrecisionScaleFields = {\n  precision: z.number().optional(),\n  scale: z.number().optional(),\n};\n\n// 각 타입별 스키마 정의\n\nconst StringPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string\"),\n    length: z.number().optional(),\n    zodFormat: ZodStringFormat.optional(),\n  })\n  .strict();\nconst StringArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"string[]\"),\n    length: z.number().optional(),\n    zodFormat: ZodStringFormat.optional(),\n  })\n  .strict();\n\nconst EnumPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum\"),\n    id: z.string(),\n    length: z.number().optional(),\n  })\n  .strict();\nconst EnumArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"enum[]\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst NumberPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\nconst NumberArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"number[]\"),\n    ...PrecisionScaleFields,\n    numberType: z.enum([\"real\", \"double precision\", \"numeric\"]).optional(),\n  })\n  .strict();\n\nconst DatePropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"date\"),\n    precision: z.number().optional(),\n  })\n  .strict();\nconst DateArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"date[]\"),\n    precision: z.number().optional(),\n  })\n  .strict();\n\nconst NumericPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\nconst NumericArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"numeric[]\"),\n    ...PrecisionScaleFields,\n  })\n  .strict();\n\nconst JsonPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"json\"),\n    id: z.string(),\n  })\n  .strict();\n\nconst SearchTextSourceColumnSchema = z\n  .object({\n    name: z.string(),\n    caseInsensitive: z.boolean().optional(),\n  })\n  .strict();\n\nconst SearchTextPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"searchText\"),\n    sourceColumns: z.array(SearchTextSourceColumnSchema).min(1),\n  })\n  .strict();\n\nconst VirtualPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"virtual\"),\n    id: z.string(),\n    virtualType: z.enum([\"query\", \"code\"]).optional(),\n  })\n  .strict();\n\nconst VectorPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector\"),\n    dimensions: z.number(),\n  })\n  .strict();\nconst VectorArrayPropSchema = z\n  .object({\n    ...BasePropFields,\n    type: z.literal(\"vector[]\"),\n    dimensions: z.number(),\n  })\n  .strict();\n\n// Relation 타입은 relationType에 따라 세분화\nconst BaseRelationFields = {\n  ...BasePropFields,\n  type: z.literal(\"relation\"),\n  with: z.string(),\n};\n\n// RelationOn 타입\nconst RelationOnSchema = z.enum([\"CASCADE\", \"SET NULL\", \"NO ACTION\", \"SET DEFAULT\", \"RESTRICT\"]);\n\nconst BelongsToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"BelongsToOne\"),\n    customJoinClause: z.string().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst HasManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"HasMany\"),\n    joinColumn: z.string(),\n    fromColumn: z.string().optional(),\n  })\n  .strict();\n\nconst ManyToManyRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"ManyToMany\"),\n    joinTable: z.string(),\n    onUpdate: RelationOnSchema,\n    onDelete: RelationOnSchema,\n  })\n  .strict();\n\nconst OneToOneRelationPropSchema = z\n  .object({\n    ...BaseRelationFields,\n    relationType: z.literal(\"OneToOne\"),\n    customJoinClause: z.string().optional(),\n    hasJoinColumn: z.boolean().optional(),\n    useConstraint: z.boolean().optional(),\n    onUpdate: RelationOnSchema.optional(),\n    onDelete: RelationOnSchema.optional(),\n  })\n  .strict();\n\nconst RelationTypes = [\"BelongsToOne\", \"HasMany\", \"ManyToMany\", \"OneToOne\"] as const;\nexport const RelationPropSchema = z.discriminatedUnion(\n  \"relationType\",\n  [\n    BelongsToOneRelationPropSchema,\n    HasManyRelationPropSchema,\n    ManyToManyRelationPropSchema,\n    OneToOneRelationPropSchema,\n  ],\n  {\n    error: (iss) =>\n      `relationType은 ${RelationTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.relationType}\"`,\n  },\n);\n\nconst NormalPropTypes = [\n  \"integer\",\n  \"integer[]\",\n  \"bigInteger\",\n  \"bigInteger[]\",\n  \"string\",\n  \"string[]\",\n  \"enum\",\n  \"enum[]\",\n  \"number\",\n  \"number[]\",\n  \"numeric\",\n  \"numeric[]\",\n  \"boolean\",\n  \"boolean[]\",\n  \"date\",\n  \"date[]\",\n  \"uuid\",\n  \"uuid[]\",\n  \"json\",\n  \"searchText\",\n  \"virtual\",\n  \"vector\",\n  \"vector[]\",\n  \"tsvector\",\n] as const;\n\n// VIRTUAL Generated Column에서 사용 불가능한 타입들\nconst VirtualGeneratedDisallowedTypes = [\n  \"json\",\n  \"vector\",\n  \"vector[]\",\n  \"string[]\",\n  \"integer[]\",\n  \"bigInteger[]\",\n  \"boolean[]\",\n  \"date[]\",\n  \"uuid[]\",\n  \"number[]\",\n  \"numeric[]\",\n  \"enum[]\",\n] as const;\n\nexport const NormalPropSchema = z\n  .discriminatedUnion(\n    \"type\",\n    [\n      BasePropFieldsWithoutAdditional,\n      StringPropSchema,\n      StringArrayPropSchema,\n      EnumPropSchema,\n      EnumArrayPropSchema,\n      NumberPropSchema,\n      NumberArrayPropSchema,\n      DatePropSchema,\n      DateArrayPropSchema,\n      NumericPropSchema,\n      NumericArrayPropSchema,\n      JsonPropSchema,\n      SearchTextPropSchema,\n      VirtualPropSchema,\n      VectorPropSchema,\n      VectorArrayPropSchema,\n    ],\n    {\n      error: (iss) =>\n        `type은 ${NormalPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n    },\n  )\n  .superRefine((data, ctx) => {\n    if (!data.generated) {\n      return;\n    }\n\n    // dbDefault와 generated 동시 사용 불가\n    if (data.dbDefault !== undefined) {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"dbDefault와 generated는 함께 사용할 수 없습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // virtual 타입은 generated 불가\n    if (data.type === \"virtual\") {\n      ctx.addIssue({\n        code: \"custom\",\n        message: \"virtual 타입은 generated column을 지원하지 않습니다\",\n        path: [\"generated\"],\n      });\n    }\n\n    // VIRTUAL Generated Column 타입 제한 검증\n    if (data.generated.type === \"VIRTUAL\") {\n      if ((VirtualGeneratedDisallowedTypes as readonly string[]).includes(data.type)) {\n        ctx.addIssue({\n          code: \"custom\",\n          message: `VIRTUAL generated column은 ${data.type} 타입을 지원하지 않습니다. STORED를 사용하세요.`,\n          path: [\"generated\", \"type\"],\n          fatal: true,\n        });\n      }\n    }\n  });\n\nconst AllPropTypes = [...NormalPropTypes, \"relation\"] as const;\nconst EntityPropSchema = z.discriminatedUnion(\"type\", [NormalPropSchema, RelationPropSchema], {\n  error: (iss) =>\n    `type은 ${AllPropTypes.map((t) => `'${t}'`).join(\", \")} 중 하나여야 합니다. 입력값: \"${(iss.input as Record<string, unknown>)?.type}\"`,\n});\n\nconst EntityIndexColumnSchema = z.object({\n  name: z.string(),\n  nullsFirst: z.boolean().optional(),\n  sortOrder: z.enum([\"ASC\", \"DESC\"]).optional(),\n  vectorOps: z.enum([\"vector_cosine_ops\", \"vector_ip_ops\", \"vector_l2_ops\"]).optional(),\n  opclass: z.union([z.enum(KnownOpclassValues), z.string().min(1)]).optional(),\n});\n\n// EntityIndex 스키마 정의\nconst EntityIndexSchema = z\n  .object({\n    type: z.enum([\"index\", \"unique\", \"hnsw\", \"ivfflat\"]),\n    columns: z.array(EntityIndexColumnSchema),\n    name: z.string().min(1).max(63),\n    using: z.enum([\"btree\", \"hash\", \"gin\", \"gist\", \"pgroonga\"]).optional(),\n    nullsNotDistinct: z.boolean().optional(),\n    m: z.number().optional(),\n    efConstruction: z.number().optional(),\n    lists: z.number().optional(),\n  })\n  .strict();\n\n/**\n * SubsetDef 스키마\n *\n * 하위 호환성을 위해 배열 형태와 객체 형태 둘 다 지원합니다.\n */\nconst SubsetDefSchema = z.union([\n  // 기존 배열 형태\n  z.array(z.union([z.string(), z.object({ field: z.string(), internal: z.boolean().optional() })])),\n  // 새로운 객체 형태\n  z.object({\n    fields: z.array(\n      z.union([z.string(), z.object({ field: z.string(), internal: z.boolean().optional() })]),\n    ),\n    cone: ConeSchema.optional(),\n  }),\n]);\n\n/**\n * EnumDef 스키마\n *\n * 하위 호환성을 위해 Record 형태와 객체 형태 둘 다 지원합니다.\n */\nconst EnumDefSchema = z.union([\n  // 기존 Record 형태\n  z.record(z.string(), z.string()),\n  // 새로운 객체 형태\n  z.object({\n    values: z.record(z.string(), z.string()),\n    cone: ConeSchema.optional(),\n  }),\n]);\n\nfunction unwrapSearchTextJsonSourceType(zodType: z.ZodTypeAny): z.ZodTypeAny {\n  let current = zodType;\n\n  while (current instanceof z.ZodOptional || current instanceof z.ZodNullable) {\n    current = current.unwrap() as z.ZodTypeAny;\n  }\n\n  return current;\n}\n\nexport function isSearchTextJsonSourceZodType(zodType: z.ZodTypeAny): boolean {\n  const baseType = unwrapSearchTextJsonSourceType(zodType);\n  if (!(baseType instanceof z.ZodArray)) {\n    return false;\n  }\n\n  const elementType = baseType.def.element;\n  return elementType instanceof z.ZodString;\n}\n\nfunction validateSearchTextSources(\n  props: readonly z.infer<typeof EntityPropSchema>[],\n  ctx: z.RefinementCtx,\n  propsPath: (string | number)[] = [\"props\"],\n): void {\n  const propsByName = new Map(\n    props.map((prop) => {\n      return [prop.name, prop];\n    }),\n  );\n\n  props.forEach((prop, propIndex) => {\n    if (prop.type !== \"searchText\") {\n      return;\n    }\n\n    prop.sourceColumns.forEach((source, sourceIndex) => {\n      const sourceProp = propsByName.get(source.name);\n      const sourcePath = [...propsPath, propIndex, \"sourceColumns\", sourceIndex, \"name\"];\n\n      if (!sourceProp) {\n        ctx.addIssue({\n          code: \"custom\",\n          message: `searchText source column \"${source.name}\"을(를) 찾을 수 없습니다.`,\n          path: sourcePath,\n        });\n        return;\n      }\n\n      if (sourceProp.type === \"string\" || sourceProp.type === \"string[]\") {\n        return;\n      }\n\n      if (sourceProp.type === \"json\") {\n        // json source의 최종 타입 유효성은 EntityManager.register() 단계에서\n        // 실제 Zod 타입을 해석하여 구조적으로 검증합니다.\n        return;\n      }\n\n      ctx.addIssue({\n        code: \"custom\",\n        message: `searchText source column \"${source.name}\"의 타입 \"${sourceProp.type}\"은(는) 지원되지 않습니다.`,\n        path: sourcePath,\n      });\n    });\n  });\n}\n\nconst EntityJsonBaseSchema = z\n  .object({\n    id: z.string().describe(\"PascalCase로 된 Entity ID\"),\n    title: z.string().describe(\"Entity 이름\"),\n    table: z.string().describe(\"snake_case로 된 테이블명\"),\n    parentId: z.string().optional().describe(\"부모 Entity ID\"),\n    cone: ConeSchema.optional(),\n    props: z.array(EntityPropSchema),\n    indexes: z.array(EntityIndexSchema),\n    subsets: z.record(z.string(), SubsetDefSchema),\n    enums: z.record(z.string(), EnumDefSchema),\n  })\n  .strict();\n\nexport const EntityJsonSchema = EntityJsonBaseSchema.superRefine((entity, ctx) => {\n  validateSearchTextSources(entity.props, ctx);\n});\n\nconst TemplateEntitySchema = EntityJsonBaseSchema.omit({ id: true })\n  .extend({\n    entityId: z.string(),\n  })\n  .partial({\n    table: true,\n    props: true,\n    indexes: true,\n    subsets: true,\n    enums: true,\n  })\n  .superRefine((entity, ctx) => {\n    if (!entity.props) {\n      return;\n    }\n\n    validateSearchTextSources(entity.props, ctx);\n  });\n\nexport const TemplateOptions = z.object({\n  entity: TemplateEntitySchema,\n  init_types: z.object({\n    entityId: z.string(),\n  }),\n  generated: z.object({}),\n  generated_sso: z.object({}),\n  generated_http: z.object({\n    entityId: z.string(),\n  }),\n  model: z.object({\n    entityId: z.string(),\n    defaultSearchField: z.string().optional(),\n    defaultOrderBy: z.string().optional(),\n  }),\n  model_test: z.object({\n    entityId: z.string(),\n  }),\n  bridge: z.object({\n    entityId: z.string(),\n  }),\n  services: z.object({}),\n  view_list: z.object({\n    entityId: z.string(),\n    extra: z.unknown(),\n  }),\n  view_list_columns: z.object({\n    entityId: z.string(),\n    columns: z\n      .object({\n        name: z.string(),\n        label: z.string(),\n        tc: z.string(),\n      })\n      .array(),\n    columnImports: z.string(),\n  }),\n  view_search_input: z.object({\n    entityId: z.string(),\n  }),\n  view_form: z.object({\n    entityId: z.string(),\n  }),\n  view_id_all_select: z.object({\n    entityId: z.string(),\n  }),\n  view_enums_buttonset: z.object({\n    entityId: z.string(),\n    enumId: z.string(),\n  }),\n  queries: z.object({}),\n  entry_server: z.object({}),\n  sd: z.object({\n    target: z.enum([\"api\", \"web\", \"app\"]),\n  }),\n});\nexport type TemplateOptions = z.infer<typeof TemplateOptions>;\n\nexport const TemplateKey = z.enum([\n  \"entity\",\n  \"init_types\",\n  \"generated\",\n  \"generated_sso\",\n  \"generated_http\",\n  \"model\",\n  \"model_test\",\n  \"bridge\",\n  \"services\",\n  \"view_list\",\n  \"view_list_columns\",\n  \"view_search_input\",\n  \"view_form\",\n  \"view_id_all_select\",\n  \"view_enums_buttonset\",\n  \"queries\",\n  \"entry_server\",\n  \"sd\",\n]);\nexport type TemplateKey = z.infer<typeof TemplateKey>;\n\nexport const GenerateOptions = z.object({\n  overwrite: z.boolean().optional(),\n});\nexport type GenerateOptions = z.infer<typeof GenerateOptions>;\n\nexport const PathAndCode = z.object({\n  path: z.string(),\n  code: z.string(),\n});\nexport type PathAndCode = z.infer<typeof PathAndCode>;\n\nexport type FixtureSearchOptions = {\n  entityId: string;\n  field: string;\n  value: string;\n  searchType: \"equals\" | \"like\";\n};\n\ntype ColumnValue = string | number | boolean | Date | null;\nexport type FixtureRecord = {\n  fixtureId: string;\n  entityId: string;\n  id: number | string;\n  columns: {\n    [key: string]: {\n      prop: EntityProp;\n      value: ColumnValue | ColumnValue[];\n    };\n  };\n  fetchedRecords: string[];\n  belongsRecords: string[];\n  target?: FixtureRecord; // Import 대상 DB 레코드(id가 같은)\n  unique?: FixtureRecord; // Import 대상 DB 레코드(unique key가 같은)\n  override?: boolean;\n};\n\nexport type FixtureImportResult = {\n  entityId: string;\n  data: {\n    [key: string]: ColumnValue;\n  };\n};\n\nexport type RelationNode = {\n  fixtureId: string;\n  entityId: string;\n  related: Set<string>;\n};\n\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseSchemaExtend {}\n// biome-ignore lint/suspicious/noEmptyInterface: sonamu.generated.sso 에서 확장을 위해 준비된 빈 인터페이스\nexport interface DatabaseForeignKeys {}\nexport type ManyToManyBaseSchema<\n  FromIdKey extends string,\n  ToIdKey extends string,\n  FromPkType = number,\n  ToPkType = number,\n> = {\n  id: number;\n} & {\n  [K in `${FromIdKey}_id`]: FromPkType;\n} & {\n  [K in `${ToIdKey}_id`]: ToPkType;\n};\n\n// 객체, 함수, 비동기 함수를 모두 포괄하는 타입\nexport type Executable<T> = T | Promise<T> | (() => T) | (() => Promise<T>);\n\nexport type SonamuFastifyConfig = {\n  contextProvider: (\n    defaultContext: Pick<\n      Context,\n      \"request\" | \"reply\" | \"headers\" | \"createSSE\" | \"naiteStore\" | \"locale\" | \"user\" | \"session\"\n    >,\n    request: FastifyRequest,\n    reply: FastifyReply,\n  ) => Context | Promise<Context>;\n  guardHandler: (\n    guard: GuardKey,\n    request: FastifyRequest,\n    api: {\n      typeParameters: ApiParamType.TypeParam[];\n      parameters: ApiParam[];\n      returnType: ApiParamType;\n      modelName: string;\n      methodName: string;\n      path: string;\n      options: ApiDecoratorOptions;\n    },\n  ) => void;\n  /**\n   * 전역 Cache-Control 핸들러입니다.\n   * 요청 타입(api, assets, ssr, csr)에 따라 Cache-Control 설정을 반환합니다.\n   * undefined를 반환하면 타입별 기본값이 적용됩니다.\n   */\n  cacheControlHandler?: CacheControlHandler;\n};\n"],"names":["z","zArrayable","shape","union","array","getDescription","item","cone","note","desc","ZodStringFormat","enum","SonamuFileSchema","object","name","string","url","mime_type","size","number","describe","SonamuFileArraySchema","BUILT_IN_TYPE_IDS","KnownOpclassValues","normalizeSubsetField","f","field","isInternalSubsetField","internal","isSubsetDefWithCone","def","Array","isArray","isEnumDefWithCone","undefined","Object","keys","length","getSubsetFields","fields","getEnumDefValues","values","isIntegerSingleProp","p","type","isIntegerArrayProp","isIntegerProp","isBigIntegerSingleProp","isBigIntegerArrayProp","isBigIntegerProp","isStringSingleProp","isStringArrayProp","isStringProp","isEnumSingleProp","isEnumArrayProp","isEnumProp","isNumberSingleProp","isNumberArrayProp","isNumberProp","isNumericSingleProp","isNumericArrayProp","isNumericProp","isBooleanSingleProp","isBooleanArrayProp","isBooleanProp","isDateSingleProp","isDateArrayProp","isDateProp","isUuidSingleProp","isUuidArrayProp","isUuidProp","isJsonProp","isSearchTextProp","isVirtualProp","isVirtualCodeProp","virtualType","isVirtualQueryProp","isVectorSingleProp","isVectorArrayProp","isVectorProp","isTsVectorProp","isRelationProp","isOneToOneRelationProp","relationType","isBelongsToOneRelationProp","isHasManyRelationProp","isManyToManyRelationProp","isCustomJoinClause","custom","SonamuQueryMode","SonamuSemanticParams","semanticQuery","embedding","min","max","threshold","optional","method","isKnexError","e","code","sqlMessage","sqlState","ApiParamType","isObject","v","t","isUnion","isIntersection","isStringLiteral","isNumericLiteral","isRef","isIndexedAccess","isTupleType","isPick","id","isOmit","isPartial","isPromise","isContext","isRefKnex","isTypeParam","RenderingNode","any","GeneratedColumnSchema","expression","FixtureCompanionSchema","entity","overrides","record","unknown","count","int","positive","ConeSchema","tags","fixtureGenerator","fixtureDefault","fixtureStrategy","literal","fixtureCompanions","dataSource","strategy","config","catchall","BasePropFields","nullable","boolean","toFilter","default","dbDefault","generated","BasePropFieldsWithoutAdditional","strict","PrecisionScaleFields","precision","scale","StringPropSchema","zodFormat","StringArrayPropSchema","EnumPropSchema","EnumArrayPropSchema","NumberPropSchema","numberType","NumberArrayPropSchema","DatePropSchema","DateArrayPropSchema","NumericPropSchema","NumericArrayPropSchema","JsonPropSchema","SearchTextSourceColumnSchema","caseInsensitive","SearchTextPropSchema","sourceColumns","VirtualPropSchema","VectorPropSchema","dimensions","VectorArrayPropSchema","BaseRelationFields","with","RelationOnSchema","BelongsToOneRelationPropSchema","customJoinClause","useConstraint","onUpdate","onDelete","HasManyRelationPropSchema","joinColumn","fromColumn","ManyToManyRelationPropSchema","joinTable","OneToOneRelationPropSchema","hasJoinColumn","RelationTypes","RelationPropSchema","discriminatedUnion","error","iss","map","join","input","NormalPropTypes","VirtualGeneratedDisallowedTypes","NormalPropSchema","superRefine","data","ctx","addIssue","message","path","includes","fatal","AllPropTypes","EntityPropSchema","EntityIndexColumnSchema","nullsFirst","sortOrder","vectorOps","opclass","EntityIndexSchema","columns","using","nullsNotDistinct","m","efConstruction","lists","SubsetDefSchema","EnumDefSchema","unwrapSearchTextJsonSourceType","zodType","current","ZodOptional","ZodNullable","unwrap","isSearchTextJsonSourceZodType","baseType","ZodArray","elementType","element","ZodString","validateSearchTextSources","props","propsPath","propsByName","Map","prop","forEach","propIndex","source","sourceIndex","sourceProp","get","sourcePath","EntityJsonBaseSchema","title","table","parentId","indexes","subsets","enums","EntityJsonSchema","TemplateEntitySchema","omit","extend","entityId","partial","TemplateOptions","init_types","generated_sso","generated_http","model","defaultSearchField","defaultOrderBy","model_test","bridge","services","view_list","extra","view_list_columns","label","tc","columnImports","view_search_input","view_form","view_id_all_select","view_enums_buttonset","enumId","queries","entry_server","sd","target","TemplateKey","GenerateOptions","overwrite","PathAndCode"],"mappings":"AACA,SAASA,CAAC,QAAQ,MAAM;AAKxB;;AAEA,GACA,OAAO,SAASC,WAAmCC,KAAQ;IACzD,OAAOF,EAAEG,KAAK,CAAC;QAACD;QAAOA,MAAME,KAAK;KAAG;AACvC;AAwEA;;;;CAIC,GACD,OAAO,SAASC,eAAeC,IAAoC;IACjE,OAAOA,KAAKC,IAAI,EAAEC,QAAQF,KAAKG,IAAI;AACrC;AAcA;;;;CAIC,GACD,OAAO,MAAMC,kBAAkBV,EAAEW,IAAI,CAAC;IACpC,QAAQ;IACR;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA,kBAAkB;IAClB;IACA;IACA;IACA;IACA;IACA,SAAS;IACT;IACA;IACA;IACA;CACD,EAAE;AAwLH,OAAO,MAAMC,mBAAmBZ,EAC7Ba,MAAM,CAAC;IACNC,MAAMd,EAAEe,MAAM;IACdC,KAAKhB,EAAEe,MAAM;IACbE,WAAWjB,EAAEe,MAAM;IACnBG,MAAMlB,EAAEmB,MAAM;AAChB,GACCC,QAAQ,CAAC,cAAc;AAE1B,OAAO,MAAMC,wBAAwBrB,EAAEI,KAAK,CAACQ,kBAAkBQ,QAAQ,CAAC,gBAAgB;AAExF;;;CAGC,GACD,OAAO,MAAME,oBAAoB;IAAC;IAAc;CAAe,CAAU;AA4BzE,OAAO,MAAMC,qBAAqB;IAChC;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD,CAAU;AAyDX,OAAO,SAASC,qBAAqBC,CAAc;IACjD,OAAO,OAAOA,MAAM,WAAWA,IAAIA,EAAEC,KAAK;AAC5C;AACA,OAAO,SAASC,sBAAsBF,CAAc;IAClD,OAAO,OAAOA,MAAM,YAAYA,EAAEG,QAAQ,KAAK;AACjD;AA4BA;;CAEC,GACD,OAAO,SAASC,oBAAoBC,GAAc;IAChD,OAAO,CAACC,MAAMC,OAAO,CAACF,QAAQ,YAAYA;AAC5C;AAEA;;CAEC,GACD,OAAO,SAASG,kBACdH,GAAY;IAEZ,OACE,YAAYA,OAAO,CAAE,CAAA,UAAUA,OAAOA,IAAIvB,IAAI,KAAK2B,aAAaC,OAAOC,IAAI,CAACN,KAAKO,MAAM,GAAG,CAAA;AAE9F;AAEA;;CAEC,GACD,OAAO,SAASC,gBAAgBR,GAAc;IAC5C,OAAOC,MAAMC,OAAO,CAACF,OAAOA,MAAMA,IAAIS,MAAM;AAC9C;AAEA;;CAEC,GACD,OAAO,SAASC,iBAAiBV,GAAY;IAC3C,OAAOG,kBAAkBH,OAAOA,IAAIW,MAAM,GAAGX;AAC/C;AA+DA;;AAEA,GACA,OAAO,SAASY,oBAAoBC,CAAU;IAC5C,OAAO,AAACA,GAAmBC,SAAS;AACtC;AACA,OAAO,SAASC,mBAAmBF,CAAU;IAC3C,OAAO,AAACA,GAAwBC,SAAS;AAC3C;AACA,OAAO,SAASE,cAAcH,CAAU;IACtC,OAAOD,oBAAoBC,MAAME,mBAAmBF;AACtD;AACA,OAAO,SAASI,uBAAuBJ,CAAU;IAC/C,OAAO,AAACA,GAAsBC,SAAS;AACzC;AACA,OAAO,SAASI,sBAAsBL,CAAU;IAC9C,OAAO,AAACA,GAA2BC,SAAS;AAC9C;AACA,OAAO,SAASK,iBAAiBN,CAAU;IACzC,OAAOI,uBAAuBJ,MAAMK,sBAAsBL;AAC5D;AACA,OAAO,SAASO,mBAAmBP,CAAU;IAC3C,OAAO,AAACA,GAAkBC,SAAS;AACrC;AACA,OAAO,SAASO,kBAAkBR,CAAU;IAC1C,OAAO,AAACA,GAAuBC,SAAS;AAC1C;AACA,OAAO,SAASQ,aAAaT,CAAU;IACrC,OAAOO,mBAAmBP,MAAMQ,kBAAkBR;AACpD;AACA,OAAO,SAASU,iBAAiBV,CAAU;IACzC,OAAO,AAACA,GAAgBC,SAAS;AACnC;AACA,OAAO,SAASU,gBAAgBX,CAAU;IACxC,OAAO,AAACA,GAAqBC,SAAS;AACxC;AACA,OAAO,SAASW,WAAWZ,CAAU;IACnC,OAAOU,iBAAiBV,MAAMW,gBAAgBX;AAChD;AACA,OAAO,SAASa,mBAAmBb,CAAU;IAC3C,OAAO,AAACA,GAAkBC,SAAS;AACrC;AACA,OAAO,SAASa,kBAAkBd,CAAU;IAC1C,OAAO,AAACA,GAAuBC,SAAS;AAC1C;AACA,OAAO,SAASc,aAAaf,CAAU;IACrC,OAAOa,mBAAmBb,MAAMc,kBAAkBd;AACpD;AACA,OAAO,SAASgB,oBAAoBhB,CAAU;IAC5C,OAAO,AAACA,GAAmBC,SAAS;AACtC;AACA,OAAO,SAASgB,mBAAmBjB,CAAU;IAC3C,OAAO,AAACA,GAAwBC,SAAS;AAC3C;AACA,OAAO,SAASiB,cAAclB,CAAU;IACtC,OAAOgB,oBAAoBhB,MAAMiB,mBAAmBjB;AACtD;AACA,OAAO,SAASmB,oBAAoBnB,CAAU;IAC5C,OAAO,AAACA,GAAmBC,SAAS;AACtC;AACA,OAAO,SAASmB,mBAAmBpB,CAAU;IAC3C,OAAO,AAACA,GAAwBC,SAAS;AAC3C;AACA,OAAO,SAASoB,cAAcrB,CAAU;IACtC,OAAOmB,oBAAoBnB,MAAMoB,mBAAmBpB;AACtD;AACA,OAAO,SAASsB,iBAAiBtB,CAAU;IACzC,OAAO,AAACA,GAAgBC,SAAS;AACnC;AACA,OAAO,SAASsB,gBAAgBvB,CAAU;IACxC,OAAO,AAACA,GAAqBC,SAAS;AACxC;AACA,OAAO,SAASuB,WAAWxB,CAAU;IACnC,OAAOsB,iBAAiBtB,MAAMuB,gBAAgBvB;AAChD;AACA,OAAO,SAASyB,iBAAiBzB,CAAU;IACzC,OAAO,AAACA,GAAgBC,SAAS;AACnC;AACA,OAAO,SAASyB,gBAAgB1B,CAAU;IACxC,OAAO,AAACA,GAAqBC,SAAS;AACxC;AACA,OAAO,SAAS0B,WAAW3B,CAAU;IACnC,OAAOyB,iBAAiBzB,MAAM0B,gBAAgB1B;AAChD;AACA,OAAO,SAAS4B,WAAW5B,CAAU;IACnC,OAAO,AAACA,GAAgBC,SAAS;AACnC;AACA,OAAO,SAAS4B,iBAAiB7B,CAAU;IACzC,OAAO,AAACA,GAAsBC,SAAS;AACzC;AACA,OAAO,SAAS6B,cAAc9B,CAAU;IACtC,OAAO,AAACA,GAAmBC,SAAS;AACtC;AACA,OAAO,SAAS8B,kBAAkB/B,CAAU;IAC1C,IAAI,CAAC8B,cAAc9B,IAAI,OAAO;IAC9B,OAAOA,EAAEgC,WAAW,KAAK,SAAS,wBAAwB;AAC5D;AACA,OAAO,SAASC,mBAAmBjC,CAAU;IAC3C,IAAI,CAAC8B,cAAc9B,IAAI,OAAO;IAC9B,OAAOA,EAAEgC,WAAW,KAAK;AAC3B;AACA,OAAO,SAASE,mBAAmBlC,CAAU;IAC3C,OAAO,AAACA,GAAkBC,SAAS;AACrC;AACA,OAAO,SAASkC,kBAAkBnC,CAAU;IAC1C,OAAO,AAACA,GAAuBC,SAAS;AAC1C;AACA,OAAO,SAASmC,aAAapC,CAAU;IACrC,OAAOkC,mBAAmBlC,MAAMmC,kBAAkBnC;AACpD;AACA,OAAO,SAASqC,eAAerC,CAAU;IACvC,OAAO,AAACA,GAAoBC,SAAS;AACvC;AACA,OAAO,SAASqC,eAAetC,CAAU;IACvC,OAAO,AAACA,GAAoBC,SAAS;AACvC;AACA,OAAO,SAASsC,uBAAuBvC,CAAU;IAC/C,OAAO,AAACA,GAA4BwC,iBAAiB;AACvD;AACA,OAAO,SAASC,2BAA2BzC,CAAU;IACnD,OAAO,AAACA,GAAgCwC,iBAAiB;AAC3D;AACA,OAAO,SAASE,sBAAsB1C,CAAU;IAC9C,OAAO,AAACA,GAA2BwC,iBAAiB;AACtD;AACA,OAAO,SAASG,yBAAyB3C,CAAU;IACjD,OAAO,AAACA,GAA8BwC,iBAAiB;AACzD;AAUA,OAAO,SAASI,mBAAmB5C,CAAU;IAC3C,OAAO,CAAC,CAAEA,GAA0B6C;AACtC;AAqCA,aAAa,GACb,OAAO,MAAMC,kBAAkBzF,EAAEW,IAAI,CAAC;IAAC;IAAQ;IAAQ;CAAQ,EAAE;AAGjE,kBAAkB,GAClB,OAAO,MAAM+E,uBAAuB1F,EAAEa,MAAM,CAAC;IAC3C8E,eAAe3F,EAAEa,MAAM,CAAC;QACtB+E,WAAW5F,EAAEI,KAAK,CAACJ,EAAEmB,MAAM,IAAI0E,GAAG,CAAC,MAAMC,GAAG,CAAC;QAC7CC,WAAW/F,EAAEmB,MAAM,GAAG6E,QAAQ;QAC9BC,QAAQjG,EAAEW,IAAI,CAAC;YAAC;YAAU;YAAM;SAAgB,EAAEqF,QAAQ;IAC5D;AACF,GAAG;AAWH,OAAO,SAASE,YAAYC,CAAU;IACpC,OAAO,CAAC,CAAEA,GAAiBC,QAAQ,CAAC,CAAED,GAAiBE,cAAc,CAAC,CAAEF,GAAiBG;AAC3F;UAmGiBC;IAsER,SAASC,SAASC,CAAU;QACjC,OAAO,AAACA,GAA2BC,MAAM;IAC3C;iBAFgBF,WAAAA;IAGT,SAASG,QAAQF,CAAU;QAChC,OAAO,AAACA,GAA0BC,MAAM;IAC1C;iBAFgBC,UAAAA;IAGT,SAASC,eAAeH,CAAU;QACvC,OAAO,AAACA,GAAiCC,MAAM;IACjD;iBAFgBE,iBAAAA;IAGT,SAASC,gBAAgBJ,CAAU;QACxC,OAAO,AAACA,GAAkCC,MAAM;IAClD;iBAFgBG,kBAAAA;IAGT,SAASC,iBAAiBL,CAAU;QACzC,OAAO,AAACA,GAAmCC,MAAM;IACnD;iBAFgBI,mBAAAA;IAGT,SAAS9E,QAAQyE,CAAU;QAChC,OAAO,AAACA,GAA0BC,MAAM;IAC1C;iBAFgB1E,UAAAA;IAGT,SAAS+E,MAAMN,CAAU;QAC9B,OAAO,OAAOA,MAAM,YAAYA,MAAM,QAAQ,AAACA,EAAsBC,CAAC,KAAK;IAC7E;iBAFgBK,QAAAA;IAGT,SAASC,gBAAgBP,CAAU;QACxC,OAAO,OAAOA,MAAM,YAAYA,MAAM,QAAQ,AAACA,EAAsBC,CAAC,KAAK;IAC7E;iBAFgBM,kBAAAA;IAGT,SAASC,YAAYR,CAAU;QACpC,OAAO,OAAOA,MAAM,YAAYA,MAAM,QAAQ,AAACA,EAAsBC,CAAC,KAAK;IAC7E;iBAFgBO,cAAAA;IAGT,SAASC,OAAOT,CAAU;QAC/B,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBD,SAAAA;IAQT,SAASE,OAAOX,CAAU;QAC/B,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBC,SAAAA;IAQT,SAASC,UAAUZ,CAAU;QAClC,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBE,YAAAA;IAQT,SAASC,UAAUb,CAAU;QAClC,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBG,YAAAA;IAQT,SAASC,UAAUd,CAAU;QAClC,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBI,YAAAA;IAQT,SAASC,UAAUf,CAAU;QAClC,OACE,OAAOA,MAAM,YACbA,MAAM,QACN,AAACA,EAAsBC,CAAC,KAAK,SAC7B,AAACD,EAAuBU,EAAE,KAAK;IAEnC;iBAPgBK,YAAAA;IAQT,SAASC,YAAYhB,CAAU;QACpC,OAAO,OAAOA,MAAM,YAAYA,MAAM,QAAQ,AAACA,EAAsBC,CAAC,KAAK;IAC7E;iBAFgBe,cAAAA;AAGlB,GApJiBlB,iBAAAA;AA4KjB,YAAY,GACZ;;;;;;;;;;;;;;;;;;;CAmBC,GACD,6BAA6B;AAC7B,OAAO,MAAMmB,gBAAgB1H,EAAE2H,GAAG,GAAG;AAmCrC,MAAMC,wBAAwB5H,EAAEa,MAAM,CAAC;IACrC+B,MAAM5C,EAAEW,IAAI,CAAC;QAAC;QAAU;KAAU;IAClCkH,YAAY7H,EAAEe,MAAM;AACtB;AAEA,MAAM+G,yBAAyB9H,EAAEa,MAAM,CAAC;IACtCkH,QAAQ/H,EAAEe,MAAM;IAChBiH,WAAWhI,EAAEiI,MAAM,CAACjI,EAAEe,MAAM,IAAIf,EAAEkI,OAAO,IAAIlC,QAAQ;IACrDmC,OAAOnI,EAAEmB,MAAM,GAAGiH,GAAG,GAAGC,QAAQ,GAAGrC,QAAQ;AAC7C;AAEA;;;;CAIC,GACD,MAAMsC,aAAatI,EAChBa,MAAM,CAAC;IACNL,MAAMR,EAAEe,MAAM,GAAGiF,QAAQ;IACzBuC,MAAMvI,EAAEI,KAAK,CAACJ,EAAEe,MAAM,IAAIiF,QAAQ;IAClCwC,kBAAkBxI,EAAEe,MAAM,GAAGiF,QAAQ;IACrCyC,gBAAgBzI,EAAEkI,OAAO,GAAGlC,QAAQ;IACpC0C,iBAAiB1I,EAAE2I,OAAO,CAAC,YAAY3C,QAAQ;IAC/C4C,mBAAmB5I,EAAEI,KAAK,CAAC0H,wBAAwB9B,QAAQ;IAC3D6C,YAAY7I,EACTa,MAAM,CAAC;QACNiI,UAAU9I,EAAEW,IAAI,CAAC;YAAC;YAAU;YAAO;YAAS;YAAQ;YAAU;SAAS;QACvEoI,QAAQ/I,EAAEkI,OAAO,GAAGlC,QAAQ;IAC9B,GACCA,QAAQ;AACb,GACCgD,QAAQ,CAAChJ,EAAEkI,OAAO,KAAK,kBAAkB;AAE5C,MAAMe,iBAAiB;IACrBnI,MAAMd,EAAEe,MAAM;IACdN,MAAMT,EAAEe,MAAM,GAAGiF,QAAQ;IACzBkD,UAAUlJ,EAAEmJ,OAAO,GAAGnD,QAAQ;IAC9BoD,UAAUpJ,EAAEmJ,OAAO,GAAGE,OAAO,CAAC,OAAOrD,QAAQ;IAC7CsD,WAAWtJ,EAAEG,KAAK,CAAC;QAACH,EAAEe,MAAM;QAAIf,EAAEmB,MAAM;QAAInB,EAAEmJ,OAAO;KAAG,EAAEnD,QAAQ;IAClEuD,WAAW3B,sBAAsB5B,QAAQ;IACzCzF,MAAM+H,WAAWtC,QAAQ;AAC3B;AAEA,mBAAmB;AACnB,MAAMwD,kCAAkCxJ,EACrCa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAEG,KAAK,CAAC;QACZH,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;QACV3I,EAAE2I,OAAO,CAAC;KACX;AACH,GACCc,MAAM;AAET,qBAAqB;AACrB,MAAMC,uBAAuB;IAC3BC,WAAW3J,EAAEmB,MAAM,GAAG6E,QAAQ;IAC9B4D,OAAO5J,EAAEmB,MAAM,GAAG6E,QAAQ;AAC5B;AAEA,eAAe;AAEf,MAAM6D,mBAAmB7J,EACtBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBtG,QAAQrC,EAAEmB,MAAM,GAAG6E,QAAQ;IAC3B8D,WAAWpJ,gBAAgBsF,QAAQ;AACrC,GACCyD,MAAM;AACT,MAAMM,wBAAwB/J,EAC3Ba,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBtG,QAAQrC,EAAEmB,MAAM,GAAG6E,QAAQ;IAC3B8D,WAAWpJ,gBAAgBsF,QAAQ;AACrC,GACCyD,MAAM;AAET,MAAMO,iBAAiBhK,EACpBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBxB,IAAInH,EAAEe,MAAM;IACZsB,QAAQrC,EAAEmB,MAAM,GAAG6E,QAAQ;AAC7B,GACCyD,MAAM;AACT,MAAMQ,sBAAsBjK,EACzBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBxB,IAAInH,EAAEe,MAAM;AACd,GACC0I,MAAM;AAET,MAAMS,mBAAmBlK,EACtBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChB,GAAGe,oBAAoB;IACvBS,YAAYnK,EAAEW,IAAI,CAAC;QAAC;QAAQ;QAAoB;KAAU,EAAEqF,QAAQ;AACtE,GACCyD,MAAM;AACT,MAAMW,wBAAwBpK,EAC3Ba,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChB,GAAGe,oBAAoB;IACvBS,YAAYnK,EAAEW,IAAI,CAAC;QAAC;QAAQ;QAAoB;KAAU,EAAEqF,QAAQ;AACtE,GACCyD,MAAM;AAET,MAAMY,iBAAiBrK,EACpBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBgB,WAAW3J,EAAEmB,MAAM,GAAG6E,QAAQ;AAChC,GACCyD,MAAM;AACT,MAAMa,sBAAsBtK,EACzBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBgB,WAAW3J,EAAEmB,MAAM,GAAG6E,QAAQ;AAChC,GACCyD,MAAM;AAET,MAAMc,oBAAoBvK,EACvBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChB,GAAGe,oBAAoB;AACzB,GACCD,MAAM;AACT,MAAMe,yBAAyBxK,EAC5Ba,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChB,GAAGe,oBAAoB;AACzB,GACCD,MAAM;AAET,MAAMgB,iBAAiBzK,EACpBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBxB,IAAInH,EAAEe,MAAM;AACd,GACC0I,MAAM;AAET,MAAMiB,+BAA+B1K,EAClCa,MAAM,CAAC;IACNC,MAAMd,EAAEe,MAAM;IACd4J,iBAAiB3K,EAAEmJ,OAAO,GAAGnD,QAAQ;AACvC,GACCyD,MAAM;AAET,MAAMmB,uBAAuB5K,EAC1Ba,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBkC,eAAe7K,EAAEI,KAAK,CAACsK,8BAA8B7E,GAAG,CAAC;AAC3D,GACC4D,MAAM;AAET,MAAMqB,oBAAoB9K,EACvBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBxB,IAAInH,EAAEe,MAAM;IACZ4D,aAAa3E,EAAEW,IAAI,CAAC;QAAC;QAAS;KAAO,EAAEqF,QAAQ;AACjD,GACCyD,MAAM;AAET,MAAMsB,mBAAmB/K,EACtBa,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBqC,YAAYhL,EAAEmB,MAAM;AACtB,GACCsI,MAAM;AACT,MAAMwB,wBAAwBjL,EAC3Ba,MAAM,CAAC;IACN,GAAGoI,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBqC,YAAYhL,EAAEmB,MAAM;AACtB,GACCsI,MAAM;AAET,oCAAoC;AACpC,MAAMyB,qBAAqB;IACzB,GAAGjC,cAAc;IACjBrG,MAAM5C,EAAE2I,OAAO,CAAC;IAChBwC,MAAMnL,EAAEe,MAAM;AAChB;AAEA,gBAAgB;AAChB,MAAMqK,mBAAmBpL,EAAEW,IAAI,CAAC;IAAC;IAAW;IAAY;IAAa;IAAe;CAAW;AAE/F,MAAM0K,iCAAiCrL,EACpCa,MAAM,CAAC;IACN,GAAGqK,kBAAkB;IACrB/F,cAAcnF,EAAE2I,OAAO,CAAC;IACxB2C,kBAAkBtL,EAAEe,MAAM,GAAGiF,QAAQ;IACrCuF,eAAevL,EAAEmJ,OAAO,GAAGnD,QAAQ;IACnCwF,UAAUJ,iBAAiBpF,QAAQ;IACnCyF,UAAUL,iBAAiBpF,QAAQ;AACrC,GACCyD,MAAM;AAET,MAAMiC,4BAA4B1L,EAC/Ba,MAAM,CAAC;IACN,GAAGqK,kBAAkB;IACrB/F,cAAcnF,EAAE2I,OAAO,CAAC;IACxBgD,YAAY3L,EAAEe,MAAM;IACpB6K,YAAY5L,EAAEe,MAAM,GAAGiF,QAAQ;AACjC,GACCyD,MAAM;AAET,MAAMoC,+BAA+B7L,EAClCa,MAAM,CAAC;IACN,GAAGqK,kBAAkB;IACrB/F,cAAcnF,EAAE2I,OAAO,CAAC;IACxBmD,WAAW9L,EAAEe,MAAM;IACnByK,UAAUJ;IACVK,UAAUL;AACZ,GACC3B,MAAM;AAET,MAAMsC,6BAA6B/L,EAChCa,MAAM,CAAC;IACN,GAAGqK,kBAAkB;IACrB/F,cAAcnF,EAAE2I,OAAO,CAAC;IACxB2C,kBAAkBtL,EAAEe,MAAM,GAAGiF,QAAQ;IACrCgG,eAAehM,EAAEmJ,OAAO,GAAGnD,QAAQ;IACnCuF,eAAevL,EAAEmJ,OAAO,GAAGnD,QAAQ;IACnCwF,UAAUJ,iBAAiBpF,QAAQ;IACnCyF,UAAUL,iBAAiBpF,QAAQ;AACrC,GACCyD,MAAM;AAET,MAAMwC,gBAAgB;IAAC;IAAgB;IAAW;IAAc;CAAW;AAC3E,OAAO,MAAMC,qBAAqBlM,EAAEmM,kBAAkB,CACpD,gBACA;IACEd;IACAK;IACAG;IACAE;CACD,EACD;IACEK,OAAO,CAACC,MACN,CAAC,cAAc,EAAEJ,cAAcK,GAAG,CAAC,CAAC5F,IAAM,CAAC,CAAC,EAAEA,EAAE,CAAC,CAAC,EAAE6F,IAAI,CAAC,MAAM,mBAAmB,EAAGF,IAAIG,KAAK,EAA8BrH,aAAa,CAAC,CAAC;AAC/I,GACA;AAEF,MAAMsH,kBAAkB;IACtB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,yCAAyC;AACzC,MAAMC,kCAAkC;IACtC;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD;AAED,OAAO,MAAMC,mBAAmB3M,EAC7BmM,kBAAkB,CACjB,QACA;IACE3C;IACAK;IACAE;IACAC;IACAC;IACAC;IACAE;IACAC;IACAC;IACAC;IACAC;IACAC;IACAG;IACAE;IACAC;IACAE;CACD,EACD;IACEmB,OAAO,CAACC,MACN,CAAC,MAAM,EAAEI,gBAAgBH,GAAG,CAAC,CAAC5F,IAAM,CAAC,CAAC,EAAEA,EAAE,CAAC,CAAC,EAAE6F,IAAI,CAAC,MAAM,mBAAmB,EAAGF,IAAIG,KAAK,EAA8B5J,KAAK,CAAC,CAAC;AACjI,GAEDgK,WAAW,CAAC,CAACC,MAAMC;IAClB,IAAI,CAACD,KAAKtD,SAAS,EAAE;QACnB;IACF;IAEA,gCAAgC;IAChC,IAAIsD,KAAKvD,SAAS,KAAKpH,WAAW;QAChC4K,IAAIC,QAAQ,CAAC;YACX3G,MAAM;YACN4G,SAAS;YACTC,MAAM;gBAAC;aAAY;QACrB;IACF;IAEA,2BAA2B;IAC3B,IAAIJ,KAAKjK,IAAI,KAAK,WAAW;QAC3BkK,IAAIC,QAAQ,CAAC;YACX3G,MAAM;YACN4G,SAAS;YACTC,MAAM;gBAAC;aAAY;QACrB;IACF;IAEA,oCAAoC;IACpC,IAAIJ,KAAKtD,SAAS,CAAC3G,IAAI,KAAK,WAAW;QACrC,IAAI,AAAC8J,gCAAsDQ,QAAQ,CAACL,KAAKjK,IAAI,GAAG;YAC9EkK,IAAIC,QAAQ,CAAC;gBACX3G,MAAM;gBACN4G,SAAS,CAAC,0BAA0B,EAAEH,KAAKjK,IAAI,CAAC,8BAA8B,CAAC;gBAC/EqK,MAAM;oBAAC;oBAAa;iBAAO;gBAC3BE,OAAO;YACT;QACF;IACF;AACF,GAAG;AAEL,MAAMC,eAAe;OAAIX;IAAiB;CAAW;AACrD,MAAMY,mBAAmBrN,EAAEmM,kBAAkB,CAAC,QAAQ;IAACQ;IAAkBT;CAAmB,EAAE;IAC5FE,OAAO,CAACC,MACN,CAAC,MAAM,EAAEe,aAAad,GAAG,CAAC,CAAC5F,IAAM,CAAC,CAAC,EAAEA,EAAE,CAAC,CAAC,EAAE6F,IAAI,CAAC,MAAM,mBAAmB,EAAGF,IAAIG,KAAK,EAA8B5J,KAAK,CAAC,CAAC;AAC9H;AAEA,MAAM0K,0BAA0BtN,EAAEa,MAAM,CAAC;IACvCC,MAAMd,EAAEe,MAAM;IACdwM,YAAYvN,EAAEmJ,OAAO,GAAGnD,QAAQ;IAChCwH,WAAWxN,EAAEW,IAAI,CAAC;QAAC;QAAO;KAAO,EAAEqF,QAAQ;IAC3CyH,WAAWzN,EAAEW,IAAI,CAAC;QAAC;QAAqB;QAAiB;KAAgB,EAAEqF,QAAQ;IACnF0H,SAAS1N,EAAEG,KAAK,CAAC;QAACH,EAAEW,IAAI,CAACY;QAAqBvB,EAAEe,MAAM,GAAG8E,GAAG,CAAC;KAAG,EAAEG,QAAQ;AAC5E;AAEA,qBAAqB;AACrB,MAAM2H,oBAAoB3N,EACvBa,MAAM,CAAC;IACN+B,MAAM5C,EAAEW,IAAI,CAAC;QAAC;QAAS;QAAU;QAAQ;KAAU;IACnDiN,SAAS5N,EAAEI,KAAK,CAACkN;IACjBxM,MAAMd,EAAEe,MAAM,GAAG8E,GAAG,CAAC,GAAGC,GAAG,CAAC;IAC5B+H,OAAO7N,EAAEW,IAAI,CAAC;QAAC;QAAS;QAAQ;QAAO;QAAQ;KAAW,EAAEqF,QAAQ;IACpE8H,kBAAkB9N,EAAEmJ,OAAO,GAAGnD,QAAQ;IACtC+H,GAAG/N,EAAEmB,MAAM,GAAG6E,QAAQ;IACtBgI,gBAAgBhO,EAAEmB,MAAM,GAAG6E,QAAQ;IACnCiI,OAAOjO,EAAEmB,MAAM,GAAG6E,QAAQ;AAC5B,GACCyD,MAAM;AAET;;;;CAIC,GACD,MAAMyE,kBAAkBlO,EAAEG,KAAK,CAAC;IAC9B,WAAW;IACXH,EAAEI,KAAK,CAACJ,EAAEG,KAAK,CAAC;QAACH,EAAEe,MAAM;QAAIf,EAAEa,MAAM,CAAC;YAAEa,OAAO1B,EAAEe,MAAM;YAAIa,UAAU5B,EAAEmJ,OAAO,GAAGnD,QAAQ;QAAG;KAAG;IAC/F,YAAY;IACZhG,EAAEa,MAAM,CAAC;QACP0B,QAAQvC,EAAEI,KAAK,CACbJ,EAAEG,KAAK,CAAC;YAACH,EAAEe,MAAM;YAAIf,EAAEa,MAAM,CAAC;gBAAEa,OAAO1B,EAAEe,MAAM;gBAAIa,UAAU5B,EAAEmJ,OAAO,GAAGnD,QAAQ;YAAG;SAAG;QAEzFzF,MAAM+H,WAAWtC,QAAQ;IAC3B;CACD;AAED;;;;CAIC,GACD,MAAMmI,gBAAgBnO,EAAEG,KAAK,CAAC;IAC5B,eAAe;IACfH,EAAEiI,MAAM,CAACjI,EAAEe,MAAM,IAAIf,EAAEe,MAAM;IAC7B,YAAY;IACZf,EAAEa,MAAM,CAAC;QACP4B,QAAQzC,EAAEiI,MAAM,CAACjI,EAAEe,MAAM,IAAIf,EAAEe,MAAM;QACrCR,MAAM+H,WAAWtC,QAAQ;IAC3B;CACD;AAED,SAASoI,+BAA+BC,OAAqB;IAC3D,IAAIC,UAAUD;IAEd,MAAOC,mBAAmBtO,EAAEuO,WAAW,IAAID,mBAAmBtO,EAAEwO,WAAW,CAAE;QAC3EF,UAAUA,QAAQG,MAAM;IAC1B;IAEA,OAAOH;AACT;AAEA,OAAO,SAASI,8BAA8BL,OAAqB;IACjE,MAAMM,WAAWP,+BAA+BC;IAChD,IAAI,CAAEM,CAAAA,oBAAoB3O,EAAE4O,QAAQ,AAAD,GAAI;QACrC,OAAO;IACT;IAEA,MAAMC,cAAcF,SAAS7M,GAAG,CAACgN,OAAO;IACxC,OAAOD,uBAAuB7O,EAAE+O,SAAS;AAC3C;AAEA,SAASC,0BACPC,KAAkD,EAClDnC,GAAoB,EACpBoC,YAAiC;IAAC;CAAQ;IAE1C,MAAMC,cAAc,IAAIC,IACtBH,MAAM3C,GAAG,CAAC,CAAC+C;QACT,OAAO;YAACA,KAAKvO,IAAI;YAAEuO;SAAK;IAC1B;IAGFJ,MAAMK,OAAO,CAAC,CAACD,MAAME;QACnB,IAAIF,KAAKzM,IAAI,KAAK,cAAc;YAC9B;QACF;QAEAyM,KAAKxE,aAAa,CAACyE,OAAO,CAAC,CAACE,QAAQC;YAClC,MAAMC,aAAaP,YAAYQ,GAAG,CAACH,OAAO1O,IAAI;YAC9C,MAAM8O,aAAa;mBAAIV;gBAAWK;gBAAW;gBAAiBE;gBAAa;aAAO;YAElF,IAAI,CAACC,YAAY;gBACf5C,IAAIC,QAAQ,CAAC;oBACX3G,MAAM;oBACN4G,SAAS,CAAC,0BAA0B,EAAEwC,OAAO1O,IAAI,CAAC,gBAAgB,CAAC;oBACnEmM,MAAM2C;gBACR;gBACA;YACF;YAEA,IAAIF,WAAW9M,IAAI,KAAK,YAAY8M,WAAW9M,IAAI,KAAK,YAAY;gBAClE;YACF;YAEA,IAAI8M,WAAW9M,IAAI,KAAK,QAAQ;gBAC9B,wDAAwD;gBACxD,+BAA+B;gBAC/B;YACF;YAEAkK,IAAIC,QAAQ,CAAC;gBACX3G,MAAM;gBACN4G,SAAS,CAAC,0BAA0B,EAAEwC,OAAO1O,IAAI,CAAC,OAAO,EAAE4O,WAAW9M,IAAI,CAAC,gBAAgB,CAAC;gBAC5FqK,MAAM2C;YACR;QACF;IACF;AACF;AAEA,MAAMC,uBAAuB7P,EAC1Ba,MAAM,CAAC;IACNsG,IAAInH,EAAEe,MAAM,GAAGK,QAAQ,CAAC;IACxB0O,OAAO9P,EAAEe,MAAM,GAAGK,QAAQ,CAAC;IAC3B2O,OAAO/P,EAAEe,MAAM,GAAGK,QAAQ,CAAC;IAC3B4O,UAAUhQ,EAAEe,MAAM,GAAGiF,QAAQ,GAAG5E,QAAQ,CAAC;IACzCb,MAAM+H,WAAWtC,QAAQ;IACzBiJ,OAAOjP,EAAEI,KAAK,CAACiN;IACf4C,SAASjQ,EAAEI,KAAK,CAACuN;IACjBuC,SAASlQ,EAAEiI,MAAM,CAACjI,EAAEe,MAAM,IAAImN;IAC9BiC,OAAOnQ,EAAEiI,MAAM,CAACjI,EAAEe,MAAM,IAAIoN;AAC9B,GACC1E,MAAM;AAET,OAAO,MAAM2G,mBAAmBP,qBAAqBjD,WAAW,CAAC,CAAC7E,QAAQ+E;IACxEkC,0BAA0BjH,OAAOkH,KAAK,EAAEnC;AAC1C,GAAG;AAEH,MAAMuD,uBAAuBR,qBAAqBS,IAAI,CAAC;IAAEnJ,IAAI;AAAK,GAC/DoJ,MAAM,CAAC;IACNC,UAAUxQ,EAAEe,MAAM;AACpB,GACC0P,OAAO,CAAC;IACPV,OAAO;IACPd,OAAO;IACPgB,SAAS;IACTC,SAAS;IACTC,OAAO;AACT,GACCvD,WAAW,CAAC,CAAC7E,QAAQ+E;IACpB,IAAI,CAAC/E,OAAOkH,KAAK,EAAE;QACjB;IACF;IAEAD,0BAA0BjH,OAAOkH,KAAK,EAAEnC;AAC1C;AAEF,OAAO,MAAM4D,kBAAkB1Q,EAAEa,MAAM,CAAC;IACtCkH,QAAQsI;IACRM,YAAY3Q,EAAEa,MAAM,CAAC;QACnB2P,UAAUxQ,EAAEe,MAAM;IACpB;IACAwI,WAAWvJ,EAAEa,MAAM,CAAC,CAAC;IACrB+P,eAAe5Q,EAAEa,MAAM,CAAC,CAAC;IACzBgQ,gBAAgB7Q,EAAEa,MAAM,CAAC;QACvB2P,UAAUxQ,EAAEe,MAAM;IACpB;IACA+P,OAAO9Q,EAAEa,MAAM,CAAC;QACd2P,UAAUxQ,EAAEe,MAAM;QAClBgQ,oBAAoB/Q,EAAEe,MAAM,GAAGiF,QAAQ;QACvCgL,gBAAgBhR,EAAEe,MAAM,GAAGiF,QAAQ;IACrC;IACAiL,YAAYjR,EAAEa,MAAM,CAAC;QACnB2P,UAAUxQ,EAAEe,MAAM;IACpB;IACAmQ,QAAQlR,EAAEa,MAAM,CAAC;QACf2P,UAAUxQ,EAAEe,MAAM;IACpB;IACAoQ,UAAUnR,EAAEa,MAAM,CAAC,CAAC;IACpBuQ,WAAWpR,EAAEa,MAAM,CAAC;QAClB2P,UAAUxQ,EAAEe,MAAM;QAClBsQ,OAAOrR,EAAEkI,OAAO;IAClB;IACAoJ,mBAAmBtR,EAAEa,MAAM,CAAC;QAC1B2P,UAAUxQ,EAAEe,MAAM;QAClB6M,SAAS5N,EACNa,MAAM,CAAC;YACNC,MAAMd,EAAEe,MAAM;YACdwQ,OAAOvR,EAAEe,MAAM;YACfyQ,IAAIxR,EAAEe,MAAM;QACd,GACCX,KAAK;QACRqR,eAAezR,EAAEe,MAAM;IACzB;IACA2Q,mBAAmB1R,EAAEa,MAAM,CAAC;QAC1B2P,UAAUxQ,EAAEe,MAAM;IACpB;IACA4Q,WAAW3R,EAAEa,MAAM,CAAC;QAClB2P,UAAUxQ,EAAEe,MAAM;IACpB;IACA6Q,oBAAoB5R,EAAEa,MAAM,CAAC;QAC3B2P,UAAUxQ,EAAEe,MAAM;IACpB;IACA8Q,sBAAsB7R,EAAEa,MAAM,CAAC;QAC7B2P,UAAUxQ,EAAEe,MAAM;QAClB+Q,QAAQ9R,EAAEe,MAAM;IAClB;IACAgR,SAAS/R,EAAEa,MAAM,CAAC,CAAC;IACnBmR,cAAchS,EAAEa,MAAM,CAAC,CAAC;IACxBoR,IAAIjS,EAAEa,MAAM,CAAC;QACXqR,QAAQlS,EAAEW,IAAI,CAAC;YAAC;YAAO;YAAO;SAAM;IACtC;AACF,GAAG;AAGH,OAAO,MAAMwR,cAAcnS,EAAEW,IAAI,CAAC;IAChC;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD,EAAE;AAGH,OAAO,MAAMyR,kBAAkBpS,EAAEa,MAAM,CAAC;IACtCwR,WAAWrS,EAAEmJ,OAAO,GAAGnD,QAAQ;AACjC,GAAG;AAGH,OAAO,MAAMsM,cAActS,EAAEa,MAAM,CAAC;IAClCoM,MAAMjN,EAAEe,MAAM;IACdqF,MAAMpG,EAAEe,MAAM;AAChB,GAAG"}
|