sonamu 0.7.2 → 0.7.3

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.
Files changed (55) hide show
  1. package/dist/api/code-converters.js +2 -2
  2. package/dist/api/config.js +2 -2
  3. package/dist/api/decorators.d.ts.map +1 -1
  4. package/dist/api/decorators.js +2 -2
  5. package/dist/api/sonamu.d.ts.map +1 -1
  6. package/dist/api/sonamu.js +3 -4
  7. package/dist/bin/cli.js +1 -17
  8. package/dist/database/base-model.types.d.ts +1 -0
  9. package/dist/database/base-model.types.d.ts.map +1 -1
  10. package/dist/database/base-model.types.js +2 -2
  11. package/dist/database/puri-wrapper.js +7 -3
  12. package/dist/database/upsert-builder.d.ts +7 -3
  13. package/dist/database/upsert-builder.d.ts.map +1 -1
  14. package/dist/database/upsert-builder.js +63 -25
  15. package/dist/entity/entity-manager.d.ts +1 -1
  16. package/dist/entity/entity.js +3 -3
  17. package/dist/migration/code-generation.d.ts.map +1 -1
  18. package/dist/migration/code-generation.js +8 -7
  19. package/dist/migration/migration-set.d.ts.map +1 -1
  20. package/dist/migration/migration-set.js +2 -25
  21. package/dist/migration/migrator.js +2 -2
  22. package/dist/migration/postgresql-schema-reader.d.ts.map +1 -1
  23. package/dist/migration/postgresql-schema-reader.js +2 -1
  24. package/dist/syncer/file-patterns.js +2 -2
  25. package/dist/template/implementations/service.template.d.ts.map +1 -1
  26. package/dist/template/implementations/service.template.js +3 -2
  27. package/dist/types/types.d.ts +4 -3
  28. package/dist/types/types.d.ts.map +1 -1
  29. package/dist/types/types.js +2 -2
  30. package/dist/utils/model.d.ts +9 -2
  31. package/dist/utils/model.d.ts.map +1 -1
  32. package/dist/utils/model.js +1 -1
  33. package/dist/utils/path-utils.d.ts +1 -1
  34. package/dist/utils/path-utils.d.ts.map +1 -1
  35. package/dist/utils/path-utils.js +1 -1
  36. package/package.json +7 -7
  37. package/src/api/code-converters.ts +2 -2
  38. package/src/api/config.ts +1 -1
  39. package/src/api/decorators.ts +1 -1
  40. package/src/api/sonamu.ts +2 -5
  41. package/src/bin/cli.ts +0 -17
  42. package/src/database/base-model.types.ts +2 -0
  43. package/src/database/puri-wrapper.ts +2 -2
  44. package/src/database/upsert-builder.ts +88 -29
  45. package/src/entity/entity.ts +2 -2
  46. package/src/migration/code-generation.ts +8 -6
  47. package/src/migration/migration-set.ts +0 -20
  48. package/src/migration/migrator.ts +1 -1
  49. package/src/migration/postgresql-schema-reader.ts +1 -0
  50. package/src/shared/web.shared.ts.txt +6 -4
  51. package/src/syncer/file-patterns.ts +1 -1
  52. package/src/template/implementations/service.template.ts +2 -1
  53. package/src/types/types.ts +3 -2
  54. package/src/utils/model.ts +10 -4
  55. package/src/utils/path-utils.ts +5 -2
@@ -235,7 +235,7 @@ import { ApiParamType } from "../types/types.js";
235
235
  } else if (ApiParamType.isTupleType(paramType)) {
236
236
  return `[ ${paramType.elements.map((elem)=>apiParamTypeToTsType(elem, injectImportKeys))} ]`;
237
237
  } else if (ApiParamType.isTypeParam(paramType)) {
238
- return `<${paramType.id}${paramType.constraint ? ` extends ${apiParamTypeToTsType(paramType.constraint, injectImportKeys)}` : ""}>`;
238
+ return `${paramType.id}${paramType.constraint ? ` extends ${apiParamTypeToTsType(paramType.constraint, injectImportKeys)}` : ""}`;
239
239
  } else {
240
240
  throw new Error(`resolve 불가 ApiParamType ${paramType}`);
241
241
  }
@@ -255,4 +255,4 @@ import { ApiParamType } from "../types/types.js";
255
255
  return `{ ${params.map((param)=>`${param.name}${param.optional ? "?" : ""}: ${apiParamTypeToTsType(param.type, injectImportKeys)}${param.defaultDef ? `= ${param.defaultDef}` : ""}`).join(", ")} }`;
256
256
  }
257
257
 
258
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/api/code-converters.ts"],"sourcesContent":["/**\n * code-converters는 API 타입 정의들을 Zod 객체나 TypeScript 코드로 변환하는 함수들을 제공합니다.\n *\n * 1. API 시리즈들:\n * - ExtendedApi, ApiParam, ApiParamType\n * - API 메타데이터를 표현하는 타입 정의들\n *\n * 2. ZodObject 변환\n * - API 타입 정의 → Zod 타입 인스턴스 (런타임 밸리데이션용)\n * - getZodTypeFromApiParamType → getZodObjectFromApiParams → getZodObjectFromApi\n *\n * 3. TsTypeDef 변환\n * - API 타입 정의 → TypeScript 타입 코드 문자열 (코드 생성용)\n * - apiParamTypeToTsType → apiParamToTsCode, apiParamToTsCodeAsObject\n *\n * 참고:\n * - ZodTypeDef 생성 (Zod 코드 문자열): zod-converter.ts의 zodTypeToZodCode 사용\n * - EntityProp 변환: zod-converter.ts 참조\n */\n\nimport { z } from \"zod\";\nimport type { core } from \"zod/v4\";\nimport type { $ZodLooseShape } from \"zod/v4/core\";\nimport { type ApiParam, ApiParamType } from \"../types/types\";\nimport type { ExtendedApi } from \"./decorators\";\n\n// <any>를 자제하고, Zod에서 제약하는 기본적인 Generic Type Parameter를 사용함.\ntype AnyZodObject = z.ZodObject<$ZodLooseShape>;\ntype AnyZodLiteral = z.ZodLiteral<core.util.Literal>;\n\n/**\n * Promise 타입을 한 번 언래핑하여 내부 타입을 반환합니다.\n * Promise가 아닌 경우 원본 타입을 그대로 반환합니다.\n */\nexport function unwrapPromiseOnce(paramType: ApiParamType) {\n  if (ApiParamType.isPromise(paramType)) {\n    return paramType.args?.[0];\n  } else {\n    return paramType;\n  }\n}\n\n/*\n * API를 구성하는 요소들을 ZodObject로 변환하기 위한 함수들입니다.\n */\n\n/**\n * ApiParamType을 Zod 타입 인스턴스로 변환합니다.\n * string, number, array, union 등 모든 ApiParamType을 처리하며,\n * 순환참조가 발생하는 경우 z.unknown()으로 fallback합니다.\n */\nexport function getZodTypeFromApiParamType(\n  paramType: ApiParamType,\n  references: {\n    [id: string]: AnyZodObject;\n  },\n): z.ZodType<unknown> {\n  switch (paramType) {\n    case \"string\":\n      return z.string();\n    case \"number\":\n      return z.number();\n    case \"boolean\":\n      return z.boolean();\n    default: {\n      const advType = paramType as { t: string; value?: string | number };\n      switch (advType.t) {\n        case \"string-literal\":\n        case \"numeric-literal\":\n          return z.literal(advType.value);\n        case \"object\": {\n          const objType = paramType as { t: string; props: ApiParam[] };\n          return getZodObjectFromApiParams(objType.props);\n        }\n        case \"array\": {\n          const arrType = paramType as {\n            t: string;\n            elementsType: ApiParamType;\n          };\n          return z.array(getZodTypeFromApiParamType(arrType.elementsType, references));\n        }\n        case \"ref\": {\n          const refType = paramType as {\n            t: string;\n            id: string;\n            args?: ApiParamType[];\n          };\n          // Date 타입 처리\n          if (refType.id === \"Date\") {\n            return z.date();\n          }\n          // 객체 키 관리 유틸리티\n          if ([\"Pick\", \"Omit\"].includes(refType.id)) {\n            if (refType.args?.length !== 2) {\n              throw new Error(`잘못된 ${refType.id}`);\n            }\n            const [obj, literalOrUnion] = refType.args.map(\n              (arg) => getZodTypeFromApiParamType(arg, references),\n              // biome-ignore lint/suspicious/noExplicitAny: 생성되는 ZodUnion의 타입을 추적하기 어려움\n            ) as [AnyZodObject, z.ZodUnion<any> | AnyZodLiteral];\n\n            let keys: string[] = [];\n            if (literalOrUnion instanceof z.ZodUnion) {\n              keys = literalOrUnion.def.options.map(\n                (option: { def: { values: string[] } }) => option.def.values[0],\n              );\n            } else {\n              keys = (literalOrUnion as z.ZodLiteral<string>).def.values;\n            }\n            const keyRecord = Object.fromEntries(keys.map((key) => [key, true as const]));\n            if (refType.id === \"Pick\") {\n              if (obj.pick) {\n                return obj.pick(keyRecord);\n              }\n            } else {\n              if (obj.omit) {\n                return obj.omit(keyRecord);\n              }\n            }\n          }\n          if ([\"Partial\"].includes(refType.id)) {\n            if (refType.args?.length !== 1) {\n              throw new Error(`잘못된 ${refType.id}`);\n            }\n            const obj = getZodTypeFromApiParamType(refType.args[0], references);\n            // biome-ignore lint/suspicious/noExplicitAny: Partial 인수 타입 캐스팅\n            return (obj as z.ZodObject<any>).partial();\n          }\n          const reference = references[refType.id];\n          if (reference === undefined) {\n            return z.unknown();\n            // throw new Error(`ref 참조 불가 ${refType.id}`);\n          }\n          return reference;\n        }\n        case \"union\": {\n          const unionType = paramType as {\n            t: string;\n            types: ApiParamType[];\n          };\n          // nullable 유니온\n          if (unionType.types.length === 2 && unionType.types.some((type) => type === \"null\")) {\n            if (unionType.types[0] === \"null\") {\n              return getZodTypeFromApiParamType(unionType.types[1], references).nullable();\n            } else {\n              return getZodTypeFromApiParamType(unionType.types[0], references).nullable();\n            }\n          }\n          // 일반 유니온\n          return z.union(\n            unionType.types.map((type) => getZodTypeFromApiParamType(type, references)),\n          );\n        }\n        case \"intersection\": {\n          const intersectionType = paramType as {\n            t: string;\n            types: ApiParamType[];\n          };\n          return intersectionType.types.reduce(\n            (result, type, index) => {\n              const resolvedType = getZodTypeFromApiParamType(type, references);\n              if (index === 0) {\n                return resolvedType;\n              } else {\n                return z.intersection(result, resolvedType);\n              }\n            },\n            z.unknown() as z.ZodType<unknown>,\n          );\n        }\n        case \"tuple-type\": {\n          const tupleType = paramType as ApiParamType.TupleType;\n          return z.tuple(\n            // biome-ignore lint/suspicious/noExplicitAny: 생성되는 ZodTuple의 타입을 추적하기 어려움\n            tupleType.elements.map((elem) => getZodTypeFromApiParamType(elem, references)) as any,\n          );\n        }\n      }\n      return z.unknown();\n    }\n  }\n}\n\n/**\n * ApiParam 배열을 ZodObject로 변환합니다.\n * 각 파라미터의 optional 여부를 반영하여 Zod 스키마를 생성합니다.\n */\nexport function getZodObjectFromApiParams(\n  apiParams: ApiParam[],\n  references: {\n    [id: string]: AnyZodObject;\n  } = {},\n): z.ZodObject {\n  return z.object(\n    Object.fromEntries(\n      apiParams.map((param) => {\n        let zodType = getZodTypeFromApiParamType(param.type, references);\n        if (param.optional) {\n          zodType = zodType.optional();\n        }\n        return [param.name, zodType];\n      }),\n    ),\n  );\n}\n\n/**\n * ExtendedApi를 ZodObject로 변환합니다.\n * TypeParameter와 일반 파라미터를 처리하며,\n * Context, RefKnex, _로 시작하는 optional 파라미터는 제외합니다.\n */\nexport function getZodObjectFromApi(\n  api: ExtendedApi,\n  references: {\n    [id: string]: AnyZodObject;\n  } = {},\n) {\n  if (api.typeParameters?.length > 0) {\n    for (const typeParam of api.typeParameters) {\n      if (typeParam.constraint) {\n        const zodType = getZodTypeFromApiParamType(typeParam.constraint, references);\n        // biome-ignore lint/suspicious/noExplicitAny: 레퍼런스 타입 캐스팅\n        (references[typeParam.id] as z.ZodType<any>) = zodType;\n      }\n    }\n  }\n  const ReqType = getZodObjectFromApiParams(\n    // api parsing한 결과가 api params\n    api.parameters.filter(\n      (param) =>\n        !ApiParamType.isContext(param.type) &&\n        !ApiParamType.isRefKnex(param.type) &&\n        !(param.optional === true && param.name.startsWith(\"_\")), // _로 시작하는 파라미터는 제외\n    ),\n    references,\n  );\n  return ReqType;\n}\n\n/*\n * API 타입 정의를 TypeScript 코드 문자열로 변환하기 위한 함수들입니다.\n */\n\n/**\n * ApiParamType을 TypeScript 타입 문자열로 변환합니다.\n * union, intersection, array, ref 등 모든 타입을 TS 문법으로 표현하며,\n * import가 필요한 타입 ID는 injectImportKeys에 수집합니다.\n */\nexport function apiParamTypeToTsType(paramType: ApiParamType, injectImportKeys: string[]): string {\n  if (\n    [\n      \"string\",\n      \"number\",\n      \"boolean\",\n      \"true\",\n      \"false\",\n      \"null\",\n      \"undefined\",\n      \"void\",\n      \"any\",\n      \"unknown\",\n    ].includes(paramType as string)\n  ) {\n    return paramType as string;\n  } else if (ApiParamType.isObject(paramType)) {\n    return `{ ${apiParamToTsCode(paramType.props, injectImportKeys)} }`;\n  } else if (ApiParamType.isStringLiteral(paramType)) {\n    return `\"${paramType.value}\"`;\n  } else if (ApiParamType.isNumericLiteral(paramType)) {\n    return String(paramType.value);\n  } else if (ApiParamType.isUnion(paramType)) {\n    return paramType.types.map((type) => apiParamTypeToTsType(type, injectImportKeys)).join(\" | \");\n  } else if (ApiParamType.isIntersection(paramType)) {\n    return paramType.types.map((type) => apiParamTypeToTsType(type, injectImportKeys)).join(\" & \");\n  } else if (ApiParamType.isArray(paramType)) {\n    return `${apiParamTypeToTsType(paramType.elementsType, injectImportKeys)}[]`;\n  } else if (ApiParamType.isRef(paramType)) {\n    if ([\"Pick\", \"Omit\", \"Promise\", \"Partial\", \"Date\"].includes(paramType.id) === false) {\n      // importKeys 인젝션\n      injectImportKeys.push(paramType.id);\n    }\n    if (paramType.args === undefined || paramType.args.length === 0) {\n      return paramType.id;\n    } else {\n      return `${paramType.id}<${paramType.args\n        .map((arg) => apiParamTypeToTsType(arg, injectImportKeys))\n        .join(\",\")}>`;\n    }\n  } else if (ApiParamType.isIndexedAccess(paramType)) {\n    return `${apiParamTypeToTsType(\n      paramType.object,\n      injectImportKeys,\n    )}[${apiParamTypeToTsType(paramType.index, injectImportKeys)}]`;\n  } else if (ApiParamType.isTupleType(paramType)) {\n    return `[ ${paramType.elements.map((elem) => apiParamTypeToTsType(elem, injectImportKeys))} ]`;\n  } else if (ApiParamType.isTypeParam(paramType)) {\n    return `<${paramType.id}${\n      paramType.constraint\n        ? ` extends ${apiParamTypeToTsType(paramType.constraint, injectImportKeys)}`\n        : \"\"\n    }>`;\n  } else {\n    throw new Error(`resolve 불가 ApiParamType ${paramType}`);\n  }\n}\n\n/**\n * ApiParam 배열을 TypeScript 함수 파라미터 코드로 변환합니다.\n * 예: \"name: string, age?: number, active: boolean = true\"\n */\nexport function apiParamToTsCode(params: ApiParam[], injectImportKeys: string[]): string {\n  return params\n    .map((param) => {\n      return `${param.name}${\n        param.optional && !param.defaultDef ? \"?\" : \"\"\n      }: ${apiParamTypeToTsType(param.type, injectImportKeys)}${\n        param.defaultDef ? `= ${param.defaultDef}` : \"\"\n      }`;\n    })\n    .join(\", \");\n}\n\n/**\n * ApiParam 배열을 TypeScript 객체 타입 코드로 변환합니다.\n * 예: \"{ name: string, age?: number, active: boolean = true }\"\n */\nexport function apiParamToTsCodeAsObject(params: ApiParam[], injectImportKeys: string[]): string {\n  return `{ ${params\n    .map(\n      (param) =>\n        `${param.name}${param.optional ? \"?\" : \"\"}: ${apiParamTypeToTsType(\n          param.type,\n          injectImportKeys,\n        )}${param.defaultDef ? `= ${param.defaultDef}` : \"\"}`,\n    )\n    .join(\", \")} }`;\n}\n"],"names":["z","ApiParamType","unwrapPromiseOnce","paramType","isPromise","args","getZodTypeFromApiParamType","references","string","number","boolean","advType","t","literal","value","objType","getZodObjectFromApiParams","props","arrType","array","elementsType","refType","id","date","includes","length","Error","obj","literalOrUnion","map","arg","keys","ZodUnion","def","options","option","values","keyRecord","Object","fromEntries","key","pick","omit","partial","reference","undefined","unknown","unionType","types","some","type","nullable","union","intersectionType","reduce","result","index","resolvedType","intersection","tupleType","tuple","elements","elem","apiParams","object","param","zodType","optional","name","getZodObjectFromApi","api","typeParameters","typeParam","constraint","ReqType","parameters","filter","isContext","isRefKnex","startsWith","apiParamTypeToTsType","injectImportKeys","isObject","apiParamToTsCode","isStringLiteral","isNumericLiteral","String","isUnion","join","isIntersection","isArray","isRef","push","isIndexedAccess","isTupleType","isTypeParam","params","defaultDef","apiParamToTsCodeAsObject"],"mappings":"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"}
258
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/api/code-converters.ts"],"sourcesContent":["/**\n * code-converters는 API 타입 정의들을 Zod 객체나 TypeScript 코드로 변환하는 함수들을 제공합니다.\n *\n * 1. API 시리즈들:\n * - ExtendedApi, ApiParam, ApiParamType\n * - API 메타데이터를 표현하는 타입 정의들\n *\n * 2. ZodObject 변환\n * - API 타입 정의 → Zod 타입 인스턴스 (런타임 밸리데이션용)\n * - getZodTypeFromApiParamType → getZodObjectFromApiParams → getZodObjectFromApi\n *\n * 3. TsTypeDef 변환\n * - API 타입 정의 → TypeScript 타입 코드 문자열 (코드 생성용)\n * - apiParamTypeToTsType → apiParamToTsCode, apiParamToTsCodeAsObject\n *\n * 참고:\n * - ZodTypeDef 생성 (Zod 코드 문자열): zod-converter.ts의 zodTypeToZodCode 사용\n * - EntityProp 변환: zod-converter.ts 참조\n */\n\nimport { z } from \"zod\";\nimport type { core } from \"zod/v4\";\nimport type { $ZodLooseShape } from \"zod/v4/core\";\nimport { type ApiParam, ApiParamType } from \"../types/types\";\nimport type { ExtendedApi } from \"./decorators\";\n\n// <any>를 자제하고, Zod에서 제약하는 기본적인 Generic Type Parameter를 사용함.\ntype AnyZodObject = z.ZodObject<$ZodLooseShape>;\ntype AnyZodLiteral = z.ZodLiteral<core.util.Literal>;\n\n/**\n * Promise 타입을 한 번 언래핑하여 내부 타입을 반환합니다.\n * Promise가 아닌 경우 원본 타입을 그대로 반환합니다.\n */\nexport function unwrapPromiseOnce(paramType: ApiParamType) {\n  if (ApiParamType.isPromise(paramType)) {\n    return paramType.args?.[0];\n  } else {\n    return paramType;\n  }\n}\n\n/*\n * API를 구성하는 요소들을 ZodObject로 변환하기 위한 함수들입니다.\n */\n\n/**\n * ApiParamType을 Zod 타입 인스턴스로 변환합니다.\n * string, number, array, union 등 모든 ApiParamType을 처리하며,\n * 순환참조가 발생하는 경우 z.unknown()으로 fallback합니다.\n */\nexport function getZodTypeFromApiParamType(\n  paramType: ApiParamType,\n  references: {\n    [id: string]: AnyZodObject;\n  },\n): z.ZodType<unknown> {\n  switch (paramType) {\n    case \"string\":\n      return z.string();\n    case \"number\":\n      return z.number();\n    case \"boolean\":\n      return z.boolean();\n    default: {\n      const advType = paramType as { t: string; value?: string | number };\n      switch (advType.t) {\n        case \"string-literal\":\n        case \"numeric-literal\":\n          return z.literal(advType.value);\n        case \"object\": {\n          const objType = paramType as { t: string; props: ApiParam[] };\n          return getZodObjectFromApiParams(objType.props);\n        }\n        case \"array\": {\n          const arrType = paramType as {\n            t: string;\n            elementsType: ApiParamType;\n          };\n          return z.array(getZodTypeFromApiParamType(arrType.elementsType, references));\n        }\n        case \"ref\": {\n          const refType = paramType as {\n            t: string;\n            id: string;\n            args?: ApiParamType[];\n          };\n          // Date 타입 처리\n          if (refType.id === \"Date\") {\n            return z.date();\n          }\n          // 객체 키 관리 유틸리티\n          if ([\"Pick\", \"Omit\"].includes(refType.id)) {\n            if (refType.args?.length !== 2) {\n              throw new Error(`잘못된 ${refType.id}`);\n            }\n            const [obj, literalOrUnion] = refType.args.map(\n              (arg) => getZodTypeFromApiParamType(arg, references),\n              // biome-ignore lint/suspicious/noExplicitAny: 생성되는 ZodUnion의 타입을 추적하기 어려움\n            ) as [AnyZodObject, z.ZodUnion<any> | AnyZodLiteral];\n\n            let keys: string[] = [];\n            if (literalOrUnion instanceof z.ZodUnion) {\n              keys = literalOrUnion.def.options.map(\n                (option: { def: { values: string[] } }) => option.def.values[0],\n              );\n            } else {\n              keys = (literalOrUnion as z.ZodLiteral<string>).def.values;\n            }\n            const keyRecord = Object.fromEntries(keys.map((key) => [key, true as const]));\n            if (refType.id === \"Pick\") {\n              if (obj.pick) {\n                return obj.pick(keyRecord);\n              }\n            } else {\n              if (obj.omit) {\n                return obj.omit(keyRecord);\n              }\n            }\n          }\n          if ([\"Partial\"].includes(refType.id)) {\n            if (refType.args?.length !== 1) {\n              throw new Error(`잘못된 ${refType.id}`);\n            }\n            const obj = getZodTypeFromApiParamType(refType.args[0], references);\n            // biome-ignore lint/suspicious/noExplicitAny: Partial 인수 타입 캐스팅\n            return (obj as z.ZodObject<any>).partial();\n          }\n          const reference = references[refType.id];\n          if (reference === undefined) {\n            return z.unknown();\n            // throw new Error(`ref 참조 불가 ${refType.id}`);\n          }\n          return reference;\n        }\n        case \"union\": {\n          const unionType = paramType as {\n            t: string;\n            types: ApiParamType[];\n          };\n          // nullable 유니온\n          if (unionType.types.length === 2 && unionType.types.some((type) => type === \"null\")) {\n            if (unionType.types[0] === \"null\") {\n              return getZodTypeFromApiParamType(unionType.types[1], references).nullable();\n            } else {\n              return getZodTypeFromApiParamType(unionType.types[0], references).nullable();\n            }\n          }\n          // 일반 유니온\n          return z.union(\n            unionType.types.map((type) => getZodTypeFromApiParamType(type, references)),\n          );\n        }\n        case \"intersection\": {\n          const intersectionType = paramType as {\n            t: string;\n            types: ApiParamType[];\n          };\n          return intersectionType.types.reduce(\n            (result, type, index) => {\n              const resolvedType = getZodTypeFromApiParamType(type, references);\n              if (index === 0) {\n                return resolvedType;\n              } else {\n                return z.intersection(result, resolvedType);\n              }\n            },\n            z.unknown() as z.ZodType<unknown>,\n          );\n        }\n        case \"tuple-type\": {\n          const tupleType = paramType as ApiParamType.TupleType;\n          return z.tuple(\n            // biome-ignore lint/suspicious/noExplicitAny: 생성되는 ZodTuple의 타입을 추적하기 어려움\n            tupleType.elements.map((elem) => getZodTypeFromApiParamType(elem, references)) as any,\n          );\n        }\n      }\n      return z.unknown();\n    }\n  }\n}\n\n/**\n * ApiParam 배열을 ZodObject로 변환합니다.\n * 각 파라미터의 optional 여부를 반영하여 Zod 스키마를 생성합니다.\n */\nexport function getZodObjectFromApiParams(\n  apiParams: ApiParam[],\n  references: {\n    [id: string]: AnyZodObject;\n  } = {},\n): z.ZodObject {\n  return z.object(\n    Object.fromEntries(\n      apiParams.map((param) => {\n        let zodType = getZodTypeFromApiParamType(param.type, references);\n        if (param.optional) {\n          zodType = zodType.optional();\n        }\n        return [param.name, zodType];\n      }),\n    ),\n  );\n}\n\n/**\n * ExtendedApi를 ZodObject로 변환합니다.\n * TypeParameter와 일반 파라미터를 처리하며,\n * Context, RefKnex, _로 시작하는 optional 파라미터는 제외합니다.\n */\nexport function getZodObjectFromApi(\n  api: ExtendedApi,\n  references: {\n    [id: string]: AnyZodObject;\n  } = {},\n) {\n  if (api.typeParameters?.length > 0) {\n    for (const typeParam of api.typeParameters) {\n      if (typeParam.constraint) {\n        const zodType = getZodTypeFromApiParamType(typeParam.constraint, references);\n        // biome-ignore lint/suspicious/noExplicitAny: 레퍼런스 타입 캐스팅\n        (references[typeParam.id] as z.ZodType<any>) = zodType;\n      }\n    }\n  }\n  const ReqType = getZodObjectFromApiParams(\n    // api parsing한 결과가 api params\n    api.parameters.filter(\n      (param) =>\n        !ApiParamType.isContext(param.type) &&\n        !ApiParamType.isRefKnex(param.type) &&\n        !(param.optional === true && param.name.startsWith(\"_\")), // _로 시작하는 파라미터는 제외\n    ),\n    references,\n  );\n  return ReqType;\n}\n\n/*\n * API 타입 정의를 TypeScript 코드 문자열로 변환하기 위한 함수들입니다.\n */\n\n/**\n * ApiParamType을 TypeScript 타입 문자열로 변환합니다.\n * union, intersection, array, ref 등 모든 타입을 TS 문법으로 표현하며,\n * import가 필요한 타입 ID는 injectImportKeys에 수집합니다.\n */\nexport function apiParamTypeToTsType(paramType: ApiParamType, injectImportKeys: string[]): string {\n  if (\n    [\n      \"string\",\n      \"number\",\n      \"boolean\",\n      \"true\",\n      \"false\",\n      \"null\",\n      \"undefined\",\n      \"void\",\n      \"any\",\n      \"unknown\",\n    ].includes(paramType as string)\n  ) {\n    return paramType as string;\n  } else if (ApiParamType.isObject(paramType)) {\n    return `{ ${apiParamToTsCode(paramType.props, injectImportKeys)} }`;\n  } else if (ApiParamType.isStringLiteral(paramType)) {\n    return `\"${paramType.value}\"`;\n  } else if (ApiParamType.isNumericLiteral(paramType)) {\n    return String(paramType.value);\n  } else if (ApiParamType.isUnion(paramType)) {\n    return paramType.types.map((type) => apiParamTypeToTsType(type, injectImportKeys)).join(\" | \");\n  } else if (ApiParamType.isIntersection(paramType)) {\n    return paramType.types.map((type) => apiParamTypeToTsType(type, injectImportKeys)).join(\" & \");\n  } else if (ApiParamType.isArray(paramType)) {\n    return `${apiParamTypeToTsType(paramType.elementsType, injectImportKeys)}[]`;\n  } else if (ApiParamType.isRef(paramType)) {\n    if ([\"Pick\", \"Omit\", \"Promise\", \"Partial\", \"Date\"].includes(paramType.id) === false) {\n      // importKeys 인젝션\n      injectImportKeys.push(paramType.id);\n    }\n    if (paramType.args === undefined || paramType.args.length === 0) {\n      return paramType.id;\n    } else {\n      return `${paramType.id}<${paramType.args\n        .map((arg) => apiParamTypeToTsType(arg, injectImportKeys))\n        .join(\",\")}>`;\n    }\n  } else if (ApiParamType.isIndexedAccess(paramType)) {\n    return `${apiParamTypeToTsType(\n      paramType.object,\n      injectImportKeys,\n    )}[${apiParamTypeToTsType(paramType.index, injectImportKeys)}]`;\n  } else if (ApiParamType.isTupleType(paramType)) {\n    return `[ ${paramType.elements.map((elem) => apiParamTypeToTsType(elem, injectImportKeys))} ]`;\n  } else if (ApiParamType.isTypeParam(paramType)) {\n    return `${paramType.id}${\n      paramType.constraint\n        ? ` extends ${apiParamTypeToTsType(paramType.constraint, injectImportKeys)}`\n        : \"\"\n    }`;\n  } else {\n    throw new Error(`resolve 불가 ApiParamType ${paramType}`);\n  }\n}\n\n/**\n * ApiParam 배열을 TypeScript 함수 파라미터 코드로 변환합니다.\n * 예: \"name: string, age?: number, active: boolean = true\"\n */\nexport function apiParamToTsCode(params: ApiParam[], injectImportKeys: string[]): string {\n  return params\n    .map((param) => {\n      return `${param.name}${\n        param.optional && !param.defaultDef ? \"?\" : \"\"\n      }: ${apiParamTypeToTsType(param.type, injectImportKeys)}${\n        param.defaultDef ? `= ${param.defaultDef}` : \"\"\n      }`;\n    })\n    .join(\", \");\n}\n\n/**\n * ApiParam 배열을 TypeScript 객체 타입 코드로 변환합니다.\n * 예: \"{ name: string, age?: number, active: boolean = true }\"\n */\nexport function apiParamToTsCodeAsObject(params: ApiParam[], injectImportKeys: string[]): string {\n  return `{ ${params\n    .map(\n      (param) =>\n        `${param.name}${param.optional ? \"?\" : \"\"}: ${apiParamTypeToTsType(\n          param.type,\n          injectImportKeys,\n        )}${param.defaultDef ? `= ${param.defaultDef}` : \"\"}`,\n    )\n    .join(\", \")} }`;\n}\n"],"names":["z","ApiParamType","unwrapPromiseOnce","paramType","isPromise","args","getZodTypeFromApiParamType","references","string","number","boolean","advType","t","literal","value","objType","getZodObjectFromApiParams","props","arrType","array","elementsType","refType","id","date","includes","length","Error","obj","literalOrUnion","map","arg","keys","ZodUnion","def","options","option","values","keyRecord","Object","fromEntries","key","pick","omit","partial","reference","undefined","unknown","unionType","types","some","type","nullable","union","intersectionType","reduce","result","index","resolvedType","intersection","tupleType","tuple","elements","elem","apiParams","object","param","zodType","optional","name","getZodObjectFromApi","api","typeParameters","typeParam","constraint","ReqType","parameters","filter","isContext","isRefKnex","startsWith","apiParamTypeToTsType","injectImportKeys","isObject","apiParamToTsCode","isStringLiteral","isNumericLiteral","String","isUnion","join","isIntersection","isArray","isRef","push","isIndexedAccess","isTupleType","isTypeParam","params","defaultDef","apiParamToTsCodeAsObject"],"mappings":"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"}
@@ -18,11 +18,11 @@ export function defineConfig(config) {
18
18
  * @returns
19
19
  */ export async function loadConfig(rootPath) {
20
20
  const start = performance.now();
21
- const configPath = process.env.HOT === "yes" || process.env.VITEST === "true" ? `${rootPath}/sonamu.config.ts` : `${rootPath}/dist/sonamu.config.js`;
21
+ const configPath = process.env.HOT === "yes" || process.env.VITEST === "true" ? `${rootPath}/src/sonamu.config.ts` : `${rootPath}/dist/sonamu.config.js`;
22
22
  const { default: config } = await import(`file://${configPath}`);
23
23
  const importTime = performance.now() - start;
24
24
  process.env.NODE_ENV !== "test" && console.log(`[TIMING] loadConfig took ${importTime.toFixed(2)}ms`);
25
25
  return config;
26
26
  }
27
27
 
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcGkvY29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmFzdGlmeUNvcnNPcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L2NvcnNcIjtcbmltcG9ydCB0eXBlIHsgRmFzdGlmeUZvcm1ib2R5T3B0aW9ucyB9IGZyb20gXCJAZmFzdGlmeS9mb3JtYm9keVwiO1xuaW1wb3J0IHR5cGUgeyBGYXN0aWZ5TXVsdGlwYXJ0T3B0aW9ucyB9IGZyb20gXCJAZmFzdGlmeS9tdWx0aXBhcnRcIjtcbmltcG9ydCB0eXBlIHsgRGVzZXJpYWxpemVGdW5jdGlvbiwgU2VyaWFsaXplRnVuY3Rpb24gfSBmcm9tIFwiQGZhc3RpZnkvcGFzc3BvcnQvZGlzdC9BdXRoZW50aWNhdG9yXCI7XG5pbXBvcnQgdHlwZSB7IFNlY3VyZVNlc3Npb25QbHVnaW5PcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L3NlY3VyZS1zZXNzaW9uXCI7XG5pbXBvcnQgdHlwZSB7IEZhc3RpZnlTdGF0aWNPcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L3N0YXRpY1wiO1xuaW1wb3J0IHR5cGUgeyBGYXN0aWZ5SW5zdGFuY2UsIEZhc3RpZnlSZXBseSwgRmFzdGlmeVJlcXVlc3QsIEZhc3RpZnlTZXJ2ZXJPcHRpb25zIH0gZnJvbSBcImZhc3RpZnlcIjtcbmltcG9ydCB0eXBlIHsgUXNQbHVnaW5PcHRpb25zIH0gZnJvbSBcImZhc3RpZnktcXNcIjtcbmltcG9ydCB0eXBlIHsgU3NlUGx1Z2luT3B0aW9ucyB9IGZyb20gXCJmYXN0aWZ5LXNzZS12Mi9saWIvdHlwZXNcIjtcbmltcG9ydCB0eXBlIHsgS25leCB9IGZyb20gXCJrbmV4XCI7XG5pbXBvcnQgdHlwZSB7IERyaXZlciB9IGZyb20gXCIuLi9maWxlLXN0b3JhZ2UvZHJpdmVyXCI7XG5pbXBvcnQgdHlwZSB7IFNvbmFtdUZhc3RpZnlDb25maWcgfSBmcm9tIFwiLi4vdHlwZXMvdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgRGF0YWJhc2VDb25maWcgPSBPbWl0PEtuZXguQ29uZmlnLCBcImNvbm5lY3Rpb25cIj4gJiB7XG4gIGNvbm5lY3Rpb24/OiBLbmV4LlBnQ29ubmVjdGlvbkNvbmZpZztcbn07XG5cbmV4cG9ydCB0eXBlIFNvbmFtdUNvbmZpZyA9IHtcbiAgcHJvamVjdE5hbWU/OiBzdHJpbmc7XG5cbiAgYXBpOiB7XG4gICAgZGlyOiBzdHJpbmc7XG4gICAgcm91dGU6IHtcbiAgICAgIHByZWZpeDogc3RyaW5nO1xuICAgIH07XG4gICAgdGltZXpvbmU/OiBzdHJpbmc7XG4gIH07XG4gIHN5bmM6IHtcbiAgICB0YXJnZXRzOiBzdHJpbmdbXTsgLy8gXCJ3ZWJcIiwgXCJhcHBcIiDrk7FcbiAgfTtcbiAgdWk/OiB7XG4gICAgcG9ydDogbnVtYmVyO1xuICB9O1xuXG4gIGRhdGFiYXNlOiB7XG4gICAgLy8g642w7J207YSw67Kg7J207IqkXG4gICAgZGF0YWJhc2U/OiBcInBvc3RncmVzcWxcIjtcbiAgICAvLyDquLDrs7gg642w7J207YSw67Kg7J207IqkIOydtOumhFxuICAgIG5hbWU6IHN0cmluZztcbiAgICAvLyDrqqjrk6Ag7ZmY6rK97JeQIOyggeyaqeuQoCDquLDrs7ggS25leCDsmLXshZhcbiAgICBkZWZhdWx0T3B0aW9uczogRGF0YWJhc2VDb25maWc7XG4gICAgLy8g7ZmY6rK967OEIOyEpOyglVxuICAgIGVudmlyb25tZW50cz86IHtcbiAgICAgIGRldmVsb3BtZW50PzogRGF0YWJhc2VDb25maWc7XG4gICAgICBkZXZlbG9wbWVudF9zbGF2ZT86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcHJvZHVjdGlvbj86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcHJvZHVjdGlvbl9zbGF2ZT86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcmVtb3RlX2ZpeHR1cmU/OiBEYXRhYmFzZUNvbmZpZztcbiAgICB9O1xuICB9O1xuXG4gIHNlcnZlcjogU29uYW11U2VydmVyT3B0aW9ucztcbn07XG5cbmV4cG9ydCB0eXBlIFNvbmFtdVNlcnZlck9wdGlvbnMgPSB7XG4gIGZhc3RpZnk/OiBGYXN0aWZ5U2VydmVyT3B0aW9ucztcblxuICBsaXN0ZW4/OiB7XG4gICAgcG9ydDogbnVtYmVyO1xuICAgIGhvc3Q/OiBzdHJpbmc7XG4gIH07XG5cbiAgcGx1Z2lucz86IHtcbiAgICBjb3JzPzogYm9vbGVhbiB8IEZhc3RpZnlDb3JzT3B0aW9ucztcbiAgICBmb3JtYm9keT86IGJvb2xlYW4gfCBGYXN0aWZ5Rm9ybWJvZHlPcHRpb25zO1xuICAgIG11bHRpcGFydD86IGJvb2xlYW4gfCBGYXN0aWZ5TXVsdGlwYXJ0T3B0aW9ucztcbiAgICBxcz86IGJvb2xlYW4gfCBRc1BsdWdpbk9wdGlvbnM7XG4gICAgc3NlPzogYm9vbGVhbiB8IFNzZVBsdWdpbk9wdGlvbnM7XG4gICAgc3RhdGljPzogYm9vbGVhbiB8IEZhc3RpZnlTdGF0aWNPcHRpb25zO1xuICAgIHNlc3Npb24/OiBib29sZWFuIHwgU2VjdXJlU2Vzc2lvblBsdWdpbk9wdGlvbnM7XG5cbiAgICBjdXN0b20/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IHZvaWQ7XG4gIH07XG5cbiAgYXV0aD86XG4gICAgfCBib29sZWFuXG4gICAgfCB7XG4gICAgICAgIHVzZXJTZXJpYWxpemVyOiBTZXJpYWxpemVGdW5jdGlvbjx1bmtub3duLCB1bmtub3duPjtcbiAgICAgICAgdXNlckRlc2VyaWFsaXplcjogRGVzZXJpYWxpemVGdW5jdGlvbjx1bmtub3duLCB1bmtub3duPjtcbiAgICAgIH07XG5cbiAgYXBpQ29uZmlnOiBTb25hbXVGYXN0aWZ5Q29uZmlnO1xuXG4gIHN0b3JhZ2U/OiBEcml2ZXI7XG5cbiAgbGlmZWN5Y2xlPzoge1xuICAgIG9uU3RhcnQ/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuICAgIG9uU2h1dGRvd24/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuICAgIG9uRXJyb3I/OiAoZXJyb3I6IEVycm9yLCByZXF1ZXN0OiBGYXN0aWZ5UmVxdWVzdCwgcmVwbHk6IEZhc3RpZnlSZXBseSkgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWQ7XG4gIH07XG59O1xuXG4vLyBOT1RFKEhhemUsIDI1MTIwOSk6IGNvbmZpZ+yXkOuKlCBULCBQcm9taXNlPFQ+LCAoKSA9PiBULCAoKSA9PiBQcm9taXNlPFQ+6rCAIOuqqOuRkCDsmKwg7IiYIOyeiOyWtOyVvCDtlaguXG5leHBvcnQgdHlwZSBTb25hbXVDb25maWdFeHBvcnQgPVxuICB8IFNvbmFtdUNvbmZpZ1xuICB8IFByb21pc2U8U29uYW11Q29uZmlnPlxuICB8ICgoKSA9PiBTb25hbXVDb25maWcpXG4gIHwgKCgpID0+IFByb21pc2U8U29uYW11Q29uZmlnPik7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVDb25maWcoY29uZmlnOiBTb25hbXVDb25maWcpOiBQcm9taXNlPFNvbmFtdUNvbmZpZz47XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29uZmlnKGNvbmZpZzogUHJvbWlzZTxTb25hbXVDb25maWc+KTogUHJvbWlzZTxTb25hbXVDb25maWc+O1xuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZUNvbmZpZyhjb25maWc6ICgpID0+IFNvbmFtdUNvbmZpZyk6IFByb21pc2U8U29uYW11Q29uZmlnPjtcbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVDb25maWcoY29uZmlnOiAoKSA9PiBQcm9taXNlPFNvbmFtdUNvbmZpZz4pOiBQcm9taXNlPFNvbmFtdUNvbmZpZz47XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29uZmlnKGNvbmZpZzogU29uYW11Q29uZmlnRXhwb3J0KTogUHJvbWlzZTxTb25hbXVDb25maWc+IHtcbiAgaWYgKHR5cGVvZiBjb25maWcgPT09IFwiZnVuY3Rpb25cIikge1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoY29uZmlnKCkpO1xuICB9XG5cbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShjb25maWcpO1xufVxuXG4vKipcbiAqIHNvbmFtdS5jb25maWcudHMg7YyM7J287J2EIOuhnOuTnO2VqeuLiOuLpC5cbiAqIOydtCDshKTsoJUg7YyM7J287J2AIO2ZmOqyveyXkCDrlLDrnbwg64uk66W4IOqyveuhnOyXkCDsnojsnYQg7IiYIOyeiOyKteuLiOuLpC5cbiAqIGRpc3Trpbwg67mM65Oc7ZWY64qUIO2ZmOqyveydtOudvOuptCBkaXN0IOuwlOuhnCDslYTrnpjsl5Ag7J6I7J2EIOqyg+ydtOqzoChjbGktd3JhcHBlci50c+yXkOyEnCDruYzrk5wpLFxuICog6re466CH7KeAIOyViuydgCDtmZjqsr3snbTrnbzrqbQg7ZSE66Gc7KCd7Yq4IOujqO2KuOyXkCDsnojsnYQg6rKD7J6F64uI64ukLlxuICpcbiAqIOydtCDtlajsiJjripQg7J2Y64+E7KCB7Jy866GcIOuLpOuluCDsnZjsobTshLHsnZgg7IKs7Jqp7J2EIOy1nOuMgO2VnCDrsLDsoJztlZjsmIDsirXri4jri6QuXG4gKiDsnbTripQg7Iuk7ZaJIOy0iOq4sOyXkCDstZzrjIDtlZwg67mg66W06rKMIOyEpOygleydhCDsnb3slrTsmKwg7IiYIOyeiOuPhOuhnSDtlZjquLAg7JyE7ZWo7J6F64uI64ukLlxuICog65Sw65287IScIOqyveuhnCBjb25jYXTqs7wgVVJMIHNjaGVtZSDstpTqsIDrj4Qg64uo7Iic7ZWcIOusuOyekOyXtCDsobDsnpHsnLzroZwg7LKY66as7ZWY7JiA7Iq164uI64ukLlxuICpcbiAqIEBwYXJhbSByb290UGF0aFxuICogQHJldHVybnNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvYWRDb25maWcocm9vdFBhdGg6IHN0cmluZyk6IFByb21pc2U8U29uYW11Q29uZmlnPiB7XG4gIGNvbnN0IHN0YXJ0ID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gIGNvbnN0IGNvbmZpZ1BhdGggPVxuICAgIHByb2Nlc3MuZW52LkhPVCA9PT0gXCJ5ZXNcIiB8fCBwcm9jZXNzLmVudi5WSVRFU1QgPT09IFwidHJ1ZVwiXG4gICAgICA/IGAke3Jvb3RQYXRofS9zb25hbXUuY29uZmlnLnRzYFxuICAgICAgOiBgJHtyb290UGF0aH0vZGlzdC9zb25hbXUuY29uZmlnLmpzYDtcbiAgY29uc3QgeyBkZWZhdWx0OiBjb25maWcgfSA9IGF3YWl0IGltcG9ydChgZmlsZTovLyR7Y29uZmlnUGF0aH1gKTtcbiAgY29uc3QgaW1wb3J0VGltZSA9IHBlcmZvcm1hbmNlLm5vdygpIC0gc3RhcnQ7XG4gIHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSBcInRlc3RcIiAmJlxuICAgIGNvbnNvbGUubG9nKGBbVElNSU5HXSBsb2FkQ29uZmlnIHRvb2sgJHtpbXBvcnRUaW1lLnRvRml4ZWQoMil9bXNgKTtcbiAgcmV0dXJuIGNvbmZpZztcbn1cbiJdLCJuYW1lcyI6WyJkZWZpbmVDb25maWciLCJjb25maWciLCJQcm9taXNlIiwicmVzb2x2ZSIsImxvYWRDb25maWciLCJyb290UGF0aCIsInN0YXJ0IiwicGVyZm9ybWFuY2UiLCJub3ciLCJjb25maWdQYXRoIiwicHJvY2VzcyIsImVudiIsIkhPVCIsIlZJVEVTVCIsImRlZmF1bHQiLCJpbXBvcnRUaW1lIiwiTk9ERV9FTlYiLCJjb25zb2xlIiwibG9nIiwidG9GaXhlZCJdLCJtYXBwaW5ncyI6IkFBdUdBLE9BQU8sU0FBU0EsYUFBYUMsTUFBMEI7SUFDckQsSUFBSSxPQUFPQSxXQUFXLFlBQVk7UUFDaEMsT0FBT0MsUUFBUUMsT0FBTyxDQUFDRjtJQUN6QjtJQUVBLE9BQU9DLFFBQVFDLE9BQU8sQ0FBQ0Y7QUFDekI7QUFFQTs7Ozs7Ozs7Ozs7O0NBWUMsR0FDRCxPQUFPLGVBQWVHLFdBQVdDLFFBQWdCO0lBQy9DLE1BQU1DLFFBQVFDLFlBQVlDLEdBQUc7SUFDN0IsTUFBTUMsYUFDSkMsUUFBUUMsR0FBRyxDQUFDQyxHQUFHLEtBQUssU0FBU0YsUUFBUUMsR0FBRyxDQUFDRSxNQUFNLEtBQUssU0FDaEQsR0FBR1IsU0FBUyxpQkFBaUIsQ0FBQyxHQUM5QixHQUFHQSxTQUFTLHNCQUFzQixDQUFDO0lBQ3pDLE1BQU0sRUFBRVMsU0FBU2IsTUFBTSxFQUFFLEdBQUcsTUFBTSxNQUFNLENBQUMsQ0FBQyxPQUFPLEVBQUVRLFlBQVk7SUFDL0QsTUFBTU0sYUFBYVIsWUFBWUMsR0FBRyxLQUFLRjtJQUN2Q0ksUUFBUUMsR0FBRyxDQUFDSyxRQUFRLEtBQUssVUFDdkJDLFFBQVFDLEdBQUcsQ0FBQyxDQUFDLHlCQUF5QixFQUFFSCxXQUFXSSxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7SUFDbkUsT0FBT2xCO0FBQ1QifQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcGkvY29uZmlnLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmFzdGlmeUNvcnNPcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L2NvcnNcIjtcbmltcG9ydCB0eXBlIHsgRmFzdGlmeUZvcm1ib2R5T3B0aW9ucyB9IGZyb20gXCJAZmFzdGlmeS9mb3JtYm9keVwiO1xuaW1wb3J0IHR5cGUgeyBGYXN0aWZ5TXVsdGlwYXJ0T3B0aW9ucyB9IGZyb20gXCJAZmFzdGlmeS9tdWx0aXBhcnRcIjtcbmltcG9ydCB0eXBlIHsgRGVzZXJpYWxpemVGdW5jdGlvbiwgU2VyaWFsaXplRnVuY3Rpb24gfSBmcm9tIFwiQGZhc3RpZnkvcGFzc3BvcnQvZGlzdC9BdXRoZW50aWNhdG9yXCI7XG5pbXBvcnQgdHlwZSB7IFNlY3VyZVNlc3Npb25QbHVnaW5PcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L3NlY3VyZS1zZXNzaW9uXCI7XG5pbXBvcnQgdHlwZSB7IEZhc3RpZnlTdGF0aWNPcHRpb25zIH0gZnJvbSBcIkBmYXN0aWZ5L3N0YXRpY1wiO1xuaW1wb3J0IHR5cGUgeyBGYXN0aWZ5SW5zdGFuY2UsIEZhc3RpZnlSZXBseSwgRmFzdGlmeVJlcXVlc3QsIEZhc3RpZnlTZXJ2ZXJPcHRpb25zIH0gZnJvbSBcImZhc3RpZnlcIjtcbmltcG9ydCB0eXBlIHsgUXNQbHVnaW5PcHRpb25zIH0gZnJvbSBcImZhc3RpZnktcXNcIjtcbmltcG9ydCB0eXBlIHsgU3NlUGx1Z2luT3B0aW9ucyB9IGZyb20gXCJmYXN0aWZ5LXNzZS12Mi9saWIvdHlwZXNcIjtcbmltcG9ydCB0eXBlIHsgS25leCB9IGZyb20gXCJrbmV4XCI7XG5pbXBvcnQgdHlwZSB7IERyaXZlciB9IGZyb20gXCIuLi9maWxlLXN0b3JhZ2UvZHJpdmVyXCI7XG5pbXBvcnQgdHlwZSB7IFNvbmFtdUZhc3RpZnlDb25maWcgfSBmcm9tIFwiLi4vdHlwZXMvdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgRGF0YWJhc2VDb25maWcgPSBPbWl0PEtuZXguQ29uZmlnLCBcImNvbm5lY3Rpb25cIj4gJiB7XG4gIGNvbm5lY3Rpb24/OiBLbmV4LlBnQ29ubmVjdGlvbkNvbmZpZztcbn07XG5cbmV4cG9ydCB0eXBlIFNvbmFtdUNvbmZpZyA9IHtcbiAgcHJvamVjdE5hbWU/OiBzdHJpbmc7XG5cbiAgYXBpOiB7XG4gICAgZGlyOiBzdHJpbmc7XG4gICAgcm91dGU6IHtcbiAgICAgIHByZWZpeDogc3RyaW5nO1xuICAgIH07XG4gICAgdGltZXpvbmU/OiBzdHJpbmc7XG4gIH07XG4gIHN5bmM6IHtcbiAgICB0YXJnZXRzOiBzdHJpbmdbXTsgLy8gXCJ3ZWJcIiwgXCJhcHBcIiDrk7FcbiAgfTtcbiAgdWk/OiB7XG4gICAgcG9ydDogbnVtYmVyO1xuICB9O1xuXG4gIGRhdGFiYXNlOiB7XG4gICAgLy8g642w7J207YSw67Kg7J207IqkXG4gICAgZGF0YWJhc2U/OiBcInBvc3RncmVzcWxcIjtcbiAgICAvLyDquLDrs7gg642w7J207YSw67Kg7J207IqkIOydtOumhFxuICAgIG5hbWU6IHN0cmluZztcbiAgICAvLyDrqqjrk6Ag7ZmY6rK97JeQIOyggeyaqeuQoCDquLDrs7ggS25leCDsmLXshZhcbiAgICBkZWZhdWx0T3B0aW9uczogRGF0YWJhc2VDb25maWc7XG4gICAgLy8g7ZmY6rK967OEIOyEpOyglVxuICAgIGVudmlyb25tZW50cz86IHtcbiAgICAgIGRldmVsb3BtZW50PzogRGF0YWJhc2VDb25maWc7XG4gICAgICBkZXZlbG9wbWVudF9zbGF2ZT86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcHJvZHVjdGlvbj86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcHJvZHVjdGlvbl9zbGF2ZT86IERhdGFiYXNlQ29uZmlnO1xuICAgICAgcmVtb3RlX2ZpeHR1cmU/OiBEYXRhYmFzZUNvbmZpZztcbiAgICB9O1xuICB9O1xuXG4gIHNlcnZlcjogU29uYW11U2VydmVyT3B0aW9ucztcbn07XG5cbmV4cG9ydCB0eXBlIFNvbmFtdVNlcnZlck9wdGlvbnMgPSB7XG4gIGZhc3RpZnk/OiBGYXN0aWZ5U2VydmVyT3B0aW9ucztcblxuICBsaXN0ZW4/OiB7XG4gICAgcG9ydDogbnVtYmVyO1xuICAgIGhvc3Q/OiBzdHJpbmc7XG4gIH07XG5cbiAgcGx1Z2lucz86IHtcbiAgICBjb3JzPzogYm9vbGVhbiB8IEZhc3RpZnlDb3JzT3B0aW9ucztcbiAgICBmb3JtYm9keT86IGJvb2xlYW4gfCBGYXN0aWZ5Rm9ybWJvZHlPcHRpb25zO1xuICAgIG11bHRpcGFydD86IGJvb2xlYW4gfCBGYXN0aWZ5TXVsdGlwYXJ0T3B0aW9ucztcbiAgICBxcz86IGJvb2xlYW4gfCBRc1BsdWdpbk9wdGlvbnM7XG4gICAgc3NlPzogYm9vbGVhbiB8IFNzZVBsdWdpbk9wdGlvbnM7XG4gICAgc3RhdGljPzogYm9vbGVhbiB8IEZhc3RpZnlTdGF0aWNPcHRpb25zO1xuICAgIHNlc3Npb24/OiBib29sZWFuIHwgU2VjdXJlU2Vzc2lvblBsdWdpbk9wdGlvbnM7XG5cbiAgICBjdXN0b20/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IHZvaWQ7XG4gIH07XG5cbiAgYXV0aD86XG4gICAgfCBib29sZWFuXG4gICAgfCB7XG4gICAgICAgIHVzZXJTZXJpYWxpemVyOiBTZXJpYWxpemVGdW5jdGlvbjx1bmtub3duLCB1bmtub3duPjtcbiAgICAgICAgdXNlckRlc2VyaWFsaXplcjogRGVzZXJpYWxpemVGdW5jdGlvbjx1bmtub3duLCB1bmtub3duPjtcbiAgICAgIH07XG5cbiAgYXBpQ29uZmlnOiBTb25hbXVGYXN0aWZ5Q29uZmlnO1xuXG4gIHN0b3JhZ2U/OiBEcml2ZXI7XG5cbiAgbGlmZWN5Y2xlPzoge1xuICAgIG9uU3RhcnQ/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuICAgIG9uU2h1dGRvd24/OiAoc2VydmVyOiBGYXN0aWZ5SW5zdGFuY2UpID0+IFByb21pc2U8dm9pZD4gfCB2b2lkO1xuICAgIG9uRXJyb3I/OiAoZXJyb3I6IEVycm9yLCByZXF1ZXN0OiBGYXN0aWZ5UmVxdWVzdCwgcmVwbHk6IEZhc3RpZnlSZXBseSkgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWQ7XG4gIH07XG59O1xuXG4vLyBOT1RFKEhhemUsIDI1MTIwOSk6IGNvbmZpZ+yXkOuKlCBULCBQcm9taXNlPFQ+LCAoKSA9PiBULCAoKSA9PiBQcm9taXNlPFQ+6rCAIOuqqOuRkCDsmKwg7IiYIOyeiOyWtOyVvCDtlaguXG5leHBvcnQgdHlwZSBTb25hbXVDb25maWdFeHBvcnQgPVxuICB8IFNvbmFtdUNvbmZpZ1xuICB8IFByb21pc2U8U29uYW11Q29uZmlnPlxuICB8ICgoKSA9PiBTb25hbXVDb25maWcpXG4gIHwgKCgpID0+IFByb21pc2U8U29uYW11Q29uZmlnPik7XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVDb25maWcoY29uZmlnOiBTb25hbXVDb25maWcpOiBQcm9taXNlPFNvbmFtdUNvbmZpZz47XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29uZmlnKGNvbmZpZzogUHJvbWlzZTxTb25hbXVDb25maWc+KTogUHJvbWlzZTxTb25hbXVDb25maWc+O1xuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZUNvbmZpZyhjb25maWc6ICgpID0+IFNvbmFtdUNvbmZpZyk6IFByb21pc2U8U29uYW11Q29uZmlnPjtcbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVDb25maWcoY29uZmlnOiAoKSA9PiBQcm9taXNlPFNvbmFtdUNvbmZpZz4pOiBQcm9taXNlPFNvbmFtdUNvbmZpZz47XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29uZmlnKGNvbmZpZzogU29uYW11Q29uZmlnRXhwb3J0KTogUHJvbWlzZTxTb25hbXVDb25maWc+IHtcbiAgaWYgKHR5cGVvZiBjb25maWcgPT09IFwiZnVuY3Rpb25cIikge1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUoY29uZmlnKCkpO1xuICB9XG5cbiAgcmV0dXJuIFByb21pc2UucmVzb2x2ZShjb25maWcpO1xufVxuXG4vKipcbiAqIHNvbmFtdS5jb25maWcudHMg7YyM7J287J2EIOuhnOuTnO2VqeuLiOuLpC5cbiAqIOydtCDshKTsoJUg7YyM7J287J2AIO2ZmOqyveyXkCDrlLDrnbwg64uk66W4IOqyveuhnOyXkCDsnojsnYQg7IiYIOyeiOyKteuLiOuLpC5cbiAqIGRpc3Trpbwg67mM65Oc7ZWY64qUIO2ZmOqyveydtOudvOuptCBkaXN0IOuwlOuhnCDslYTrnpjsl5Ag7J6I7J2EIOqyg+ydtOqzoChjbGktd3JhcHBlci50c+yXkOyEnCDruYzrk5wpLFxuICog6re466CH7KeAIOyViuydgCDtmZjqsr3snbTrnbzrqbQg7ZSE66Gc7KCd7Yq4IOujqO2KuOyXkCDsnojsnYQg6rKD7J6F64uI64ukLlxuICpcbiAqIOydtCDtlajsiJjripQg7J2Y64+E7KCB7Jy866GcIOuLpOuluCDsnZjsobTshLHsnZgg7IKs7Jqp7J2EIOy1nOuMgO2VnCDrsLDsoJztlZjsmIDsirXri4jri6QuXG4gKiDsnbTripQg7Iuk7ZaJIOy0iOq4sOyXkCDstZzrjIDtlZwg67mg66W06rKMIOyEpOygleydhCDsnb3slrTsmKwg7IiYIOyeiOuPhOuhnSDtlZjquLAg7JyE7ZWo7J6F64uI64ukLlxuICog65Sw65287IScIOqyveuhnCBjb25jYXTqs7wgVVJMIHNjaGVtZSDstpTqsIDrj4Qg64uo7Iic7ZWcIOusuOyekOyXtCDsobDsnpHsnLzroZwg7LKY66as7ZWY7JiA7Iq164uI64ukLlxuICpcbiAqIEBwYXJhbSByb290UGF0aFxuICogQHJldHVybnNcbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvYWRDb25maWcocm9vdFBhdGg6IHN0cmluZyk6IFByb21pc2U8U29uYW11Q29uZmlnPiB7XG4gIGNvbnN0IHN0YXJ0ID0gcGVyZm9ybWFuY2Uubm93KCk7XG4gIGNvbnN0IGNvbmZpZ1BhdGggPVxuICAgIHByb2Nlc3MuZW52LkhPVCA9PT0gXCJ5ZXNcIiB8fCBwcm9jZXNzLmVudi5WSVRFU1QgPT09IFwidHJ1ZVwiXG4gICAgICA/IGAke3Jvb3RQYXRofS9zcmMvc29uYW11LmNvbmZpZy50c2BcbiAgICAgIDogYCR7cm9vdFBhdGh9L2Rpc3Qvc29uYW11LmNvbmZpZy5qc2A7XG4gIGNvbnN0IHsgZGVmYXVsdDogY29uZmlnIH0gPSBhd2FpdCBpbXBvcnQoYGZpbGU6Ly8ke2NvbmZpZ1BhdGh9YCk7XG4gIGNvbnN0IGltcG9ydFRpbWUgPSBwZXJmb3JtYW5jZS5ub3coKSAtIHN0YXJ0O1xuICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gXCJ0ZXN0XCIgJiZcbiAgICBjb25zb2xlLmxvZyhgW1RJTUlOR10gbG9hZENvbmZpZyB0b29rICR7aW1wb3J0VGltZS50b0ZpeGVkKDIpfW1zYCk7XG4gIHJldHVybiBjb25maWc7XG59XG4iXSwibmFtZXMiOlsiZGVmaW5lQ29uZmlnIiwiY29uZmlnIiwiUHJvbWlzZSIsInJlc29sdmUiLCJsb2FkQ29uZmlnIiwicm9vdFBhdGgiLCJzdGFydCIsInBlcmZvcm1hbmNlIiwibm93IiwiY29uZmlnUGF0aCIsInByb2Nlc3MiLCJlbnYiLCJIT1QiLCJWSVRFU1QiLCJkZWZhdWx0IiwiaW1wb3J0VGltZSIsIk5PREVfRU5WIiwiY29uc29sZSIsImxvZyIsInRvRml4ZWQiXSwibWFwcGluZ3MiOiJBQXVHQSxPQUFPLFNBQVNBLGFBQWFDLE1BQTBCO0lBQ3JELElBQUksT0FBT0EsV0FBVyxZQUFZO1FBQ2hDLE9BQU9DLFFBQVFDLE9BQU8sQ0FBQ0Y7SUFDekI7SUFFQSxPQUFPQyxRQUFRQyxPQUFPLENBQUNGO0FBQ3pCO0FBRUE7Ozs7Ozs7Ozs7OztDQVlDLEdBQ0QsT0FBTyxlQUFlRyxXQUFXQyxRQUFnQjtJQUMvQyxNQUFNQyxRQUFRQyxZQUFZQyxHQUFHO0lBQzdCLE1BQU1DLGFBQ0pDLFFBQVFDLEdBQUcsQ0FBQ0MsR0FBRyxLQUFLLFNBQVNGLFFBQVFDLEdBQUcsQ0FBQ0UsTUFBTSxLQUFLLFNBQ2hELEdBQUdSLFNBQVMscUJBQXFCLENBQUMsR0FDbEMsR0FBR0EsU0FBUyxzQkFBc0IsQ0FBQztJQUN6QyxNQUFNLEVBQUVTLFNBQVNiLE1BQU0sRUFBRSxHQUFHLE1BQU0sTUFBTSxDQUFDLENBQUMsT0FBTyxFQUFFUSxZQUFZO0lBQy9ELE1BQU1NLGFBQWFSLFlBQVlDLEdBQUcsS0FBS0Y7SUFDdkNJLFFBQVFDLEdBQUcsQ0FBQ0ssUUFBUSxLQUFLLFVBQ3ZCQyxRQUFRQyxHQUFHLENBQUMsQ0FBQyx5QkFBeUIsRUFBRUgsV0FBV0ksT0FBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ25FLE9BQU9sQjtBQUNUIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"decorators.d.ts","sourceRoot":"","sources":["../../src/api/decorators.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAG3C,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAG7B,OAAO,EAGL,KAAK,oBAAoB,EAC1B,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAK7D,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,IAAI,CAAC;IACZ,KAAK,EAAE,IAAI,CAAC;IACZ,IAAI,EAAE,IAAI,CAAC;CACZ;AACD,MAAM,MAAM,QAAQ,GAAG,MAAM,SAAS,CAAC;AACvC,MAAM,MAAM,aAAa,GAAG,OAAO,GAAG,iBAAiB,GAAG,KAAK,GAAG,cAAc,CAAC;AACjF,MAAM,MAAM,mBAAmB,GAAG;IAChC,UAAU,CAAC,EAAE,WAAW,CAAC;IACzB,WAAW,CAAC,EACR,YAAY,GACZ,WAAW,GACX,UAAU,GACV,kBAAkB,GAClB,0BAA0B,CAAC;IAC/B,OAAO,CAAC,EAAE,aAAa,EAAE,CAAC;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AACF,MAAM,MAAM,sBAAsB,GAAG;IACnC,IAAI,EAAE,KAAK,CAAC;IAEZ,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,CAAC,EAAE,QAAQ,EAAE,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AACF,MAAM,MAAM,sBAAsB,GAAG;IACnC,IAAI,CAAC,EAAE,QAAQ,GAAG,UAAU,CAAC;CAC9B,CAAC;AACF,eAAO,MAAM,cAAc,EAAE;IAC3B;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,mBAAmB,CAAC;IAC7B,aAAa,CAAC,EAAE,sBAAsB,CAAC;IACvC,aAAa,CAAC,EAAE,sBAAsB,CAAC;CACxC,EAAO,CAAC;AACT,MAAM,MAAM,WAAW,GAAG;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,mBAAmB,CAAC;IAC7B,aAAa,CAAC,EAAE,sBAAsB,CAAC;IACvC,aAAa,CAAC,EAAE,sBAAsB,CAAC;IACvC,cAAc,EAAE,YAAY,CAAC,SAAS,EAAE,CAAC;IACzC,UAAU,EAAE,QAAQ,EAAE,CAAC;IACvB,UAAU,EAAE,YAAY,CAAC;CAC1B,CAAC;AACF,KAAK,eAAe,GAAG;IAAE,WAAW,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE,CAAA;CAAE,CAAC;AAkBzD,wBAAgB,GAAG,CAAC,OAAO,GAAE,mBAAwB,IAQ3C,QAAQ,eAAe,EAAE,aAAa,MAAM,UAyCrD;AAED,wBAAgB,MAAM,CAAC,OAAO,EAAE,sBAAsB,IAC5C,QAAQ,eAAe,EAAE,aAAa,MAAM,UAqDrD;AAED,wBAAgB,aAAa,CAAC,OAAO,GAAE,oBAAyB,IAGtD,SAAS,eAAe,EAAE,cAAc,MAAM,EAAE,YAAY,kBAAkB,wBA8CvF;AAED;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,OAAO,GAAE,sBAA2B,IACjD,SAAS,eAAe,EAAE,cAAc,MAAM,EAAE,YAAY,kBAAkB,wBAgEvF"}
1
+ {"version":3,"file":"decorators.d.ts","sourceRoot":"","sources":["../../src/api/decorators.ts"],"names":[],"mappings":"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"}
@@ -3,8 +3,8 @@ import inflection from "inflection";
3
3
  import { isEqual } from "radashi";
4
4
  import { DB } from "../database/db.js";
5
5
  import { PuriTransactionWrapper } from "../database/puri-wrapper.js";
6
- import { Sonamu } from "./sonamu.js";
7
6
  import { UpsertBuilder } from "../database/upsert-builder.js";
7
+ import { Sonamu } from "./sonamu.js";
8
8
  export const registeredApis = [];
9
9
  const DECORATOR_TYPES = {
10
10
  API: Symbol("api"),
@@ -233,4 +233,4 @@ newOptions) {
233
233
  });
234
234
  }
235
235
 
236
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/api/decorators.ts"],"sourcesContent":["import assert from \"assert\";\nimport type { HTTPMethods } from \"fastify\";\nimport inflection from \"inflection\";\nimport { isEqual } from \"radashi\";\nimport type { z } from \"zod\";\nimport type { BaseModelClass } from \"../database/base-model\";\nimport { DB } from \"../database/db\";\nimport {\n  PuriTransactionWrapper,\n  type PuriWrapper,\n  type TransactionalOptions,\n} from \"../database/puri-wrapper\";\nimport type { ApiParam, ApiParamType } from \"../types/types\";\nimport type { UploadContext } from \"./context\";\nimport { Sonamu } from \"./sonamu\";\nimport { UpsertBuilder } from \"../database/upsert-builder\";\n\nexport interface GuardKeys {\n  query: true;\n  admin: true;\n  user: true;\n}\nexport type GuardKey = keyof GuardKeys;\nexport type ServiceClient = \"axios\" | \"axios-multipart\" | \"swr\" | \"window-fetch\";\nexport type ApiDecoratorOptions = {\n  httpMethod?: HTTPMethods;\n  contentType?:\n    | \"text/plain\"\n    | \"text/html\"\n    | \"text/xml\"\n    | \"application/json\"\n    | \"application/octet-stream\";\n  clients?: ServiceClient[];\n  path?: string;\n  resourceName?: string;\n  guards?: GuardKey[];\n  description?: string;\n  timeout?: number;\n};\nexport type StreamDecoratorOptions = {\n  type: \"sse\"; // | 'ws\n  // biome-ignore lint/suspicious/noExplicitAny: 이벤트 키별로 넘겨주는 값이므로 어떤 타입이든 상관없음\n  events: z.ZodObject<any>;\n  path?: string;\n  resourceName?: string;\n  guards?: GuardKey[];\n  description?: string;\n};\nexport type UploadDecoratorOptions = {\n  mode?: \"single\" | \"multiple\";\n};\nexport const registeredApis: {\n  /**\n   * modelName은 모델 클래스 이름입니다. (ex. \"UserModel\")\n   */\n  modelName: string;\n  methodName: string;\n  path: string;\n  options: ApiDecoratorOptions;\n  streamOptions?: StreamDecoratorOptions;\n  uploadOptions?: UploadDecoratorOptions;\n}[] = [];\nexport type ExtendedApi = {\n  modelName: string;\n  methodName: string;\n  path: string;\n  options: ApiDecoratorOptions;\n  streamOptions?: StreamDecoratorOptions;\n  uploadOptions?: UploadDecoratorOptions;\n  typeParameters: ApiParamType.TypeParam[];\n  parameters: ApiParam[];\n  returnType: ApiParamType;\n};\ntype DecoratorTarget = { constructor: { name: string } };\n\nconst DECORATOR_TYPES = {\n  API: Symbol(\"api\"),\n  STREAM: Symbol(\"stream\"),\n} as const;\n\nfunction checkSingleDecorator(target: DecoratorTarget, propertyKey: string, decoratorType: symbol) {\n  const method = target[propertyKey as keyof typeof target] as { __decoratorType?: symbol };\n  if (method?.__decoratorType && method?.__decoratorType !== decoratorType) {\n    throw new Error(\n      `@${String(decoratorType)} decorator can only be used once on ${target.constructor.name}.${propertyKey}. You can use only one of @api or @stream decorator on the same method.`,\n    );\n  } else {\n    method.__decoratorType = decoratorType;\n  }\n}\n\nexport function api(options: ApiDecoratorOptions = {}) {\n  options = {\n    httpMethod: \"GET\",\n    contentType: \"application/json\",\n    clients: [\"axios\"],\n    ...options,\n  };\n\n  return (target: DecoratorTarget, propertyKey: string) => {\n    const modelName = target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @api decorator on ${target.constructor.name}.${propertyKey}`,\n    );\n    const methodName = propertyKey;\n\n    // 메서드에 걸린 데코레이터 중복 체크\n    checkSingleDecorator(target, propertyKey, DECORATOR_TYPES.API);\n\n    const defaultPath = `/${inflection.camelize(\n      modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\"),\n      true,\n    )}/${inflection.camelize(propertyKey, true)}`;\n    const path = options.path ?? defaultPath;\n\n    // 기존 동일한 메서드가 있는지 확인 후 있는 경우 override\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      // 기존의 path와 새로운 path가 다르다면(=빈 스트링이 아니었는데 다른 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n      assertNoConflictingPath(\"api\", modelName, methodName, existingApi.path, path);\n      existingApi.path = path;\n\n      // 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n      assertNoConflictingOptions(\"api\", modelName, methodName, existingApi.options, options);\n      existingApi.options = {\n        ...existingApi.options, // 기존의 옵션을 존중하되\n        ...options, // @api 데코레이터의 옵션을 추가합니다.\n      };\n    } else {\n      registeredApis.push({\n        modelName,\n        methodName,\n        path,\n        options,\n      });\n    }\n  };\n}\n\nexport function stream(options: StreamDecoratorOptions) {\n  return (target: DecoratorTarget, propertyKey: string) => {\n    const modelName = target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @stream decorator on ${target.constructor.name}.${propertyKey}`,\n    );\n    const methodName = propertyKey;\n\n    // 메서드에 걸린 데코레이터 중복 체크\n    checkSingleDecorator(target, propertyKey, DECORATOR_TYPES.STREAM);\n\n    const defaultPath = `/${inflection.camelize(\n      modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\"),\n      true,\n    )}/${inflection.camelize(propertyKey, true)}`;\n    const path = options.path ?? defaultPath;\n    const optionsWithDefaults = {\n      ...options,\n      httpMethod: \"GET\" as HTTPMethods,\n    };\n\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      // 기존의 path와 새로운 path가 다르다면(=빈 스트링이 아니었는데 다른 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n      assertNoConflictingPath(\"stream\", modelName, methodName, existingApi.path, path);\n      existingApi.path = path;\n\n      // 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n      assertNoConflictingOptions(\n        \"stream\",\n        modelName,\n        methodName,\n        existingApi.options,\n        optionsWithDefaults,\n      );\n      existingApi.options = {\n        ...existingApi.options, // 기존의 옵션을 존중하되\n        ...optionsWithDefaults, // @stream 데코레이터의 옵션을 추가합니다.\n      };\n\n      existingApi.streamOptions = options;\n    } else {\n      registeredApis.push({\n        modelName,\n        methodName,\n        path,\n        options: optionsWithDefaults,\n        streamOptions: options,\n      });\n    }\n  };\n}\n\nexport function transactional(options: TransactionalOptions = {}) {\n  const { isolation, readOnly, dbPreset = \"w\" } = options;\n\n  return (_target: DecoratorTarget, _propertyKey: string, descriptor: PropertyDescriptor) => {\n    const originalMethod = descriptor.value;\n\n    descriptor.value = async function (this: BaseModelClass, ...args: unknown[]) {\n      const existingContext = DB.transactionStorage.getStore();\n\n      // 이미 AsyncLocalStorage 컨텍스트 안에 있는지 확인\n      if (existingContext) {\n        // 해당 preset의 트랜잭션이 이미 있으면 재사용\n        if (existingContext.getTransaction(dbPreset)) {\n          return originalMethod.apply(this, args);\n        }\n      }\n\n      // AsyncLocalStorage 컨텍스트 없거나 해당 preset의 트랜잭션이 없으면 새로 시작\n      const startTransaction = async () => {\n        const puri = this.getPuri(dbPreset) as PuriWrapper;\n\n        return puri.knex.transaction(\n          async (trx) => {\n            const trxWrapper = new PuriTransactionWrapper(trx, new UpsertBuilder());\n            // TransactionContext에 트랜잭션 저장\n            DB.getTransactionContext().setTransaction(dbPreset, trxWrapper);\n\n            try {\n              return await originalMethod.apply(this, args);\n            } finally {\n              // 트랜잭션 제거\n              DB.getTransactionContext().deleteTransaction(dbPreset);\n            }\n          },\n          { isolationLevel: isolation, readOnly },\n        );\n      };\n\n      // AsyncLocalStorage 컨텍스트가 없으면 새로 생성\n      if (!existingContext) {\n        return DB.runWithTransaction(startTransaction);\n      } else {\n        // 컨텍스트는 있지만 이 preset의 트랜잭션은 없는 경우 (같은 컨텍스트 내에서 실행)\n        return startTransaction();\n      }\n    };\n\n    return descriptor;\n  };\n}\n\n/**\n * api 데코레이터와 함께 사용할 수 있습니다.\n * @param options\n * @returns\n */\nexport function upload(options: UploadDecoratorOptions = {}) {\n  return (_target: DecoratorTarget, _propertyKey: string, descriptor: PropertyDescriptor) => {\n    const originalMethod = descriptor.value;\n    const modelName = _target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @upload decorator on ${_target.constructor.name}.${_propertyKey}`,\n    );\n    const methodName = _propertyKey;\n\n    // registeredApis에서 해당 API 찾아서 uploadOptions 추가\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      existingApi.uploadOptions = options;\n    } else {\n      // 이 메소드에 붙은 @api 데코레이터가 아직 eval되지 않은 상황입니다. (만약 @api가 안 붙어 있었다면 심각한 상황입니다..!)\n      // 여기에서 최초로 modelName과 methodName에 대해 registeredApis에 하나를 추가해주어야 합니다.\n      // uploadOptions는 그대로 추가하고, path는 빈 스트링으로 추가해줍니다.\n      // 이후 @api 데코레이터가 eval되면 실제 path로 덮어씌워지고, options가 추가됩니다.\n      registeredApis.push({\n        modelName,\n        methodName,\n        path: \"\",\n        options: {},\n        uploadOptions: options,\n      });\n    }\n\n    descriptor.value = async function (this: BaseModelClass, ...args: unknown[]) {\n      const { request } = Sonamu.getContext();\n      const uploadContext: UploadContext = {\n        file: undefined,\n        files: [],\n      };\n\n      const storage = Sonamu.storage;\n      if (!storage) {\n        throw new Error(\"Storage가 설정되지 않았습니다.\");\n      }\n\n      const { FileStorage } = await import(\"../file-storage/file-storage\");\n      if (options.mode === \"multiple\") {\n        const rawFilesIterator = request.files();\n        for await (const rawFile of rawFilesIterator) {\n          if (rawFile) {\n            await rawFile.toBuffer();\n            uploadContext.files.push(new FileStorage(rawFile, storage));\n          }\n        }\n      } else {\n        const rawFile = await request.file();\n        if (rawFile) {\n          uploadContext.file = new FileStorage(rawFile, storage);\n        }\n      }\n\n      return Sonamu.uploadStorage.run({ uploadContext }, () => {\n        return originalMethod.apply(this, args);\n      });\n    };\n\n    return descriptor;\n  };\n}\n\n/**\n * 기존의 path와 새로운 path가 다르다면(=값이 있던 스트링이 다른 값이 있는 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n * @param decoratorName 데코레이터 이름\n * @param modelName 모델 이름\n * @param methodName 메서드 이름\n * @param existingPath 기존의 path\n * @param newPath 새로운 path\n */\nfunction assertNoConflictingPath(\n  decoratorName: string,\n  modelName: string,\n  methodName: string,\n  existingPath: string,\n  newPath: string,\n) {\n  if (existingPath !== \"\" && newPath !== \"\" && existingPath !== newPath) {\n    // 이것이 무슨 상황이냐면요, api.path가 덮어씌워지는 상황입니다.\n    // 가령 @api({ path: \"/api/v1/users\" }) 데코레이터가 붙어있는 메서드에\n    // @stream({ path: \"/api/v1/users/stream\" }) 같은 것이 붙어 있는 상황입니다.\n    // 이렇게 되면 두 데코레이터가 같은 api의 path 필드를 건드리게 되므로, 에러를 터뜨려줍니다.\n    throw new Error(\n      `@${decoratorName} decorator on ${modelName}.${methodName} has conflicting path: ${newPath}. The decorator is trying to override the existing path(${existingPath}) with the new path(${newPath}).`,\n    );\n  }\n}\n\n/**\n * 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n * @param decoratorName 데코레이터 이름\n * @param modelName 모델 이름\n * @param methodName 메서드 이름\n * @param existingOptions 기존의 옵션\n * @param newOptions 새로운 옵션\n */\nfunction assertNoConflictingOptions(\n  decoratorName: string,\n  modelName: string,\n  methodName: string,\n  // biome-ignore lint/suspicious/noExplicitAny: <아 쉽게쉽게 좀 갑시다>\n  existingOptions: Record<string, any>,\n  // biome-ignore lint/suspicious/noExplicitAny: <이럴 때 아니면 any 언제 씁니까>\n  newOptions: Record<string, any>,\n) {\n  Object.keys(newOptions).forEach((key) => {\n    if (existingOptions[key] && !isEqual(existingOptions[key], newOptions[key])) {\n      // 이것이 무슨 상황이냐면요, api.options가 덮어씌워지는 상황입니다.\n      // 가령 @api({ resourceName: \"Users\" }) 데코레이터가 붙어있는 메서드에\n      // @stream({ resourceName: \"Posts\" }) 같은 것이 붙어 있는 상황입니다.\n      // 이렇게 되면 두 데코레이터가 같은 api의 options 속 같은 필드를 건드리게 되므로, 에러를 터뜨려줍니다.\n      throw new Error(\n        `@${decoratorName} decorator on ${modelName}.${methodName} has conflicting options: ${key}. The decorator is trying to override the existing option(${JSON.stringify(existingOptions[key])}) with the new option(${JSON.stringify(newOptions[key])}).`,\n      );\n    }\n  });\n}\n"],"names":["assert","inflection","isEqual","DB","PuriTransactionWrapper","Sonamu","UpsertBuilder","registeredApis","DECORATOR_TYPES","API","Symbol","STREAM","checkSingleDecorator","target","propertyKey","decoratorType","method","__decoratorType","Error","String","name","api","options","httpMethod","contentType","clients","modelName","match","methodName","defaultPath","camelize","replace","path","existingApi","find","assertNoConflictingPath","assertNoConflictingOptions","push","stream","optionsWithDefaults","streamOptions","transactional","isolation","readOnly","dbPreset","_target","_propertyKey","descriptor","originalMethod","value","args","existingContext","transactionStorage","getStore","getTransaction","apply","startTransaction","puri","getPuri","knex","transaction","trx","trxWrapper","getTransactionContext","setTransaction","deleteTransaction","isolationLevel","runWithTransaction","upload","uploadOptions","request","getContext","uploadContext","file","undefined","files","storage","FileStorage","mode","rawFilesIterator","rawFile","toBuffer","uploadStorage","run","decoratorName","existingPath","newPath","existingOptions","newOptions","Object","keys","forEach","key","JSON","stringify"],"mappings":"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"}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/api/decorators.ts"],"sourcesContent":["import assert from \"assert\";\nimport type { HTTPMethods } from \"fastify\";\nimport inflection from \"inflection\";\nimport { isEqual } from \"radashi\";\nimport type { z } from \"zod\";\nimport type { BaseModelClass } from \"../database/base-model\";\nimport { DB } from \"../database/db\";\nimport {\n  PuriTransactionWrapper,\n  type PuriWrapper,\n  type TransactionalOptions,\n} from \"../database/puri-wrapper\";\nimport { UpsertBuilder } from \"../database/upsert-builder\";\nimport type { ApiParam, ApiParamType } from \"../types/types\";\nimport type { UploadContext } from \"./context\";\nimport { Sonamu } from \"./sonamu\";\n\nexport interface GuardKeys {\n  query: true;\n  admin: true;\n  user: true;\n}\nexport type GuardKey = keyof GuardKeys;\nexport type ServiceClient = \"axios\" | \"axios-multipart\" | \"swr\" | \"window-fetch\";\nexport type ApiDecoratorOptions = {\n  httpMethod?: HTTPMethods;\n  contentType?:\n    | \"text/plain\"\n    | \"text/html\"\n    | \"text/xml\"\n    | \"application/json\"\n    | \"application/octet-stream\";\n  clients?: ServiceClient[];\n  path?: string;\n  resourceName?: string;\n  guards?: GuardKey[];\n  description?: string;\n  timeout?: number;\n};\nexport type StreamDecoratorOptions = {\n  type: \"sse\"; // | 'ws\n  // biome-ignore lint/suspicious/noExplicitAny: 이벤트 키별로 넘겨주는 값이므로 어떤 타입이든 상관없음\n  events: z.ZodObject<any>;\n  path?: string;\n  resourceName?: string;\n  guards?: GuardKey[];\n  description?: string;\n};\nexport type UploadDecoratorOptions = {\n  mode?: \"single\" | \"multiple\";\n};\nexport const registeredApis: {\n  /**\n   * modelName은 모델 클래스 이름입니다. (ex. \"UserModel\")\n   */\n  modelName: string;\n  methodName: string;\n  path: string;\n  options: ApiDecoratorOptions;\n  streamOptions?: StreamDecoratorOptions;\n  uploadOptions?: UploadDecoratorOptions;\n}[] = [];\nexport type ExtendedApi = {\n  modelName: string;\n  methodName: string;\n  path: string;\n  options: ApiDecoratorOptions;\n  streamOptions?: StreamDecoratorOptions;\n  uploadOptions?: UploadDecoratorOptions;\n  typeParameters: ApiParamType.TypeParam[];\n  parameters: ApiParam[];\n  returnType: ApiParamType;\n};\ntype DecoratorTarget = { constructor: { name: string } };\n\nconst DECORATOR_TYPES = {\n  API: Symbol(\"api\"),\n  STREAM: Symbol(\"stream\"),\n} as const;\n\nfunction checkSingleDecorator(target: DecoratorTarget, propertyKey: string, decoratorType: symbol) {\n  const method = target[propertyKey as keyof typeof target] as { __decoratorType?: symbol };\n  if (method?.__decoratorType && method?.__decoratorType !== decoratorType) {\n    throw new Error(\n      `@${String(decoratorType)} decorator can only be used once on ${target.constructor.name}.${propertyKey}. You can use only one of @api or @stream decorator on the same method.`,\n    );\n  } else {\n    method.__decoratorType = decoratorType;\n  }\n}\n\nexport function api(options: ApiDecoratorOptions = {}) {\n  options = {\n    httpMethod: \"GET\",\n    contentType: \"application/json\",\n    clients: [\"axios\"],\n    ...options,\n  };\n\n  return (target: DecoratorTarget, propertyKey: string) => {\n    const modelName = target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @api decorator on ${target.constructor.name}.${propertyKey}`,\n    );\n    const methodName = propertyKey;\n\n    // 메서드에 걸린 데코레이터 중복 체크\n    checkSingleDecorator(target, propertyKey, DECORATOR_TYPES.API);\n\n    const defaultPath = `/${inflection.camelize(\n      modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\"),\n      true,\n    )}/${inflection.camelize(propertyKey, true)}`;\n    const path = options.path ?? defaultPath;\n\n    // 기존 동일한 메서드가 있는지 확인 후 있는 경우 override\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      // 기존의 path와 새로운 path가 다르다면(=빈 스트링이 아니었는데 다른 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n      assertNoConflictingPath(\"api\", modelName, methodName, existingApi.path, path);\n      existingApi.path = path;\n\n      // 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n      assertNoConflictingOptions(\"api\", modelName, methodName, existingApi.options, options);\n      existingApi.options = {\n        ...existingApi.options, // 기존의 옵션을 존중하되\n        ...options, // @api 데코레이터의 옵션을 추가합니다.\n      };\n    } else {\n      registeredApis.push({\n        modelName,\n        methodName,\n        path,\n        options,\n      });\n    }\n  };\n}\n\nexport function stream(options: StreamDecoratorOptions) {\n  return (target: DecoratorTarget, propertyKey: string) => {\n    const modelName = target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @stream decorator on ${target.constructor.name}.${propertyKey}`,\n    );\n    const methodName = propertyKey;\n\n    // 메서드에 걸린 데코레이터 중복 체크\n    checkSingleDecorator(target, propertyKey, DECORATOR_TYPES.STREAM);\n\n    const defaultPath = `/${inflection.camelize(\n      modelName.replace(/Model$/, \"\").replace(/Frame$/, \"\"),\n      true,\n    )}/${inflection.camelize(propertyKey, true)}`;\n    const path = options.path ?? defaultPath;\n    const optionsWithDefaults = {\n      ...options,\n      httpMethod: \"GET\" as HTTPMethods,\n    };\n\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      // 기존의 path와 새로운 path가 다르다면(=빈 스트링이 아니었는데 다른 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n      assertNoConflictingPath(\"stream\", modelName, methodName, existingApi.path, path);\n      existingApi.path = path;\n\n      // 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n      assertNoConflictingOptions(\n        \"stream\",\n        modelName,\n        methodName,\n        existingApi.options,\n        optionsWithDefaults,\n      );\n      existingApi.options = {\n        ...existingApi.options, // 기존의 옵션을 존중하되\n        ...optionsWithDefaults, // @stream 데코레이터의 옵션을 추가합니다.\n      };\n\n      existingApi.streamOptions = options;\n    } else {\n      registeredApis.push({\n        modelName,\n        methodName,\n        path,\n        options: optionsWithDefaults,\n        streamOptions: options,\n      });\n    }\n  };\n}\n\nexport function transactional(options: TransactionalOptions = {}) {\n  const { isolation, readOnly, dbPreset = \"w\" } = options;\n\n  return (_target: DecoratorTarget, _propertyKey: string, descriptor: PropertyDescriptor) => {\n    const originalMethod = descriptor.value;\n\n    descriptor.value = async function (this: BaseModelClass, ...args: unknown[]) {\n      const existingContext = DB.transactionStorage.getStore();\n\n      // 이미 AsyncLocalStorage 컨텍스트 안에 있는지 확인\n      if (existingContext) {\n        // 해당 preset의 트랜잭션이 이미 있으면 재사용\n        if (existingContext.getTransaction(dbPreset)) {\n          return originalMethod.apply(this, args);\n        }\n      }\n\n      // AsyncLocalStorage 컨텍스트 없거나 해당 preset의 트랜잭션이 없으면 새로 시작\n      const startTransaction = async () => {\n        const puri = this.getPuri(dbPreset) as PuriWrapper;\n\n        return puri.knex.transaction(\n          async (trx) => {\n            const trxWrapper = new PuriTransactionWrapper(trx, new UpsertBuilder());\n            // TransactionContext에 트랜잭션 저장\n            DB.getTransactionContext().setTransaction(dbPreset, trxWrapper);\n\n            try {\n              return await originalMethod.apply(this, args);\n            } finally {\n              // 트랜잭션 제거\n              DB.getTransactionContext().deleteTransaction(dbPreset);\n            }\n          },\n          { isolationLevel: isolation, readOnly },\n        );\n      };\n\n      // AsyncLocalStorage 컨텍스트가 없으면 새로 생성\n      if (!existingContext) {\n        return DB.runWithTransaction(startTransaction);\n      } else {\n        // 컨텍스트는 있지만 이 preset의 트랜잭션은 없는 경우 (같은 컨텍스트 내에서 실행)\n        return startTransaction();\n      }\n    };\n\n    return descriptor;\n  };\n}\n\n/**\n * api 데코레이터와 함께 사용할 수 있습니다.\n * @param options\n * @returns\n */\nexport function upload(options: UploadDecoratorOptions = {}) {\n  return (_target: DecoratorTarget, _propertyKey: string, descriptor: PropertyDescriptor) => {\n    const originalMethod = descriptor.value;\n    const modelName = _target.constructor.name.match(/(.+)Class$/)?.[1];\n    assert(\n      modelName,\n      `modelName is required on @upload decorator on ${_target.constructor.name}.${_propertyKey}`,\n    );\n    const methodName = _propertyKey;\n\n    // registeredApis에서 해당 API 찾아서 uploadOptions 추가\n    const existingApi = registeredApis.find(\n      (api) => api.modelName === modelName && api.methodName === methodName,\n    );\n    if (existingApi) {\n      existingApi.uploadOptions = options;\n    } else {\n      // 이 메소드에 붙은 @api 데코레이터가 아직 eval되지 않은 상황입니다. (만약 @api가 안 붙어 있었다면 심각한 상황입니다..!)\n      // 여기에서 최초로 modelName과 methodName에 대해 registeredApis에 하나를 추가해주어야 합니다.\n      // uploadOptions는 그대로 추가하고, path는 빈 스트링으로 추가해줍니다.\n      // 이후 @api 데코레이터가 eval되면 실제 path로 덮어씌워지고, options가 추가됩니다.\n      registeredApis.push({\n        modelName,\n        methodName,\n        path: \"\",\n        options: {},\n        uploadOptions: options,\n      });\n    }\n\n    descriptor.value = async function (this: BaseModelClass, ...args: unknown[]) {\n      const { request } = Sonamu.getContext();\n      const uploadContext: UploadContext = {\n        file: undefined,\n        files: [],\n      };\n\n      const storage = Sonamu.storage;\n      if (!storage) {\n        throw new Error(\"Storage가 설정되지 않았습니다.\");\n      }\n\n      const { FileStorage } = await import(\"../file-storage/file-storage\");\n      if (options.mode === \"multiple\") {\n        const rawFilesIterator = request.files();\n        for await (const rawFile of rawFilesIterator) {\n          if (rawFile) {\n            await rawFile.toBuffer();\n            uploadContext.files.push(new FileStorage(rawFile, storage));\n          }\n        }\n      } else {\n        const rawFile = await request.file();\n        if (rawFile) {\n          uploadContext.file = new FileStorage(rawFile, storage);\n        }\n      }\n\n      return Sonamu.uploadStorage.run({ uploadContext }, () => {\n        return originalMethod.apply(this, args);\n      });\n    };\n\n    return descriptor;\n  };\n}\n\n/**\n * 기존의 path와 새로운 path가 다르다면(=값이 있던 스트링이 다른 값이 있는 스트링으로 바뀌게 된다면) 에러를 터뜨려줍니다.\n * @param decoratorName 데코레이터 이름\n * @param modelName 모델 이름\n * @param methodName 메서드 이름\n * @param existingPath 기존의 path\n * @param newPath 새로운 path\n */\nfunction assertNoConflictingPath(\n  decoratorName: string,\n  modelName: string,\n  methodName: string,\n  existingPath: string,\n  newPath: string,\n) {\n  if (existingPath !== \"\" && newPath !== \"\" && existingPath !== newPath) {\n    // 이것이 무슨 상황이냐면요, api.path가 덮어씌워지는 상황입니다.\n    // 가령 @api({ path: \"/api/v1/users\" }) 데코레이터가 붙어있는 메서드에\n    // @stream({ path: \"/api/v1/users/stream\" }) 같은 것이 붙어 있는 상황입니다.\n    // 이렇게 되면 두 데코레이터가 같은 api의 path 필드를 건드리게 되므로, 에러를 터뜨려줍니다.\n    throw new Error(\n      `@${decoratorName} decorator on ${modelName}.${methodName} has conflicting path: ${newPath}. The decorator is trying to override the existing path(${existingPath}) with the new path(${newPath}).`,\n    );\n  }\n}\n\n/**\n * 기존의 옵션과 새로운 옵션이 겹치는 부분이 있다면 에러를 터뜨려줍니다.\n * @param decoratorName 데코레이터 이름\n * @param modelName 모델 이름\n * @param methodName 메서드 이름\n * @param existingOptions 기존의 옵션\n * @param newOptions 새로운 옵션\n */\nfunction assertNoConflictingOptions(\n  decoratorName: string,\n  modelName: string,\n  methodName: string,\n  // biome-ignore lint/suspicious/noExplicitAny: <아 쉽게쉽게 좀 갑시다>\n  existingOptions: Record<string, any>,\n  // biome-ignore lint/suspicious/noExplicitAny: <이럴 때 아니면 any 언제 씁니까>\n  newOptions: Record<string, any>,\n) {\n  Object.keys(newOptions).forEach((key) => {\n    if (existingOptions[key] && !isEqual(existingOptions[key], newOptions[key])) {\n      // 이것이 무슨 상황이냐면요, api.options가 덮어씌워지는 상황입니다.\n      // 가령 @api({ resourceName: \"Users\" }) 데코레이터가 붙어있는 메서드에\n      // @stream({ resourceName: \"Posts\" }) 같은 것이 붙어 있는 상황입니다.\n      // 이렇게 되면 두 데코레이터가 같은 api의 options 속 같은 필드를 건드리게 되므로, 에러를 터뜨려줍니다.\n      throw new Error(\n        `@${decoratorName} decorator on ${modelName}.${methodName} has conflicting options: ${key}. The decorator is trying to override the existing option(${JSON.stringify(existingOptions[key])}) with the new option(${JSON.stringify(newOptions[key])}).`,\n      );\n    }\n  });\n}\n"],"names":["assert","inflection","isEqual","DB","PuriTransactionWrapper","UpsertBuilder","Sonamu","registeredApis","DECORATOR_TYPES","API","Symbol","STREAM","checkSingleDecorator","target","propertyKey","decoratorType","method","__decoratorType","Error","String","name","api","options","httpMethod","contentType","clients","modelName","match","methodName","defaultPath","camelize","replace","path","existingApi","find","assertNoConflictingPath","assertNoConflictingOptions","push","stream","optionsWithDefaults","streamOptions","transactional","isolation","readOnly","dbPreset","_target","_propertyKey","descriptor","originalMethod","value","args","existingContext","transactionStorage","getStore","getTransaction","apply","startTransaction","puri","getPuri","knex","transaction","trx","trxWrapper","getTransactionContext","setTransaction","deleteTransaction","isolationLevel","runWithTransaction","upload","uploadOptions","request","getContext","uploadContext","file","undefined","files","storage","FileStorage","mode","rawFilesIterator","rawFile","toBuffer","uploadStorage","run","decoratorName","existingPath","newPath","existingOptions","newOptions","Object","keys","forEach","key","JSON","stringify"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"sonamu.d.ts","sourceRoot":"","sources":["../../src/api/sonamu.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sonamu.d.ts","sourceRoot":"","sources":["../../src/api/sonamu.ts"],"names":[],"mappings":"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"}