orcaq 1.0.20

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 (1018) hide show
  1. package/.output/nitro.json +15 -0
  2. package/.output/public/_nuxt/8qASMGdV.js +1 -0
  3. package/.output/public/_nuxt/9lJACZIQ.js +19 -0
  4. package/.output/public/_nuxt/B2DnNiWd.js +1 -0
  5. package/.output/public/_nuxt/B6E6ObS_.js +8 -0
  6. package/.output/public/_nuxt/BH83_dXo.js +39 -0
  7. package/.output/public/_nuxt/BIKqrFbQ.js +1 -0
  8. package/.output/public/_nuxt/BNjPC06x.js +1 -0
  9. package/.output/public/_nuxt/BPQ-Pz1w.js +39 -0
  10. package/.output/public/_nuxt/BRpgKkVT.js +51 -0
  11. package/.output/public/_nuxt/BTCLPbPY.js +4 -0
  12. package/.output/public/_nuxt/BUV-RarV.js +1 -0
  13. package/.output/public/_nuxt/Bh6RgYlO.js +1 -0
  14. package/.output/public/_nuxt/Bq3cyzOD.js +1 -0
  15. package/.output/public/_nuxt/Bt9sU68B.js +9 -0
  16. package/.output/public/_nuxt/BwpH2ZxJ.js +1 -0
  17. package/.output/public/_nuxt/C25Tmn1m.js +1 -0
  18. package/.output/public/_nuxt/C2HlI1ss.js +1 -0
  19. package/.output/public/_nuxt/CU3ZV9iV.js +1 -0
  20. package/.output/public/_nuxt/CbcyysXi.js +1 -0
  21. package/.output/public/_nuxt/CepyvMhE.js +1 -0
  22. package/.output/public/_nuxt/CrgoNCm2.js +2 -0
  23. package/.output/public/_nuxt/CuBKbBH_.js +1 -0
  24. package/.output/public/_nuxt/CulD8qYQ.js +193 -0
  25. package/.output/public/_nuxt/CustomEdge.BNBpjEHb.css +1 -0
  26. package/.output/public/_nuxt/CylkLpwm.js +1 -0
  27. package/.output/public/_nuxt/D-bWLYHw.js +1 -0
  28. package/.output/public/_nuxt/D-zecHND.js +1 -0
  29. package/.output/public/_nuxt/D8vj6kFe.js +160 -0
  30. package/.output/public/_nuxt/DIETYtCL.js +1 -0
  31. package/.output/public/_nuxt/DJ4vUzxS.js +1 -0
  32. package/.output/public/_nuxt/DK-itzXx.js +8 -0
  33. package/.output/public/_nuxt/DL3T5jYo.js +3867 -0
  34. package/.output/public/_nuxt/DUsuhY9i.js +1 -0
  35. package/.output/public/_nuxt/DXV2HFBA.js +224 -0
  36. package/.output/public/_nuxt/Dh2zppOR.js +1 -0
  37. package/.output/public/_nuxt/DlAUqK2U.js +1 -0
  38. package/.output/public/_nuxt/DlmSeCnw.js +5 -0
  39. package/.output/public/_nuxt/DswTpYG4.js +1 -0
  40. package/.output/public/_nuxt/DynamicTable.DJeANwbG.css +1 -0
  41. package/.output/public/_nuxt/G830WtVn.js +1 -0
  42. package/.output/public/_nuxt/ICwM1E4-.js +15 -0
  43. package/.output/public/_nuxt/QZbJy9YW.js +31 -0
  44. package/.output/public/_nuxt/QuickQueryTable.DS_ON57S.css +1 -0
  45. package/.output/public/_nuxt/UXhX8z2W.js +1 -0
  46. package/.output/public/_nuxt/WrapperErdDiagram.DwhUd9Wr.css +1 -0
  47. package/.output/public/_nuxt/_fileId_.DmPfwyyD.css +1 -0
  48. package/.output/public/_nuxt/_tabViewId_.9Axt3zoi.css +1 -0
  49. package/.output/public/_nuxt/builds/latest.json +1 -0
  50. package/.output/public/_nuxt/builds/meta/6364d5cf-4642-479f-ba12-6440c56702af.json +1 -0
  51. package/.output/public/_nuxt/default.DixIpIal.css +1 -0
  52. package/.output/public/_nuxt/entry.GqPNPe1e.css +1 -0
  53. package/.output/public/_nuxt/index.CrXmf4gr.css +1 -0
  54. package/.output/public/_nuxt/ivUnXl9B.js +1 -0
  55. package/.output/public/_nuxt/pAheHeBV.js +36 -0
  56. package/.output/public/_nuxt/s5fCn4j5.js +1 -0
  57. package/.output/public/favicon.ico +0 -0
  58. package/.output/public/logo.png +0 -0
  59. package/.output/public/manifest.json +25 -0
  60. package/.output/public/robots.txt +1 -0
  61. package/.output/public/vite.svg +1 -0
  62. package/.output/server/chunks/_/error-500.mjs +8 -0
  63. package/.output/server/chunks/_/error-500.mjs.map +1 -0
  64. package/.output/server/chunks/build/client.manifest.mjs +773 -0
  65. package/.output/server/chunks/build/client.manifest.mjs.map +1 -0
  66. package/.output/server/chunks/nitro/nitro.mjs +6432 -0
  67. package/.output/server/chunks/nitro/nitro.mjs.map +1 -0
  68. package/.output/server/chunks/routes/api/ai/chat.mjs +77 -0
  69. package/.output/server/chunks/routes/api/ai/chat.mjs.map +1 -0
  70. package/.output/server/chunks/routes/api/execute-bulk-delete.mjs +100 -0
  71. package/.output/server/chunks/routes/api/execute-bulk-delete.mjs.map +1 -0
  72. package/.output/server/chunks/routes/api/execute-bulk-update.mjs +105 -0
  73. package/.output/server/chunks/routes/api/execute-bulk-update.mjs.map +1 -0
  74. package/.output/server/chunks/routes/api/execute.mjs +47 -0
  75. package/.output/server/chunks/routes/api/execute.mjs.map +1 -0
  76. package/.output/server/chunks/routes/api/get-one-function.mjs +28 -0
  77. package/.output/server/chunks/routes/api/get-one-function.mjs.map +1 -0
  78. package/.output/server/chunks/routes/api/get-one-table.mjs +180 -0
  79. package/.output/server/chunks/routes/api/get-one-table.mjs.map +1 -0
  80. package/.output/server/chunks/routes/api/get-over-view-function.mjs +41 -0
  81. package/.output/server/chunks/routes/api/get-over-view-function.mjs.map +1 -0
  82. package/.output/server/chunks/routes/api/get-over-view-tables.mjs +53 -0
  83. package/.output/server/chunks/routes/api/get-over-view-tables.mjs.map +1 -0
  84. package/.output/server/chunks/routes/api/get-reverse-table-schemas.mjs +112 -0
  85. package/.output/server/chunks/routes/api/get-reverse-table-schemas.mjs.map +1 -0
  86. package/.output/server/chunks/routes/api/get-schema-meta-data.mjs +152 -0
  87. package/.output/server/chunks/routes/api/get-schema-meta-data.mjs.map +1 -0
  88. package/.output/server/chunks/routes/api/get-table-size.mjs +49 -0
  89. package/.output/server/chunks/routes/api/get-table-size.mjs.map +1 -0
  90. package/.output/server/chunks/routes/api/get-table-structure.mjs +111 -0
  91. package/.output/server/chunks/routes/api/get-table-structure.mjs.map +1 -0
  92. package/.output/server/chunks/routes/api/get-tables.mjs +287 -0
  93. package/.output/server/chunks/routes/api/get-tables.mjs.map +1 -0
  94. package/.output/server/chunks/routes/api/getMetricMonitor.mjs +46 -0
  95. package/.output/server/chunks/routes/api/getMetricMonitor.mjs.map +1 -0
  96. package/.output/server/chunks/routes/api/managment-connection/health-check.mjs +28 -0
  97. package/.output/server/chunks/routes/api/managment-connection/health-check.mjs.map +1 -0
  98. package/.output/server/chunks/routes/api/raw-execute.mjs +48 -0
  99. package/.output/server/chunks/routes/api/raw-execute.mjs.map +1 -0
  100. package/.output/server/chunks/routes/renderer.mjs +316 -0
  101. package/.output/server/chunks/routes/renderer.mjs.map +1 -0
  102. package/.output/server/chunks/virtual/_virtual_spa-template.mjs +4 -0
  103. package/.output/server/chunks/virtual/_virtual_spa-template.mjs.map +1 -0
  104. package/.output/server/index.mjs +14 -0
  105. package/.output/server/index.mjs.map +1 -0
  106. package/.output/server/node_modules/@ai-sdk/anthropic/dist/index.mjs +4374 -0
  107. package/.output/server/node_modules/@ai-sdk/anthropic/package.json +74 -0
  108. package/.output/server/node_modules/@ai-sdk/gateway/dist/index.mjs +1082 -0
  109. package/.output/server/node_modules/@ai-sdk/gateway/package.json +69 -0
  110. package/.output/server/node_modules/@ai-sdk/google/dist/index.mjs +2007 -0
  111. package/.output/server/node_modules/@ai-sdk/google/package.json +74 -0
  112. package/.output/server/node_modules/@ai-sdk/openai/dist/index.mjs +5956 -0
  113. package/.output/server/node_modules/@ai-sdk/openai/package.json +74 -0
  114. package/.output/server/node_modules/@ai-sdk/openai-compatible/dist/index.mjs +1551 -0
  115. package/.output/server/node_modules/@ai-sdk/openai-compatible/package.json +74 -0
  116. package/.output/server/node_modules/@ai-sdk/provider/dist/index.mjs +377 -0
  117. package/.output/server/node_modules/@ai-sdk/provider/package.json +57 -0
  118. package/.output/server/node_modules/@ai-sdk/provider-utils/dist/index.mjs +2549 -0
  119. package/.output/server/node_modules/@ai-sdk/provider-utils/package.json +75 -0
  120. package/.output/server/node_modules/@ai-sdk/xai/dist/index.mjs +2214 -0
  121. package/.output/server/node_modules/@ai-sdk/xai/package.json +68 -0
  122. package/.output/server/node_modules/@babel/parser/lib/index.js +14246 -0
  123. package/.output/server/node_modules/@babel/parser/package.json +50 -0
  124. package/.output/server/node_modules/@iconify/utils/lib/colors/index.mjs +350 -0
  125. package/.output/server/node_modules/@iconify/utils/lib/colors/keywords.mjs +188 -0
  126. package/.output/server/node_modules/@iconify/utils/lib/css/common.mjs +90 -0
  127. package/.output/server/node_modules/@iconify/utils/lib/css/format.mjs +38 -0
  128. package/.output/server/node_modules/@iconify/utils/lib/css/icon.mjs +76 -0
  129. package/.output/server/node_modules/@iconify/utils/lib/css/icons.mjs +168 -0
  130. package/.output/server/node_modules/@iconify/utils/lib/customisations/bool.mjs +22 -0
  131. package/.output/server/node_modules/@iconify/utils/lib/customisations/defaults.mjs +14 -0
  132. package/.output/server/node_modules/@iconify/utils/lib/customisations/flip.mjs +16 -0
  133. package/.output/server/node_modules/@iconify/utils/lib/customisations/merge.mjs +22 -0
  134. package/.output/server/node_modules/@iconify/utils/lib/customisations/rotate.mjs +33 -0
  135. package/.output/server/node_modules/@iconify/utils/lib/emoji/cleanup.mjs +51 -0
  136. package/.output/server/node_modules/@iconify/utils/lib/emoji/convert.mjs +84 -0
  137. package/.output/server/node_modules/@iconify/utils/lib/emoji/data.mjs +16 -0
  138. package/.output/server/node_modules/@iconify/utils/lib/emoji/format.mjs +44 -0
  139. package/.output/server/node_modules/@iconify/utils/lib/emoji/parse.mjs +58 -0
  140. package/.output/server/node_modules/@iconify/utils/lib/emoji/regex/base.mjs +231 -0
  141. package/.output/server/node_modules/@iconify/utils/lib/emoji/regex/create.mjs +31 -0
  142. package/.output/server/node_modules/@iconify/utils/lib/emoji/regex/numbers.mjs +164 -0
  143. package/.output/server/node_modules/@iconify/utils/lib/emoji/regex/similar.mjs +216 -0
  144. package/.output/server/node_modules/@iconify/utils/lib/emoji/regex/tree.mjs +113 -0
  145. package/.output/server/node_modules/@iconify/utils/lib/emoji/replace/find.mjs +104 -0
  146. package/.output/server/node_modules/@iconify/utils/lib/emoji/replace/replace.mjs +34 -0
  147. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/components.mjs +75 -0
  148. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/missing.mjs +97 -0
  149. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/name.mjs +54 -0
  150. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/parse.mjs +97 -0
  151. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/similar.mjs +45 -0
  152. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/tree.mjs +105 -0
  153. package/.output/server/node_modules/@iconify/utils/lib/emoji/test/variations.mjs +54 -0
  154. package/.output/server/node_modules/@iconify/utils/lib/icon/defaults.mjs +24 -0
  155. package/.output/server/node_modules/@iconify/utils/lib/icon/merge.mjs +20 -0
  156. package/.output/server/node_modules/@iconify/utils/lib/icon/name.mjs +53 -0
  157. package/.output/server/node_modules/@iconify/utils/lib/icon/square.mjs +23 -0
  158. package/.output/server/node_modules/@iconify/utils/lib/icon/transformations.mjs +16 -0
  159. package/.output/server/node_modules/@iconify/utils/lib/icon-set/convert-info.mjs +182 -0
  160. package/.output/server/node_modules/@iconify/utils/lib/icon-set/expand.mjs +22 -0
  161. package/.output/server/node_modules/@iconify/utils/lib/icon-set/get-icon.mjs +28 -0
  162. package/.output/server/node_modules/@iconify/utils/lib/icon-set/get-icons.mjs +46 -0
  163. package/.output/server/node_modules/@iconify/utils/lib/icon-set/minify.mjs +66 -0
  164. package/.output/server/node_modules/@iconify/utils/lib/icon-set/parse.mjs +51 -0
  165. package/.output/server/node_modules/@iconify/utils/lib/icon-set/tree.mjs +23 -0
  166. package/.output/server/node_modules/@iconify/utils/lib/icon-set/validate-basic.mjs +62 -0
  167. package/.output/server/node_modules/@iconify/utils/lib/icon-set/validate.mjs +161 -0
  168. package/.output/server/node_modules/@iconify/utils/lib/index.mjs +64 -0
  169. package/.output/server/node_modules/@iconify/utils/lib/loader/custom.mjs +50 -0
  170. package/.output/server/node_modules/@iconify/utils/lib/loader/loader.mjs +59 -0
  171. package/.output/server/node_modules/@iconify/utils/lib/loader/modern.mjs +80 -0
  172. package/.output/server/node_modules/@iconify/utils/lib/loader/utils.mjs +92 -0
  173. package/.output/server/node_modules/@iconify/utils/lib/misc/objects.mjs +30 -0
  174. package/.output/server/node_modules/@iconify/utils/lib/misc/strings.mjs +17 -0
  175. package/.output/server/node_modules/@iconify/utils/lib/misc/title.mjs +5 -0
  176. package/.output/server/node_modules/@iconify/utils/lib/svg/build.mjs +119 -0
  177. package/.output/server/node_modules/@iconify/utils/lib/svg/defs.mjs +30 -0
  178. package/.output/server/node_modules/@iconify/utils/lib/svg/encode-svg-for-css.mjs +20 -0
  179. package/.output/server/node_modules/@iconify/utils/lib/svg/html.mjs +9 -0
  180. package/.output/server/node_modules/@iconify/utils/lib/svg/id.mjs +28 -0
  181. package/.output/server/node_modules/@iconify/utils/lib/svg/inner-html.mjs +19 -0
  182. package/.output/server/node_modules/@iconify/utils/lib/svg/parse.mjs +83 -0
  183. package/.output/server/node_modules/@iconify/utils/lib/svg/pretty.mjs +70 -0
  184. package/.output/server/node_modules/@iconify/utils/lib/svg/size.mjs +40 -0
  185. package/.output/server/node_modules/@iconify/utils/lib/svg/trim.mjs +5 -0
  186. package/.output/server/node_modules/@iconify/utils/lib/svg/url.mjs +11 -0
  187. package/.output/server/node_modules/@iconify/utils/lib/svg/viewbox.mjs +8 -0
  188. package/.output/server/node_modules/@iconify/utils/package.json +447 -0
  189. package/.output/server/node_modules/@ioredis/commands/built/commands.json +2447 -0
  190. package/.output/server/node_modules/@ioredis/commands/built/index.js +208 -0
  191. package/.output/server/node_modules/@ioredis/commands/package.json +52 -0
  192. package/.output/server/node_modules/@opentelemetry/api/build/src/api/context.js +81 -0
  193. package/.output/server/node_modules/@opentelemetry/api/build/src/api/diag.js +93 -0
  194. package/.output/server/node_modules/@opentelemetry/api/build/src/api/metrics.js +61 -0
  195. package/.output/server/node_modules/@opentelemetry/api/build/src/api/propagation.js +89 -0
  196. package/.output/server/node_modules/@opentelemetry/api/build/src/api/trace.js +79 -0
  197. package/.output/server/node_modules/@opentelemetry/api/build/src/baggage/context-helpers.js +63 -0
  198. package/.output/server/node_modules/@opentelemetry/api/build/src/baggage/internal/baggage-impl.js +55 -0
  199. package/.output/server/node_modules/@opentelemetry/api/build/src/baggage/internal/symbol.js +23 -0
  200. package/.output/server/node_modules/@opentelemetry/api/build/src/baggage/utils.js +51 -0
  201. package/.output/server/node_modules/@opentelemetry/api/build/src/context/NoopContextManager.js +38 -0
  202. package/.output/server/node_modules/@opentelemetry/api/build/src/context/context.js +55 -0
  203. package/.output/server/node_modules/@opentelemetry/api/build/src/context-api.js +24 -0
  204. package/.output/server/node_modules/@opentelemetry/api/build/src/diag/ComponentLogger.js +59 -0
  205. package/.output/server/node_modules/@opentelemetry/api/build/src/diag/consoleLogger.js +57 -0
  206. package/.output/server/node_modules/@opentelemetry/api/build/src/diag/internal/logLevelLogger.js +45 -0
  207. package/.output/server/node_modules/@opentelemetry/api/build/src/diag/types.js +44 -0
  208. package/.output/server/node_modules/@opentelemetry/api/build/src/diag-api.js +29 -0
  209. package/.output/server/node_modules/@opentelemetry/api/build/src/index.js +81 -0
  210. package/.output/server/node_modules/@opentelemetry/api/build/src/internal/global-utils.js +64 -0
  211. package/.output/server/node_modules/@opentelemetry/api/build/src/internal/semver.js +122 -0
  212. package/.output/server/node_modules/@opentelemetry/api/build/src/metrics/Metric.js +25 -0
  213. package/.output/server/node_modules/@opentelemetry/api/build/src/metrics/NoopMeter.js +127 -0
  214. package/.output/server/node_modules/@opentelemetry/api/build/src/metrics/NoopMeterProvider.js +31 -0
  215. package/.output/server/node_modules/@opentelemetry/api/build/src/metrics-api.js +24 -0
  216. package/.output/server/node_modules/@opentelemetry/api/build/src/platform/index.js +29 -0
  217. package/.output/server/node_modules/@opentelemetry/api/build/src/platform/node/globalThis.js +22 -0
  218. package/.output/server/node_modules/@opentelemetry/api/build/src/platform/node/index.js +29 -0
  219. package/.output/server/node_modules/@opentelemetry/api/build/src/propagation/NoopTextMapPropagator.js +34 -0
  220. package/.output/server/node_modules/@opentelemetry/api/build/src/propagation/TextMapPropagator.js +41 -0
  221. package/.output/server/node_modules/@opentelemetry/api/build/src/propagation-api.js +24 -0
  222. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/NonRecordingSpan.js +69 -0
  223. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/NoopTracer.js +75 -0
  224. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/NoopTracerProvider.js +32 -0
  225. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/ProxyTracer.js +55 -0
  226. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/ProxyTracerProvider.js +54 -0
  227. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/SamplingResult.js +42 -0
  228. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/context-utils.js +82 -0
  229. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/internal/tracestate-impl.js +103 -0
  230. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/internal/tracestate-validators.js +46 -0
  231. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/internal/utils.js +24 -0
  232. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/invalid-span-constants.js +27 -0
  233. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/span_kind.js +46 -0
  234. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/spancontext-utils.js +49 -0
  235. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/status.js +23 -0
  236. package/.output/server/node_modules/@opentelemetry/api/build/src/trace/trace_flags.js +26 -0
  237. package/.output/server/node_modules/@opentelemetry/api/build/src/trace-api.js +24 -0
  238. package/.output/server/node_modules/@opentelemetry/api/build/src/version.js +21 -0
  239. package/.output/server/node_modules/@opentelemetry/api/package.json +113 -0
  240. package/.output/server/node_modules/@sqltools/formatter/lib/core/Formatter.js +234 -0
  241. package/.output/server/node_modules/@sqltools/formatter/lib/core/Indentation.js +42 -0
  242. package/.output/server/node_modules/@sqltools/formatter/lib/core/InlineBlock.js +60 -0
  243. package/.output/server/node_modules/@sqltools/formatter/lib/core/Params.js +21 -0
  244. package/.output/server/node_modules/@sqltools/formatter/lib/core/Tokenizer.js +272 -0
  245. package/.output/server/node_modules/@sqltools/formatter/lib/core/escapeRegExp.js +10 -0
  246. package/.output/server/node_modules/@sqltools/formatter/lib/core/last.js +7 -0
  247. package/.output/server/node_modules/@sqltools/formatter/lib/core/types.js +22 -0
  248. package/.output/server/node_modules/@sqltools/formatter/lib/languages/Db2Formatter.js +585 -0
  249. package/.output/server/node_modules/@sqltools/formatter/lib/languages/N1qlFormatter.js +257 -0
  250. package/.output/server/node_modules/@sqltools/formatter/lib/languages/PlSqlFormatter.js +459 -0
  251. package/.output/server/node_modules/@sqltools/formatter/lib/languages/StandardSqlFormatter.js +369 -0
  252. package/.output/server/node_modules/@sqltools/formatter/lib/languages/utils/abstract.js +23 -0
  253. package/.output/server/node_modules/@sqltools/formatter/lib/sqlFormatter.js +34 -0
  254. package/.output/server/node_modules/@sqltools/formatter/package.json +59 -0
  255. package/.output/server/node_modules/@standard-schema/spec/dist/index.js +0 -0
  256. package/.output/server/node_modules/@standard-schema/spec/package.json +52 -0
  257. package/.output/server/node_modules/@vercel/oidc/dist/auth-config.js +84 -0
  258. package/.output/server/node_modules/@vercel/oidc/dist/get-context.js +34 -0
  259. package/.output/server/node_modules/@vercel/oidc/dist/get-vercel-oidc-token.js +80 -0
  260. package/.output/server/node_modules/@vercel/oidc/dist/index.js +33 -0
  261. package/.output/server/node_modules/@vercel/oidc/dist/oauth.js +88 -0
  262. package/.output/server/node_modules/@vercel/oidc/dist/token-error.js +40 -0
  263. package/.output/server/node_modules/@vercel/oidc/dist/token-io.js +78 -0
  264. package/.output/server/node_modules/@vercel/oidc/dist/token-util.js +198 -0
  265. package/.output/server/node_modules/@vercel/oidc/dist/token.js +53 -0
  266. package/.output/server/node_modules/@vercel/oidc/package.json +52 -0
  267. package/.output/server/node_modules/@vue/compiler-core/dist/compiler-core.cjs.prod.js +6690 -0
  268. package/.output/server/node_modules/@vue/compiler-core/package.json +58 -0
  269. package/.output/server/node_modules/@vue/compiler-dom/dist/compiler-dom.cjs.prod.js +686 -0
  270. package/.output/server/node_modules/@vue/compiler-dom/package.json +57 -0
  271. package/.output/server/node_modules/@vue/compiler-ssr/dist/compiler-ssr.cjs.js +1404 -0
  272. package/.output/server/node_modules/@vue/compiler-ssr/package.json +34 -0
  273. package/.output/server/node_modules/@vue/reactivity/dist/reactivity.cjs.prod.js +1789 -0
  274. package/.output/server/node_modules/@vue/reactivity/package.json +55 -0
  275. package/.output/server/node_modules/@vue/runtime-core/dist/runtime-core.cjs.prod.js +6654 -0
  276. package/.output/server/node_modules/@vue/runtime-core/package.json +52 -0
  277. package/.output/server/node_modules/@vue/runtime-dom/dist/runtime-dom.cjs.prod.js +1669 -0
  278. package/.output/server/node_modules/@vue/runtime-dom/package.json +60 -0
  279. package/.output/server/node_modules/@vue/server-renderer/dist/server-renderer.cjs.prod.js +857 -0
  280. package/.output/server/node_modules/@vue/server-renderer/package.json +55 -0
  281. package/.output/server/node_modules/@vue/shared/dist/shared.cjs.prod.js +594 -0
  282. package/.output/server/node_modules/@vue/shared/package.json +47 -0
  283. package/.output/server/node_modules/ai/dist/index.mjs +12363 -0
  284. package/.output/server/node_modules/ai/package.json +106 -0
  285. package/.output/server/node_modules/ansis/index.js +1 -0
  286. package/.output/server/node_modules/ansis/package.json +28 -0
  287. package/.output/server/node_modules/app-root-path/index.js +4 -0
  288. package/.output/server/node_modules/app-root-path/lib/app-root-path.js +30 -0
  289. package/.output/server/node_modules/app-root-path/lib/resolve.js +128 -0
  290. package/.output/server/node_modules/app-root-path/package.json +66 -0
  291. package/.output/server/node_modules/balanced-match/index.js +62 -0
  292. package/.output/server/node_modules/balanced-match/package.json +48 -0
  293. package/.output/server/node_modules/bindings/bindings.js +221 -0
  294. package/.output/server/node_modules/bindings/package.json +28 -0
  295. package/.output/server/node_modules/brace-expansion/index.js +203 -0
  296. package/.output/server/node_modules/brace-expansion/package.json +46 -0
  297. package/.output/server/node_modules/cluster-key-slot/lib/index.js +166 -0
  298. package/.output/server/node_modules/cluster-key-slot/package.json +56 -0
  299. package/.output/server/node_modules/consola/dist/chunks/prompt.mjs +280 -0
  300. package/.output/server/node_modules/consola/dist/core.mjs +512 -0
  301. package/.output/server/node_modules/consola/dist/index.mjs +651 -0
  302. package/.output/server/node_modules/consola/dist/shared/consola.DRwqZj3T.mjs +72 -0
  303. package/.output/server/node_modules/consola/dist/shared/consola.DXBYu-KD.mjs +288 -0
  304. package/.output/server/node_modules/consola/package.json +136 -0
  305. package/.output/server/node_modules/dayjs/dayjs.min.js +1 -0
  306. package/.output/server/node_modules/dayjs/package.json +84 -0
  307. package/.output/server/node_modules/debug/package.json +65 -0
  308. package/.output/server/node_modules/debug/src/browser.js +272 -0
  309. package/.output/server/node_modules/debug/src/common.js +292 -0
  310. package/.output/server/node_modules/debug/src/index.js +10 -0
  311. package/.output/server/node_modules/debug/src/node.js +263 -0
  312. package/.output/server/node_modules/dedent/dist/dedent.js +73 -0
  313. package/.output/server/node_modules/dedent/package.json +119 -0
  314. package/.output/server/node_modules/denque/index.js +481 -0
  315. package/.output/server/node_modules/denque/package.json +58 -0
  316. package/.output/server/node_modules/devalue/index.js +3 -0
  317. package/.output/server/node_modules/devalue/package.json +34 -0
  318. package/.output/server/node_modules/devalue/src/base64.js +110 -0
  319. package/.output/server/node_modules/devalue/src/constants.js +6 -0
  320. package/.output/server/node_modules/devalue/src/parse.js +160 -0
  321. package/.output/server/node_modules/devalue/src/stringify.js +232 -0
  322. package/.output/server/node_modules/devalue/src/uneval.js +351 -0
  323. package/.output/server/node_modules/devalue/src/utils.js +113 -0
  324. package/.output/server/node_modules/dotenv/lib/main.js +361 -0
  325. package/.output/server/node_modules/dotenv/package.json +61 -0
  326. package/.output/server/node_modules/entities/lib/decode.js +536 -0
  327. package/.output/server/node_modules/entities/lib/decode_codepoint.js +76 -0
  328. package/.output/server/node_modules/entities/lib/generated/decode-data-html.js +9 -0
  329. package/.output/server/node_modules/entities/lib/generated/decode-data-xml.js +9 -0
  330. package/.output/server/node_modules/entities/package.json +90 -0
  331. package/.output/server/node_modules/estree-walker/dist/umd/estree-walker.js +344 -0
  332. package/.output/server/node_modules/estree-walker/package.json +37 -0
  333. package/.output/server/node_modules/eventsource-parser/dist/index.js +106 -0
  334. package/.output/server/node_modules/eventsource-parser/dist/stream.js +29 -0
  335. package/.output/server/node_modules/eventsource-parser/package.json +115 -0
  336. package/.output/server/node_modules/file-uri-to-path/index.js +66 -0
  337. package/.output/server/node_modules/file-uri-to-path/package.json +32 -0
  338. package/.output/server/node_modules/glob/dist/commonjs/glob.js +247 -0
  339. package/.output/server/node_modules/glob/dist/commonjs/has-magic.js +27 -0
  340. package/.output/server/node_modules/glob/dist/commonjs/ignore.js +119 -0
  341. package/.output/server/node_modules/glob/dist/commonjs/index.js +68 -0
  342. package/.output/server/node_modules/glob/dist/commonjs/package.json +3 -0
  343. package/.output/server/node_modules/glob/dist/commonjs/pattern.js +219 -0
  344. package/.output/server/node_modules/glob/dist/commonjs/processor.js +301 -0
  345. package/.output/server/node_modules/glob/dist/commonjs/walker.js +387 -0
  346. package/.output/server/node_modules/glob/package.json +99 -0
  347. package/.output/server/node_modules/has-flag/index.js +8 -0
  348. package/.output/server/node_modules/has-flag/package.json +46 -0
  349. package/.output/server/node_modules/hookable/dist/index.mjs +290 -0
  350. package/.output/server/node_modules/hookable/package.json +49 -0
  351. package/.output/server/node_modules/inherits/inherits.js +9 -0
  352. package/.output/server/node_modules/inherits/inherits_browser.js +27 -0
  353. package/.output/server/node_modules/inherits/package.json +29 -0
  354. package/.output/server/node_modules/ioredis/built/Command.js +349 -0
  355. package/.output/server/node_modules/ioredis/built/DataHandler.js +220 -0
  356. package/.output/server/node_modules/ioredis/built/Pipeline.js +334 -0
  357. package/.output/server/node_modules/ioredis/built/Redis.js +697 -0
  358. package/.output/server/node_modules/ioredis/built/ScanStream.js +51 -0
  359. package/.output/server/node_modules/ioredis/built/Script.js +62 -0
  360. package/.output/server/node_modules/ioredis/built/SubscriptionSet.js +41 -0
  361. package/.output/server/node_modules/ioredis/built/autoPipelining.js +159 -0
  362. package/.output/server/node_modules/ioredis/built/cluster/ClusterOptions.js +22 -0
  363. package/.output/server/node_modules/ioredis/built/cluster/ClusterSubscriber.js +202 -0
  364. package/.output/server/node_modules/ioredis/built/cluster/ClusterSubscriberGroup.js +224 -0
  365. package/.output/server/node_modules/ioredis/built/cluster/ConnectionPool.js +154 -0
  366. package/.output/server/node_modules/ioredis/built/cluster/DelayQueue.js +53 -0
  367. package/.output/server/node_modules/ioredis/built/cluster/index.js +862 -0
  368. package/.output/server/node_modules/ioredis/built/cluster/util.js +100 -0
  369. package/.output/server/node_modules/ioredis/built/connectors/AbstractConnector.js +26 -0
  370. package/.output/server/node_modules/ioredis/built/connectors/SentinelConnector/FailoverDetector.js +45 -0
  371. package/.output/server/node_modules/ioredis/built/connectors/SentinelConnector/SentinelIterator.js +37 -0
  372. package/.output/server/node_modules/ioredis/built/connectors/SentinelConnector/index.js +305 -0
  373. package/.output/server/node_modules/ioredis/built/connectors/StandaloneConnector.js +69 -0
  374. package/.output/server/node_modules/ioredis/built/connectors/index.js +7 -0
  375. package/.output/server/node_modules/ioredis/built/constants/TLSProfiles.js +149 -0
  376. package/.output/server/node_modules/ioredis/built/errors/ClusterAllFailedError.js +15 -0
  377. package/.output/server/node_modules/ioredis/built/errors/MaxRetriesPerRequestError.js +14 -0
  378. package/.output/server/node_modules/ioredis/built/errors/index.js +5 -0
  379. package/.output/server/node_modules/ioredis/built/index.js +62 -0
  380. package/.output/server/node_modules/ioredis/built/redis/RedisOptions.js +55 -0
  381. package/.output/server/node_modules/ioredis/built/redis/event_handler.js +292 -0
  382. package/.output/server/node_modules/ioredis/built/transaction.js +93 -0
  383. package/.output/server/node_modules/ioredis/built/utils/Commander.js +117 -0
  384. package/.output/server/node_modules/ioredis/built/utils/applyMixin.js +8 -0
  385. package/.output/server/node_modules/ioredis/built/utils/debug.js +95 -0
  386. package/.output/server/node_modules/ioredis/built/utils/index.js +297 -0
  387. package/.output/server/node_modules/ioredis/built/utils/lodash.js +9 -0
  388. package/.output/server/node_modules/ioredis/package.json +100 -0
  389. package/.output/server/node_modules/lodash.defaults/index.js +668 -0
  390. package/.output/server/node_modules/lodash.defaults/package.json +19 -0
  391. package/.output/server/node_modules/lodash.isarguments/index.js +229 -0
  392. package/.output/server/node_modules/lodash.isarguments/package.json +19 -0
  393. package/.output/server/node_modules/lru-cache/dist/commonjs/index.js +1546 -0
  394. package/.output/server/node_modules/lru-cache/dist/commonjs/package.json +3 -0
  395. package/.output/server/node_modules/lru-cache/package.json +116 -0
  396. package/.output/server/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +14 -0
  397. package/.output/server/node_modules/minimatch/dist/commonjs/ast.js +592 -0
  398. package/.output/server/node_modules/minimatch/dist/commonjs/brace-expressions.js +152 -0
  399. package/.output/server/node_modules/minimatch/dist/commonjs/escape.js +22 -0
  400. package/.output/server/node_modules/minimatch/dist/commonjs/index.js +1017 -0
  401. package/.output/server/node_modules/minimatch/dist/commonjs/package.json +3 -0
  402. package/.output/server/node_modules/minimatch/dist/commonjs/unescape.js +24 -0
  403. package/.output/server/node_modules/minimatch/package.json +82 -0
  404. package/.output/server/node_modules/minipass/dist/commonjs/index.js +1028 -0
  405. package/.output/server/node_modules/minipass/dist/commonjs/package.json +3 -0
  406. package/.output/server/node_modules/minipass/package.json +82 -0
  407. package/.output/server/node_modules/ms/index.js +162 -0
  408. package/.output/server/node_modules/ms/package.json +38 -0
  409. package/.output/server/node_modules/path-scurry/dist/commonjs/index.js +2014 -0
  410. package/.output/server/node_modules/path-scurry/dist/commonjs/package.json +3 -0
  411. package/.output/server/node_modules/path-scurry/package.json +89 -0
  412. package/.output/server/node_modules/pg/lib/client.js +650 -0
  413. package/.output/server/node_modules/pg/lib/connection-parameters.js +167 -0
  414. package/.output/server/node_modules/pg/lib/connection.js +222 -0
  415. package/.output/server/node_modules/pg/lib/crypto/cert-signatures.js +121 -0
  416. package/.output/server/node_modules/pg/lib/crypto/sasl.js +212 -0
  417. package/.output/server/node_modules/pg/lib/crypto/utils-legacy.js +43 -0
  418. package/.output/server/node_modules/pg/lib/crypto/utils-webcrypto.js +88 -0
  419. package/.output/server/node_modules/pg/lib/crypto/utils.js +9 -0
  420. package/.output/server/node_modules/pg/lib/defaults.js +84 -0
  421. package/.output/server/node_modules/pg/lib/index.js +58 -0
  422. package/.output/server/node_modules/pg/lib/native/client.js +307 -0
  423. package/.output/server/node_modules/pg/lib/native/index.js +2 -0
  424. package/.output/server/node_modules/pg/lib/native/query.js +168 -0
  425. package/.output/server/node_modules/pg/lib/query.js +253 -0
  426. package/.output/server/node_modules/pg/lib/result.js +108 -0
  427. package/.output/server/node_modules/pg/lib/stream.js +81 -0
  428. package/.output/server/node_modules/pg/lib/type-overrides.js +35 -0
  429. package/.output/server/node_modules/pg/lib/utils.js +206 -0
  430. package/.output/server/node_modules/pg/package.json +62 -0
  431. package/.output/server/node_modules/pg-cloudflare/dist/empty.js +4 -0
  432. package/.output/server/node_modules/pg-cloudflare/package.json +32 -0
  433. package/.output/server/node_modules/pg-connection-string/index.js +112 -0
  434. package/.output/server/node_modules/pg-connection-string/package.json +40 -0
  435. package/.output/server/node_modules/pg-cursor/index.js +265 -0
  436. package/.output/server/node_modules/pg-cursor/package.json +38 -0
  437. package/.output/server/node_modules/pg-int8/index.js +100 -0
  438. package/.output/server/node_modules/pg-int8/package.json +24 -0
  439. package/.output/server/node_modules/pg-pool/index.js +471 -0
  440. package/.output/server/node_modules/pg-pool/package.json +41 -0
  441. package/.output/server/node_modules/pg-protocol/dist/buffer-reader.js +55 -0
  442. package/.output/server/node_modules/pg-protocol/dist/buffer-writer.js +81 -0
  443. package/.output/server/node_modules/pg-protocol/dist/index.js +15 -0
  444. package/.output/server/node_modules/pg-protocol/dist/messages.js +160 -0
  445. package/.output/server/node_modules/pg-protocol/dist/parser.js +304 -0
  446. package/.output/server/node_modules/pg-protocol/dist/serializer.js +189 -0
  447. package/.output/server/node_modules/pg-protocol/package.json +35 -0
  448. package/.output/server/node_modules/pg-query-stream/dist/index.js +48 -0
  449. package/.output/server/node_modules/pg-query-stream/package.json +60 -0
  450. package/.output/server/node_modules/pg-types/index.js +47 -0
  451. package/.output/server/node_modules/pg-types/lib/arrayParser.js +11 -0
  452. package/.output/server/node_modules/pg-types/lib/binaryParsers.js +257 -0
  453. package/.output/server/node_modules/pg-types/lib/builtins.js +73 -0
  454. package/.output/server/node_modules/pg-types/lib/textParsers.js +215 -0
  455. package/.output/server/node_modules/pg-types/package.json +42 -0
  456. package/.output/server/node_modules/pgpass/lib/helper.js +233 -0
  457. package/.output/server/node_modules/pgpass/lib/index.js +23 -0
  458. package/.output/server/node_modules/pgpass/package.json +41 -0
  459. package/.output/server/node_modules/postgres-array/index.js +97 -0
  460. package/.output/server/node_modules/postgres-array/package.json +35 -0
  461. package/.output/server/node_modules/postgres-bytea/index.js +31 -0
  462. package/.output/server/node_modules/postgres-bytea/package.json +34 -0
  463. package/.output/server/node_modules/postgres-date/index.js +116 -0
  464. package/.output/server/node_modules/postgres-date/package.json +33 -0
  465. package/.output/server/node_modules/postgres-interval/index.js +125 -0
  466. package/.output/server/node_modules/postgres-interval/package.json +36 -0
  467. package/.output/server/node_modules/redis-errors/index.js +7 -0
  468. package/.output/server/node_modules/redis-errors/lib/modern.js +59 -0
  469. package/.output/server/node_modules/redis-errors/lib/old.js +119 -0
  470. package/.output/server/node_modules/redis-errors/package.json +41 -0
  471. package/.output/server/node_modules/redis-parser/index.js +3 -0
  472. package/.output/server/node_modules/redis-parser/lib/parser.js +552 -0
  473. package/.output/server/node_modules/redis-parser/package.json +53 -0
  474. package/.output/server/node_modules/reflect-metadata/Reflect.js +1415 -0
  475. package/.output/server/node_modules/reflect-metadata/package.json +68 -0
  476. package/.output/server/node_modules/safe-buffer/index.js +65 -0
  477. package/.output/server/node_modules/safe-buffer/package.json +51 -0
  478. package/.output/server/node_modules/sha.js/hash.js +81 -0
  479. package/.output/server/node_modules/sha.js/index.js +15 -0
  480. package/.output/server/node_modules/sha.js/package.json +30 -0
  481. package/.output/server/node_modules/sha.js/sha.js +94 -0
  482. package/.output/server/node_modules/sha.js/sha1.js +99 -0
  483. package/.output/server/node_modules/sha.js/sha224.js +53 -0
  484. package/.output/server/node_modules/sha.js/sha256.js +135 -0
  485. package/.output/server/node_modules/sha.js/sha384.js +57 -0
  486. package/.output/server/node_modules/sha.js/sha512.js +260 -0
  487. package/.output/server/node_modules/source-map-js/lib/array-set.js +121 -0
  488. package/.output/server/node_modules/source-map-js/lib/base64-vlq.js +140 -0
  489. package/.output/server/node_modules/source-map-js/lib/base64.js +67 -0
  490. package/.output/server/node_modules/source-map-js/lib/binary-search.js +111 -0
  491. package/.output/server/node_modules/source-map-js/lib/mapping-list.js +79 -0
  492. package/.output/server/node_modules/source-map-js/lib/quick-sort.js +132 -0
  493. package/.output/server/node_modules/source-map-js/lib/source-map-consumer.js +1188 -0
  494. package/.output/server/node_modules/source-map-js/lib/source-map-generator.js +444 -0
  495. package/.output/server/node_modules/source-map-js/lib/source-node.js +413 -0
  496. package/.output/server/node_modules/source-map-js/lib/util.js +594 -0
  497. package/.output/server/node_modules/source-map-js/package.json +71 -0
  498. package/.output/server/node_modules/source-map-js/source-map.js +8 -0
  499. package/.output/server/node_modules/split2/index.js +141 -0
  500. package/.output/server/node_modules/split2/package.json +39 -0
  501. package/.output/server/node_modules/sql-highlight/lib/escapeHtml.js +59 -0
  502. package/.output/server/node_modules/sql-highlight/lib/index.js +85 -0
  503. package/.output/server/node_modules/sql-highlight/lib/keywords.js +145 -0
  504. package/.output/server/node_modules/sql-highlight/package.json +49 -0
  505. package/.output/server/node_modules/sqlite3/build/Release/node_sqlite3.node +0 -0
  506. package/.output/server/node_modules/sqlite3/build/Release/node_sqlite3.node.bak +0 -0
  507. package/.output/server/node_modules/sqlite3/lib/sqlite3-binding.js +1 -0
  508. package/.output/server/node_modules/sqlite3/lib/sqlite3.js +207 -0
  509. package/.output/server/node_modules/sqlite3/lib/trace.js +38 -0
  510. package/.output/server/node_modules/sqlite3/package.json +89 -0
  511. package/.output/server/node_modules/standard-as-callback/built/index.js +41 -0
  512. package/.output/server/node_modules/standard-as-callback/built/utils.js +23 -0
  513. package/.output/server/node_modules/standard-as-callback/package.json +40 -0
  514. package/.output/server/node_modules/supports-color/index.js +152 -0
  515. package/.output/server/node_modules/supports-color/package.json +58 -0
  516. package/.output/server/node_modules/tslib/package.json +47 -0
  517. package/.output/server/node_modules/tslib/tslib.js +484 -0
  518. package/.output/server/node_modules/typeorm/cache/DbQueryResultCache.js +264 -0
  519. package/.output/server/node_modules/typeorm/cache/QueryResultCacheFactory.js +42 -0
  520. package/.output/server/node_modules/typeorm/cache/RedisQueryResultCache.js +197 -0
  521. package/.output/server/node_modules/typeorm/common/DeepPartial.js +4 -0
  522. package/.output/server/node_modules/typeorm/common/EntityTarget.js +4 -0
  523. package/.output/server/node_modules/typeorm/common/MixedList.js +4 -0
  524. package/.output/server/node_modules/typeorm/common/ObjectLiteral.js +4 -0
  525. package/.output/server/node_modules/typeorm/common/ObjectType.js +4 -0
  526. package/.output/server/node_modules/typeorm/common/RelationType.js +4 -0
  527. package/.output/server/node_modules/typeorm/connection/Connection.js +16 -0
  528. package/.output/server/node_modules/typeorm/connection/ConnectionManager.js +66 -0
  529. package/.output/server/node_modules/typeorm/connection/ConnectionMetadataBuilder.js +74 -0
  530. package/.output/server/node_modules/typeorm/connection/ConnectionOptionsReader.js +198 -0
  531. package/.output/server/node_modules/typeorm/connection/options-reader/ConnectionOptionsEnvReader.js +111 -0
  532. package/.output/server/node_modules/typeorm/container.js +60 -0
  533. package/.output/server/node_modules/typeorm/data-source/DataSource.js +517 -0
  534. package/.output/server/node_modules/typeorm/decorator/Check.js +27 -0
  535. package/.output/server/node_modules/typeorm/decorator/EntityRepository.js +21 -0
  536. package/.output/server/node_modules/typeorm/decorator/Exclusion.js +27 -0
  537. package/.output/server/node_modules/typeorm/decorator/ForeignKey.js +44 -0
  538. package/.output/server/node_modules/typeorm/decorator/Generated.js +24 -0
  539. package/.output/server/node_modules/typeorm/decorator/Index.js +56 -0
  540. package/.output/server/node_modules/typeorm/decorator/Unique.js +50 -0
  541. package/.output/server/node_modules/typeorm/decorator/columns/Column.js +78 -0
  542. package/.output/server/node_modules/typeorm/decorator/columns/CreateDateColumn.js +21 -0
  543. package/.output/server/node_modules/typeorm/decorator/columns/DeleteDateColumn.js +20 -0
  544. package/.output/server/node_modules/typeorm/decorator/columns/ObjectIdColumn.js +27 -0
  545. package/.output/server/node_modules/typeorm/decorator/columns/PrimaryColumn.js +63 -0
  546. package/.output/server/node_modules/typeorm/decorator/columns/PrimaryGeneratedColumn.js +59 -0
  547. package/.output/server/node_modules/typeorm/decorator/columns/UpdateDateColumn.js +20 -0
  548. package/.output/server/node_modules/typeorm/decorator/columns/VersionColumn.js +21 -0
  549. package/.output/server/node_modules/typeorm/decorator/columns/ViewColumn.js +19 -0
  550. package/.output/server/node_modules/typeorm/decorator/columns/VirtualColumn.js +49 -0
  551. package/.output/server/node_modules/typeorm/decorator/entity/ChildEntity.js +25 -0
  552. package/.output/server/node_modules/typeorm/decorator/entity/Entity.js +31 -0
  553. package/.output/server/node_modules/typeorm/decorator/entity/TableInheritance.js +22 -0
  554. package/.output/server/node_modules/typeorm/decorator/entity-view/ViewEntity.js +32 -0
  555. package/.output/server/node_modules/typeorm/decorator/listeners/AfterInsert.js +19 -0
  556. package/.output/server/node_modules/typeorm/decorator/listeners/AfterLoad.js +19 -0
  557. package/.output/server/node_modules/typeorm/decorator/listeners/AfterRecover.js +19 -0
  558. package/.output/server/node_modules/typeorm/decorator/listeners/AfterRemove.js +19 -0
  559. package/.output/server/node_modules/typeorm/decorator/listeners/AfterSoftRemove.js +19 -0
  560. package/.output/server/node_modules/typeorm/decorator/listeners/AfterUpdate.js +19 -0
  561. package/.output/server/node_modules/typeorm/decorator/listeners/BeforeInsert.js +19 -0
  562. package/.output/server/node_modules/typeorm/decorator/listeners/BeforeRecover.js +19 -0
  563. package/.output/server/node_modules/typeorm/decorator/listeners/BeforeRemove.js +19 -0
  564. package/.output/server/node_modules/typeorm/decorator/listeners/BeforeSoftRemove.js +19 -0
  565. package/.output/server/node_modules/typeorm/decorator/listeners/BeforeUpdate.js +19 -0
  566. package/.output/server/node_modules/typeorm/decorator/listeners/EventSubscriber.js +17 -0
  567. package/.output/server/node_modules/typeorm/decorator/options/ColumnOptions.js +4 -0
  568. package/.output/server/node_modules/typeorm/decorator/options/EntityOptions.js +4 -0
  569. package/.output/server/node_modules/typeorm/decorator/options/IndexOptions.js +4 -0
  570. package/.output/server/node_modules/typeorm/decorator/options/JoinColumnOptions.js +4 -0
  571. package/.output/server/node_modules/typeorm/decorator/options/JoinTableOptions.js +4 -0
  572. package/.output/server/node_modules/typeorm/decorator/options/RelationOptions.js +4 -0
  573. package/.output/server/node_modules/typeorm/decorator/options/ValueTransformer.js +4 -0
  574. package/.output/server/node_modules/typeorm/decorator/relations/JoinColumn.js +27 -0
  575. package/.output/server/node_modules/typeorm/decorator/relations/JoinTable.js +34 -0
  576. package/.output/server/node_modules/typeorm/decorator/relations/ManyToMany.js +46 -0
  577. package/.output/server/node_modules/typeorm/decorator/relations/ManyToOne.js +46 -0
  578. package/.output/server/node_modules/typeorm/decorator/relations/OneToMany.js +37 -0
  579. package/.output/server/node_modules/typeorm/decorator/relations/OneToOne.js +45 -0
  580. package/.output/server/node_modules/typeorm/decorator/relations/RelationCount.js +23 -0
  581. package/.output/server/node_modules/typeorm/decorator/relations/RelationId.js +22 -0
  582. package/.output/server/node_modules/typeorm/decorator/tree/Tree.js +21 -0
  583. package/.output/server/node_modules/typeorm/decorator/tree/TreeChildren.js +34 -0
  584. package/.output/server/node_modules/typeorm/decorator/tree/TreeLevelColumn.js +19 -0
  585. package/.output/server/node_modules/typeorm/decorator/tree/TreeParent.js +33 -0
  586. package/.output/server/node_modules/typeorm/driver/DriverFactory.js +98 -0
  587. package/.output/server/node_modules/typeorm/driver/DriverUtils.js +228 -0
  588. package/.output/server/node_modules/typeorm/driver/Query.js +16 -0
  589. package/.output/server/node_modules/typeorm/driver/SqlInMemory.js +15 -0
  590. package/.output/server/node_modules/typeorm/driver/aurora-mysql/AuroraMysqlDriver.js +847 -0
  591. package/.output/server/node_modules/typeorm/driver/aurora-mysql/AuroraMysqlQueryRunner.js +1709 -0
  592. package/.output/server/node_modules/typeorm/driver/aurora-postgres/AuroraPostgresDriver.js +103 -0
  593. package/.output/server/node_modules/typeorm/driver/aurora-postgres/AuroraPostgresQueryRunner.js +146 -0
  594. package/.output/server/node_modules/typeorm/driver/better-sqlite3/BetterSqlite3Driver.js +153 -0
  595. package/.output/server/node_modules/typeorm/driver/better-sqlite3/BetterSqlite3QueryRunner.js +126 -0
  596. package/.output/server/node_modules/typeorm/driver/capacitor/CapacitorDriver.js +78 -0
  597. package/.output/server/node_modules/typeorm/driver/capacitor/CapacitorQueryRunner.js +98 -0
  598. package/.output/server/node_modules/typeorm/driver/cockroachdb/CockroachDriver.js +885 -0
  599. package/.output/server/node_modules/typeorm/driver/cockroachdb/CockroachQueryRunner.js +2453 -0
  600. package/.output/server/node_modules/typeorm/driver/cordova/CordovaDriver.js +76 -0
  601. package/.output/server/node_modules/typeorm/driver/cordova/CordovaQueryRunner.js +170 -0
  602. package/.output/server/node_modules/typeorm/driver/expo/ExpoDriver.js +29 -0
  603. package/.output/server/node_modules/typeorm/driver/expo/ExpoDriverFactory.js +22 -0
  604. package/.output/server/node_modules/typeorm/driver/expo/ExpoQueryRunner.js +65 -0
  605. package/.output/server/node_modules/typeorm/driver/expo/legacy/ExpoLegacyDriver.js +75 -0
  606. package/.output/server/node_modules/typeorm/driver/expo/legacy/ExpoLegacyQueryRunner.js +169 -0
  607. package/.output/server/node_modules/typeorm/driver/mongodb/MongoDriver.js +404 -0
  608. package/.output/server/node_modules/typeorm/driver/mongodb/MongoQueryRunner.js +701 -0
  609. package/.output/server/node_modules/typeorm/driver/mongodb/bson.typings.js +5 -0
  610. package/.output/server/node_modules/typeorm/driver/mongodb/typings.js +23 -0
  611. package/.output/server/node_modules/typeorm/driver/mysql/MysqlDriver.js +1105 -0
  612. package/.output/server/node_modules/typeorm/driver/mysql/MysqlQueryRunner.js +2139 -0
  613. package/.output/server/node_modules/typeorm/driver/nativescript/NativescriptDriver.js +94 -0
  614. package/.output/server/node_modules/typeorm/driver/nativescript/NativescriptQueryRunner.js +92 -0
  615. package/.output/server/node_modules/typeorm/driver/oracle/OracleDriver.js +869 -0
  616. package/.output/server/node_modules/typeorm/driver/oracle/OracleQueryRunner.js +1884 -0
  617. package/.output/server/node_modules/typeorm/driver/postgres/PostgresDriver.js +1259 -0
  618. package/.output/server/node_modules/typeorm/driver/postgres/PostgresQueryRunner.js +2729 -0
  619. package/.output/server/node_modules/typeorm/driver/react-native/ReactNativeDriver.js +728 -0
  620. package/.output/server/node_modules/typeorm/driver/react-native/ReactNativeQueryRunner.js +107 -0
  621. package/.output/server/node_modules/typeorm/driver/sap/SapDriver.js +681 -0
  622. package/.output/server/node_modules/typeorm/driver/sap/SapQueryRunner.js +2054 -0
  623. package/.output/server/node_modules/typeorm/driver/spanner/SpannerDriver.js +613 -0
  624. package/.output/server/node_modules/typeorm/driver/spanner/SpannerQueryRunner.js +1464 -0
  625. package/.output/server/node_modules/typeorm/driver/sqlite/SqliteDriver.js +174 -0
  626. package/.output/server/node_modules/typeorm/driver/sqlite/SqliteQueryRunner.js +124 -0
  627. package/.output/server/node_modules/typeorm/driver/sqlite-abstract/AbstractSqliteDriver.js +695 -0
  628. package/.output/server/node_modules/typeorm/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +1511 -0
  629. package/.output/server/node_modules/typeorm/driver/sqljs/SqljsDriver.js +250 -0
  630. package/.output/server/node_modules/typeorm/driver/sqljs/SqljsQueryRunner.js +123 -0
  631. package/.output/server/node_modules/typeorm/driver/sqlserver/MssqlParameter.js +23 -0
  632. package/.output/server/node_modules/typeorm/driver/sqlserver/SqlServerDriver.js +922 -0
  633. package/.output/server/node_modules/typeorm/driver/sqlserver/SqlServerQueryRunner.js +2484 -0
  634. package/.output/server/node_modules/typeorm/driver/types/DatabaseType.js +4 -0
  635. package/.output/server/node_modules/typeorm/driver/types/GeoJsonTypes.js +4 -0
  636. package/.output/server/node_modules/typeorm/driver/types/MetadataTableType.js +11 -0
  637. package/.output/server/node_modules/typeorm/driver/types/ReplicationMode.js +4 -0
  638. package/.output/server/node_modules/typeorm/entity-manager/EntityManager.js +853 -0
  639. package/.output/server/node_modules/typeorm/entity-manager/EntityManagerFactory.js +24 -0
  640. package/.output/server/node_modules/typeorm/entity-manager/MongoEntityManager.js +668 -0
  641. package/.output/server/node_modules/typeorm/entity-manager/SqljsEntityManager.js +44 -0
  642. package/.output/server/node_modules/typeorm/entity-schema/EntitySchema.js +15 -0
  643. package/.output/server/node_modules/typeorm/entity-schema/EntitySchemaEmbeddedColumnOptions.js +8 -0
  644. package/.output/server/node_modules/typeorm/entity-schema/EntitySchemaEmbeddedError.js +18 -0
  645. package/.output/server/node_modules/typeorm/entity-schema/EntitySchemaOptions.js +11 -0
  646. package/.output/server/node_modules/typeorm/entity-schema/EntitySchemaTransformer.js +333 -0
  647. package/.output/server/node_modules/typeorm/error/AlreadyHasActiveConnectionError.js +16 -0
  648. package/.output/server/node_modules/typeorm/error/CannotAttachTreeChildrenEntityError.js +16 -0
  649. package/.output/server/node_modules/typeorm/error/CannotConnectAlreadyConnectedError.js +15 -0
  650. package/.output/server/node_modules/typeorm/error/CannotCreateEntityIdMapError.js +21 -0
  651. package/.output/server/node_modules/typeorm/error/CannotDetermineEntityError.js +16 -0
  652. package/.output/server/node_modules/typeorm/error/CannotExecuteNotConnectedError.js +15 -0
  653. package/.output/server/node_modules/typeorm/error/CannotGetEntityManagerNotConnectedError.js +15 -0
  654. package/.output/server/node_modules/typeorm/error/CannotReflectMethodParameterTypeError.js +18 -0
  655. package/.output/server/node_modules/typeorm/error/CircularRelationsError.js +16 -0
  656. package/.output/server/node_modules/typeorm/error/ColumnTypeUndefinedError.js +19 -0
  657. package/.output/server/node_modules/typeorm/error/ConnectionIsNotSetError.js +15 -0
  658. package/.output/server/node_modules/typeorm/error/ConnectionNotFoundError.js +15 -0
  659. package/.output/server/node_modules/typeorm/error/CustomRepositoryCannotInheritRepositoryError.js +18 -0
  660. package/.output/server/node_modules/typeorm/error/CustomRepositoryDoesNotHaveEntityError.js +18 -0
  661. package/.output/server/node_modules/typeorm/error/CustomRepositoryNotFoundError.js +18 -0
  662. package/.output/server/node_modules/typeorm/error/DataTypeNotSupportedError.js +14 -0
  663. package/.output/server/node_modules/typeorm/error/DriverOptionNotSetError.js +16 -0
  664. package/.output/server/node_modules/typeorm/error/DriverPackageNotInstalledError.js +16 -0
  665. package/.output/server/node_modules/typeorm/error/EntityMetadataNotFoundError.js +29 -0
  666. package/.output/server/node_modules/typeorm/error/EntityNotFoundError.js +42 -0
  667. package/.output/server/node_modules/typeorm/error/EntityPropertyNotFoundError.js +17 -0
  668. package/.output/server/node_modules/typeorm/error/FindRelationsNotFoundError.js +23 -0
  669. package/.output/server/node_modules/typeorm/error/ForbiddenTransactionModeOverrideError.js +16 -0
  670. package/.output/server/node_modules/typeorm/error/InitializedRelationError.js +20 -0
  671. package/.output/server/node_modules/typeorm/error/InsertValuesMissingError.js +16 -0
  672. package/.output/server/node_modules/typeorm/error/LimitOnUpdateNotSupportedError.js +15 -0
  673. package/.output/server/node_modules/typeorm/error/LockNotSupportedOnGivenDriverError.js +15 -0
  674. package/.output/server/node_modules/typeorm/error/MetadataAlreadyExistsError.js +18 -0
  675. package/.output/server/node_modules/typeorm/error/MetadataWithSuchNameAlreadyExistsError.js +16 -0
  676. package/.output/server/node_modules/typeorm/error/MissingDeleteDateColumnError.js +12 -0
  677. package/.output/server/node_modules/typeorm/error/MissingDriverError.js +16 -0
  678. package/.output/server/node_modules/typeorm/error/MissingJoinColumnError.js +23 -0
  679. package/.output/server/node_modules/typeorm/error/MissingJoinTableError.js +23 -0
  680. package/.output/server/node_modules/typeorm/error/MissingPrimaryColumnError.js +13 -0
  681. package/.output/server/node_modules/typeorm/error/MustBeEntityError.js +15 -0
  682. package/.output/server/node_modules/typeorm/error/NestedSetMultipleRootError.js +12 -0
  683. package/.output/server/node_modules/typeorm/error/NoConnectionForRepositoryError.js +16 -0
  684. package/.output/server/node_modules/typeorm/error/NoConnectionOptionError.js +16 -0
  685. package/.output/server/node_modules/typeorm/error/NoNeedToReleaseEntityManagerError.js +17 -0
  686. package/.output/server/node_modules/typeorm/error/NoVersionOrUpdateDateColumnError.js +15 -0
  687. package/.output/server/node_modules/typeorm/error/OffsetWithoutLimitNotSupportedError.js +17 -0
  688. package/.output/server/node_modules/typeorm/error/OptimisticLockCanNotBeUsedError.js +15 -0
  689. package/.output/server/node_modules/typeorm/error/OptimisticLockVersionMismatchError.js +15 -0
  690. package/.output/server/node_modules/typeorm/error/PersistedEntityNotFoundError.js +15 -0
  691. package/.output/server/node_modules/typeorm/error/PessimisticLockTransactionRequiredError.js +15 -0
  692. package/.output/server/node_modules/typeorm/error/PrimaryColumnCannotBeNullableError.js +13 -0
  693. package/.output/server/node_modules/typeorm/error/QueryFailedError.js +30 -0
  694. package/.output/server/node_modules/typeorm/error/QueryRunnerAlreadyReleasedError.js +12 -0
  695. package/.output/server/node_modules/typeorm/error/QueryRunnerProviderAlreadyReleasedError.js +16 -0
  696. package/.output/server/node_modules/typeorm/error/RepositoryNotTreeError.js +32 -0
  697. package/.output/server/node_modules/typeorm/error/ReturningStatementNotSupportedError.js +16 -0
  698. package/.output/server/node_modules/typeorm/error/SubjectRemovedAndUpdatedError.js +16 -0
  699. package/.output/server/node_modules/typeorm/error/SubjectWithoutIdentifierError.js +17 -0
  700. package/.output/server/node_modules/typeorm/error/TransactionAlreadyStartedError.js +15 -0
  701. package/.output/server/node_modules/typeorm/error/TransactionNotStartedError.js +15 -0
  702. package/.output/server/node_modules/typeorm/error/TreeRepositoryNotSupportedError.js +12 -0
  703. package/.output/server/node_modules/typeorm/error/TypeORMError.js +23 -0
  704. package/.output/server/node_modules/typeorm/error/UpdateValuesMissingError.js +12 -0
  705. package/.output/server/node_modules/typeorm/error/UsingJoinColumnIsNotAllowedError.js +13 -0
  706. package/.output/server/node_modules/typeorm/error/UsingJoinColumnOnlyOnOneSideAllowedError.js +14 -0
  707. package/.output/server/node_modules/typeorm/error/UsingJoinTableIsNotAllowedError.js +14 -0
  708. package/.output/server/node_modules/typeorm/error/UsingJoinTableOnlyOnOneSideAllowedError.js +14 -0
  709. package/.output/server/node_modules/typeorm/error/index.js +66 -0
  710. package/.output/server/node_modules/typeorm/find-options/EqualOperator.js +13 -0
  711. package/.output/server/node_modules/typeorm/find-options/FindManyOptions.js +4 -0
  712. package/.output/server/node_modules/typeorm/find-options/FindOneOptions.js +4 -0
  713. package/.output/server/node_modules/typeorm/find-options/FindOperator.js +96 -0
  714. package/.output/server/node_modules/typeorm/find-options/FindOperatorType.js +4 -0
  715. package/.output/server/node_modules/typeorm/find-options/FindOptionsOrder.js +4 -0
  716. package/.output/server/node_modules/typeorm/find-options/FindOptionsRelations.js +4 -0
  717. package/.output/server/node_modules/typeorm/find-options/FindOptionsSelect.js +4 -0
  718. package/.output/server/node_modules/typeorm/find-options/FindOptionsUtils.js +350 -0
  719. package/.output/server/node_modules/typeorm/find-options/FindOptionsWhere.js +4 -0
  720. package/.output/server/node_modules/typeorm/find-options/FindTreeOptions.js +4 -0
  721. package/.output/server/node_modules/typeorm/find-options/JoinOptions.js +4 -0
  722. package/.output/server/node_modules/typeorm/find-options/OrderByCondition.js +4 -0
  723. package/.output/server/node_modules/typeorm/find-options/operator/And.js +9 -0
  724. package/.output/server/node_modules/typeorm/find-options/operator/Any.js +13 -0
  725. package/.output/server/node_modules/typeorm/find-options/operator/ArrayContainedBy.js +13 -0
  726. package/.output/server/node_modules/typeorm/find-options/operator/ArrayContains.js +13 -0
  727. package/.output/server/node_modules/typeorm/find-options/operator/ArrayOverlap.js +13 -0
  728. package/.output/server/node_modules/typeorm/find-options/operator/Between.js +13 -0
  729. package/.output/server/node_modules/typeorm/find-options/operator/Equal.js +17 -0
  730. package/.output/server/node_modules/typeorm/find-options/operator/ILike.js +13 -0
  731. package/.output/server/node_modules/typeorm/find-options/operator/In.js +13 -0
  732. package/.output/server/node_modules/typeorm/find-options/operator/IsNull.js +13 -0
  733. package/.output/server/node_modules/typeorm/find-options/operator/JsonContains.js +13 -0
  734. package/.output/server/node_modules/typeorm/find-options/operator/LessThan.js +13 -0
  735. package/.output/server/node_modules/typeorm/find-options/operator/LessThanOrEqual.js +13 -0
  736. package/.output/server/node_modules/typeorm/find-options/operator/Like.js +13 -0
  737. package/.output/server/node_modules/typeorm/find-options/operator/MoreThan.js +13 -0
  738. package/.output/server/node_modules/typeorm/find-options/operator/MoreThanOrEqual.js +13 -0
  739. package/.output/server/node_modules/typeorm/find-options/operator/Not.js +14 -0
  740. package/.output/server/node_modules/typeorm/find-options/operator/Or.js +9 -0
  741. package/.output/server/node_modules/typeorm/find-options/operator/Raw.js +12 -0
  742. package/.output/server/node_modules/typeorm/globals.js +182 -0
  743. package/.output/server/node_modules/typeorm/index.js +196 -0
  744. package/.output/server/node_modules/typeorm/index.mjs +422 -0
  745. package/.output/server/node_modules/typeorm/logger/AbstractLogger.js +238 -0
  746. package/.output/server/node_modules/typeorm/logger/AdvancedConsoleLogger.js +56 -0
  747. package/.output/server/node_modules/typeorm/logger/DebugLogger.js +78 -0
  748. package/.output/server/node_modules/typeorm/logger/FileLogger.js +88 -0
  749. package/.output/server/node_modules/typeorm/logger/FormattedConsoleLogger.js +59 -0
  750. package/.output/server/node_modules/typeorm/logger/Logger.js +4 -0
  751. package/.output/server/node_modules/typeorm/logger/LoggerFactory.js +39 -0
  752. package/.output/server/node_modules/typeorm/logger/LoggerOptions.js +4 -0
  753. package/.output/server/node_modules/typeorm/logger/SimpleConsoleLogger.js +57 -0
  754. package/.output/server/node_modules/typeorm/metadata/CheckMetadata.js +35 -0
  755. package/.output/server/node_modules/typeorm/metadata/ColumnMetadata.js +618 -0
  756. package/.output/server/node_modules/typeorm/metadata/EmbeddedMetadata.js +224 -0
  757. package/.output/server/node_modules/typeorm/metadata/EntityListenerMetadata.js +77 -0
  758. package/.output/server/node_modules/typeorm/metadata/EntityMetadata.js +692 -0
  759. package/.output/server/node_modules/typeorm/metadata/ExclusionMetadata.js +35 -0
  760. package/.output/server/node_modules/typeorm/metadata/ForeignKeyMetadata.js +57 -0
  761. package/.output/server/node_modules/typeorm/metadata/IndexMetadata.js +144 -0
  762. package/.output/server/node_modules/typeorm/metadata/RelationCountMetadata.js +39 -0
  763. package/.output/server/node_modules/typeorm/metadata/RelationIdMetadata.js +62 -0
  764. package/.output/server/node_modules/typeorm/metadata/RelationMetadata.js +440 -0
  765. package/.output/server/node_modules/typeorm/metadata/UniqueMetadata.js +101 -0
  766. package/.output/server/node_modules/typeorm/metadata/types/EventListenerTypes.js +22 -0
  767. package/.output/server/node_modules/typeorm/metadata-args/MetadataArgsStorage.js +236 -0
  768. package/.output/server/node_modules/typeorm/metadata-builder/ClosureJunctionEntityMetadataBuilder.js +145 -0
  769. package/.output/server/node_modules/typeorm/metadata-builder/EntityMetadataBuilder.js +838 -0
  770. package/.output/server/node_modules/typeorm/metadata-builder/EntityMetadataValidator.js +258 -0
  771. package/.output/server/node_modules/typeorm/metadata-builder/JunctionEntityMetadataBuilder.js +287 -0
  772. package/.output/server/node_modules/typeorm/metadata-builder/MetadataUtils.js +44 -0
  773. package/.output/server/node_modules/typeorm/metadata-builder/RelationJoinColumnBuilder.js +185 -0
  774. package/.output/server/node_modules/typeorm/migration/Migration.js +21 -0
  775. package/.output/server/node_modules/typeorm/migration/MigrationExecutor.js +534 -0
  776. package/.output/server/node_modules/typeorm/naming-strategy/DefaultNamingStrategy.js +145 -0
  777. package/.output/server/node_modules/typeorm/naming-strategy/LegacyOracleNamingStrategy.js +50 -0
  778. package/.output/server/node_modules/typeorm/package.json +268 -0
  779. package/.output/server/node_modules/typeorm/persistence/EntityPersistExecutor.js +170 -0
  780. package/.output/server/node_modules/typeorm/persistence/Subject.js +239 -0
  781. package/.output/server/node_modules/typeorm/persistence/SubjectChangedColumnsComputer.js +216 -0
  782. package/.output/server/node_modules/typeorm/persistence/SubjectDatabaseEntityLoader.js +135 -0
  783. package/.output/server/node_modules/typeorm/persistence/SubjectExecutor.js +760 -0
  784. package/.output/server/node_modules/typeorm/persistence/SubjectTopologicalSorter.js +174 -0
  785. package/.output/server/node_modules/typeorm/persistence/subject-builder/CascadesSubjectBuilder.js +107 -0
  786. package/.output/server/node_modules/typeorm/persistence/subject-builder/ManyToManySubjectBuilder.js +218 -0
  787. package/.output/server/node_modules/typeorm/persistence/subject-builder/OneToManySubjectBuilder.js +181 -0
  788. package/.output/server/node_modules/typeorm/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +155 -0
  789. package/.output/server/node_modules/typeorm/persistence/tree/ClosureSubjectExecutor.js +241 -0
  790. package/.output/server/node_modules/typeorm/persistence/tree/MaterializedPathSubjectExecutor.js +125 -0
  791. package/.output/server/node_modules/typeorm/persistence/tree/NestedSetSubjectExecutor.js +271 -0
  792. package/.output/server/node_modules/typeorm/platform/PlatformTools.js +243 -0
  793. package/.output/server/node_modules/typeorm/query-builder/Alias.js +29 -0
  794. package/.output/server/node_modules/typeorm/query-builder/Brackets.js +19 -0
  795. package/.output/server/node_modules/typeorm/query-builder/DeleteQueryBuilder.js +200 -0
  796. package/.output/server/node_modules/typeorm/query-builder/InsertQueryBuilder.js +745 -0
  797. package/.output/server/node_modules/typeorm/query-builder/JoinAttribute.js +175 -0
  798. package/.output/server/node_modules/typeorm/query-builder/NotBrackets.js +17 -0
  799. package/.output/server/node_modules/typeorm/query-builder/QueryBuilder.js +1139 -0
  800. package/.output/server/node_modules/typeorm/query-builder/QueryBuilderUtils.js +32 -0
  801. package/.output/server/node_modules/typeorm/query-builder/QueryExpressionMap.js +328 -0
  802. package/.output/server/node_modules/typeorm/query-builder/RelationIdLoader.js +503 -0
  803. package/.output/server/node_modules/typeorm/query-builder/RelationLoader.js +283 -0
  804. package/.output/server/node_modules/typeorm/query-builder/RelationQueryBuilder.js +155 -0
  805. package/.output/server/node_modules/typeorm/query-builder/RelationRemover.js +143 -0
  806. package/.output/server/node_modules/typeorm/query-builder/RelationUpdater.js +152 -0
  807. package/.output/server/node_modules/typeorm/query-builder/ReturningResultsEntityUpdator.js +176 -0
  808. package/.output/server/node_modules/typeorm/query-builder/SelectQueryBuilder.js +2656 -0
  809. package/.output/server/node_modules/typeorm/query-builder/SoftDeleteQueryBuilder.js +368 -0
  810. package/.output/server/node_modules/typeorm/query-builder/UpdateQueryBuilder.js +498 -0
  811. package/.output/server/node_modules/typeorm/query-builder/index.js +20 -0
  812. package/.output/server/node_modules/typeorm/query-builder/relation-count/RelationCountAttribute.js +80 -0
  813. package/.output/server/node_modules/typeorm/query-builder/relation-count/RelationCountLoader.js +168 -0
  814. package/.output/server/node_modules/typeorm/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js +55 -0
  815. package/.output/server/node_modules/typeorm/query-builder/relation-id/RelationIdAttribute.js +88 -0
  816. package/.output/server/node_modules/typeorm/query-builder/relation-id/RelationIdLoader.js +275 -0
  817. package/.output/server/node_modules/typeorm/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js +55 -0
  818. package/.output/server/node_modules/typeorm/query-builder/result/DeleteResult.js +17 -0
  819. package/.output/server/node_modules/typeorm/query-builder/result/InsertResult.js +28 -0
  820. package/.output/server/node_modules/typeorm/query-builder/result/UpdateResult.js +29 -0
  821. package/.output/server/node_modules/typeorm/query-builder/transformer/DocumentToEntityTransformer.js +196 -0
  822. package/.output/server/node_modules/typeorm/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js +112 -0
  823. package/.output/server/node_modules/typeorm/query-builder/transformer/PlainObjectToNewEntityTransformer.js +92 -0
  824. package/.output/server/node_modules/typeorm/query-builder/transformer/RawSqlResultsToEntityTransformer.js +447 -0
  825. package/.output/server/node_modules/typeorm/query-runner/BaseQueryRunner.js +454 -0
  826. package/.output/server/node_modules/typeorm/query-runner/QueryLock.js +28 -0
  827. package/.output/server/node_modules/typeorm/query-runner/QueryResult.js +17 -0
  828. package/.output/server/node_modules/typeorm/repository/AbstractRepository.js +92 -0
  829. package/.output/server/node_modules/typeorm/repository/BaseEntity.js +328 -0
  830. package/.output/server/node_modules/typeorm/repository/MongoRepository.js +305 -0
  831. package/.output/server/node_modules/typeorm/repository/RemoveOptions.js +4 -0
  832. package/.output/server/node_modules/typeorm/repository/Repository.js +379 -0
  833. package/.output/server/node_modules/typeorm/repository/SaveOptions.js +4 -0
  834. package/.output/server/node_modules/typeorm/repository/TreeRepository.js +255 -0
  835. package/.output/server/node_modules/typeorm/schema-builder/MongoSchemaBuilder.js +66 -0
  836. package/.output/server/node_modules/typeorm/schema-builder/RdbmsSchemaBuilder.js +929 -0
  837. package/.output/server/node_modules/typeorm/schema-builder/options/TableCheckOptions.js +4 -0
  838. package/.output/server/node_modules/typeorm/schema-builder/options/TableColumnOptions.js +4 -0
  839. package/.output/server/node_modules/typeorm/schema-builder/options/TableExclusionOptions.js +4 -0
  840. package/.output/server/node_modules/typeorm/schema-builder/options/TableForeignKeyOptions.js +4 -0
  841. package/.output/server/node_modules/typeorm/schema-builder/options/TableIndexOptions.js +4 -0
  842. package/.output/server/node_modules/typeorm/schema-builder/options/TableOptions.js +4 -0
  843. package/.output/server/node_modules/typeorm/schema-builder/options/TableUniqueOptions.js +4 -0
  844. package/.output/server/node_modules/typeorm/schema-builder/options/ViewOptions.js +4 -0
  845. package/.output/server/node_modules/typeorm/schema-builder/table/Table.js +296 -0
  846. package/.output/server/node_modules/typeorm/schema-builder/table/TableCheck.js +49 -0
  847. package/.output/server/node_modules/typeorm/schema-builder/table/TableColumn.js +117 -0
  848. package/.output/server/node_modules/typeorm/schema-builder/table/TableExclusion.js +43 -0
  849. package/.output/server/node_modules/typeorm/schema-builder/table/TableForeignKey.js +72 -0
  850. package/.output/server/node_modules/typeorm/schema-builder/table/TableIndex.js +68 -0
  851. package/.output/server/node_modules/typeorm/schema-builder/table/TableUnique.js +50 -0
  852. package/.output/server/node_modules/typeorm/schema-builder/util/TableUtils.js +41 -0
  853. package/.output/server/node_modules/typeorm/schema-builder/util/ViewUtils.js +27 -0
  854. package/.output/server/node_modules/typeorm/schema-builder/view/View.js +71 -0
  855. package/.output/server/node_modules/typeorm/subscriber/Broadcaster.js +660 -0
  856. package/.output/server/node_modules/typeorm/subscriber/BroadcasterResult.js +30 -0
  857. package/.output/server/node_modules/typeorm/subscriber/event/QueryEvent.js +4 -0
  858. package/.output/server/node_modules/typeorm/util/ApplyValueTransformers.js +25 -0
  859. package/.output/server/node_modules/typeorm/util/DateUtils.js +229 -0
  860. package/.output/server/node_modules/typeorm/util/DepGraph.js +230 -0
  861. package/.output/server/node_modules/typeorm/util/DirectoryExportedClassesLoader.js +65 -0
  862. package/.output/server/node_modules/typeorm/util/ImportUtils.js +66 -0
  863. package/.output/server/node_modules/typeorm/util/InstanceChecker.js +104 -0
  864. package/.output/server/node_modules/typeorm/util/ObjectUtils.js +49 -0
  865. package/.output/server/node_modules/typeorm/util/OrmUtils.js +443 -0
  866. package/.output/server/node_modules/typeorm/util/PathUtils.js +33 -0
  867. package/.output/server/node_modules/typeorm/util/RandomGenerator.js +154 -0
  868. package/.output/server/node_modules/typeorm/util/SqlTagUtils.js +43 -0
  869. package/.output/server/node_modules/typeorm/util/StringUtils.js +113 -0
  870. package/.output/server/node_modules/typeorm/util/TreeRepositoryUtils.js +67 -0
  871. package/.output/server/node_modules/typeorm/util/VersionUtils.js +27 -0
  872. package/.output/server/node_modules/typeorm/util/escapeRegExp.js +10 -0
  873. package/.output/server/node_modules/ufo/dist/index.mjs +630 -0
  874. package/.output/server/node_modules/ufo/package.json +47 -0
  875. package/.output/server/node_modules/unhead/dist/plugins.mjs +94 -0
  876. package/.output/server/node_modules/unhead/dist/server.mjs +220 -0
  877. package/.output/server/node_modules/unhead/dist/shared/unhead.C13swrCa.mjs +48 -0
  878. package/.output/server/node_modules/unhead/dist/shared/unhead.CApf5sj3.mjs +148 -0
  879. package/.output/server/node_modules/unhead/dist/shared/unhead.Cp0iF6eN.mjs +177 -0
  880. package/.output/server/node_modules/unhead/dist/shared/unhead.DGkFBTYv.mjs +172 -0
  881. package/.output/server/node_modules/unhead/dist/shared/unhead.DQc16pHI.mjs +196 -0
  882. package/.output/server/node_modules/unhead/dist/shared/unhead.DZbvapt-.mjs +70 -0
  883. package/.output/server/node_modules/unhead/dist/shared/unhead.DeCxexjU.mjs +166 -0
  884. package/.output/server/node_modules/unhead/dist/shared/unhead.yem5I2v_.mjs +38 -0
  885. package/.output/server/node_modules/unhead/dist/utils.mjs +5 -0
  886. package/.output/server/node_modules/unhead/package.json +101 -0
  887. package/.output/server/node_modules/uuid/dist/cjs/index.js +31 -0
  888. package/.output/server/node_modules/uuid/dist/cjs/max.js +3 -0
  889. package/.output/server/node_modules/uuid/dist/cjs/md5.js +13 -0
  890. package/.output/server/node_modules/uuid/dist/cjs/native.js +4 -0
  891. package/.output/server/node_modules/uuid/dist/cjs/nil.js +3 -0
  892. package/.output/server/node_modules/uuid/dist/cjs/package.json +1 -0
  893. package/.output/server/node_modules/uuid/dist/cjs/parse.js +11 -0
  894. package/.output/server/node_modules/uuid/dist/cjs/regex.js +3 -0
  895. package/.output/server/node_modules/uuid/dist/cjs/rng.js +13 -0
  896. package/.output/server/node_modules/uuid/dist/cjs/sha1.js +13 -0
  897. package/.output/server/node_modules/uuid/dist/cjs/stringify.js +39 -0
  898. package/.output/server/node_modules/uuid/dist/cjs/v1.js +87 -0
  899. package/.output/server/node_modules/uuid/dist/cjs/v1ToV6.js +13 -0
  900. package/.output/server/node_modules/uuid/dist/cjs/v3.js +14 -0
  901. package/.output/server/node_modules/uuid/dist/cjs/v35.js +41 -0
  902. package/.output/server/node_modules/uuid/dist/cjs/v4.js +29 -0
  903. package/.output/server/node_modules/uuid/dist/cjs/v5.js +14 -0
  904. package/.output/server/node_modules/uuid/dist/cjs/v6.js +19 -0
  905. package/.output/server/node_modules/uuid/dist/cjs/v6ToV1.js +13 -0
  906. package/.output/server/node_modules/uuid/dist/cjs/v7.js +69 -0
  907. package/.output/server/node_modules/uuid/dist/cjs/validate.js +7 -0
  908. package/.output/server/node_modules/uuid/dist/cjs/version.js +10 -0
  909. package/.output/server/node_modules/uuid/package.json +132 -0
  910. package/.output/server/node_modules/vue/dist/vue.cjs.js +80 -0
  911. package/.output/server/node_modules/vue/dist/vue.cjs.prod.js +66 -0
  912. package/.output/server/node_modules/vue/index.js +7 -0
  913. package/.output/server/node_modules/vue/index.mjs +1 -0
  914. package/.output/server/node_modules/vue/package.json +112 -0
  915. package/.output/server/node_modules/vue/server-renderer/index.mjs +1 -0
  916. package/.output/server/node_modules/vue-bundle-renderer/dist/runtime.mjs +196 -0
  917. package/.output/server/node_modules/vue-bundle-renderer/package.json +50 -0
  918. package/.output/server/node_modules/xtend/mutable.js +17 -0
  919. package/.output/server/node_modules/xtend/package.json +55 -0
  920. package/.output/server/node_modules/zod/index.js +4 -0
  921. package/.output/server/node_modules/zod/package.json +135 -0
  922. package/.output/server/node_modules/zod/v3/ZodError.js +133 -0
  923. package/.output/server/node_modules/zod/v3/errors.js +9 -0
  924. package/.output/server/node_modules/zod/v3/external.js +6 -0
  925. package/.output/server/node_modules/zod/v3/helpers/errorUtil.js +6 -0
  926. package/.output/server/node_modules/zod/v3/helpers/parseUtil.js +109 -0
  927. package/.output/server/node_modules/zod/v3/helpers/typeAliases.js +1 -0
  928. package/.output/server/node_modules/zod/v3/helpers/util.js +133 -0
  929. package/.output/server/node_modules/zod/v3/index.js +4 -0
  930. package/.output/server/node_modules/zod/v3/locales/en.js +109 -0
  931. package/.output/server/node_modules/zod/v3/package.json +6 -0
  932. package/.output/server/node_modules/zod/v3/types.js +3695 -0
  933. package/.output/server/node_modules/zod/v4/classic/checks.js +1 -0
  934. package/.output/server/node_modules/zod/v4/classic/coerce.js +17 -0
  935. package/.output/server/node_modules/zod/v4/classic/compat.js +31 -0
  936. package/.output/server/node_modules/zod/v4/classic/errors.js +48 -0
  937. package/.output/server/node_modules/zod/v4/classic/external.js +20 -0
  938. package/.output/server/node_modules/zod/v4/classic/from-json-schema.js +584 -0
  939. package/.output/server/node_modules/zod/v4/classic/index.js +4 -0
  940. package/.output/server/node_modules/zod/v4/classic/iso.js +30 -0
  941. package/.output/server/node_modules/zod/v4/classic/package.json +6 -0
  942. package/.output/server/node_modules/zod/v4/classic/parse.js +15 -0
  943. package/.output/server/node_modules/zod/v4/classic/schemas.js +1157 -0
  944. package/.output/server/node_modules/zod/v4/core/api.js +1082 -0
  945. package/.output/server/node_modules/zod/v4/core/checks.js +575 -0
  946. package/.output/server/node_modules/zod/v4/core/core.js +76 -0
  947. package/.output/server/node_modules/zod/v4/core/doc.js +35 -0
  948. package/.output/server/node_modules/zod/v4/core/errors.js +182 -0
  949. package/.output/server/node_modules/zod/v4/core/index.js +16 -0
  950. package/.output/server/node_modules/zod/v4/core/json-schema-generator.js +95 -0
  951. package/.output/server/node_modules/zod/v4/core/json-schema-processors.js +605 -0
  952. package/.output/server/node_modules/zod/v4/core/json-schema.js +1 -0
  953. package/.output/server/node_modules/zod/v4/core/package.json +6 -0
  954. package/.output/server/node_modules/zod/v4/core/parse.js +93 -0
  955. package/.output/server/node_modules/zod/v4/core/regexes.js +133 -0
  956. package/.output/server/node_modules/zod/v4/core/registries.js +51 -0
  957. package/.output/server/node_modules/zod/v4/core/schemas.js +2095 -0
  958. package/.output/server/node_modules/zod/v4/core/to-json-schema.js +437 -0
  959. package/.output/server/node_modules/zod/v4/core/util.js +651 -0
  960. package/.output/server/node_modules/zod/v4/core/versions.js +5 -0
  961. package/.output/server/node_modules/zod/v4/index.js +3 -0
  962. package/.output/server/node_modules/zod/v4/locales/ar.js +106 -0
  963. package/.output/server/node_modules/zod/v4/locales/az.js +105 -0
  964. package/.output/server/node_modules/zod/v4/locales/be.js +156 -0
  965. package/.output/server/node_modules/zod/v4/locales/bg.js +120 -0
  966. package/.output/server/node_modules/zod/v4/locales/ca.js +107 -0
  967. package/.output/server/node_modules/zod/v4/locales/cs.js +111 -0
  968. package/.output/server/node_modules/zod/v4/locales/da.js +115 -0
  969. package/.output/server/node_modules/zod/v4/locales/de.js +108 -0
  970. package/.output/server/node_modules/zod/v4/locales/en.js +109 -0
  971. package/.output/server/node_modules/zod/v4/locales/eo.js +109 -0
  972. package/.output/server/node_modules/zod/v4/locales/es.js +132 -0
  973. package/.output/server/node_modules/zod/v4/locales/fa.js +114 -0
  974. package/.output/server/node_modules/zod/v4/locales/fi.js +112 -0
  975. package/.output/server/node_modules/zod/v4/locales/fr-CA.js +107 -0
  976. package/.output/server/node_modules/zod/v4/locales/fr.js +108 -0
  977. package/.output/server/node_modules/zod/v4/locales/he.js +214 -0
  978. package/.output/server/node_modules/zod/v4/locales/hu.js +108 -0
  979. package/.output/server/node_modules/zod/v4/locales/hy.js +147 -0
  980. package/.output/server/node_modules/zod/v4/locales/id.js +106 -0
  981. package/.output/server/node_modules/zod/v4/locales/index.js +49 -0
  982. package/.output/server/node_modules/zod/v4/locales/is.js +109 -0
  983. package/.output/server/node_modules/zod/v4/locales/it.js +108 -0
  984. package/.output/server/node_modules/zod/v4/locales/ja.js +107 -0
  985. package/.output/server/node_modules/zod/v4/locales/ka.js +112 -0
  986. package/.output/server/node_modules/zod/v4/locales/kh.js +5 -0
  987. package/.output/server/node_modules/zod/v4/locales/km.js +110 -0
  988. package/.output/server/node_modules/zod/v4/locales/ko.js +111 -0
  989. package/.output/server/node_modules/zod/v4/locales/lt.js +203 -0
  990. package/.output/server/node_modules/zod/v4/locales/mk.js +109 -0
  991. package/.output/server/node_modules/zod/v4/locales/ms.js +107 -0
  992. package/.output/server/node_modules/zod/v4/locales/nl.js +110 -0
  993. package/.output/server/node_modules/zod/v4/locales/no.js +108 -0
  994. package/.output/server/node_modules/zod/v4/locales/ota.js +109 -0
  995. package/.output/server/node_modules/zod/v4/locales/package.json +6 -0
  996. package/.output/server/node_modules/zod/v4/locales/pl.js +109 -0
  997. package/.output/server/node_modules/zod/v4/locales/ps.js +114 -0
  998. package/.output/server/node_modules/zod/v4/locales/pt.js +108 -0
  999. package/.output/server/node_modules/zod/v4/locales/ru.js +156 -0
  1000. package/.output/server/node_modules/zod/v4/locales/sl.js +109 -0
  1001. package/.output/server/node_modules/zod/v4/locales/sv.js +110 -0
  1002. package/.output/server/node_modules/zod/v4/locales/ta.js +110 -0
  1003. package/.output/server/node_modules/zod/v4/locales/th.js +110 -0
  1004. package/.output/server/node_modules/zod/v4/locales/tr.js +105 -0
  1005. package/.output/server/node_modules/zod/v4/locales/ua.js +5 -0
  1006. package/.output/server/node_modules/zod/v4/locales/uk.js +108 -0
  1007. package/.output/server/node_modules/zod/v4/locales/ur.js +110 -0
  1008. package/.output/server/node_modules/zod/v4/locales/uz.js +109 -0
  1009. package/.output/server/node_modules/zod/v4/locales/vi.js +108 -0
  1010. package/.output/server/node_modules/zod/v4/locales/yo.js +107 -0
  1011. package/.output/server/node_modules/zod/v4/locales/zh-CN.js +109 -0
  1012. package/.output/server/node_modules/zod/v4/locales/zh-TW.js +107 -0
  1013. package/.output/server/node_modules/zod/v4/package.json +6 -0
  1014. package/.output/server/package.json +95 -0
  1015. package/README.md +46 -0
  1016. package/bin/cli.mjs +113 -0
  1017. package/bin/entry.cjs +84 -0
  1018. package/package.json +48 -0
@@ -0,0 +1,1709 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AuroraMysqlQueryRunner = void 0;
4
+ const QueryResult_1 = require("../../query-runner/QueryResult");
5
+ const TransactionNotStartedError_1 = require("../../error/TransactionNotStartedError");
6
+ const TableColumn_1 = require("../../schema-builder/table/TableColumn");
7
+ const Table_1 = require("../../schema-builder/table/Table");
8
+ const TableForeignKey_1 = require("../../schema-builder/table/TableForeignKey");
9
+ const TableIndex_1 = require("../../schema-builder/table/TableIndex");
10
+ const QueryRunnerAlreadyReleasedError_1 = require("../../error/QueryRunnerAlreadyReleasedError");
11
+ const View_1 = require("../../schema-builder/view/View");
12
+ const Query_1 = require("../Query");
13
+ const OrmUtils_1 = require("../../util/OrmUtils");
14
+ const TableUnique_1 = require("../../schema-builder/table/TableUnique");
15
+ const BaseQueryRunner_1 = require("../../query-runner/BaseQueryRunner");
16
+ const Broadcaster_1 = require("../../subscriber/Broadcaster");
17
+ const error_1 = require("../../error");
18
+ const MetadataTableType_1 = require("../types/MetadataTableType");
19
+ const InstanceChecker_1 = require("../../util/InstanceChecker");
20
+ /**
21
+ * Runs queries on a single mysql database connection.
22
+ */
23
+ class AuroraMysqlQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
24
+ // -------------------------------------------------------------------------
25
+ // Constructor
26
+ // -------------------------------------------------------------------------
27
+ constructor(driver, client) {
28
+ super();
29
+ this.driver = driver;
30
+ this.connection = driver.connection;
31
+ this.client = client;
32
+ this.broadcaster = new Broadcaster_1.Broadcaster(this);
33
+ }
34
+ // -------------------------------------------------------------------------
35
+ // Public Methods
36
+ // -------------------------------------------------------------------------
37
+ /**
38
+ * Creates/uses database connection from the connection pool to perform further operations.
39
+ * Returns obtained database connection.
40
+ */
41
+ async connect() {
42
+ return {};
43
+ }
44
+ /**
45
+ * Releases used database connection.
46
+ * You cannot use query runner methods once its released.
47
+ */
48
+ release() {
49
+ this.isReleased = true;
50
+ if (this.databaseConnection)
51
+ this.databaseConnection.release();
52
+ return Promise.resolve();
53
+ }
54
+ /**
55
+ * Starts transaction on the current connection.
56
+ */
57
+ async startTransaction(isolationLevel) {
58
+ this.isTransactionActive = true;
59
+ try {
60
+ await this.broadcaster.broadcast("BeforeTransactionStart");
61
+ }
62
+ catch (err) {
63
+ this.isTransactionActive = false;
64
+ throw err;
65
+ }
66
+ if (this.transactionDepth === 0) {
67
+ await this.client.startTransaction();
68
+ }
69
+ else {
70
+ await this.query(`SAVEPOINT typeorm_${this.transactionDepth}`);
71
+ }
72
+ this.transactionDepth += 1;
73
+ await this.broadcaster.broadcast("AfterTransactionStart");
74
+ }
75
+ /**
76
+ * Commits transaction.
77
+ * Error will be thrown if transaction was not started.
78
+ */
79
+ async commitTransaction() {
80
+ if (!this.isTransactionActive)
81
+ throw new TransactionNotStartedError_1.TransactionNotStartedError();
82
+ await this.broadcaster.broadcast("BeforeTransactionCommit");
83
+ if (this.transactionDepth > 1) {
84
+ await this.query(`RELEASE SAVEPOINT typeorm_${this.transactionDepth - 1}`);
85
+ }
86
+ else {
87
+ await this.client.commitTransaction();
88
+ this.isTransactionActive = false;
89
+ }
90
+ this.transactionDepth -= 1;
91
+ await this.broadcaster.broadcast("AfterTransactionCommit");
92
+ }
93
+ /**
94
+ * Rollbacks transaction.
95
+ * Error will be thrown if transaction was not started.
96
+ */
97
+ async rollbackTransaction() {
98
+ if (!this.isTransactionActive)
99
+ throw new TransactionNotStartedError_1.TransactionNotStartedError();
100
+ await this.broadcaster.broadcast("BeforeTransactionRollback");
101
+ if (this.transactionDepth > 1) {
102
+ await this.query(`ROLLBACK TO SAVEPOINT typeorm_${this.transactionDepth - 1}`);
103
+ }
104
+ else {
105
+ await this.client.rollbackTransaction();
106
+ this.isTransactionActive = false;
107
+ }
108
+ this.transactionDepth -= 1;
109
+ await this.broadcaster.broadcast("AfterTransactionRollback");
110
+ }
111
+ /**
112
+ * Executes a raw SQL query.
113
+ */
114
+ async query(query, parameters, useStructuredResult = false) {
115
+ if (this.isReleased)
116
+ throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
117
+ const raw = await this.client.query(query, parameters);
118
+ const result = new QueryResult_1.QueryResult();
119
+ result.raw = raw;
120
+ if (raw?.hasOwnProperty("records") && Array.isArray(raw.records)) {
121
+ result.records = raw.records;
122
+ }
123
+ if (raw?.hasOwnProperty("numberOfRecordsUpdated")) {
124
+ result.affected = raw.numberOfRecordsUpdated;
125
+ }
126
+ if (!useStructuredResult) {
127
+ return result.raw;
128
+ }
129
+ return result;
130
+ }
131
+ /**
132
+ * Returns raw data stream.
133
+ */
134
+ stream(query, parameters, onEnd, onError) {
135
+ if (this.isReleased)
136
+ throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
137
+ return new Promise(async (ok, fail) => {
138
+ try {
139
+ const databaseConnection = await this.connect();
140
+ const stream = databaseConnection.query(query, parameters);
141
+ if (onEnd)
142
+ stream.on("end", onEnd);
143
+ if (onError)
144
+ stream.on("error", onError);
145
+ ok(stream);
146
+ }
147
+ catch (err) {
148
+ fail(err);
149
+ }
150
+ });
151
+ }
152
+ /**
153
+ * Returns all available database names including system databases.
154
+ */
155
+ async getDatabases() {
156
+ return Promise.resolve([]);
157
+ }
158
+ /**
159
+ * Returns all available schema names including system schemas.
160
+ * If database parameter specified, returns schemas of that database.
161
+ */
162
+ async getSchemas(database) {
163
+ throw new error_1.TypeORMError(`MySql driver does not support table schemas`);
164
+ }
165
+ /**
166
+ * Checks if database with the given name exist.
167
+ */
168
+ async hasDatabase(database) {
169
+ const result = await this.query(`SELECT * FROM \`INFORMATION_SCHEMA\`.\`SCHEMATA\` WHERE \`SCHEMA_NAME\` = '${database}'`);
170
+ return result.length ? true : false;
171
+ }
172
+ /**
173
+ * Loads currently using database
174
+ */
175
+ async getCurrentDatabase() {
176
+ const query = await this.query(`SELECT DATABASE() AS \`db_name\``);
177
+ return query[0]["db_name"];
178
+ }
179
+ /**
180
+ * Checks if schema with the given name exist.
181
+ */
182
+ async hasSchema(schema) {
183
+ throw new error_1.TypeORMError(`MySql driver does not support table schemas`);
184
+ }
185
+ /**
186
+ * Loads currently using database schema
187
+ */
188
+ async getCurrentSchema() {
189
+ const query = await this.query(`SELECT SCHEMA() AS \`schema_name\``);
190
+ return query[0]["schema_name"];
191
+ }
192
+ /**
193
+ * Checks if table with the given name exist in the database.
194
+ */
195
+ async hasTable(tableOrName) {
196
+ const parsedTableName = this.driver.parseTableName(tableOrName);
197
+ const sql = `SELECT * FROM \`INFORMATION_SCHEMA\`.\`COLUMNS\` WHERE \`TABLE_SCHEMA\` = '${parsedTableName.database}' AND \`TABLE_NAME\` = '${parsedTableName.tableName}'`;
198
+ const result = await this.query(sql);
199
+ return result.length ? true : false;
200
+ }
201
+ /**
202
+ * Checks if column with the given name exist in the given table.
203
+ */
204
+ async hasColumn(tableOrName, column) {
205
+ const parsedTableName = this.driver.parseTableName(tableOrName);
206
+ const columnName = InstanceChecker_1.InstanceChecker.isTableColumn(column)
207
+ ? column.name
208
+ : column;
209
+ const sql = `SELECT * FROM \`INFORMATION_SCHEMA\`.\`COLUMNS\` WHERE \`TABLE_SCHEMA\` = '${parsedTableName.database}' AND \`TABLE_NAME\` = '${parsedTableName.tableName}' AND \`COLUMN_NAME\` = '${columnName}'`;
210
+ const result = await this.query(sql);
211
+ return result.length ? true : false;
212
+ }
213
+ /**
214
+ * Creates a new database.
215
+ */
216
+ async createDatabase(database, ifNotExist) {
217
+ const up = ifNotExist
218
+ ? `CREATE DATABASE IF NOT EXISTS \`${database}\``
219
+ : `CREATE DATABASE \`${database}\``;
220
+ const down = `DROP DATABASE \`${database}\``;
221
+ await this.executeQueries(new Query_1.Query(up), new Query_1.Query(down));
222
+ }
223
+ /**
224
+ * Drops database.
225
+ */
226
+ async dropDatabase(database, ifExist) {
227
+ const up = ifExist
228
+ ? `DROP DATABASE IF EXISTS \`${database}\``
229
+ : `DROP DATABASE \`${database}\``;
230
+ const down = `CREATE DATABASE \`${database}\``;
231
+ await this.executeQueries(new Query_1.Query(up), new Query_1.Query(down));
232
+ }
233
+ /**
234
+ * Creates a new table schema.
235
+ */
236
+ async createSchema(schemaPath, ifNotExist) {
237
+ throw new error_1.TypeORMError(`Schema create queries are not supported by MySql driver.`);
238
+ }
239
+ /**
240
+ * Drops table schema.
241
+ */
242
+ async dropSchema(schemaPath, ifExist) {
243
+ throw new error_1.TypeORMError(`Schema drop queries are not supported by MySql driver.`);
244
+ }
245
+ /**
246
+ * Creates a new table.
247
+ */
248
+ async createTable(table, ifNotExist = false, createForeignKeys = true) {
249
+ if (ifNotExist) {
250
+ const isTableExist = await this.hasTable(table);
251
+ if (isTableExist)
252
+ return Promise.resolve();
253
+ }
254
+ const upQueries = [];
255
+ const downQueries = [];
256
+ upQueries.push(this.createTableSql(table, createForeignKeys));
257
+ downQueries.push(this.dropTableSql(table));
258
+ // we must first drop indices, than drop foreign keys, because drop queries runs in reversed order
259
+ // and foreign keys will be dropped first as indices. This order is very important, because we can't drop index
260
+ // if it related to the foreign key.
261
+ // createTable does not need separate method to create indices, because it create indices in the same query with table creation.
262
+ table.indices.forEach((index) => downQueries.push(this.dropIndexSql(table, index)));
263
+ // if createForeignKeys is true, we must drop created foreign keys in down query.
264
+ // createTable does not need separate method to create foreign keys, because it create fk's in the same query with table creation.
265
+ if (createForeignKeys)
266
+ table.foreignKeys.forEach((foreignKey) => downQueries.push(this.dropForeignKeySql(table, foreignKey)));
267
+ return this.executeQueries(upQueries, downQueries);
268
+ }
269
+ /**
270
+ * Drop the table.
271
+ */
272
+ async dropTable(target, ifExist, dropForeignKeys = true) {
273
+ // It needs because if table does not exist and dropForeignKeys or dropIndices is true, we don't need
274
+ // to perform drop queries for foreign keys and indices.
275
+ if (ifExist) {
276
+ const isTableExist = await this.hasTable(target);
277
+ if (!isTableExist)
278
+ return Promise.resolve();
279
+ }
280
+ // if dropTable called with dropForeignKeys = true, we must create foreign keys in down query.
281
+ const createForeignKeys = dropForeignKeys;
282
+ const tablePath = this.getTablePath(target);
283
+ const table = await this.getCachedTable(tablePath);
284
+ const upQueries = [];
285
+ const downQueries = [];
286
+ if (dropForeignKeys)
287
+ table.foreignKeys.forEach((foreignKey) => upQueries.push(this.dropForeignKeySql(table, foreignKey)));
288
+ table.indices.forEach((index) => upQueries.push(this.dropIndexSql(table, index)));
289
+ upQueries.push(this.dropTableSql(table));
290
+ downQueries.push(this.createTableSql(table, createForeignKeys));
291
+ await this.executeQueries(upQueries, downQueries);
292
+ }
293
+ /**
294
+ * Creates a new view.
295
+ */
296
+ async createView(view, syncWithMetadata = false) {
297
+ const upQueries = [];
298
+ const downQueries = [];
299
+ upQueries.push(this.createViewSql(view));
300
+ if (syncWithMetadata)
301
+ upQueries.push(await this.insertViewDefinitionSql(view));
302
+ downQueries.push(this.dropViewSql(view));
303
+ if (syncWithMetadata)
304
+ downQueries.push(await this.deleteViewDefinitionSql(view));
305
+ await this.executeQueries(upQueries, downQueries);
306
+ }
307
+ /**
308
+ * Drops the view.
309
+ */
310
+ async dropView(target) {
311
+ const viewName = InstanceChecker_1.InstanceChecker.isView(target) ? target.name : target;
312
+ const view = await this.getCachedView(viewName);
313
+ const upQueries = [];
314
+ const downQueries = [];
315
+ upQueries.push(await this.deleteViewDefinitionSql(view));
316
+ upQueries.push(this.dropViewSql(view));
317
+ downQueries.push(await this.insertViewDefinitionSql(view));
318
+ downQueries.push(this.createViewSql(view));
319
+ await this.executeQueries(upQueries, downQueries);
320
+ }
321
+ /**
322
+ * Renames a table.
323
+ */
324
+ async renameTable(oldTableOrName, newTableName) {
325
+ const upQueries = [];
326
+ const downQueries = [];
327
+ const oldTable = InstanceChecker_1.InstanceChecker.isTable(oldTableOrName)
328
+ ? oldTableOrName
329
+ : await this.getCachedTable(oldTableOrName);
330
+ const newTable = oldTable.clone();
331
+ const { database } = this.driver.parseTableName(oldTable);
332
+ newTable.name = database ? `${database}.${newTableName}` : newTableName;
333
+ // rename table
334
+ upQueries.push(new Query_1.Query(`RENAME TABLE ${this.escapePath(oldTable)} TO ${this.escapePath(newTable)}`));
335
+ downQueries.push(new Query_1.Query(`RENAME TABLE ${this.escapePath(newTable)} TO ${this.escapePath(oldTable)}`));
336
+ // rename index constraints
337
+ newTable.indices.forEach((index) => {
338
+ // build new constraint name
339
+ const columnNames = index.columnNames
340
+ .map((column) => `\`${column}\``)
341
+ .join(", ");
342
+ const newIndexName = this.connection.namingStrategy.indexName(newTable, index.columnNames, index.where);
343
+ // build queries
344
+ let indexType = "";
345
+ if (index.isUnique)
346
+ indexType += "UNIQUE ";
347
+ if (index.isSpatial)
348
+ indexType += "SPATIAL ";
349
+ if (index.isFulltext)
350
+ indexType += "FULLTEXT ";
351
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(newTable)} DROP INDEX \`${index.name}\`, ADD ${indexType}INDEX \`${newIndexName}\` (${columnNames})`));
352
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(newTable)} DROP INDEX \`${newIndexName}\`, ADD ${indexType}INDEX \`${index.name}\` (${columnNames})`));
353
+ // replace constraint name
354
+ index.name = newIndexName;
355
+ });
356
+ // rename foreign key constraint
357
+ newTable.foreignKeys.forEach((foreignKey) => {
358
+ // build new constraint name
359
+ const columnNames = foreignKey.columnNames
360
+ .map((column) => `\`${column}\``)
361
+ .join(", ");
362
+ const referencedColumnNames = foreignKey.referencedColumnNames
363
+ .map((column) => `\`${column}\``)
364
+ .join(",");
365
+ const newForeignKeyName = this.connection.namingStrategy.foreignKeyName(newTable, foreignKey.columnNames);
366
+ // build queries
367
+ let up = `ALTER TABLE ${this.escapePath(newTable)} DROP FOREIGN KEY \`${foreignKey.name}\`, ADD CONSTRAINT \`${newForeignKeyName}\` FOREIGN KEY (${columnNames}) ` +
368
+ `REFERENCES ${this.escapePath(this.getTablePath(foreignKey))}(${referencedColumnNames})`;
369
+ if (foreignKey.onDelete)
370
+ up += ` ON DELETE ${foreignKey.onDelete}`;
371
+ if (foreignKey.onUpdate)
372
+ up += ` ON UPDATE ${foreignKey.onUpdate}`;
373
+ let down = `ALTER TABLE ${this.escapePath(newTable)} DROP FOREIGN KEY \`${newForeignKeyName}\`, ADD CONSTRAINT \`${foreignKey.name}\` FOREIGN KEY (${columnNames}) ` +
374
+ `REFERENCES ${this.escapePath(this.getTablePath(foreignKey))}(${referencedColumnNames})`;
375
+ if (foreignKey.onDelete)
376
+ down += ` ON DELETE ${foreignKey.onDelete}`;
377
+ if (foreignKey.onUpdate)
378
+ down += ` ON UPDATE ${foreignKey.onUpdate}`;
379
+ upQueries.push(new Query_1.Query(up));
380
+ downQueries.push(new Query_1.Query(down));
381
+ // replace constraint name
382
+ foreignKey.name = newForeignKeyName;
383
+ });
384
+ await this.executeQueries(upQueries, downQueries);
385
+ // rename old table and replace it in cached tabled;
386
+ oldTable.name = newTable.name;
387
+ this.replaceCachedTable(oldTable, newTable);
388
+ }
389
+ /**
390
+ * Creates a new column from the column in the table.
391
+ */
392
+ async addColumn(tableOrName, column) {
393
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
394
+ ? tableOrName
395
+ : await this.getCachedTable(tableOrName);
396
+ const clonedTable = table.clone();
397
+ const upQueries = [];
398
+ const downQueries = [];
399
+ const skipColumnLevelPrimary = clonedTable.primaryColumns.length > 0;
400
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD ${this.buildCreateColumnSql(column, skipColumnLevelPrimary, false)}`));
401
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP COLUMN \`${column.name}\``));
402
+ // create or update primary key constraint
403
+ if (column.isPrimary && skipColumnLevelPrimary) {
404
+ // if we already have generated column, we must temporary drop AUTO_INCREMENT property.
405
+ const generatedColumn = clonedTable.columns.find((column) => column.isGenerated &&
406
+ column.generationStrategy === "increment");
407
+ if (generatedColumn) {
408
+ const nonGeneratedColumn = generatedColumn.clone();
409
+ nonGeneratedColumn.isGenerated = false;
410
+ nonGeneratedColumn.generationStrategy = undefined;
411
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${column.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
412
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(column, true)}`));
413
+ }
414
+ const primaryColumns = clonedTable.primaryColumns;
415
+ let columnNames = primaryColumns
416
+ .map((column) => `\`${column.name}\``)
417
+ .join(", ");
418
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
419
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
420
+ primaryColumns.push(column);
421
+ columnNames = primaryColumns
422
+ .map((column) => `\`${column.name}\``)
423
+ .join(", ");
424
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
425
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
426
+ // if we previously dropped AUTO_INCREMENT property, we must bring it back
427
+ if (generatedColumn) {
428
+ const nonGeneratedColumn = generatedColumn.clone();
429
+ nonGeneratedColumn.isGenerated = false;
430
+ nonGeneratedColumn.generationStrategy = undefined;
431
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(column, true)}`));
432
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${column.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
433
+ }
434
+ }
435
+ // create column index
436
+ const columnIndex = clonedTable.indices.find((index) => index.columnNames.length === 1 &&
437
+ index.columnNames[0] === column.name);
438
+ if (columnIndex) {
439
+ upQueries.push(this.createIndexSql(table, columnIndex));
440
+ downQueries.push(this.dropIndexSql(table, columnIndex));
441
+ }
442
+ else if (column.isUnique) {
443
+ const uniqueIndex = new TableIndex_1.TableIndex({
444
+ name: this.connection.namingStrategy.indexName(table, [
445
+ column.name,
446
+ ]),
447
+ columnNames: [column.name],
448
+ isUnique: true,
449
+ });
450
+ clonedTable.indices.push(uniqueIndex);
451
+ clonedTable.uniques.push(new TableUnique_1.TableUnique({
452
+ name: uniqueIndex.name,
453
+ columnNames: uniqueIndex.columnNames,
454
+ }));
455
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD UNIQUE INDEX \`${uniqueIndex.name}\` (\`${column.name}\`)`));
456
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${uniqueIndex.name}\``));
457
+ }
458
+ await this.executeQueries(upQueries, downQueries);
459
+ clonedTable.addColumn(column);
460
+ this.replaceCachedTable(table, clonedTable);
461
+ }
462
+ /**
463
+ * Creates a new columns from the column in the table.
464
+ */
465
+ async addColumns(tableOrName, columns) {
466
+ for (const column of columns) {
467
+ await this.addColumn(tableOrName, column);
468
+ }
469
+ }
470
+ /**
471
+ * Renames column in the given table.
472
+ */
473
+ async renameColumn(tableOrName, oldTableColumnOrName, newTableColumnOrName) {
474
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
475
+ ? tableOrName
476
+ : await this.getCachedTable(tableOrName);
477
+ const oldColumn = InstanceChecker_1.InstanceChecker.isTableColumn(oldTableColumnOrName)
478
+ ? oldTableColumnOrName
479
+ : table.columns.find((c) => c.name === oldTableColumnOrName);
480
+ if (!oldColumn)
481
+ throw new error_1.TypeORMError(`Column "${oldTableColumnOrName}" was not found in the "${table.name}" table.`);
482
+ let newColumn = undefined;
483
+ if (InstanceChecker_1.InstanceChecker.isTableColumn(newTableColumnOrName)) {
484
+ newColumn = newTableColumnOrName;
485
+ }
486
+ else {
487
+ newColumn = oldColumn.clone();
488
+ newColumn.name = newTableColumnOrName;
489
+ }
490
+ await this.changeColumn(table, oldColumn, newColumn);
491
+ }
492
+ /**
493
+ * Changes a column in the table.
494
+ */
495
+ async changeColumn(tableOrName, oldColumnOrName, newColumn) {
496
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
497
+ ? tableOrName
498
+ : await this.getCachedTable(tableOrName);
499
+ let clonedTable = table.clone();
500
+ const upQueries = [];
501
+ const downQueries = [];
502
+ const oldColumn = InstanceChecker_1.InstanceChecker.isTableColumn(oldColumnOrName)
503
+ ? oldColumnOrName
504
+ : table.columns.find((column) => column.name === oldColumnOrName);
505
+ if (!oldColumn)
506
+ throw new error_1.TypeORMError(`Column "${oldColumnOrName}" was not found in the "${table.name}" table.`);
507
+ if ((newColumn.isGenerated !== oldColumn.isGenerated &&
508
+ newColumn.generationStrategy !== "uuid") ||
509
+ oldColumn.type !== newColumn.type ||
510
+ oldColumn.length !== newColumn.length ||
511
+ oldColumn.generatedType !== newColumn.generatedType) {
512
+ await this.dropColumn(table, oldColumn);
513
+ await this.addColumn(table, newColumn);
514
+ // update cloned table
515
+ clonedTable = table.clone();
516
+ }
517
+ else {
518
+ if (newColumn.name !== oldColumn.name) {
519
+ // We don't change any column properties, just rename it.
520
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${oldColumn.name}\` \`${newColumn.name}\` ${this.buildCreateColumnSql(oldColumn, true, true)}`));
521
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${newColumn.name}\` \`${oldColumn.name}\` ${this.buildCreateColumnSql(oldColumn, true, true)}`));
522
+ // rename index constraints
523
+ clonedTable.findColumnIndices(oldColumn).forEach((index) => {
524
+ // build new constraint name
525
+ index.columnNames.splice(index.columnNames.indexOf(oldColumn.name), 1);
526
+ index.columnNames.push(newColumn.name);
527
+ const columnNames = index.columnNames
528
+ .map((column) => `\`${column}\``)
529
+ .join(", ");
530
+ const newIndexName = this.connection.namingStrategy.indexName(clonedTable, index.columnNames, index.where);
531
+ // build queries
532
+ let indexType = "";
533
+ if (index.isUnique)
534
+ indexType += "UNIQUE ";
535
+ if (index.isSpatial)
536
+ indexType += "SPATIAL ";
537
+ if (index.isFulltext)
538
+ indexType += "FULLTEXT ";
539
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${index.name}\`, ADD ${indexType}INDEX \`${newIndexName}\` (${columnNames})`));
540
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${newIndexName}\`, ADD ${indexType}INDEX \`${index.name}\` (${columnNames})`));
541
+ // replace constraint name
542
+ index.name = newIndexName;
543
+ });
544
+ // rename foreign key constraints
545
+ clonedTable
546
+ .findColumnForeignKeys(oldColumn)
547
+ .forEach((foreignKey) => {
548
+ // build new constraint name
549
+ foreignKey.columnNames.splice(foreignKey.columnNames.indexOf(oldColumn.name), 1);
550
+ foreignKey.columnNames.push(newColumn.name);
551
+ const columnNames = foreignKey.columnNames
552
+ .map((column) => `\`${column}\``)
553
+ .join(", ");
554
+ const referencedColumnNames = foreignKey.referencedColumnNames
555
+ .map((column) => `\`${column}\``)
556
+ .join(",");
557
+ const newForeignKeyName = this.connection.namingStrategy.foreignKeyName(clonedTable, foreignKey.columnNames);
558
+ // build queries
559
+ let up = `ALTER TABLE ${this.escapePath(table)} DROP FOREIGN KEY \`${foreignKey.name}\`, ADD CONSTRAINT \`${newForeignKeyName}\` FOREIGN KEY (${columnNames}) ` +
560
+ `REFERENCES ${this.escapePath(this.getTablePath(foreignKey))}(${referencedColumnNames})`;
561
+ if (foreignKey.onDelete)
562
+ up += ` ON DELETE ${foreignKey.onDelete}`;
563
+ if (foreignKey.onUpdate)
564
+ up += ` ON UPDATE ${foreignKey.onUpdate}`;
565
+ let down = `ALTER TABLE ${this.escapePath(table)} DROP FOREIGN KEY \`${newForeignKeyName}\`, ADD CONSTRAINT \`${foreignKey.name}\` FOREIGN KEY (${columnNames}) ` +
566
+ `REFERENCES ${this.escapePath(this.getTablePath(foreignKey))}(${referencedColumnNames})`;
567
+ if (foreignKey.onDelete)
568
+ down += ` ON DELETE ${foreignKey.onDelete}`;
569
+ if (foreignKey.onUpdate)
570
+ down += ` ON UPDATE ${foreignKey.onUpdate}`;
571
+ upQueries.push(new Query_1.Query(up));
572
+ downQueries.push(new Query_1.Query(down));
573
+ // replace constraint name
574
+ foreignKey.name = newForeignKeyName;
575
+ });
576
+ // rename old column in the Table object
577
+ const oldTableColumn = clonedTable.columns.find((column) => column.name === oldColumn.name);
578
+ clonedTable.columns[clonedTable.columns.indexOf(oldTableColumn)].name = newColumn.name;
579
+ oldColumn.name = newColumn.name;
580
+ }
581
+ if (this.isColumnChanged(oldColumn, newColumn, true)) {
582
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${oldColumn.name}\` ${this.buildCreateColumnSql(newColumn, true)}`));
583
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${newColumn.name}\` ${this.buildCreateColumnSql(oldColumn, true)}`));
584
+ }
585
+ if (newColumn.isPrimary !== oldColumn.isPrimary) {
586
+ // if table have generated column, we must drop AUTO_INCREMENT before changing primary constraints.
587
+ const generatedColumn = clonedTable.columns.find((column) => column.isGenerated &&
588
+ column.generationStrategy === "increment");
589
+ if (generatedColumn) {
590
+ const nonGeneratedColumn = generatedColumn.clone();
591
+ nonGeneratedColumn.isGenerated = false;
592
+ nonGeneratedColumn.generationStrategy = undefined;
593
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${generatedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
594
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(generatedColumn, true)}`));
595
+ }
596
+ const primaryColumns = clonedTable.primaryColumns;
597
+ // if primary column state changed, we must always drop existed constraint.
598
+ if (primaryColumns.length > 0) {
599
+ const columnNames = primaryColumns
600
+ .map((column) => `\`${column.name}\``)
601
+ .join(", ");
602
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
603
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
604
+ }
605
+ if (newColumn.isPrimary === true) {
606
+ primaryColumns.push(newColumn);
607
+ // update column in table
608
+ const column = clonedTable.columns.find((column) => column.name === newColumn.name);
609
+ column.isPrimary = true;
610
+ const columnNames = primaryColumns
611
+ .map((column) => `\`${column.name}\``)
612
+ .join(", ");
613
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
614
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
615
+ }
616
+ else {
617
+ const primaryColumn = primaryColumns.find((c) => c.name === newColumn.name);
618
+ primaryColumns.splice(primaryColumns.indexOf(primaryColumn), 1);
619
+ // update column in table
620
+ const column = clonedTable.columns.find((column) => column.name === newColumn.name);
621
+ column.isPrimary = false;
622
+ // if we have another primary keys, we must recreate constraint.
623
+ if (primaryColumns.length > 0) {
624
+ const columnNames = primaryColumns
625
+ .map((column) => `\`${column.name}\``)
626
+ .join(", ");
627
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
628
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
629
+ }
630
+ }
631
+ // if we have generated column, and we dropped AUTO_INCREMENT property before, we must bring it back
632
+ if (generatedColumn) {
633
+ const nonGeneratedColumn = generatedColumn.clone();
634
+ nonGeneratedColumn.isGenerated = false;
635
+ nonGeneratedColumn.generationStrategy = undefined;
636
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(generatedColumn, true)}`));
637
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${generatedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
638
+ }
639
+ }
640
+ if (newColumn.isUnique !== oldColumn.isUnique) {
641
+ if (newColumn.isUnique === true) {
642
+ const uniqueIndex = new TableIndex_1.TableIndex({
643
+ name: this.connection.namingStrategy.indexName(table, [
644
+ newColumn.name,
645
+ ]),
646
+ columnNames: [newColumn.name],
647
+ isUnique: true,
648
+ });
649
+ clonedTable.indices.push(uniqueIndex);
650
+ clonedTable.uniques.push(new TableUnique_1.TableUnique({
651
+ name: uniqueIndex.name,
652
+ columnNames: uniqueIndex.columnNames,
653
+ }));
654
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD UNIQUE INDEX \`${uniqueIndex.name}\` (\`${newColumn.name}\`)`));
655
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${uniqueIndex.name}\``));
656
+ }
657
+ else {
658
+ const uniqueIndex = clonedTable.indices.find((index) => {
659
+ return (index.columnNames.length === 1 &&
660
+ index.isUnique === true &&
661
+ !!index.columnNames.find((columnName) => columnName === newColumn.name));
662
+ });
663
+ clonedTable.indices.splice(clonedTable.indices.indexOf(uniqueIndex), 1);
664
+ const tableUnique = clonedTable.uniques.find((unique) => unique.name === uniqueIndex.name);
665
+ clonedTable.uniques.splice(clonedTable.uniques.indexOf(tableUnique), 1);
666
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${uniqueIndex.name}\``));
667
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD UNIQUE INDEX \`${uniqueIndex.name}\` (\`${newColumn.name}\`)`));
668
+ }
669
+ }
670
+ }
671
+ await this.executeQueries(upQueries, downQueries);
672
+ this.replaceCachedTable(table, clonedTable);
673
+ }
674
+ /**
675
+ * Changes a column in the table.
676
+ */
677
+ async changeColumns(tableOrName, changedColumns) {
678
+ for (const { oldColumn, newColumn } of changedColumns) {
679
+ await this.changeColumn(tableOrName, oldColumn, newColumn);
680
+ }
681
+ }
682
+ /**
683
+ * Drops column in the table.
684
+ */
685
+ async dropColumn(tableOrName, columnOrName) {
686
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
687
+ ? tableOrName
688
+ : await this.getCachedTable(tableOrName);
689
+ const column = InstanceChecker_1.InstanceChecker.isTableColumn(columnOrName)
690
+ ? columnOrName
691
+ : table.findColumnByName(columnOrName);
692
+ if (!column)
693
+ throw new error_1.TypeORMError(`Column "${columnOrName}" was not found in table "${table.name}"`);
694
+ const clonedTable = table.clone();
695
+ const upQueries = [];
696
+ const downQueries = [];
697
+ // drop primary key constraint
698
+ if (column.isPrimary) {
699
+ // if table have generated column, we must drop AUTO_INCREMENT before changing primary constraints.
700
+ const generatedColumn = clonedTable.columns.find((column) => column.isGenerated &&
701
+ column.generationStrategy === "increment");
702
+ if (generatedColumn) {
703
+ const nonGeneratedColumn = generatedColumn.clone();
704
+ nonGeneratedColumn.isGenerated = false;
705
+ nonGeneratedColumn.generationStrategy = undefined;
706
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${generatedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
707
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(generatedColumn, true)}`));
708
+ }
709
+ // dropping primary key constraint
710
+ const columnNames = clonedTable.primaryColumns
711
+ .map((primaryColumn) => `\`${primaryColumn.name}\``)
712
+ .join(", ");
713
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(clonedTable)} DROP PRIMARY KEY`));
714
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(clonedTable)} ADD PRIMARY KEY (${columnNames})`));
715
+ // update column in table
716
+ const tableColumn = clonedTable.findColumnByName(column.name);
717
+ tableColumn.isPrimary = false;
718
+ // if primary key have multiple columns, we must recreate it without dropped column
719
+ if (clonedTable.primaryColumns.length > 0) {
720
+ const columnNames = clonedTable.primaryColumns
721
+ .map((primaryColumn) => `\`${primaryColumn.name}\``)
722
+ .join(", ");
723
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(clonedTable)} ADD PRIMARY KEY (${columnNames})`));
724
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(clonedTable)} DROP PRIMARY KEY`));
725
+ }
726
+ // if we have generated column, and we dropped AUTO_INCREMENT property before, and this column is not current dropping column, we must bring it back
727
+ if (generatedColumn && generatedColumn.name !== column.name) {
728
+ const nonGeneratedColumn = generatedColumn.clone();
729
+ nonGeneratedColumn.isGenerated = false;
730
+ nonGeneratedColumn.generationStrategy = undefined;
731
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(generatedColumn, true)}`));
732
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${generatedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
733
+ }
734
+ }
735
+ // drop column index
736
+ const columnIndex = clonedTable.indices.find((index) => index.columnNames.length === 1 &&
737
+ index.columnNames[0] === column.name);
738
+ if (columnIndex) {
739
+ clonedTable.indices.splice(clonedTable.indices.indexOf(columnIndex), 1);
740
+ upQueries.push(this.dropIndexSql(table, columnIndex));
741
+ downQueries.push(this.createIndexSql(table, columnIndex));
742
+ }
743
+ else if (column.isUnique) {
744
+ // we splice constraints both from table uniques and indices.
745
+ const uniqueName = this.connection.namingStrategy.uniqueConstraintName(table, [
746
+ column.name,
747
+ ]);
748
+ const foundUnique = clonedTable.uniques.find((unique) => unique.name === uniqueName);
749
+ if (foundUnique)
750
+ clonedTable.uniques.splice(clonedTable.uniques.indexOf(foundUnique), 1);
751
+ const indexName = this.connection.namingStrategy.indexName(table, [
752
+ column.name,
753
+ ]);
754
+ const foundIndex = clonedTable.indices.find((index) => index.name === indexName);
755
+ if (foundIndex)
756
+ clonedTable.indices.splice(clonedTable.indices.indexOf(foundIndex), 1);
757
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP INDEX \`${indexName}\``));
758
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD UNIQUE INDEX \`${indexName}\` (\`${column.name}\`)`));
759
+ }
760
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP COLUMN \`${column.name}\``));
761
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD ${this.buildCreateColumnSql(column, true)}`));
762
+ await this.executeQueries(upQueries, downQueries);
763
+ clonedTable.removeColumn(column);
764
+ this.replaceCachedTable(table, clonedTable);
765
+ }
766
+ /**
767
+ * Drops the columns in the table.
768
+ */
769
+ async dropColumns(tableOrName, columns) {
770
+ for (const column of columns) {
771
+ await this.dropColumn(tableOrName, column);
772
+ }
773
+ }
774
+ /**
775
+ * Creates a new primary key.
776
+ */
777
+ async createPrimaryKey(tableOrName, columnNames) {
778
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
779
+ ? tableOrName
780
+ : await this.getCachedTable(tableOrName);
781
+ const clonedTable = table.clone();
782
+ const up = this.createPrimaryKeySql(table, columnNames);
783
+ const down = this.dropPrimaryKeySql(table);
784
+ await this.executeQueries(up, down);
785
+ clonedTable.columns.forEach((column) => {
786
+ if (columnNames.find((columnName) => columnName === column.name))
787
+ column.isPrimary = true;
788
+ });
789
+ this.replaceCachedTable(table, clonedTable);
790
+ }
791
+ /**
792
+ * Updates composite primary keys.
793
+ */
794
+ async updatePrimaryKeys(tableOrName, columns) {
795
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
796
+ ? tableOrName
797
+ : await this.getCachedTable(tableOrName);
798
+ const clonedTable = table.clone();
799
+ const columnNames = columns.map((column) => column.name);
800
+ const upQueries = [];
801
+ const downQueries = [];
802
+ // if table have generated column, we must drop AUTO_INCREMENT before changing primary constraints.
803
+ const generatedColumn = clonedTable.columns.find((column) => column.isGenerated && column.generationStrategy === "increment");
804
+ if (generatedColumn) {
805
+ const nonGeneratedColumn = generatedColumn.clone();
806
+ nonGeneratedColumn.isGenerated = false;
807
+ nonGeneratedColumn.generationStrategy = undefined;
808
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${generatedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
809
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(generatedColumn, true)}`));
810
+ }
811
+ // if table already have primary columns, we must drop them.
812
+ const primaryColumns = clonedTable.primaryColumns;
813
+ if (primaryColumns.length > 0) {
814
+ const columnNames = primaryColumns
815
+ .map((column) => `\`${column.name}\``)
816
+ .join(", ");
817
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
818
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNames})`));
819
+ }
820
+ // update columns in table.
821
+ clonedTable.columns
822
+ .filter((column) => columnNames.indexOf(column.name) !== -1)
823
+ .forEach((column) => (column.isPrimary = true));
824
+ const columnNamesString = columnNames
825
+ .map((columnName) => `\`${columnName}\``)
826
+ .join(", ");
827
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNamesString})`));
828
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`));
829
+ // if we already have generated column or column is changed to generated, and we dropped AUTO_INCREMENT property before, we must bring it back
830
+ const newOrExistGeneratedColumn = generatedColumn
831
+ ? generatedColumn
832
+ : columns.find((column) => column.isGenerated &&
833
+ column.generationStrategy === "increment");
834
+ if (newOrExistGeneratedColumn) {
835
+ const nonGeneratedColumn = newOrExistGeneratedColumn.clone();
836
+ nonGeneratedColumn.isGenerated = false;
837
+ nonGeneratedColumn.generationStrategy = undefined;
838
+ upQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${nonGeneratedColumn.name}\` ${this.buildCreateColumnSql(newOrExistGeneratedColumn, true)}`));
839
+ downQueries.push(new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} CHANGE \`${newOrExistGeneratedColumn.name}\` ${this.buildCreateColumnSql(nonGeneratedColumn, true)}`));
840
+ // if column changed to generated, we must update it in table
841
+ const changedGeneratedColumn = clonedTable.columns.find((column) => column.name === newOrExistGeneratedColumn.name);
842
+ changedGeneratedColumn.isGenerated = true;
843
+ changedGeneratedColumn.generationStrategy = "increment";
844
+ }
845
+ await this.executeQueries(upQueries, downQueries);
846
+ this.replaceCachedTable(table, clonedTable);
847
+ }
848
+ /**
849
+ * Drops a primary key.
850
+ */
851
+ async dropPrimaryKey(tableOrName) {
852
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
853
+ ? tableOrName
854
+ : await this.getCachedTable(tableOrName);
855
+ const up = this.dropPrimaryKeySql(table);
856
+ const down = this.createPrimaryKeySql(table, table.primaryColumns.map((column) => column.name));
857
+ await this.executeQueries(up, down);
858
+ table.primaryColumns.forEach((column) => {
859
+ column.isPrimary = false;
860
+ });
861
+ }
862
+ /**
863
+ * Creates a new unique constraint.
864
+ */
865
+ async createUniqueConstraint(tableOrName, uniqueConstraint) {
866
+ throw new error_1.TypeORMError(`MySql does not support unique constraints. Use unique index instead.`);
867
+ }
868
+ /**
869
+ * Creates a new unique constraints.
870
+ */
871
+ async createUniqueConstraints(tableOrName, uniqueConstraints) {
872
+ throw new error_1.TypeORMError(`MySql does not support unique constraints. Use unique index instead.`);
873
+ }
874
+ /**
875
+ * Drops an unique constraint.
876
+ */
877
+ async dropUniqueConstraint(tableOrName, uniqueOrName) {
878
+ throw new error_1.TypeORMError(`MySql does not support unique constraints. Use unique index instead.`);
879
+ }
880
+ /**
881
+ * Drops an unique constraints.
882
+ */
883
+ async dropUniqueConstraints(tableOrName, uniqueConstraints) {
884
+ throw new error_1.TypeORMError(`MySql does not support unique constraints. Use unique index instead.`);
885
+ }
886
+ /**
887
+ * Creates a new check constraint.
888
+ */
889
+ async createCheckConstraint(tableOrName, checkConstraint) {
890
+ throw new error_1.TypeORMError(`MySql does not support check constraints.`);
891
+ }
892
+ /**
893
+ * Creates a new check constraints.
894
+ */
895
+ async createCheckConstraints(tableOrName, checkConstraints) {
896
+ throw new error_1.TypeORMError(`MySql does not support check constraints.`);
897
+ }
898
+ /**
899
+ * Drops check constraint.
900
+ */
901
+ async dropCheckConstraint(tableOrName, checkOrName) {
902
+ throw new error_1.TypeORMError(`MySql does not support check constraints.`);
903
+ }
904
+ /**
905
+ * Drops check constraints.
906
+ */
907
+ async dropCheckConstraints(tableOrName, checkConstraints) {
908
+ throw new error_1.TypeORMError(`MySql does not support check constraints.`);
909
+ }
910
+ /**
911
+ * Creates a new exclusion constraint.
912
+ */
913
+ async createExclusionConstraint(tableOrName, exclusionConstraint) {
914
+ throw new error_1.TypeORMError(`MySql does not support exclusion constraints.`);
915
+ }
916
+ /**
917
+ * Creates a new exclusion constraints.
918
+ */
919
+ async createExclusionConstraints(tableOrName, exclusionConstraints) {
920
+ throw new error_1.TypeORMError(`MySql does not support exclusion constraints.`);
921
+ }
922
+ /**
923
+ * Drops exclusion constraint.
924
+ */
925
+ async dropExclusionConstraint(tableOrName, exclusionOrName) {
926
+ throw new error_1.TypeORMError(`MySql does not support exclusion constraints.`);
927
+ }
928
+ /**
929
+ * Drops exclusion constraints.
930
+ */
931
+ async dropExclusionConstraints(tableOrName, exclusionConstraints) {
932
+ throw new error_1.TypeORMError(`MySql does not support exclusion constraints.`);
933
+ }
934
+ /**
935
+ * Creates a new foreign key.
936
+ */
937
+ async createForeignKey(tableOrName, foreignKey) {
938
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
939
+ ? tableOrName
940
+ : await this.getCachedTable(tableOrName);
941
+ // new FK may be passed without name. In this case we generate FK name manually.
942
+ if (!foreignKey.name)
943
+ foreignKey.name = this.connection.namingStrategy.foreignKeyName(table, foreignKey.columnNames);
944
+ const up = this.createForeignKeySql(table, foreignKey);
945
+ const down = this.dropForeignKeySql(table, foreignKey);
946
+ await this.executeQueries(up, down);
947
+ table.addForeignKey(foreignKey);
948
+ }
949
+ /**
950
+ * Creates a new foreign keys.
951
+ */
952
+ async createForeignKeys(tableOrName, foreignKeys) {
953
+ const promises = foreignKeys.map((foreignKey) => this.createForeignKey(tableOrName, foreignKey));
954
+ await Promise.all(promises);
955
+ }
956
+ /**
957
+ * Drops a foreign key.
958
+ */
959
+ async dropForeignKey(tableOrName, foreignKeyOrName) {
960
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
961
+ ? tableOrName
962
+ : await this.getCachedTable(tableOrName);
963
+ const foreignKey = InstanceChecker_1.InstanceChecker.isTableForeignKey(foreignKeyOrName)
964
+ ? foreignKeyOrName
965
+ : table.foreignKeys.find((fk) => fk.name === foreignKeyOrName);
966
+ if (!foreignKey)
967
+ throw new error_1.TypeORMError(`Supplied foreign key was not found in table ${table.name}`);
968
+ const up = this.dropForeignKeySql(table, foreignKey);
969
+ const down = this.createForeignKeySql(table, foreignKey);
970
+ await this.executeQueries(up, down);
971
+ table.removeForeignKey(foreignKey);
972
+ }
973
+ /**
974
+ * Drops a foreign keys from the table.
975
+ */
976
+ async dropForeignKeys(tableOrName, foreignKeys) {
977
+ const promises = foreignKeys.map((foreignKey) => this.dropForeignKey(tableOrName, foreignKey));
978
+ await Promise.all(promises);
979
+ }
980
+ /**
981
+ * Creates a new index.
982
+ */
983
+ async createIndex(tableOrName, index) {
984
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
985
+ ? tableOrName
986
+ : await this.getCachedTable(tableOrName);
987
+ // new index may be passed without name. In this case we generate index name manually.
988
+ if (!index.name)
989
+ index.name = this.generateIndexName(table, index);
990
+ const up = this.createIndexSql(table, index);
991
+ const down = this.dropIndexSql(table, index);
992
+ await this.executeQueries(up, down);
993
+ table.addIndex(index, true);
994
+ }
995
+ /**
996
+ * Creates a new indices
997
+ */
998
+ async createIndices(tableOrName, indices) {
999
+ const promises = indices.map((index) => this.createIndex(tableOrName, index));
1000
+ await Promise.all(promises);
1001
+ }
1002
+ /**
1003
+ * Drops an index.
1004
+ */
1005
+ async dropIndex(tableOrName, indexOrName) {
1006
+ const table = InstanceChecker_1.InstanceChecker.isTable(tableOrName)
1007
+ ? tableOrName
1008
+ : await this.getCachedTable(tableOrName);
1009
+ const index = InstanceChecker_1.InstanceChecker.isTableIndex(indexOrName)
1010
+ ? indexOrName
1011
+ : table.indices.find((i) => i.name === indexOrName);
1012
+ if (!index)
1013
+ throw new error_1.TypeORMError(`Supplied index ${indexOrName} was not found in table ${table.name}`);
1014
+ // old index may be passed without name. In this case we generate index name manually.
1015
+ if (!index.name)
1016
+ index.name = this.generateIndexName(table, index);
1017
+ const up = this.dropIndexSql(table, index);
1018
+ const down = this.createIndexSql(table, index);
1019
+ await this.executeQueries(up, down);
1020
+ table.removeIndex(index, true);
1021
+ }
1022
+ /**
1023
+ * Drops an indices from the table.
1024
+ */
1025
+ async dropIndices(tableOrName, indices) {
1026
+ const promises = indices.map((index) => this.dropIndex(tableOrName, index));
1027
+ await Promise.all(promises);
1028
+ }
1029
+ /**
1030
+ * Clears all table contents.
1031
+ * Note: this operation uses SQL's TRUNCATE query which cannot be reverted in transactions.
1032
+ */
1033
+ async clearTable(tableOrName) {
1034
+ await this.query(`TRUNCATE TABLE ${this.escapePath(tableOrName)}`);
1035
+ }
1036
+ /**
1037
+ * Removes all tables from the currently connected database.
1038
+ * Be careful using this method and avoid using it in production or migrations
1039
+ * (because it can clear all your database).
1040
+ */
1041
+ async clearDatabase(database) {
1042
+ const dbName = database ? database : this.driver.database;
1043
+ if (dbName) {
1044
+ const isDatabaseExist = await this.hasDatabase(dbName);
1045
+ if (!isDatabaseExist)
1046
+ return Promise.resolve();
1047
+ }
1048
+ else {
1049
+ throw new error_1.TypeORMError(`Can not clear database. No database is specified`);
1050
+ }
1051
+ const isAnotherTransactionActive = this.isTransactionActive;
1052
+ if (!isAnotherTransactionActive)
1053
+ await this.startTransaction();
1054
+ try {
1055
+ const selectViewDropsQuery = `SELECT concat('DROP VIEW IF EXISTS \`', table_schema, '\`.\`', table_name, '\`') AS \`query\` FROM \`INFORMATION_SCHEMA\`.\`VIEWS\` WHERE \`TABLE_SCHEMA\` = '${dbName}'`;
1056
+ const dropViewQueries = await this.query(selectViewDropsQuery);
1057
+ await Promise.all(dropViewQueries.map((q) => this.query(q["query"])));
1058
+ const disableForeignKeysCheckQuery = `SET FOREIGN_KEY_CHECKS = 0;`;
1059
+ const dropTablesQuery = `SELECT concat('DROP TABLE IF EXISTS \`', table_schema, '\`.\`', table_name, '\`') AS \`query\` FROM \`INFORMATION_SCHEMA\`.\`TABLES\` WHERE \`TABLE_SCHEMA\` = '${dbName}'`;
1060
+ const enableForeignKeysCheckQuery = `SET FOREIGN_KEY_CHECKS = 1;`;
1061
+ await this.query(disableForeignKeysCheckQuery);
1062
+ const dropQueries = await this.query(dropTablesQuery);
1063
+ await Promise.all(dropQueries.map((query) => this.query(query["query"])));
1064
+ await this.query(enableForeignKeysCheckQuery);
1065
+ if (!isAnotherTransactionActive) {
1066
+ await this.commitTransaction();
1067
+ }
1068
+ }
1069
+ catch (error) {
1070
+ try {
1071
+ // we throw original error even if rollback thrown an error
1072
+ if (!isAnotherTransactionActive) {
1073
+ await this.rollbackTransaction();
1074
+ }
1075
+ }
1076
+ catch (rollbackError) { }
1077
+ throw error;
1078
+ }
1079
+ }
1080
+ // -------------------------------------------------------------------------
1081
+ // Protected Methods
1082
+ // -------------------------------------------------------------------------
1083
+ async loadViews(viewNames) {
1084
+ const hasTable = await this.hasTable(this.getTypeormMetadataTableName());
1085
+ if (!hasTable) {
1086
+ return [];
1087
+ }
1088
+ if (!viewNames) {
1089
+ viewNames = [];
1090
+ }
1091
+ const currentDatabase = await this.getCurrentDatabase();
1092
+ const viewsCondition = viewNames
1093
+ .map((tableName) => {
1094
+ let { database, tableName: name } = this.driver.parseTableName(tableName);
1095
+ if (!database) {
1096
+ database = currentDatabase;
1097
+ }
1098
+ return `(\`t\`.\`schema\` = '${database}' AND \`t\`.\`name\` = '${name}')`;
1099
+ })
1100
+ .join(" OR ");
1101
+ const query = `SELECT \`t\`.*, \`v\`.\`check_option\` FROM ${this.escapePath(this.getTypeormMetadataTableName())} \`t\` ` +
1102
+ `INNER JOIN \`information_schema\`.\`views\` \`v\` ON \`v\`.\`table_schema\` = \`t\`.\`schema\` AND \`v\`.\`table_name\` = \`t\`.\`name\` WHERE \`t\`.\`type\` = '${MetadataTableType_1.MetadataTableType.VIEW}' ${viewsCondition ? `AND (${viewsCondition})` : ""}`;
1103
+ const dbViews = await this.query(query);
1104
+ return dbViews.map((dbView) => {
1105
+ const view = new View_1.View();
1106
+ const db = dbView["schema"] === currentDatabase
1107
+ ? undefined
1108
+ : dbView["schema"];
1109
+ view.database = dbView["schema"];
1110
+ view.name = this.driver.buildTableName(dbView["name"], undefined, db);
1111
+ view.expression = dbView["value"];
1112
+ return view;
1113
+ });
1114
+ }
1115
+ /**
1116
+ * Loads all tables (with given names) from the database and creates a Table from them.
1117
+ */
1118
+ async loadTables(tableNames) {
1119
+ // if no tables given then no need to proceed
1120
+ if (tableNames && tableNames.length === 0) {
1121
+ return [];
1122
+ }
1123
+ const dbTables = [];
1124
+ const currentDatabase = await this.getCurrentDatabase();
1125
+ if (!tableNames) {
1126
+ const tablesSql = `SELECT TABLE_NAME, TABLE_SCHEMA FROM \`INFORMATION_SCHEMA\`.\`TABLES\``;
1127
+ dbTables.push(...(await this.query(tablesSql)));
1128
+ }
1129
+ else {
1130
+ const tablesCondition = tableNames
1131
+ .map((tableName) => {
1132
+ let [database, name] = tableName.split(".");
1133
+ if (!name) {
1134
+ name = database;
1135
+ database = this.driver.database || currentDatabase;
1136
+ }
1137
+ return `(\`TABLE_SCHEMA\` = '${database}' AND \`TABLE_NAME\` = '${name}')`;
1138
+ })
1139
+ .join(" OR ");
1140
+ const tablesSql = `SELECT TABLE_NAME, TABLE_SCHEMA FROM \`INFORMATION_SCHEMA\`.\`TABLES\` WHERE ` +
1141
+ tablesCondition;
1142
+ dbTables.push(...(await this.query(tablesSql)));
1143
+ }
1144
+ if (dbTables.length === 0) {
1145
+ return [];
1146
+ }
1147
+ const columnsCondition = dbTables
1148
+ .map(({ TABLE_NAME, TABLE_SCHEMA }) => {
1149
+ return `(\`TABLE_SCHEMA\` = '${TABLE_SCHEMA}' AND \`TABLE_NAME\` = '${TABLE_NAME}')`;
1150
+ })
1151
+ .join(" OR ");
1152
+ const columnsSql = `SELECT * FROM \`INFORMATION_SCHEMA\`.\`COLUMNS\` WHERE ` +
1153
+ columnsCondition;
1154
+ const primaryKeySql = `SELECT * FROM \`INFORMATION_SCHEMA\`.\`KEY_COLUMN_USAGE\` WHERE \`CONSTRAINT_NAME\` = 'PRIMARY' AND (${columnsCondition})`;
1155
+ const collationsSql = `SELECT \`SCHEMA_NAME\`, \`DEFAULT_CHARACTER_SET_NAME\` as \`CHARSET\`, \`DEFAULT_COLLATION_NAME\` AS \`COLLATION\` FROM \`INFORMATION_SCHEMA\`.\`SCHEMATA\``;
1156
+ const indicesCondition = dbTables
1157
+ .map(({ TABLE_NAME, TABLE_SCHEMA }) => {
1158
+ return `(\`s\`.\`TABLE_SCHEMA\` = '${TABLE_SCHEMA}' AND \`s\`.\`TABLE_NAME\` = '${TABLE_NAME}')`;
1159
+ })
1160
+ .join(" OR ");
1161
+ const indicesSql = `SELECT \`s\`.* FROM \`INFORMATION_SCHEMA\`.\`STATISTICS\` \`s\` ` +
1162
+ `LEFT JOIN \`INFORMATION_SCHEMA\`.\`REFERENTIAL_CONSTRAINTS\` \`rc\` ON \`s\`.\`INDEX_NAME\` = \`rc\`.\`CONSTRAINT_NAME\` ` +
1163
+ `WHERE (${indicesCondition}) AND \`s\`.\`INDEX_NAME\` != 'PRIMARY' AND \`rc\`.\`CONSTRAINT_NAME\` IS NULL`;
1164
+ const foreignKeysCondition = dbTables
1165
+ .map(({ TABLE_NAME, TABLE_SCHEMA }) => {
1166
+ return `(\`kcu\`.\`TABLE_SCHEMA\` = '${TABLE_SCHEMA}' AND \`kcu\`.\`TABLE_NAME\` = '${TABLE_NAME}')`;
1167
+ })
1168
+ .join(" OR ");
1169
+ const foreignKeysSql = `SELECT \`kcu\`.\`TABLE_SCHEMA\`, \`kcu\`.\`TABLE_NAME\`, \`kcu\`.\`CONSTRAINT_NAME\`, \`kcu\`.\`COLUMN_NAME\`, \`kcu\`.\`REFERENCED_TABLE_SCHEMA\`, ` +
1170
+ `\`kcu\`.\`REFERENCED_TABLE_NAME\`, \`kcu\`.\`REFERENCED_COLUMN_NAME\`, \`rc\`.\`DELETE_RULE\` \`ON_DELETE\`, \`rc\`.\`UPDATE_RULE\` \`ON_UPDATE\` ` +
1171
+ `FROM \`INFORMATION_SCHEMA\`.\`KEY_COLUMN_USAGE\` \`kcu\` ` +
1172
+ `INNER JOIN \`INFORMATION_SCHEMA\`.\`REFERENTIAL_CONSTRAINTS\` \`rc\` ON \`rc\`.\`constraint_name\` = \`kcu\`.\`constraint_name\` ` +
1173
+ `WHERE ` +
1174
+ foreignKeysCondition;
1175
+ const [dbColumns, dbPrimaryKeys, dbCollations, dbIndices, dbForeignKeys,] = await Promise.all([
1176
+ this.query(columnsSql),
1177
+ this.query(primaryKeySql),
1178
+ this.query(collationsSql),
1179
+ this.query(indicesSql),
1180
+ this.query(foreignKeysSql),
1181
+ ]);
1182
+ // create tables for loaded tables
1183
+ return Promise.all(dbTables.map(async (dbTable) => {
1184
+ const table = new Table_1.Table();
1185
+ const dbCollation = dbCollations.find((coll) => coll["SCHEMA_NAME"] === dbTable["TABLE_SCHEMA"]);
1186
+ const defaultCollation = dbCollation["COLLATION"];
1187
+ const defaultCharset = dbCollation["CHARSET"];
1188
+ // We do not need to join database name, when database is by default.
1189
+ const db = dbTable["TABLE_SCHEMA"] === currentDatabase
1190
+ ? undefined
1191
+ : dbTable["TABLE_SCHEMA"];
1192
+ table.database = dbTable["TABLE_SCHEMA"];
1193
+ table.name = this.driver.buildTableName(dbTable["TABLE_NAME"], undefined, db);
1194
+ // create columns from the loaded columns
1195
+ table.columns = dbColumns
1196
+ .filter((dbColumn) => dbColumn["TABLE_NAME"] === dbTable["TABLE_NAME"] &&
1197
+ dbColumn["TABLE_SCHEMA"] ===
1198
+ dbTable["TABLE_SCHEMA"])
1199
+ .map((dbColumn) => {
1200
+ const columnUniqueIndices = dbIndices.filter((dbIndex) => {
1201
+ return (dbIndex["TABLE_NAME"] ===
1202
+ dbTable["TABLE_NAME"] &&
1203
+ dbIndex["TABLE_SCHEMA"] ===
1204
+ dbTable["TABLE_SCHEMA"] &&
1205
+ dbIndex["COLUMN_NAME"] ===
1206
+ dbColumn["COLUMN_NAME"] &&
1207
+ parseInt(dbIndex["NON_UNIQUE"], 10) === 0);
1208
+ });
1209
+ const tableMetadata = this.connection.entityMetadatas.find((metadata) => this.getTablePath(table) ===
1210
+ this.getTablePath(metadata));
1211
+ const hasIgnoredIndex = columnUniqueIndices.length > 0 &&
1212
+ tableMetadata &&
1213
+ tableMetadata.indices.some((index) => {
1214
+ return columnUniqueIndices.some((uniqueIndex) => {
1215
+ return (index.name ===
1216
+ uniqueIndex["INDEX_NAME"] &&
1217
+ index.synchronize === false);
1218
+ });
1219
+ });
1220
+ const isConstraintComposite = columnUniqueIndices.every((uniqueIndex) => {
1221
+ return dbIndices.some((dbIndex) => dbIndex["INDEX_NAME"] ===
1222
+ uniqueIndex["INDEX_NAME"] &&
1223
+ dbIndex["COLUMN_NAME"] !==
1224
+ dbColumn["COLUMN_NAME"]);
1225
+ });
1226
+ const tableColumn = new TableColumn_1.TableColumn();
1227
+ tableColumn.name = dbColumn["COLUMN_NAME"];
1228
+ tableColumn.type = dbColumn["DATA_TYPE"].toLowerCase();
1229
+ // Unsigned columns are handled differently when it comes to width.
1230
+ // Hence, we need to set the unsigned attribute before we check the width.
1231
+ tableColumn.unsigned = tableColumn.zerofill
1232
+ ? true
1233
+ : dbColumn["COLUMN_TYPE"].indexOf("unsigned") !== -1;
1234
+ if (this.driver.withWidthColumnTypes.indexOf(tableColumn.type) !== -1) {
1235
+ const width = dbColumn["COLUMN_TYPE"].substring(dbColumn["COLUMN_TYPE"].indexOf("(") + 1, dbColumn["COLUMN_TYPE"].indexOf(")"));
1236
+ tableColumn.width =
1237
+ width &&
1238
+ !this.isDefaultColumnWidth(table, tableColumn, parseInt(width))
1239
+ ? parseInt(width)
1240
+ : undefined;
1241
+ }
1242
+ if (dbColumn["COLUMN_DEFAULT"] === null ||
1243
+ dbColumn["COLUMN_DEFAULT"] === undefined) {
1244
+ tableColumn.default = undefined;
1245
+ }
1246
+ else {
1247
+ tableColumn.default =
1248
+ dbColumn["COLUMN_DEFAULT"] ===
1249
+ "CURRENT_TIMESTAMP"
1250
+ ? dbColumn["COLUMN_DEFAULT"]
1251
+ : `'${dbColumn["COLUMN_DEFAULT"]}'`;
1252
+ }
1253
+ if (dbColumn["EXTRA"].indexOf("on update") !== -1) {
1254
+ tableColumn.onUpdate = dbColumn["EXTRA"].substring(dbColumn["EXTRA"].indexOf("on update") + 10);
1255
+ }
1256
+ if (dbColumn["GENERATION_EXPRESSION"]) {
1257
+ tableColumn.asExpression =
1258
+ dbColumn["GENERATION_EXPRESSION"];
1259
+ tableColumn.generatedType =
1260
+ dbColumn["EXTRA"].indexOf("VIRTUAL") !== -1
1261
+ ? "VIRTUAL"
1262
+ : "STORED";
1263
+ }
1264
+ tableColumn.isUnique =
1265
+ columnUniqueIndices.length > 0 &&
1266
+ !hasIgnoredIndex &&
1267
+ !isConstraintComposite;
1268
+ tableColumn.isNullable =
1269
+ dbColumn["IS_NULLABLE"] === "YES";
1270
+ tableColumn.isPrimary = dbPrimaryKeys.some((dbPrimaryKey) => {
1271
+ return (dbPrimaryKey["TABLE_NAME"] ===
1272
+ dbColumn["TABLE_NAME"] &&
1273
+ dbPrimaryKey["TABLE_SCHEMA"] ===
1274
+ dbColumn["TABLE_SCHEMA"] &&
1275
+ dbPrimaryKey["COLUMN_NAME"] ===
1276
+ dbColumn["COLUMN_NAME"]);
1277
+ });
1278
+ tableColumn.zerofill =
1279
+ dbColumn["COLUMN_TYPE"].indexOf("zerofill") !== -1;
1280
+ tableColumn.isGenerated =
1281
+ dbColumn["EXTRA"].indexOf("auto_increment") !== -1;
1282
+ if (tableColumn.isGenerated)
1283
+ tableColumn.generationStrategy = "increment";
1284
+ tableColumn.comment =
1285
+ typeof dbColumn["COLUMN_COMMENT"] === "string" &&
1286
+ dbColumn["COLUMN_COMMENT"].length === 0
1287
+ ? undefined
1288
+ : dbColumn["COLUMN_COMMENT"];
1289
+ if (dbColumn["CHARACTER_SET_NAME"])
1290
+ tableColumn.charset =
1291
+ dbColumn["CHARACTER_SET_NAME"] ===
1292
+ defaultCharset
1293
+ ? undefined
1294
+ : dbColumn["CHARACTER_SET_NAME"];
1295
+ if (dbColumn["COLLATION_NAME"])
1296
+ tableColumn.collation =
1297
+ dbColumn["COLLATION_NAME"] === defaultCollation
1298
+ ? undefined
1299
+ : dbColumn["COLLATION_NAME"];
1300
+ // check only columns that have length property
1301
+ if (this.driver.withLengthColumnTypes.indexOf(tableColumn.type) !== -1 &&
1302
+ dbColumn["CHARACTER_MAXIMUM_LENGTH"]) {
1303
+ const length = dbColumn["CHARACTER_MAXIMUM_LENGTH"].toString();
1304
+ tableColumn.length = !this.isDefaultColumnLength(table, tableColumn, length)
1305
+ ? length
1306
+ : "";
1307
+ }
1308
+ if (tableColumn.type === "decimal" ||
1309
+ tableColumn.type === "double" ||
1310
+ tableColumn.type === "float") {
1311
+ if (dbColumn["NUMERIC_PRECISION"] !== null &&
1312
+ !this.isDefaultColumnPrecision(table, tableColumn, dbColumn["NUMERIC_PRECISION"]))
1313
+ tableColumn.precision = parseInt(dbColumn["NUMERIC_PRECISION"]);
1314
+ if (dbColumn["NUMERIC_SCALE"] !== null &&
1315
+ !this.isDefaultColumnScale(table, tableColumn, dbColumn["NUMERIC_SCALE"]))
1316
+ tableColumn.scale = parseInt(dbColumn["NUMERIC_SCALE"]);
1317
+ }
1318
+ if (tableColumn.type === "enum" ||
1319
+ tableColumn.type === "simple-enum" ||
1320
+ tableColumn.type === "set") {
1321
+ const colType = dbColumn["COLUMN_TYPE"];
1322
+ const items = colType
1323
+ .substring(colType.indexOf("(") + 1, colType.lastIndexOf(")"))
1324
+ .split(",");
1325
+ tableColumn.enum = items.map((item) => {
1326
+ return item.substring(1, item.length - 1);
1327
+ });
1328
+ tableColumn.length = "";
1329
+ }
1330
+ if ((tableColumn.type === "datetime" ||
1331
+ tableColumn.type === "time" ||
1332
+ tableColumn.type === "timestamp") &&
1333
+ dbColumn["DATETIME_PRECISION"] !== null &&
1334
+ dbColumn["DATETIME_PRECISION"] !== undefined &&
1335
+ !this.isDefaultColumnPrecision(table, tableColumn, parseInt(dbColumn["DATETIME_PRECISION"]))) {
1336
+ tableColumn.precision = parseInt(dbColumn["DATETIME_PRECISION"]);
1337
+ }
1338
+ return tableColumn;
1339
+ });
1340
+ // find foreign key constraints of table, group them by constraint name and build TableForeignKey.
1341
+ const tableForeignKeyConstraints = OrmUtils_1.OrmUtils.uniq(dbForeignKeys.filter((dbForeignKey) => {
1342
+ return (dbForeignKey["TABLE_NAME"] ===
1343
+ dbTable["TABLE_NAME"] &&
1344
+ dbForeignKey["TABLE_SCHEMA"] ===
1345
+ dbTable["TABLE_SCHEMA"]);
1346
+ }), (dbForeignKey) => dbForeignKey["CONSTRAINT_NAME"]);
1347
+ table.foreignKeys = tableForeignKeyConstraints.map((dbForeignKey) => {
1348
+ const foreignKeys = dbForeignKeys.filter((dbFk) => dbFk["CONSTRAINT_NAME"] ===
1349
+ dbForeignKey["CONSTRAINT_NAME"]);
1350
+ // if referenced table located in currently used db, we don't need to concat db name to table name.
1351
+ const database = dbForeignKey["REFERENCED_TABLE_SCHEMA"] ===
1352
+ currentDatabase
1353
+ ? undefined
1354
+ : dbForeignKey["REFERENCED_TABLE_SCHEMA"];
1355
+ const referencedTableName = this.driver.buildTableName(dbForeignKey["REFERENCED_TABLE_NAME"], undefined, database);
1356
+ return new TableForeignKey_1.TableForeignKey({
1357
+ name: dbForeignKey["CONSTRAINT_NAME"],
1358
+ columnNames: foreignKeys.map((dbFk) => dbFk["COLUMN_NAME"]),
1359
+ referencedDatabase: dbForeignKey["REFERENCED_TABLE_SCHEMA"],
1360
+ referencedTableName: referencedTableName,
1361
+ referencedColumnNames: foreignKeys.map((dbFk) => dbFk["REFERENCED_COLUMN_NAME"]),
1362
+ onDelete: dbForeignKey["ON_DELETE"],
1363
+ onUpdate: dbForeignKey["ON_UPDATE"],
1364
+ });
1365
+ });
1366
+ // find index constraints of table, group them by constraint name and build TableIndex.
1367
+ const tableIndexConstraints = OrmUtils_1.OrmUtils.uniq(dbIndices.filter((dbIndex) => {
1368
+ return (dbIndex["TABLE_NAME"] === dbTable["TABLE_NAME"] &&
1369
+ dbIndex["TABLE_SCHEMA"] === dbTable["TABLE_SCHEMA"]);
1370
+ }), (dbIndex) => dbIndex["INDEX_NAME"]);
1371
+ table.indices = tableIndexConstraints.map((constraint) => {
1372
+ const indices = dbIndices.filter((index) => {
1373
+ return (index["TABLE_SCHEMA"] ===
1374
+ constraint["TABLE_SCHEMA"] &&
1375
+ index["TABLE_NAME"] === constraint["TABLE_NAME"] &&
1376
+ index["INDEX_NAME"] === constraint["INDEX_NAME"]);
1377
+ });
1378
+ const nonUnique = parseInt(constraint["NON_UNIQUE"], 10);
1379
+ return new TableIndex_1.TableIndex({
1380
+ table: table,
1381
+ name: constraint["INDEX_NAME"],
1382
+ columnNames: indices.map((i) => i["COLUMN_NAME"]),
1383
+ isUnique: nonUnique === 0,
1384
+ isSpatial: constraint["INDEX_TYPE"] === "SPATIAL",
1385
+ isFulltext: constraint["INDEX_TYPE"] === "FULLTEXT",
1386
+ });
1387
+ });
1388
+ return table;
1389
+ }));
1390
+ }
1391
+ /**
1392
+ * Builds create table sql
1393
+ */
1394
+ createTableSql(table, createForeignKeys) {
1395
+ const columnDefinitions = table.columns
1396
+ .map((column) => this.buildCreateColumnSql(column, true))
1397
+ .join(", ");
1398
+ let sql = `CREATE TABLE ${this.escapePath(table)} (${columnDefinitions}`;
1399
+ // we create unique indexes instead of unique constraints, because MySql does not have unique constraints.
1400
+ // if we mark column as Unique, it means that we create UNIQUE INDEX.
1401
+ table.columns
1402
+ .filter((column) => column.isUnique)
1403
+ .forEach((column) => {
1404
+ const isUniqueIndexExist = table.indices.some((index) => {
1405
+ return (index.columnNames.length === 1 &&
1406
+ !!index.isUnique &&
1407
+ index.columnNames.indexOf(column.name) !== -1);
1408
+ });
1409
+ const isUniqueConstraintExist = table.uniques.some((unique) => {
1410
+ return (unique.columnNames.length === 1 &&
1411
+ unique.columnNames.indexOf(column.name) !== -1);
1412
+ });
1413
+ if (!isUniqueIndexExist && !isUniqueConstraintExist)
1414
+ table.indices.push(new TableIndex_1.TableIndex({
1415
+ name: this.connection.namingStrategy.uniqueConstraintName(table, [column.name]),
1416
+ columnNames: [column.name],
1417
+ isUnique: true,
1418
+ }));
1419
+ });
1420
+ // as MySql does not have unique constraints, we must create table indices from table uniques and mark them as unique.
1421
+ if (table.uniques.length > 0) {
1422
+ table.uniques.forEach((unique) => {
1423
+ const uniqueExist = table.indices.some((index) => index.name === unique.name);
1424
+ if (!uniqueExist) {
1425
+ table.indices.push(new TableIndex_1.TableIndex({
1426
+ name: unique.name,
1427
+ columnNames: unique.columnNames,
1428
+ isUnique: true,
1429
+ }));
1430
+ }
1431
+ });
1432
+ }
1433
+ if (table.indices.length > 0) {
1434
+ const indicesSql = table.indices
1435
+ .map((index) => {
1436
+ const columnNames = index.columnNames
1437
+ .map((columnName) => `\`${columnName}\``)
1438
+ .join(", ");
1439
+ if (!index.name)
1440
+ index.name = this.connection.namingStrategy.indexName(table, index.columnNames, index.where);
1441
+ let indexType = "";
1442
+ if (index.isUnique)
1443
+ indexType += "UNIQUE ";
1444
+ if (index.isSpatial)
1445
+ indexType += "SPATIAL ";
1446
+ if (index.isFulltext)
1447
+ indexType += "FULLTEXT ";
1448
+ return `${indexType}INDEX \`${index.name}\` (${columnNames})`;
1449
+ })
1450
+ .join(", ");
1451
+ sql += `, ${indicesSql}`;
1452
+ }
1453
+ if (table.foreignKeys.length > 0 && createForeignKeys) {
1454
+ const foreignKeysSql = table.foreignKeys
1455
+ .map((fk) => {
1456
+ const columnNames = fk.columnNames
1457
+ .map((columnName) => `\`${columnName}\``)
1458
+ .join(", ");
1459
+ if (!fk.name)
1460
+ fk.name = this.connection.namingStrategy.foreignKeyName(table, fk.columnNames);
1461
+ const referencedColumnNames = fk.referencedColumnNames
1462
+ .map((columnName) => `\`${columnName}\``)
1463
+ .join(", ");
1464
+ let constraint = `CONSTRAINT \`${fk.name}\` FOREIGN KEY (${columnNames}) REFERENCES ${this.escapePath(this.getTablePath(fk))} (${referencedColumnNames})`;
1465
+ if (fk.onDelete)
1466
+ constraint += ` ON DELETE ${fk.onDelete}`;
1467
+ if (fk.onUpdate)
1468
+ constraint += ` ON UPDATE ${fk.onUpdate}`;
1469
+ return constraint;
1470
+ })
1471
+ .join(", ");
1472
+ sql += `, ${foreignKeysSql}`;
1473
+ }
1474
+ if (table.primaryColumns.length > 0) {
1475
+ const columnNames = table.primaryColumns
1476
+ .map((column) => `\`${column.name}\``)
1477
+ .join(", ");
1478
+ sql += `, PRIMARY KEY (${columnNames})`;
1479
+ }
1480
+ sql += `) ENGINE=${table.engine || "InnoDB"}`;
1481
+ return new Query_1.Query(sql);
1482
+ }
1483
+ /**
1484
+ * Builds drop table sql
1485
+ */
1486
+ dropTableSql(tableOrName) {
1487
+ return new Query_1.Query(`DROP TABLE ${this.escapePath(tableOrName)}`);
1488
+ }
1489
+ createViewSql(view) {
1490
+ if (typeof view.expression === "string") {
1491
+ return new Query_1.Query(`CREATE VIEW ${this.escapePath(view)} AS ${view.expression}`);
1492
+ }
1493
+ else {
1494
+ return new Query_1.Query(`CREATE VIEW ${this.escapePath(view)} AS ${view
1495
+ .expression(this.connection)
1496
+ .getQuery()}`);
1497
+ }
1498
+ }
1499
+ async insertViewDefinitionSql(view) {
1500
+ const currentDatabase = await this.getCurrentDatabase();
1501
+ const expression = typeof view.expression === "string"
1502
+ ? view.expression.trim()
1503
+ : view.expression(this.connection).getQuery();
1504
+ return this.insertTypeormMetadataSql({
1505
+ type: MetadataTableType_1.MetadataTableType.VIEW,
1506
+ schema: currentDatabase,
1507
+ name: view.name,
1508
+ value: expression,
1509
+ });
1510
+ }
1511
+ /**
1512
+ * Builds drop view sql.
1513
+ */
1514
+ dropViewSql(viewOrPath) {
1515
+ return new Query_1.Query(`DROP VIEW ${this.escapePath(viewOrPath)}`);
1516
+ }
1517
+ /**
1518
+ * Builds remove view sql.
1519
+ */
1520
+ async deleteViewDefinitionSql(viewOrPath) {
1521
+ const currentDatabase = await this.getCurrentDatabase();
1522
+ const viewName = InstanceChecker_1.InstanceChecker.isView(viewOrPath)
1523
+ ? viewOrPath.name
1524
+ : viewOrPath;
1525
+ return this.deleteTypeormMetadataSql({
1526
+ type: MetadataTableType_1.MetadataTableType.VIEW,
1527
+ schema: currentDatabase,
1528
+ name: viewName,
1529
+ });
1530
+ }
1531
+ /**
1532
+ * Builds create index sql.
1533
+ */
1534
+ createIndexSql(table, index) {
1535
+ const columns = index.columnNames
1536
+ .map((columnName) => `\`${columnName}\``)
1537
+ .join(", ");
1538
+ let indexType = "";
1539
+ if (index.isUnique)
1540
+ indexType += "UNIQUE ";
1541
+ if (index.isSpatial)
1542
+ indexType += "SPATIAL ";
1543
+ if (index.isFulltext)
1544
+ indexType += "FULLTEXT ";
1545
+ return new Query_1.Query(`CREATE ${indexType}INDEX \`${index.name}\` ON ${this.escapePath(table)} (${columns})`);
1546
+ }
1547
+ /**
1548
+ * Builds drop index sql.
1549
+ */
1550
+ dropIndexSql(table, indexOrName) {
1551
+ const indexName = InstanceChecker_1.InstanceChecker.isTableIndex(indexOrName)
1552
+ ? indexOrName.name
1553
+ : indexOrName;
1554
+ return new Query_1.Query(`DROP INDEX \`${indexName}\` ON ${this.escapePath(table)}`);
1555
+ }
1556
+ /**
1557
+ * Builds create primary key sql.
1558
+ */
1559
+ createPrimaryKeySql(table, columnNames) {
1560
+ const columnNamesString = columnNames
1561
+ .map((columnName) => `\`${columnName}\``)
1562
+ .join(", ");
1563
+ return new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} ADD PRIMARY KEY (${columnNamesString})`);
1564
+ }
1565
+ /**
1566
+ * Builds drop primary key sql.
1567
+ */
1568
+ dropPrimaryKeySql(table) {
1569
+ return new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP PRIMARY KEY`);
1570
+ }
1571
+ /**
1572
+ * Builds create foreign key sql.
1573
+ */
1574
+ createForeignKeySql(table, foreignKey) {
1575
+ const columnNames = foreignKey.columnNames
1576
+ .map((column) => `\`${column}\``)
1577
+ .join(", ");
1578
+ const referencedColumnNames = foreignKey.referencedColumnNames
1579
+ .map((column) => `\`${column}\``)
1580
+ .join(",");
1581
+ let sql = `ALTER TABLE ${this.escapePath(table)} ADD CONSTRAINT \`${foreignKey.name}\` FOREIGN KEY (${columnNames}) ` +
1582
+ `REFERENCES ${this.escapePath(this.getTablePath(foreignKey))}(${referencedColumnNames})`;
1583
+ if (foreignKey.onDelete)
1584
+ sql += ` ON DELETE ${foreignKey.onDelete}`;
1585
+ if (foreignKey.onUpdate)
1586
+ sql += ` ON UPDATE ${foreignKey.onUpdate}`;
1587
+ return new Query_1.Query(sql);
1588
+ }
1589
+ /**
1590
+ * Builds drop foreign key sql.
1591
+ */
1592
+ dropForeignKeySql(table, foreignKeyOrName) {
1593
+ const foreignKeyName = InstanceChecker_1.InstanceChecker.isTableForeignKey(foreignKeyOrName)
1594
+ ? foreignKeyOrName.name
1595
+ : foreignKeyOrName;
1596
+ return new Query_1.Query(`ALTER TABLE ${this.escapePath(table)} DROP FOREIGN KEY \`${foreignKeyName}\``);
1597
+ }
1598
+ /**
1599
+ * Escapes a given comment so it's safe to include in a query.
1600
+ */
1601
+ escapeComment(comment) {
1602
+ if (!comment || comment.length === 0) {
1603
+ return `''`;
1604
+ }
1605
+ comment = comment
1606
+ .replace(/\\/g, "\\\\") // MySQL allows escaping characters via backslashes
1607
+ .replace(/'/g, "''")
1608
+ .replace(/\u0000/g, ""); // Null bytes aren't allowed in comments
1609
+ return `'${comment}'`;
1610
+ }
1611
+ /**
1612
+ * Escapes given table or view path.
1613
+ */
1614
+ escapePath(target) {
1615
+ const { database, tableName } = this.driver.parseTableName(target);
1616
+ if (database && database !== this.driver.database) {
1617
+ return `\`${database}\`.\`${tableName}\``;
1618
+ }
1619
+ return `\`${tableName}\``;
1620
+ }
1621
+ /**
1622
+ * Builds a part of query to create/change a column.
1623
+ */
1624
+ buildCreateColumnSql(column, skipPrimary, skipName = false) {
1625
+ let c = "";
1626
+ if (skipName) {
1627
+ c = this.connection.driver.createFullType(column);
1628
+ }
1629
+ else {
1630
+ c = `\`${column.name}\` ${this.connection.driver.createFullType(column)}`;
1631
+ }
1632
+ if (column.asExpression)
1633
+ c += ` AS (${column.asExpression}) ${column.generatedType ? column.generatedType : "VIRTUAL"}`;
1634
+ // if you specify ZEROFILL for a numeric column, MySQL automatically adds the UNSIGNED attribute to that column.
1635
+ if (column.zerofill) {
1636
+ c += " ZEROFILL";
1637
+ }
1638
+ else if (column.unsigned) {
1639
+ c += " UNSIGNED";
1640
+ }
1641
+ if (column.enum)
1642
+ c += ` (${column.enum
1643
+ .map((value) => "'" + value + "'")
1644
+ .join(", ")})`;
1645
+ if (column.charset)
1646
+ c += ` CHARACTER SET "${column.charset}"`;
1647
+ if (column.collation)
1648
+ c += ` COLLATE "${column.collation}"`;
1649
+ if (!column.isNullable)
1650
+ c += " NOT NULL";
1651
+ if (column.isNullable)
1652
+ c += " NULL";
1653
+ if (column.isPrimary && !skipPrimary)
1654
+ c += " PRIMARY KEY";
1655
+ if (column.isGenerated && column.generationStrategy === "increment")
1656
+ // don't use skipPrimary here since updates can update already exist primary without auto inc.
1657
+ c += " AUTO_INCREMENT";
1658
+ if (column.comment)
1659
+ c += ` COMMENT ${this.escapeComment(column.comment)}`;
1660
+ if (column.default !== undefined && column.default !== null)
1661
+ c += ` DEFAULT ${column.default}`;
1662
+ if (column.onUpdate)
1663
+ c += ` ON UPDATE ${column.onUpdate}`;
1664
+ return c;
1665
+ }
1666
+ /**
1667
+ * Checks if column display width is by default.
1668
+ */
1669
+ isDefaultColumnWidth(table, column, width) {
1670
+ // if table have metadata, we check if length is specified in column metadata
1671
+ if (this.connection.hasMetadata(table.name)) {
1672
+ const metadata = this.connection.getMetadata(table.name);
1673
+ const columnMetadata = metadata.findColumnWithDatabaseName(column.name);
1674
+ if (columnMetadata && columnMetadata.width)
1675
+ return false;
1676
+ }
1677
+ const defaultWidthForType = this.connection.driver.dataTypeDefaults &&
1678
+ this.connection.driver.dataTypeDefaults[column.type] &&
1679
+ this.connection.driver.dataTypeDefaults[column.type].width;
1680
+ if (defaultWidthForType) {
1681
+ // In MariaDB & MySQL 5.7, the default widths of certain numeric types are 1 less than
1682
+ // the usual defaults when the column is unsigned.
1683
+ // This also applies to Aurora MySQL.
1684
+ const typesWithReducedUnsignedDefault = [
1685
+ "int",
1686
+ "tinyint",
1687
+ "smallint",
1688
+ "mediumint",
1689
+ ];
1690
+ const needsAdjustment = typesWithReducedUnsignedDefault.indexOf(column.type) !== -1;
1691
+ if (column.unsigned && needsAdjustment) {
1692
+ return defaultWidthForType - 1 === width;
1693
+ }
1694
+ else {
1695
+ return defaultWidthForType === width;
1696
+ }
1697
+ }
1698
+ return false;
1699
+ }
1700
+ /**
1701
+ * Change table comment.
1702
+ */
1703
+ changeTableComment(tableOrName, comment) {
1704
+ throw new error_1.TypeORMError(`aurora-mysql driver does not support change table comment.`);
1705
+ }
1706
+ }
1707
+ exports.AuroraMysqlQueryRunner = AuroraMysqlQueryRunner;
1708
+
1709
+ //# sourceMappingURL=AuroraMysqlQueryRunner.js.map