@stingerloom/orm 0.1.0

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 (595) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +53 -0
  3. package/dist/DatabaseClient.d.ts +23 -0
  4. package/dist/DatabaseClient.d.ts.map +1 -0
  5. package/dist/DatabaseClient.js +125 -0
  6. package/dist/DatabaseClient.js.map +1 -0
  7. package/dist/core/BaseEntityManager.d.ts +29 -0
  8. package/dist/core/BaseEntityManager.d.ts.map +1 -0
  9. package/dist/core/BaseEntityManager.js +7 -0
  10. package/dist/core/BaseEntityManager.js.map +1 -0
  11. package/dist/core/BaseInsertQueryBuilder.d.ts +8 -0
  12. package/dist/core/BaseInsertQueryBuilder.d.ts.map +1 -0
  13. package/dist/core/BaseInsertQueryBuilder.js +3 -0
  14. package/dist/core/BaseInsertQueryBuilder.js.map +1 -0
  15. package/dist/core/BaseRawQueryBuilder.d.ts +33 -0
  16. package/dist/core/BaseRawQueryBuilder.d.ts.map +1 -0
  17. package/dist/core/BaseRawQueryBuilder.js +3 -0
  18. package/dist/core/BaseRawQueryBuilder.js.map +1 -0
  19. package/dist/core/BaseRepository.d.ts +37 -0
  20. package/dist/core/BaseRepository.d.ts.map +1 -0
  21. package/dist/core/BaseRepository.js +77 -0
  22. package/dist/core/BaseRepository.js.map +1 -0
  23. package/dist/core/BaseResultTransformer.d.ts +11 -0
  24. package/dist/core/BaseResultTransformer.d.ts.map +1 -0
  25. package/dist/core/BaseResultTransformer.js +3 -0
  26. package/dist/core/BaseResultTransformer.js.map +1 -0
  27. package/dist/core/Conditions.d.ts +33 -0
  28. package/dist/core/Conditions.d.ts.map +1 -0
  29. package/dist/core/Conditions.js +154 -0
  30. package/dist/core/Conditions.js.map +1 -0
  31. package/dist/core/CursorPagination.d.ts +19 -0
  32. package/dist/core/CursorPagination.d.ts.map +1 -0
  33. package/dist/core/CursorPagination.js +27 -0
  34. package/dist/core/CursorPagination.js.map +1 -0
  35. package/dist/core/DatabaseClientOptions.d.ts +41 -0
  36. package/dist/core/DatabaseClientOptions.d.ts.map +1 -0
  37. package/dist/core/DatabaseClientOptions.js +3 -0
  38. package/dist/core/DatabaseClientOptions.js.map +1 -0
  39. package/dist/core/EntityEventEmitter.d.ts +14 -0
  40. package/dist/core/EntityEventEmitter.d.ts.map +1 -0
  41. package/dist/core/EntityEventEmitter.js +35 -0
  42. package/dist/core/EntityEventEmitter.js.map +1 -0
  43. package/dist/core/EntityManager.d.ts +115 -0
  44. package/dist/core/EntityManager.d.ts.map +1 -0
  45. package/dist/core/EntityManager.js +2347 -0
  46. package/dist/core/EntityManager.js.map +1 -0
  47. package/dist/core/EntitySubscriber.d.ts +31 -0
  48. package/dist/core/EntitySubscriber.d.ts.map +1 -0
  49. package/dist/core/EntitySubscriber.js +3 -0
  50. package/dist/core/EntitySubscriber.js.map +1 -0
  51. package/dist/core/EntityValidator.d.ts +6 -0
  52. package/dist/core/EntityValidator.d.ts.map +1 -0
  53. package/dist/core/EntityValidator.js +43 -0
  54. package/dist/core/EntityValidator.js.map +1 -0
  55. package/dist/core/ExplainResult.d.ts +9 -0
  56. package/dist/core/ExplainResult.d.ts.map +1 -0
  57. package/dist/core/ExplainResult.js +3 -0
  58. package/dist/core/ExplainResult.js.map +1 -0
  59. package/dist/core/IConnector.d.ts +18 -0
  60. package/dist/core/IConnector.d.ts.map +1 -0
  61. package/dist/core/IConnector.js +7 -0
  62. package/dist/core/IConnector.js.map +1 -0
  63. package/dist/core/LazyLoader.d.ts +6 -0
  64. package/dist/core/LazyLoader.d.ts.map +1 -0
  65. package/dist/core/LazyLoader.js +94 -0
  66. package/dist/core/LazyLoader.js.map +1 -0
  67. package/dist/core/MyClassConstructor.d.ts +4 -0
  68. package/dist/core/MyClassConstructor.d.ts.map +1 -0
  69. package/dist/core/MyClassConstructor.js +3 -0
  70. package/dist/core/MyClassConstructor.js.map +1 -0
  71. package/dist/core/QueryTracker.d.ts +37 -0
  72. package/dist/core/QueryTracker.d.ts.map +1 -0
  73. package/dist/core/QueryTracker.js +111 -0
  74. package/dist/core/QueryTracker.js.map +1 -0
  75. package/dist/core/RawQueryBuilder.d.ts +40 -0
  76. package/dist/core/RawQueryBuilder.d.ts.map +1 -0
  77. package/dist/core/RawQueryBuilder.js +211 -0
  78. package/dist/core/RawQueryBuilder.js.map +1 -0
  79. package/dist/core/RawQueryBuilderFactory.d.ts +6 -0
  80. package/dist/core/RawQueryBuilderFactory.d.ts.map +1 -0
  81. package/dist/core/RawQueryBuilderFactory.js +14 -0
  82. package/dist/core/RawQueryBuilderFactory.js.map +1 -0
  83. package/dist/core/ResultTransformer.d.ts +24 -0
  84. package/dist/core/ResultTransformer.d.ts.map +1 -0
  85. package/dist/core/ResultTransformer.js +134 -0
  86. package/dist/core/ResultTransformer.js.map +1 -0
  87. package/dist/core/ResultTransformerFactory.d.ts +5 -0
  88. package/dist/core/ResultTransformerFactory.d.ts.map +1 -0
  89. package/dist/core/ResultTransformerFactory.js +11 -0
  90. package/dist/core/ResultTransformerFactory.js.map +1 -0
  91. package/dist/core/SelectUtils.d.ts +14 -0
  92. package/dist/core/SelectUtils.d.ts.map +1 -0
  93. package/dist/core/SelectUtils.js +19 -0
  94. package/dist/core/SelectUtils.js.map +1 -0
  95. package/dist/core/deserializer/ClassTransformerDeserializer.d.ts +7 -0
  96. package/dist/core/deserializer/ClassTransformerDeserializer.d.ts.map +1 -0
  97. package/dist/core/deserializer/ClassTransformerDeserializer.js +14 -0
  98. package/dist/core/deserializer/ClassTransformerDeserializer.js.map +1 -0
  99. package/dist/core/deserializer/DeserializeEntity.d.ts +7 -0
  100. package/dist/core/deserializer/DeserializeEntity.d.ts.map +1 -0
  101. package/dist/core/deserializer/DeserializeEntity.js +17 -0
  102. package/dist/core/deserializer/DeserializeEntity.js.map +1 -0
  103. package/dist/core/deserializer/DeserializeOptions.d.ts +9 -0
  104. package/dist/core/deserializer/DeserializeOptions.d.ts.map +1 -0
  105. package/dist/core/deserializer/DeserializeOptions.js +3 -0
  106. package/dist/core/deserializer/DeserializeOptions.js.map +1 -0
  107. package/dist/core/deserializer/Deserializer.d.ts +6 -0
  108. package/dist/core/deserializer/Deserializer.d.ts.map +1 -0
  109. package/dist/core/deserializer/Deserializer.js +3 -0
  110. package/dist/core/deserializer/Deserializer.js.map +1 -0
  111. package/dist/core/deserializer/DeserializerRegistry.d.ts +13 -0
  112. package/dist/core/deserializer/DeserializerRegistry.d.ts.map +1 -0
  113. package/dist/core/deserializer/DeserializerRegistry.js +26 -0
  114. package/dist/core/deserializer/DeserializerRegistry.js.map +1 -0
  115. package/dist/core/deserializer/index.d.ts +6 -0
  116. package/dist/core/deserializer/index.d.ts.map +1 -0
  117. package/dist/core/deserializer/index.js +22 -0
  118. package/dist/core/deserializer/index.js.map +1 -0
  119. package/dist/core/generators/SchemaDiff.d.ts +34 -0
  120. package/dist/core/generators/SchemaDiff.d.ts.map +1 -0
  121. package/dist/core/generators/SchemaDiff.js +231 -0
  122. package/dist/core/generators/SchemaDiff.js.map +1 -0
  123. package/dist/core/generators/SchemaDiffMigrationGenerator.d.ts +11 -0
  124. package/dist/core/generators/SchemaDiffMigrationGenerator.d.ts.map +1 -0
  125. package/dist/core/generators/SchemaDiffMigrationGenerator.js +108 -0
  126. package/dist/core/generators/SchemaDiffMigrationGenerator.js.map +1 -0
  127. package/dist/core/generators/SchemaGenerator.d.ts +37 -0
  128. package/dist/core/generators/SchemaGenerator.d.ts.map +1 -0
  129. package/dist/core/generators/SchemaGenerator.js +379 -0
  130. package/dist/core/generators/SchemaGenerator.js.map +1 -0
  131. package/dist/core/generators/index.d.ts +4 -0
  132. package/dist/core/generators/index.d.ts.map +1 -0
  133. package/dist/core/generators/index.js +20 -0
  134. package/dist/core/generators/index.js.map +1 -0
  135. package/dist/core/index.d.ts +20 -0
  136. package/dist/core/index.d.ts.map +1 -0
  137. package/dist/core/index.js +36 -0
  138. package/dist/core/index.js.map +1 -0
  139. package/dist/decorators/Column.d.ts +19 -0
  140. package/dist/decorators/Column.d.ts.map +1 -0
  141. package/dist/decorators/Column.js +53 -0
  142. package/dist/decorators/Column.js.map +1 -0
  143. package/dist/decorators/CustomColumn.d.ts +6 -0
  144. package/dist/decorators/CustomColumn.d.ts.map +1 -0
  145. package/dist/decorators/CustomColumn.js +13 -0
  146. package/dist/decorators/CustomColumn.js.map +1 -0
  147. package/dist/decorators/DeletedAt.d.ts +3 -0
  148. package/dist/decorators/DeletedAt.d.ts.map +1 -0
  149. package/dist/decorators/DeletedAt.js +16 -0
  150. package/dist/decorators/DeletedAt.js.map +1 -0
  151. package/dist/decorators/Entity.d.ts +16 -0
  152. package/dist/decorators/Entity.d.ts.map +1 -0
  153. package/dist/decorators/Entity.js +32 -0
  154. package/dist/decorators/Entity.js.map +1 -0
  155. package/dist/decorators/Hooks.d.ts +14 -0
  156. package/dist/decorators/Hooks.d.ts.map +1 -0
  157. package/dist/decorators/Hooks.js +36 -0
  158. package/dist/decorators/Hooks.js.map +1 -0
  159. package/dist/decorators/Indexer.d.ts +11 -0
  160. package/dist/decorators/Indexer.d.ts.map +1 -0
  161. package/dist/decorators/Indexer.js +21 -0
  162. package/dist/decorators/Indexer.js.map +1 -0
  163. package/dist/decorators/InjectEntityManager.d.ts +3 -0
  164. package/dist/decorators/InjectEntityManager.d.ts.map +1 -0
  165. package/dist/decorators/InjectEntityManager.js +13 -0
  166. package/dist/decorators/InjectEntityManager.js.map +1 -0
  167. package/dist/decorators/InjectRepository.d.ts +4 -0
  168. package/dist/decorators/InjectRepository.d.ts.map +1 -0
  169. package/dist/decorators/InjectRepository.js +22 -0
  170. package/dist/decorators/InjectRepository.js.map +1 -0
  171. package/dist/decorators/ManyToMany.d.ts +21 -0
  172. package/dist/decorators/ManyToMany.d.ts.map +1 -0
  173. package/dist/decorators/ManyToMany.js +29 -0
  174. package/dist/decorators/ManyToMany.js.map +1 -0
  175. package/dist/decorators/ManyToOne.d.ts +27 -0
  176. package/dist/decorators/ManyToOne.d.ts.map +1 -0
  177. package/dist/decorators/ManyToOne.js +35 -0
  178. package/dist/decorators/ManyToOne.js.map +1 -0
  179. package/dist/decorators/OneToMany.d.ts +17 -0
  180. package/dist/decorators/OneToMany.d.ts.map +1 -0
  181. package/dist/decorators/OneToMany.js +29 -0
  182. package/dist/decorators/OneToMany.js.map +1 -0
  183. package/dist/decorators/OneToOne.d.ts +20 -0
  184. package/dist/decorators/OneToOne.d.ts.map +1 -0
  185. package/dist/decorators/OneToOne.js +30 -0
  186. package/dist/decorators/OneToOne.js.map +1 -0
  187. package/dist/decorators/PrimaryColumn.d.ts +3 -0
  188. package/dist/decorators/PrimaryColumn.d.ts.map +1 -0
  189. package/dist/decorators/PrimaryColumn.js +14 -0
  190. package/dist/decorators/PrimaryColumn.js.map +1 -0
  191. package/dist/decorators/PrimaryGeneratedColumn.d.ts +3 -0
  192. package/dist/decorators/PrimaryGeneratedColumn.d.ts.map +1 -0
  193. package/dist/decorators/PrimaryGeneratedColumn.js +17 -0
  194. package/dist/decorators/PrimaryGeneratedColumn.js.map +1 -0
  195. package/dist/decorators/Transactional.d.ts +15 -0
  196. package/dist/decorators/Transactional.d.ts.map +1 -0
  197. package/dist/decorators/Transactional.js +76 -0
  198. package/dist/decorators/Transactional.js.map +1 -0
  199. package/dist/decorators/UniqueIndex.d.ts +7 -0
  200. package/dist/decorators/UniqueIndex.d.ts.map +1 -0
  201. package/dist/decorators/UniqueIndex.js +12 -0
  202. package/dist/decorators/UniqueIndex.js.map +1 -0
  203. package/dist/decorators/Validation.d.ts +15 -0
  204. package/dist/decorators/Validation.d.ts.map +1 -0
  205. package/dist/decorators/Validation.js +64 -0
  206. package/dist/decorators/Validation.js.map +1 -0
  207. package/dist/decorators/Version.d.ts +3 -0
  208. package/dist/decorators/Version.d.ts.map +1 -0
  209. package/dist/decorators/Version.js +17 -0
  210. package/dist/decorators/Version.js.map +1 -0
  211. package/dist/decorators/index.d.ts +19 -0
  212. package/dist/decorators/index.d.ts.map +1 -0
  213. package/dist/decorators/index.js +35 -0
  214. package/dist/decorators/index.js.map +1 -0
  215. package/dist/dialects/ConnectionLeakDetector.d.ts +19 -0
  216. package/dist/dialects/ConnectionLeakDetector.d.ts.map +1 -0
  217. package/dist/dialects/ConnectionLeakDetector.js +50 -0
  218. package/dist/dialects/ConnectionLeakDetector.js.map +1 -0
  219. package/dist/dialects/EntityNotFound.d.ts +4 -0
  220. package/dist/dialects/EntityNotFound.d.ts.map +1 -0
  221. package/dist/dialects/EntityNotFound.js +10 -0
  222. package/dist/dialects/EntityNotFound.js.map +1 -0
  223. package/dist/dialects/FindOption.d.ts +20 -0
  224. package/dist/dialects/FindOption.d.ts.map +1 -0
  225. package/dist/dialects/FindOption.js +3 -0
  226. package/dist/dialects/FindOption.js.map +1 -0
  227. package/dist/dialects/IConnection.d.ts +7 -0
  228. package/dist/dialects/IConnection.d.ts.map +1 -0
  229. package/dist/dialects/IConnection.js +3 -0
  230. package/dist/dialects/IConnection.js.map +1 -0
  231. package/dist/dialects/IDataSource.d.ts +12 -0
  232. package/dist/dialects/IDataSource.d.ts.map +1 -0
  233. package/dist/dialects/IDataSource.js +3 -0
  234. package/dist/dialects/IDataSource.js.map +1 -0
  235. package/dist/dialects/IOrderBy.d.ts +4 -0
  236. package/dist/dialects/IOrderBy.d.ts.map +1 -0
  237. package/dist/dialects/IOrderBy.js +3 -0
  238. package/dist/dialects/IOrderBy.js.map +1 -0
  239. package/dist/dialects/IQueryEngine.d.ts +15 -0
  240. package/dist/dialects/IQueryEngine.d.ts.map +1 -0
  241. package/dist/dialects/IQueryEngine.js +7 -0
  242. package/dist/dialects/IQueryEngine.js.map +1 -0
  243. package/dist/dialects/ISelectOption.d.ts +7 -0
  244. package/dist/dialects/ISelectOption.d.ts.map +1 -0
  245. package/dist/dialects/ISelectOption.js +3 -0
  246. package/dist/dialects/ISelectOption.js.map +1 -0
  247. package/dist/dialects/ITenantMigrationRunner.d.ts +16 -0
  248. package/dist/dialects/ITenantMigrationRunner.d.ts.map +1 -0
  249. package/dist/dialects/ITenantMigrationRunner.js +3 -0
  250. package/dist/dialects/ITenantMigrationRunner.js.map +1 -0
  251. package/dist/dialects/ITxEngine.d.ts +9 -0
  252. package/dist/dialects/ITxEngine.d.ts.map +1 -0
  253. package/dist/dialects/ITxEngine.js +3 -0
  254. package/dist/dialects/ITxEngine.js.map +1 -0
  255. package/dist/dialects/IsolationLevel.d.ts +2 -0
  256. package/dist/dialects/IsolationLevel.d.ts.map +1 -0
  257. package/dist/dialects/IsolationLevel.js +3 -0
  258. package/dist/dialects/IsolationLevel.js.map +1 -0
  259. package/dist/dialects/ReplicationRouter.d.ts +28 -0
  260. package/dist/dialects/ReplicationRouter.d.ts.map +1 -0
  261. package/dist/dialects/ReplicationRouter.js +64 -0
  262. package/dist/dialects/ReplicationRouter.js.map +1 -0
  263. package/dist/dialects/SqlDriver.d.ts +43 -0
  264. package/dist/dialects/SqlDriver.d.ts.map +1 -0
  265. package/dist/dialects/SqlDriver.js +3 -0
  266. package/dist/dialects/SqlDriver.js.map +1 -0
  267. package/dist/dialects/TransactionSessionManager.d.ts +21 -0
  268. package/dist/dialects/TransactionSessionManager.d.ts.map +1 -0
  269. package/dist/dialects/TransactionSessionManager.js +112 -0
  270. package/dist/dialects/TransactionSessionManager.js.map +1 -0
  271. package/dist/dialects/index.d.ts +32 -0
  272. package/dist/dialects/index.d.ts.map +1 -0
  273. package/dist/dialects/index.js +65 -0
  274. package/dist/dialects/index.js.map +1 -0
  275. package/dist/dialects/mysql/BaseSchema.d.ts +9 -0
  276. package/dist/dialects/mysql/BaseSchema.d.ts.map +1 -0
  277. package/dist/dialects/mysql/BaseSchema.js +3 -0
  278. package/dist/dialects/mysql/BaseSchema.js.map +1 -0
  279. package/dist/dialects/mysql/Connection.d.ts +9 -0
  280. package/dist/dialects/mysql/Connection.d.ts.map +1 -0
  281. package/dist/dialects/mysql/Connection.js +3 -0
  282. package/dist/dialects/mysql/Connection.js.map +1 -0
  283. package/dist/dialects/mysql/ConnectionNotFound.d.ts +4 -0
  284. package/dist/dialects/mysql/ConnectionNotFound.d.ts.map +1 -0
  285. package/dist/dialects/mysql/ConnectionNotFound.js +10 -0
  286. package/dist/dialects/mysql/ConnectionNotFound.js.map +1 -0
  287. package/dist/dialects/mysql/MySqlConnectionError.d.ts +4 -0
  288. package/dist/dialects/mysql/MySqlConnectionError.d.ts.map +1 -0
  289. package/dist/dialects/mysql/MySqlConnectionError.js +10 -0
  290. package/dist/dialects/mysql/MySqlConnectionError.js.map +1 -0
  291. package/dist/dialects/mysql/MySqlConnector.d.ts +26 -0
  292. package/dist/dialects/mysql/MySqlConnector.d.ts.map +1 -0
  293. package/dist/dialects/mysql/MySqlConnector.js +195 -0
  294. package/dist/dialects/mysql/MySqlConnector.js.map +1 -0
  295. package/dist/dialects/mysql/MySqlDataSource.d.ts +17 -0
  296. package/dist/dialects/mysql/MySqlDataSource.d.ts.map +1 -0
  297. package/dist/dialects/mysql/MySqlDataSource.js +63 -0
  298. package/dist/dialects/mysql/MySqlDataSource.js.map +1 -0
  299. package/dist/dialects/mysql/MySqlDriver.d.ts +49 -0
  300. package/dist/dialects/mysql/MySqlDriver.d.ts.map +1 -0
  301. package/dist/dialects/mysql/MySqlDriver.js +260 -0
  302. package/dist/dialects/mysql/MySqlDriver.js.map +1 -0
  303. package/dist/dialects/mysql/MySqlTenantMigrationRunner.d.ts +11 -0
  304. package/dist/dialects/mysql/MySqlTenantMigrationRunner.d.ts.map +1 -0
  305. package/dist/dialects/mysql/MySqlTenantMigrationRunner.js +31 -0
  306. package/dist/dialects/mysql/MySqlTenantMigrationRunner.js.map +1 -0
  307. package/dist/dialects/mysql/MysqlConnection.d.ts +12 -0
  308. package/dist/dialects/mysql/MysqlConnection.d.ts.map +1 -0
  309. package/dist/dialects/mysql/MysqlConnection.js +26 -0
  310. package/dist/dialects/mysql/MysqlConnection.js.map +1 -0
  311. package/dist/dialects/mysql/PoolNotFound.d.ts +4 -0
  312. package/dist/dialects/mysql/PoolNotFound.d.ts.map +1 -0
  313. package/dist/dialects/mysql/PoolNotFound.js +10 -0
  314. package/dist/dialects/mysql/PoolNotFound.js.map +1 -0
  315. package/dist/dialects/mysql/index.d.ts +10 -0
  316. package/dist/dialects/mysql/index.d.ts.map +1 -0
  317. package/dist/dialects/mysql/index.js +26 -0
  318. package/dist/dialects/mysql/index.js.map +1 -0
  319. package/dist/dialects/postgres/ConnectionNotFound.d.ts +4 -0
  320. package/dist/dialects/postgres/ConnectionNotFound.d.ts.map +1 -0
  321. package/dist/dialects/postgres/ConnectionNotFound.js +10 -0
  322. package/dist/dialects/postgres/ConnectionNotFound.js.map +1 -0
  323. package/dist/dialects/postgres/PoolNotFound.d.ts +4 -0
  324. package/dist/dialects/postgres/PoolNotFound.d.ts.map +1 -0
  325. package/dist/dialects/postgres/PoolNotFound.js +10 -0
  326. package/dist/dialects/postgres/PoolNotFound.js.map +1 -0
  327. package/dist/dialects/postgres/PostgresConnection.d.ts +12 -0
  328. package/dist/dialects/postgres/PostgresConnection.d.ts.map +1 -0
  329. package/dist/dialects/postgres/PostgresConnection.js +26 -0
  330. package/dist/dialects/postgres/PostgresConnection.js.map +1 -0
  331. package/dist/dialects/postgres/PostgresConnectionError.d.ts +4 -0
  332. package/dist/dialects/postgres/PostgresConnectionError.d.ts.map +1 -0
  333. package/dist/dialects/postgres/PostgresConnectionError.js +10 -0
  334. package/dist/dialects/postgres/PostgresConnectionError.js.map +1 -0
  335. package/dist/dialects/postgres/PostgresConnector.d.ts +24 -0
  336. package/dist/dialects/postgres/PostgresConnector.d.ts.map +1 -0
  337. package/dist/dialects/postgres/PostgresConnector.js +158 -0
  338. package/dist/dialects/postgres/PostgresConnector.js.map +1 -0
  339. package/dist/dialects/postgres/PostgresDataSource.d.ts +18 -0
  340. package/dist/dialects/postgres/PostgresDataSource.d.ts.map +1 -0
  341. package/dist/dialects/postgres/PostgresDataSource.js +66 -0
  342. package/dist/dialects/postgres/PostgresDataSource.js.map +1 -0
  343. package/dist/dialects/postgres/PostgresDriver.d.ts +71 -0
  344. package/dist/dialects/postgres/PostgresDriver.d.ts.map +1 -0
  345. package/dist/dialects/postgres/PostgresDriver.js +440 -0
  346. package/dist/dialects/postgres/PostgresDriver.js.map +1 -0
  347. package/dist/dialects/postgres/PostgresTenantMigrationRunner.d.ts +18 -0
  348. package/dist/dialects/postgres/PostgresTenantMigrationRunner.d.ts.map +1 -0
  349. package/dist/dialects/postgres/PostgresTenantMigrationRunner.js +78 -0
  350. package/dist/dialects/postgres/PostgresTenantMigrationRunner.js.map +1 -0
  351. package/dist/dialects/postgres/index.d.ts +8 -0
  352. package/dist/dialects/postgres/index.d.ts.map +1 -0
  353. package/dist/dialects/postgres/index.js +26 -0
  354. package/dist/dialects/postgres/index.js.map +1 -0
  355. package/dist/dialects/sqlite/ConnectionNotFound.d.ts +4 -0
  356. package/dist/dialects/sqlite/ConnectionNotFound.d.ts.map +1 -0
  357. package/dist/dialects/sqlite/ConnectionNotFound.js +10 -0
  358. package/dist/dialects/sqlite/ConnectionNotFound.js.map +1 -0
  359. package/dist/dialects/sqlite/SqliteConnection.d.ts +12 -0
  360. package/dist/dialects/sqlite/SqliteConnection.d.ts.map +1 -0
  361. package/dist/dialects/sqlite/SqliteConnection.js +23 -0
  362. package/dist/dialects/sqlite/SqliteConnection.js.map +1 -0
  363. package/dist/dialects/sqlite/SqliteConnectionError.d.ts +4 -0
  364. package/dist/dialects/sqlite/SqliteConnectionError.d.ts.map +1 -0
  365. package/dist/dialects/sqlite/SqliteConnectionError.js +10 -0
  366. package/dist/dialects/sqlite/SqliteConnectionError.js.map +1 -0
  367. package/dist/dialects/sqlite/SqliteConnector.d.ts +24 -0
  368. package/dist/dialects/sqlite/SqliteConnector.d.ts.map +1 -0
  369. package/dist/dialects/sqlite/SqliteConnector.js +119 -0
  370. package/dist/dialects/sqlite/SqliteConnector.js.map +1 -0
  371. package/dist/dialects/sqlite/SqliteDataSource.d.ts +18 -0
  372. package/dist/dialects/sqlite/SqliteDataSource.d.ts.map +1 -0
  373. package/dist/dialects/sqlite/SqliteDataSource.js +56 -0
  374. package/dist/dialects/sqlite/SqliteDataSource.js.map +1 -0
  375. package/dist/dialects/sqlite/SqliteDriver.d.ts +49 -0
  376. package/dist/dialects/sqlite/SqliteDriver.d.ts.map +1 -0
  377. package/dist/dialects/sqlite/SqliteDriver.js +234 -0
  378. package/dist/dialects/sqlite/SqliteDriver.js.map +1 -0
  379. package/dist/dialects/sqlite/SqliteTenantMigrationRunner.d.ts +11 -0
  380. package/dist/dialects/sqlite/SqliteTenantMigrationRunner.d.ts.map +1 -0
  381. package/dist/dialects/sqlite/SqliteTenantMigrationRunner.js +31 -0
  382. package/dist/dialects/sqlite/SqliteTenantMigrationRunner.js.map +1 -0
  383. package/dist/dialects/sqlite/index.d.ts +7 -0
  384. package/dist/dialects/sqlite/index.d.ts.map +1 -0
  385. package/dist/dialects/sqlite/index.js +23 -0
  386. package/dist/dialects/sqlite/index.js.map +1 -0
  387. package/dist/errors/AdvisoryLockError.d.ts +5 -0
  388. package/dist/errors/AdvisoryLockError.d.ts.map +1 -0
  389. package/dist/errors/AdvisoryLockError.js +13 -0
  390. package/dist/errors/AdvisoryLockError.js.map +1 -0
  391. package/dist/errors/DatabaseConnectionFailedError.d.ts +5 -0
  392. package/dist/errors/DatabaseConnectionFailedError.d.ts.map +1 -0
  393. package/dist/errors/DatabaseConnectionFailedError.js +11 -0
  394. package/dist/errors/DatabaseConnectionFailedError.js.map +1 -0
  395. package/dist/errors/DatabaseNotConnectedError.d.ts +5 -0
  396. package/dist/errors/DatabaseNotConnectedError.d.ts.map +1 -0
  397. package/dist/errors/DatabaseNotConnectedError.js +11 -0
  398. package/dist/errors/DatabaseNotConnectedError.js.map +1 -0
  399. package/dist/errors/DeleteWithoutConditionsError.d.ts +5 -0
  400. package/dist/errors/DeleteWithoutConditionsError.d.ts.map +1 -0
  401. package/dist/errors/DeleteWithoutConditionsError.js +13 -0
  402. package/dist/errors/DeleteWithoutConditionsError.js.map +1 -0
  403. package/dist/errors/EntityMetadataNotFoundError.d.ts +5 -0
  404. package/dist/errors/EntityMetadataNotFoundError.d.ts.map +1 -0
  405. package/dist/errors/EntityMetadataNotFoundError.js +13 -0
  406. package/dist/errors/EntityMetadataNotFoundError.js.map +1 -0
  407. package/dist/errors/EntityNotFoundError.d.ts +5 -0
  408. package/dist/errors/EntityNotFoundError.d.ts.map +1 -0
  409. package/dist/errors/EntityNotFoundError.js +13 -0
  410. package/dist/errors/EntityNotFoundError.js.map +1 -0
  411. package/dist/errors/Exception.d.ts +5 -0
  412. package/dist/errors/Exception.d.ts.map +1 -0
  413. package/dist/errors/Exception.js +11 -0
  414. package/dist/errors/Exception.js.map +1 -0
  415. package/dist/errors/InvalidQueryError.d.ts +5 -0
  416. package/dist/errors/InvalidQueryError.d.ts.map +1 -0
  417. package/dist/errors/InvalidQueryError.js +13 -0
  418. package/dist/errors/InvalidQueryError.js.map +1 -0
  419. package/dist/errors/NotSupportedDatabaseTypeError.d.ts +5 -0
  420. package/dist/errors/NotSupportedDatabaseTypeError.d.ts.map +1 -0
  421. package/dist/errors/NotSupportedDatabaseTypeError.js +11 -0
  422. package/dist/errors/NotSupportedDatabaseTypeError.js.map +1 -0
  423. package/dist/errors/OrmError.d.ts +6 -0
  424. package/dist/errors/OrmError.d.ts.map +1 -0
  425. package/dist/errors/OrmError.js +12 -0
  426. package/dist/errors/OrmError.js.map +1 -0
  427. package/dist/errors/OrmErrorCode.d.ts +16 -0
  428. package/dist/errors/OrmErrorCode.d.ts.map +1 -0
  429. package/dist/errors/OrmErrorCode.js +20 -0
  430. package/dist/errors/OrmErrorCode.js.map +1 -0
  431. package/dist/errors/PrimaryKeyNotFoundError.d.ts +5 -0
  432. package/dist/errors/PrimaryKeyNotFoundError.d.ts.map +1 -0
  433. package/dist/errors/PrimaryKeyNotFoundError.js +13 -0
  434. package/dist/errors/PrimaryKeyNotFoundError.js.map +1 -0
  435. package/dist/errors/QueryTimeoutError.d.ts +5 -0
  436. package/dist/errors/QueryTimeoutError.d.ts.map +1 -0
  437. package/dist/errors/QueryTimeoutError.js +13 -0
  438. package/dist/errors/QueryTimeoutError.js.map +1 -0
  439. package/dist/errors/TransactionError.d.ts +5 -0
  440. package/dist/errors/TransactionError.d.ts.map +1 -0
  441. package/dist/errors/TransactionError.js +13 -0
  442. package/dist/errors/TransactionError.js.map +1 -0
  443. package/dist/errors/ValidationError.d.ts +6 -0
  444. package/dist/errors/ValidationError.d.ts.map +1 -0
  445. package/dist/errors/ValidationError.js +13 -0
  446. package/dist/errors/ValidationError.js.map +1 -0
  447. package/dist/errors/index.d.ts +16 -0
  448. package/dist/errors/index.d.ts.map +1 -0
  449. package/dist/errors/index.js +32 -0
  450. package/dist/errors/index.js.map +1 -0
  451. package/dist/index.d.ts +14 -0
  452. package/dist/index.d.ts.map +1 -0
  453. package/dist/index.js +34 -0
  454. package/dist/index.js.map +1 -0
  455. package/dist/metadata/LayeredMetadataScanner.d.ts +32 -0
  456. package/dist/metadata/LayeredMetadataScanner.d.ts.map +1 -0
  457. package/dist/metadata/LayeredMetadataScanner.js +119 -0
  458. package/dist/metadata/LayeredMetadataScanner.js.map +1 -0
  459. package/dist/metadata/LayeredMetadataStore.d.ts +30 -0
  460. package/dist/metadata/LayeredMetadataStore.d.ts.map +1 -0
  461. package/dist/metadata/LayeredMetadataStore.js +150 -0
  462. package/dist/metadata/LayeredMetadataStore.js.map +1 -0
  463. package/dist/metadata/MetadataContext.d.ts +11 -0
  464. package/dist/metadata/MetadataContext.d.ts.map +1 -0
  465. package/dist/metadata/MetadataContext.js +23 -0
  466. package/dist/metadata/MetadataContext.js.map +1 -0
  467. package/dist/metadata/MetadataLayer.d.ts +27 -0
  468. package/dist/metadata/MetadataLayer.d.ts.map +1 -0
  469. package/dist/metadata/MetadataLayer.js +78 -0
  470. package/dist/metadata/MetadataLayer.js.map +1 -0
  471. package/dist/metadata/MetadataPath.d.ts +24 -0
  472. package/dist/metadata/MetadataPath.d.ts.map +1 -0
  473. package/dist/metadata/MetadataPath.js +104 -0
  474. package/dist/metadata/MetadataPath.js.map +1 -0
  475. package/dist/metadata/MultiTenantMetadataManager.d.ts +27 -0
  476. package/dist/metadata/MultiTenantMetadataManager.d.ts.map +1 -0
  477. package/dist/metadata/MultiTenantMetadataManager.js +69 -0
  478. package/dist/metadata/MultiTenantMetadataManager.js.map +1 -0
  479. package/dist/metadata/index.d.ts +7 -0
  480. package/dist/metadata/index.d.ts.map +1 -0
  481. package/dist/metadata/index.js +23 -0
  482. package/dist/metadata/index.js.map +1 -0
  483. package/dist/migration/Migration.d.ts +11 -0
  484. package/dist/migration/Migration.d.ts.map +1 -0
  485. package/dist/migration/Migration.js +10 -0
  486. package/dist/migration/Migration.js.map +1 -0
  487. package/dist/migration/MigrationCli.d.ts +25 -0
  488. package/dist/migration/MigrationCli.d.ts.map +1 -0
  489. package/dist/migration/MigrationCli.js +108 -0
  490. package/dist/migration/MigrationCli.js.map +1 -0
  491. package/dist/migration/MigrationRunner.d.ts +47 -0
  492. package/dist/migration/MigrationRunner.d.ts.map +1 -0
  493. package/dist/migration/MigrationRunner.js +182 -0
  494. package/dist/migration/MigrationRunner.js.map +1 -0
  495. package/dist/migration/index.d.ts +4 -0
  496. package/dist/migration/index.d.ts.map +1 -0
  497. package/dist/migration/index.js +20 -0
  498. package/dist/migration/index.js.map +1 -0
  499. package/dist/scanner/ColumnScanner.d.ts +16 -0
  500. package/dist/scanner/ColumnScanner.d.ts.map +1 -0
  501. package/dist/scanner/ColumnScanner.js +30 -0
  502. package/dist/scanner/ColumnScanner.js.map +1 -0
  503. package/dist/scanner/EntityScanner.d.ts +14 -0
  504. package/dist/scanner/EntityScanner.d.ts.map +1 -0
  505. package/dist/scanner/EntityScanner.js +38 -0
  506. package/dist/scanner/EntityScanner.js.map +1 -0
  507. package/dist/scanner/ManyToManyScanner.d.ts +9 -0
  508. package/dist/scanner/ManyToManyScanner.d.ts.map +1 -0
  509. package/dist/scanner/ManyToManyScanner.js +39 -0
  510. package/dist/scanner/ManyToManyScanner.js.map +1 -0
  511. package/dist/scanner/ManyToOneScanner.d.ts +9 -0
  512. package/dist/scanner/ManyToOneScanner.d.ts.map +1 -0
  513. package/dist/scanner/ManyToOneScanner.js +38 -0
  514. package/dist/scanner/ManyToOneScanner.js.map +1 -0
  515. package/dist/scanner/MetadataScanner.d.ts +45 -0
  516. package/dist/scanner/MetadataScanner.d.ts.map +1 -0
  517. package/dist/scanner/MetadataScanner.js +200 -0
  518. package/dist/scanner/MetadataScanner.js.map +1 -0
  519. package/dist/scanner/OneToManyScanner.d.ts +9 -0
  520. package/dist/scanner/OneToManyScanner.d.ts.map +1 -0
  521. package/dist/scanner/OneToManyScanner.js +39 -0
  522. package/dist/scanner/OneToManyScanner.js.map +1 -0
  523. package/dist/scanner/OneToOneScanner.d.ts +9 -0
  524. package/dist/scanner/OneToOneScanner.d.ts.map +1 -0
  525. package/dist/scanner/OneToOneScanner.js +39 -0
  526. package/dist/scanner/OneToOneScanner.js.map +1 -0
  527. package/dist/scanner/index.d.ts +9 -0
  528. package/dist/scanner/index.d.ts.map +1 -0
  529. package/dist/scanner/index.js +27 -0
  530. package/dist/scanner/index.js.map +1 -0
  531. package/dist/types/CascadeType.d.ts +5 -0
  532. package/dist/types/CascadeType.d.ts.map +1 -0
  533. package/dist/types/CascadeType.js +19 -0
  534. package/dist/types/CascadeType.js.map +1 -0
  535. package/dist/types/ColumnPaths.d.ts +7 -0
  536. package/dist/types/ColumnPaths.d.ts.map +1 -0
  537. package/dist/types/ColumnPaths.js +3 -0
  538. package/dist/types/ColumnPaths.js.map +1 -0
  539. package/dist/types/DeepPartial.d.ts +4 -0
  540. package/dist/types/DeepPartial.d.ts.map +1 -0
  541. package/dist/types/DeepPartial.js +3 -0
  542. package/dist/types/DeepPartial.js.map +1 -0
  543. package/dist/types/DeleteResult.d.ts +4 -0
  544. package/dist/types/DeleteResult.d.ts.map +1 -0
  545. package/dist/types/DeleteResult.js +3 -0
  546. package/dist/types/DeleteResult.js.map +1 -0
  547. package/dist/types/EntityResult.d.ts +3 -0
  548. package/dist/types/EntityResult.d.ts.map +1 -0
  549. package/dist/types/EntityResult.js +3 -0
  550. package/dist/types/EntityResult.js.map +1 -0
  551. package/dist/types/FindCondition.d.ts +16 -0
  552. package/dist/types/FindCondition.d.ts.map +1 -0
  553. package/dist/types/FindCondition.js +3 -0
  554. package/dist/types/FindCondition.js.map +1 -0
  555. package/dist/types/OrderByOption.d.ts +5 -0
  556. package/dist/types/OrderByOption.d.ts.map +1 -0
  557. package/dist/types/OrderByOption.js +3 -0
  558. package/dist/types/OrderByOption.js.map +1 -0
  559. package/dist/types/QueryResult.d.ts +5 -0
  560. package/dist/types/QueryResult.d.ts.map +1 -0
  561. package/dist/types/QueryResult.js +3 -0
  562. package/dist/types/QueryResult.js.map +1 -0
  563. package/dist/types/SchemaOption.d.ts +3 -0
  564. package/dist/types/SchemaOption.d.ts.map +1 -0
  565. package/dist/types/SchemaOption.js +3 -0
  566. package/dist/types/SchemaOption.js.map +1 -0
  567. package/dist/types/index.d.ts +9 -0
  568. package/dist/types/index.d.ts.map +1 -0
  569. package/dist/types/index.js +25 -0
  570. package/dist/types/index.js.map +1 -0
  571. package/dist/utils/Logger.d.ts +15 -0
  572. package/dist/utils/Logger.d.ts.map +1 -0
  573. package/dist/utils/Logger.js +75 -0
  574. package/dist/utils/Logger.js.map +1 -0
  575. package/dist/utils/ReflectManager.d.ts +12 -0
  576. package/dist/utils/ReflectManager.d.ts.map +1 -0
  577. package/dist/utils/ReflectManager.js +34 -0
  578. package/dist/utils/ReflectManager.js.map +1 -0
  579. package/dist/utils/camelToSnakeCase.d.ts +2 -0
  580. package/dist/utils/camelToSnakeCase.d.ts.map +1 -0
  581. package/dist/utils/camelToSnakeCase.js +7 -0
  582. package/dist/utils/camelToSnakeCase.js.map +1 -0
  583. package/dist/utils/index.d.ts +6 -0
  584. package/dist/utils/index.d.ts.map +1 -0
  585. package/dist/utils/index.js +22 -0
  586. package/dist/utils/index.js.map +1 -0
  587. package/dist/utils/scanner.d.ts +2 -0
  588. package/dist/utils/scanner.d.ts.map +1 -0
  589. package/dist/utils/scanner.js +8 -0
  590. package/dist/utils/scanner.js.map +1 -0
  591. package/dist/utils/types.d.ts +5 -0
  592. package/dist/utils/types.d.ts.map +1 -0
  593. package/dist/utils/types.js +3 -0
  594. package/dist/utils/types.js.map +1 -0
  595. package/package.json +87 -0
@@ -0,0 +1,71 @@
1
+ import { IConnector } from "../../core/IConnector";
2
+ import { MysqlSchemaInterface } from "../mysql/BaseSchema";
3
+ import { ColumnType } from "../../decorators";
4
+ import { ISqlDriver } from "../SqlDriver";
5
+ import { SchemaOptions } from "../../types/SchemaOption";
6
+ export declare class PostgresDriver implements ISqlDriver {
7
+ private readonly connector;
8
+ private readonly clientType;
9
+ private readonly schema;
10
+ constructor(connector: IConnector, clientType?: string, schema?: string);
11
+ getSchema(): string;
12
+ hasSchema(schemaName?: string): Promise<any>;
13
+ createSchema(schemaName?: string): Promise<any>;
14
+ dropSchema(schemaName: string, cascade?: boolean): Promise<any>;
15
+ listSchemas(): Promise<any>;
16
+ setSearchPath(schemaName?: string): Promise<any>;
17
+ listTables(schemaName?: string): Promise<any>;
18
+ moveTableToSchema(tableName: string, targetSchema: string): Promise<any>;
19
+ hasTable(name: string): Promise<any>;
20
+ executeRaw(sqlStr: string): Promise<any>;
21
+ addPrimaryKey(tableName: string, columnName: string): Promise<any>;
22
+ addAutoIncrement(tableName: string, columnName: string): Promise<any>;
23
+ dropPrimaryKey(tableName: string): Promise<any>;
24
+ addUniqueKey(tableName: string, columnName: string): Promise<any>;
25
+ dropUniqueKey(tableName: string, columnName: string): Promise<any>;
26
+ addColumn(tableName: string, columnName: string, columnType: string): Promise<any>;
27
+ dropColumn(tableName: string, columnName: string): Promise<any>;
28
+ addForeignKey(tableName: string, columnName: string, foreignTableName: string, foreignColumnName: string): Promise<any>;
29
+ generateForeignKeyName(sourceTable: string, targetTable: string, sourceColumn: string): string;
30
+ dropForeignKey(tableName: string, columnName: string): Promise<any>;
31
+ addIndex(tableName: string, columnName: string, indexName: string): Promise<any>;
32
+ hasIndex(tableName: string, indexName: string): Promise<any>;
33
+ dropIndex(tableName: string, indexName: string): Promise<any>;
34
+ hasEnumType(enumName: string): Promise<any>;
35
+ createEnumType(enumName: string, values: string[]): Promise<any>;
36
+ dropEnumType(enumName: string, cascade?: boolean): Promise<any>;
37
+ addEnumValue(enumName: string, value: string, placement?: {
38
+ before?: string;
39
+ after?: string;
40
+ }): Promise<any>;
41
+ renameEnumValue(enumName: string, oldValue: string, newValue: string): Promise<any>;
42
+ listEnumValues(enumName: string): Promise<{
43
+ enumlabel: string;
44
+ }[]>;
45
+ getSchemas(tableName: string): Promise<MysqlSchemaInterface[]>;
46
+ getIndexes(tableName: string): Promise<MysqlSchemaInterface[]>;
47
+ getForeignKeys(tableName: string): Promise<MysqlSchemaInterface[]>;
48
+ getPrimaryKeys(tableName: string): Promise<MysqlSchemaInterface[]>;
49
+ createTable(tableName: string, columns: SchemaOptions[]): Promise<any>;
50
+ wrap(name: string): string;
51
+ wrapQualified(name: string): string;
52
+ getColumnType(type: any): string;
53
+ castType(type: ColumnType): string;
54
+ isMySqlFamily(): boolean;
55
+ setQueryTimeout(ms: number): string;
56
+ supportsExplain(): boolean;
57
+ buildExplainSql(selectSql: string): string;
58
+ buildUpsertSql(tableName: string, columns: string[], conflictColumns: string[], updateColumns: string[]): string;
59
+ hasColumn(tableName: string, columnName: string): Promise<boolean>;
60
+ hasForeignKey(tableName: string, constraintName: string): Promise<boolean>;
61
+ addCompositeUniqueIndex(tableName: string, columns: string[], indexName: string): Promise<any>;
62
+ acquireAdvisoryLock(lockId: string, timeoutMs?: number): Promise<boolean>;
63
+ releaseAdvisoryLock(lockId: string): Promise<void>;
64
+ private hashLockId;
65
+ createSavepointSql(name: string): string;
66
+ rollbackToSavepointSql(name: string): string;
67
+ releaseSavepointSql(name: string): string;
68
+ clear(tableName: string): Promise<any>;
69
+ getForUpdateNoWait(): string;
70
+ }
71
+ //# sourceMappingURL=PostgresDriver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PostgresDriver.d.ts","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresDriver.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAgB,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAWzD,qBAAa,cAAe,YAAW,UAAU;IAI7C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAJ7B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;gBAGb,SAAS,EAAE,UAAU,EACrB,UAAU,GAAE,MAAmB,EAChD,MAAM,CAAC,EAAE,MAAM;IAYjB,SAAS,IAAI,MAAM;IAUnB,SAAS,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAa5C,YAAY,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAc/C,UAAU,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,GAAE,OAAe,GAAG,OAAO,CAAC,GAAG,CAAC;IAWtE,WAAW,IAAI,OAAO,CAAC,GAAG,CAAC;IAc3B,aAAa,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAUhD,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAa7C,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IASxE,QAAQ,CAAC,IAAI,EAAE,MAAM;IAMrB,UAAU,CAAC,MAAM,EAAE,MAAM;IAOzB,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAUnD,gBAAgB,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAYhD,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IA2BrD,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAY5C,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IA8BxE,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IASnE,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAShD,aAAa,CACX,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,MAAM,EAClB,gBAAgB,EAAE,MAAM,EACxB,iBAAiB,EAAE,MAAM;IAiB3B,sBAAsB,CACpB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,GACnB,MAAM;IAUH,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IA8BzE,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IASjE,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAS7C,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAgB9C,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC;IAuBrC,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC;IAqBtE,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,GAAE,OAAe,GAAG,OAAO,CAAC,GAAG,CAAC;IAyBtE,YAAY,CACV,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,EACb,SAAS,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAC9C,OAAO,CAAC,GAAG,CAAC;IAuBf,eAAe,CACb,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,GACf,OAAO,CAAC,GAAG,CAAC;IAYf,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAclE,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,EAAE,CAAC;IA8B9D,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAU9D,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAoBlE,cAAc,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,oBAAoB,EAAE,CAAC;IAelE,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE;IAwEvD,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAS1B,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAOnC,aAAa,CAAC,IAAI,EAAE,GAAG,GAAG,MAAM;IA2ChC,QAAQ,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM;IA4C3B,aAAa;IAIpB,eAAe,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM;IAInC,eAAe,IAAI,OAAO;IAI1B,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM;IAI1C,cAAc,CACZ,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EAAE,EACjB,eAAe,EAAE,MAAM,EAAE,EACzB,aAAa,EAAE,MAAM,EAAE,GACtB,MAAM;IAaH,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAOlE,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAOhF,uBAAuB,CACrB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,MAAM,EAAE,EACjB,SAAS,EAAE,MAAM;IAQb,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,GAAE,MAAU,GAAG,OAAO,CAAC,OAAO,CAAC;IAwC5E,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAOxD,OAAO,CAAC,UAAU;IASlB,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAIxC,sBAAsB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAI5C,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IASzC,KAAK,CAAC,SAAS,EAAE,MAAM;IAWvB,kBAAkB,IAAI,MAAM;CAG7B"}
@@ -0,0 +1,440 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.PostgresDriver = void 0;
37
+ const sql_template_tag_1 = __importStar(require("sql-template-tag"));
38
+ const errors_1 = require("../../errors");
39
+ const SchemaGenerator_1 = require("../../core/generators/SchemaGenerator");
40
+ class PostgresDriver {
41
+ constructor(connector, clientType = "postgres", schema) {
42
+ this.connector = connector;
43
+ this.clientType = clientType;
44
+ this.schema = schema ?? "public";
45
+ }
46
+ getSchema() {
47
+ return this.schema;
48
+ }
49
+ hasSchema(schemaName) {
50
+ const name = schemaName ?? this.schema;
51
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT schema_name FROM information_schema.schemata WHERE schema_name = ${name}`);
52
+ }
53
+ createSchema(schemaName) {
54
+ const name = schemaName ?? this.schema;
55
+ return this.connector.query(`CREATE SCHEMA IF NOT EXISTS ${this.wrap(name)}`);
56
+ }
57
+ dropSchema(schemaName, cascade = false) {
58
+ const suffix = cascade ? " CASCADE" : "";
59
+ return this.connector.query(`DROP SCHEMA IF EXISTS ${this.wrap(schemaName)}${suffix}`);
60
+ }
61
+ listSchemas() {
62
+ return this.connector.query(`SELECT schema_name FROM information_schema.schemata
63
+ WHERE schema_name NOT LIKE 'pg_%'
64
+ AND schema_name != 'information_schema'
65
+ ORDER BY schema_name`);
66
+ }
67
+ setSearchPath(schemaName) {
68
+ const name = schemaName ?? this.schema;
69
+ return this.connector.query(`SET search_path TO ${this.wrap(name)}`);
70
+ }
71
+ listTables(schemaName) {
72
+ const name = schemaName ?? this.schema;
73
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT tablename FROM pg_tables WHERE schemaname = ${name} ORDER BY tablename`);
74
+ }
75
+ moveTableToSchema(tableName, targetSchema) {
76
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} SET SCHEMA ${this.wrap(targetSchema)}`);
77
+ }
78
+ hasTable(name) {
79
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT tablename FROM pg_tables WHERE schemaname = ${this.schema} AND tablename = ${name}`);
80
+ }
81
+ executeRaw(sqlStr) {
82
+ return this.connector.query(sqlStr);
83
+ }
84
+ addPrimaryKey(tableName, columnName) {
85
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD PRIMARY KEY (${this.wrap(columnName)})`);
86
+ }
87
+ addAutoIncrement(tableName, columnName) {
88
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ALTER COLUMN ${this.wrap(columnName)} ADD GENERATED ALWAYS AS IDENTITY`);
89
+ }
90
+ async dropPrimaryKey(tableName) {
91
+ const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
92
+ FROM pg_constraint c
93
+ JOIN pg_class t ON c.conrelid = t.oid
94
+ JOIN pg_namespace n ON t.relnamespace = n.oid
95
+ WHERE c.contype = 'p'
96
+ AND t.relname = ${tableName}
97
+ AND n.nspname = ${this.schema}`);
98
+ if (!rows || rows.length === 0) {
99
+ throw new errors_1.Exception(`테이블 "${tableName}"에서 PRIMARY KEY 제약조건을 찾을 수 없습니다.`, 404);
100
+ }
101
+ const constraintName = rows[0].conname;
102
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
103
+ }
104
+ addUniqueKey(tableName, columnName) {
105
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD UNIQUE (${this.wrap(columnName)})`);
106
+ }
107
+ async dropUniqueKey(tableName, columnName) {
108
+ const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
109
+ FROM pg_constraint c
110
+ JOIN pg_class t ON c.conrelid = t.oid
111
+ JOIN pg_namespace n ON t.relnamespace = n.oid
112
+ JOIN pg_attribute a ON a.attrelid = t.oid
113
+ AND a.attnum = ANY(c.conkey)
114
+ WHERE c.contype = 'u'
115
+ AND t.relname = ${tableName}
116
+ AND n.nspname = ${this.schema}
117
+ AND a.attname = ${columnName}`);
118
+ if (!rows || rows.length === 0) {
119
+ throw new errors_1.Exception(`테이블 "${tableName}"의 컬럼 "${columnName}"에 대한 UNIQUE 제약조건을 찾을 수 없습니다.`, 404);
120
+ }
121
+ const constraintName = rows[0].conname;
122
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
123
+ }
124
+ addColumn(tableName, columnName, columnType) {
125
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD COLUMN ${this.wrap(columnName)} ${columnType}`);
126
+ }
127
+ dropColumn(tableName, columnName) {
128
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP COLUMN ${this.wrap(columnName)}`);
129
+ }
130
+ addForeignKey(tableName, columnName, foreignTableName, foreignColumnName) {
131
+ const foreignKeyName = this.generateForeignKeyName(tableName, foreignTableName, columnName);
132
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD CONSTRAINT ${foreignKeyName} FOREIGN KEY (${this.wrap(columnName)}) REFERENCES ${this.wrapQualified(foreignTableName)}(${this.wrap(foreignColumnName)}) ON DELETE NO ACTION ON UPDATE NO ACTION`);
133
+ }
134
+ generateForeignKeyName(sourceTable, targetTable, sourceColumn) {
135
+ return SchemaGenerator_1.SchemaGenerator.generateForeignKeyName(sourceTable, sourceColumn, targetTable);
136
+ }
137
+ async dropForeignKey(tableName, columnName) {
138
+ const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
139
+ FROM pg_constraint c
140
+ JOIN pg_class t ON c.conrelid = t.oid
141
+ JOIN pg_namespace n ON t.relnamespace = n.oid
142
+ JOIN pg_attribute a ON a.attrelid = t.oid
143
+ AND a.attnum = ANY(c.conkey)
144
+ WHERE c.contype = 'f'
145
+ AND t.relname = ${tableName}
146
+ AND n.nspname = ${this.schema}
147
+ AND a.attname = ${columnName}`);
148
+ if (!rows || rows.length === 0) {
149
+ throw new errors_1.Exception(`테이블 "${tableName}"의 컬럼 "${columnName}"에 대한 FOREIGN KEY 제약조건을 찾을 수 없습니다.`, 404);
150
+ }
151
+ const constraintName = rows[0].conname;
152
+ return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
153
+ }
154
+ addIndex(tableName, columnName, indexName) {
155
+ return this.connector.query(`CREATE INDEX ${this.wrap(indexName)} ON ${this.wrapQualified(tableName)} (${this.wrap(columnName)})`);
156
+ }
157
+ hasIndex(tableName, indexName) {
158
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT COUNT(*) as count FROM pg_indexes WHERE tablename = ${tableName} AND indexname = ${indexName}`);
159
+ }
160
+ dropIndex(tableName, indexName) {
161
+ return this.connector.query(`DROP INDEX IF EXISTS ${this.wrapQualified(indexName)}`);
162
+ }
163
+ hasEnumType(enumName) {
164
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT pg_type.typname
165
+ FROM pg_type
166
+ JOIN pg_namespace ON pg_type.typnamespace = pg_namespace.oid
167
+ WHERE pg_type.typname = ${enumName}
168
+ AND pg_type.typtype = 'e'
169
+ AND pg_namespace.nspname = ${this.schema}`);
170
+ }
171
+ async createEnumType(enumName, values) {
172
+ const rows = await this.hasEnumType(enumName);
173
+ if (rows && rows.length > 0) {
174
+ return;
175
+ }
176
+ const escapedValues = values
177
+ .map((v) => `'${v.replace(/'/g, "''")}'`)
178
+ .join(", ");
179
+ return this.connector.query(`CREATE TYPE ${this.wrapQualified(enumName)} AS ENUM (${escapedValues})`);
180
+ }
181
+ dropEnumType(enumName, cascade = false) {
182
+ const suffix = cascade ? " CASCADE" : "";
183
+ return this.connector.query(`DROP TYPE IF EXISTS ${this.wrapQualified(enumName)}${suffix}`);
184
+ }
185
+ addEnumValue(enumName, value, placement) {
186
+ const escaped = `'${value.replace(/'/g, "''")}'`;
187
+ let suffix = "";
188
+ if (placement?.before) {
189
+ suffix = ` BEFORE '${placement.before.replace(/'/g, "''")}'`;
190
+ }
191
+ else if (placement?.after) {
192
+ suffix = ` AFTER '${placement.after.replace(/'/g, "''")}'`;
193
+ }
194
+ return this.connector.query(`ALTER TYPE ${this.wrapQualified(enumName)} ADD VALUE IF NOT EXISTS ${escaped}${suffix}`);
195
+ }
196
+ renameEnumValue(enumName, oldValue, newValue) {
197
+ return this.connector.query(`ALTER TYPE ${this.wrapQualified(enumName)} RENAME VALUE '${oldValue.replace(/'/g, "''")}' TO '${newValue.replace(/'/g, "''")}'`);
198
+ }
199
+ listEnumValues(enumName) {
200
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT e.enumlabel
201
+ FROM pg_enum e
202
+ JOIN pg_type t ON t.oid = e.enumtypid
203
+ WHERE t.typname = ${enumName}
204
+ ORDER BY e.enumsortorder`);
205
+ }
206
+ getSchemas(tableName) {
207
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT
208
+ column_name AS "Field",
209
+ data_type AS "Type",
210
+ is_nullable AS "Null",
211
+ CASE
212
+ WHEN column_name IN (
213
+ SELECT kcu.column_name
214
+ FROM information_schema.table_constraints tc
215
+ JOIN information_schema.key_column_usage kcu
216
+ ON tc.constraint_name = kcu.constraint_name
217
+ WHERE tc.table_name = ${tableName} AND tc.constraint_type = 'PRIMARY KEY'
218
+ ) THEN 'PRI'
219
+ ELSE ''
220
+ END AS "Key",
221
+ column_default AS "Default",
222
+ CASE
223
+ WHEN column_default LIKE 'nextval%' THEN 'auto_increment'
224
+ ELSE ''
225
+ END AS "Extra"
226
+ FROM information_schema.columns
227
+ WHERE table_schema = ${this.schema} AND table_name = ${tableName}
228
+ ORDER BY ordinal_position`);
229
+ }
230
+ getIndexes(tableName) {
231
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT indexname AS "Field", indexdef AS "Type", '' AS "Null", 'MUL' AS "Key", NULL AS "Default", '' AS "Extra"
232
+ FROM pg_indexes WHERE schemaname = ${this.schema} AND tablename = ${tableName}`);
233
+ }
234
+ getForeignKeys(tableName) {
235
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT
236
+ kcu.column_name AS "COLUMN_NAME",
237
+ ccu.table_name AS "REFERENCED_TABLE_NAME",
238
+ ccu.column_name AS "REFERENCED_COLUMN_NAME"
239
+ FROM information_schema.table_constraints tc
240
+ JOIN information_schema.key_column_usage kcu
241
+ ON tc.constraint_name = kcu.constraint_name
242
+ JOIN information_schema.constraint_column_usage ccu
243
+ ON ccu.constraint_name = tc.constraint_name
244
+ WHERE tc.constraint_type = 'FOREIGN KEY'
245
+ AND tc.table_schema = ${this.schema}
246
+ AND tc.table_name = ${tableName}`);
247
+ }
248
+ getPrimaryKeys(tableName) {
249
+ return this.connector.query((0, sql_template_tag_1.default) `SELECT kcu.column_name AS "COLUMN_NAME"
250
+ FROM information_schema.table_constraints tc
251
+ JOIN information_schema.key_column_usage kcu
252
+ ON tc.constraint_name = kcu.constraint_name
253
+ WHERE tc.constraint_type = 'PRIMARY KEY'
254
+ AND tc.table_schema = ${this.schema}
255
+ AND tc.table_name = ${tableName}`);
256
+ }
257
+ createTable(tableName, columns) {
258
+ const columnsMap = columns.map((column) => {
259
+ const option = (column.options ?? {
260
+ type: "varchar",
261
+ length: 255,
262
+ nullable: false,
263
+ });
264
+ let type = this.castType(option.type ?? "varchar");
265
+ if (option.type === "boolean") {
266
+ type = "BOOLEAN";
267
+ }
268
+ if (option.type === "enum") {
269
+ const resolvedEnumName = option.enumName ?? `${tableName}_${column.name}_enum`;
270
+ type = this.wrapQualified(resolvedEnumName);
271
+ }
272
+ if (type.startsWith("NUMERIC")) {
273
+ if (option.precision !== undefined && option.precision > 1000) {
274
+ throw new errors_1.Exception("PostgreSQL에서 지원하는 NUMERIC 타입의 precision은 1000 이하입니다.", 400);
275
+ }
276
+ type = type.replace("$precision", option.precision?.toString() || "10");
277
+ type = type.replace("$scale", option.scale?.toString() || "2");
278
+ }
279
+ const nullable = option.nullable ?? false;
280
+ if (option.autoIncrement) {
281
+ return (0, sql_template_tag_1.raw)(`${this.wrap(column.name)} SERIAL ${nullable ? "NULL" : "NOT NULL"} ${option.primary ? "PRIMARY KEY" : ""}`);
282
+ }
283
+ const needsLength = ["VARCHAR", "CHAR"].some((t) => type.toUpperCase().startsWith(t));
284
+ const typeWithLength = needsLength && option.length ? `${type}(${option.length})` : type;
285
+ return (0, sql_template_tag_1.raw)(`${this.wrap(column.name)} ${typeWithLength} ${nullable ? "NULL" : "NOT NULL"} ${option.primary ? "PRIMARY KEY" : ""}`);
286
+ });
287
+ const result = (0, sql_template_tag_1.default) `CREATE TABLE IF NOT EXISTS ${(0, sql_template_tag_1.raw)(this.wrapQualified(tableName))} (${(0, sql_template_tag_1.join)(columnsMap, ",")})`;
288
+ return this.connector.query(result);
289
+ }
290
+ wrap(name) {
291
+ return `"${name.replace(/"/g, '""')}"`;
292
+ }
293
+ wrapQualified(name) {
294
+ return `${this.wrap(this.schema)}.${this.wrap(name)}`;
295
+ }
296
+ getColumnType(type) {
297
+ switch (type) {
298
+ case String:
299
+ return "VARCHAR";
300
+ case Number:
301
+ return "INTEGER";
302
+ case Boolean:
303
+ return "BOOLEAN";
304
+ case Date:
305
+ return "TIMESTAMP";
306
+ case Buffer:
307
+ return "BYTEA";
308
+ default:
309
+ return "TEXT";
310
+ }
311
+ }
312
+ castType(type) {
313
+ switch (type) {
314
+ case "varchar":
315
+ return "VARCHAR";
316
+ case "int":
317
+ case "number":
318
+ return "INTEGER";
319
+ case "boolean":
320
+ return "BOOLEAN";
321
+ case "datetime":
322
+ return "TIMESTAMP";
323
+ case "date":
324
+ return "DATE";
325
+ case "timestamp":
326
+ return "TIMESTAMP";
327
+ case "float":
328
+ return "REAL";
329
+ case "double":
330
+ return "NUMERIC($precision, $scale)";
331
+ case "blob":
332
+ return "BYTEA";
333
+ case "text":
334
+ case "longtext":
335
+ return "TEXT";
336
+ case "bigint":
337
+ return "BIGINT";
338
+ case "json":
339
+ return "JSON";
340
+ case "jsonb":
341
+ return "JSONB";
342
+ case "char":
343
+ return "CHAR";
344
+ case "enum":
345
+ return "TEXT";
346
+ case "array":
347
+ return "ARRAY";
348
+ default:
349
+ return type;
350
+ }
351
+ }
352
+ isMySqlFamily() {
353
+ return false;
354
+ }
355
+ setQueryTimeout(ms) {
356
+ return `SET LOCAL statement_timeout = '${Math.max(0, Math.floor(ms))}ms'`;
357
+ }
358
+ supportsExplain() {
359
+ return true;
360
+ }
361
+ buildExplainSql(selectSql) {
362
+ return `EXPLAIN (FORMAT JSON) ${selectSql}`;
363
+ }
364
+ buildUpsertSql(tableName, columns, conflictColumns, updateColumns) {
365
+ const columnList = columns.join(", ");
366
+ const valuePlaceholders = columns
367
+ .map((_, i) => `$${i + 1}`)
368
+ .join(", ");
369
+ const conflictList = conflictColumns.join(", ");
370
+ const updateSet = updateColumns
371
+ .map((col) => `${col} = EXCLUDED.${col}`)
372
+ .join(", ");
373
+ return `INSERT INTO ${tableName} (${columnList}) VALUES (${valuePlaceholders}) ON CONFLICT (${conflictList}) DO UPDATE SET ${updateSet}`;
374
+ }
375
+ async hasColumn(tableName, columnName) {
376
+ const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT column_name FROM information_schema.columns WHERE table_schema = ${this.schema} AND table_name = ${tableName} AND column_name = ${columnName}`);
377
+ return Array.isArray(rows) && rows.length > 0;
378
+ }
379
+ async hasForeignKey(tableName, constraintName) {
380
+ const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT constraint_name FROM information_schema.table_constraints WHERE table_schema = ${this.schema} AND table_name = ${tableName} AND constraint_name = ${constraintName} AND constraint_type = 'FOREIGN KEY'`);
381
+ return Array.isArray(rows) && rows.length > 0;
382
+ }
383
+ addCompositeUniqueIndex(tableName, columns, indexName) {
384
+ const columnList = columns.map((col) => this.wrap(col)).join(", ");
385
+ return this.connector.query(`CREATE UNIQUE INDEX IF NOT EXISTS ${this.wrap(indexName)} ON ${this.wrapQualified(tableName)} (${columnList})`);
386
+ }
387
+ async acquireAdvisoryLock(lockId, timeoutMs = 0) {
388
+ const hash = this.hashLockId(lockId);
389
+ if (timeoutMs <= 0) {
390
+ const result = await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_try_advisory_lock(${hash}) AS lock_result`);
391
+ const rows = Array.isArray(result) ? result : result?.rows ?? [];
392
+ if (rows.length === 0)
393
+ return false;
394
+ return rows[0]?.lock_result === true;
395
+ }
396
+ const savedTimeout = await this.connector.query(`SHOW statement_timeout`);
397
+ await this.connector.query(`SET LOCAL statement_timeout = '${Math.floor(timeoutMs)}ms'`);
398
+ try {
399
+ await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_advisory_lock(${hash})`);
400
+ return true;
401
+ }
402
+ catch {
403
+ return false;
404
+ }
405
+ finally {
406
+ const rows = Array.isArray(savedTimeout) ? savedTimeout : savedTimeout?.rows ?? [];
407
+ const original = rows.length > 0 ? rows[0]?.statement_timeout ?? "0" : "0";
408
+ await this.connector.query(`SET LOCAL statement_timeout = '${original}'`);
409
+ }
410
+ }
411
+ async releaseAdvisoryLock(lockId) {
412
+ const hash = this.hashLockId(lockId);
413
+ await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_advisory_unlock(${hash})`);
414
+ }
415
+ hashLockId(lockId) {
416
+ let hash = 0;
417
+ for (let i = 0; i < lockId.length; i++) {
418
+ const char = lockId.charCodeAt(i);
419
+ hash = ((hash << 5) - hash + char) | 0;
420
+ }
421
+ return hash;
422
+ }
423
+ createSavepointSql(name) {
424
+ return `SAVEPOINT ${this.wrap(name)}`;
425
+ }
426
+ rollbackToSavepointSql(name) {
427
+ return `ROLLBACK TO SAVEPOINT ${this.wrap(name)}`;
428
+ }
429
+ releaseSavepointSql(name) {
430
+ return `RELEASE SAVEPOINT ${this.wrap(name)}`;
431
+ }
432
+ clear(tableName) {
433
+ return this.connector.query(`TRUNCATE TABLE ${this.wrapQualified(tableName)} RESTART IDENTITY CASCADE`);
434
+ }
435
+ getForUpdateNoWait() {
436
+ return " FOR UPDATE NOWAIT";
437
+ }
438
+ }
439
+ exports.PostgresDriver = PostgresDriver;
440
+ //# sourceMappingURL=PostgresDriver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PostgresDriver.js","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresDriver.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { PostgresDriver } from "./PostgresDriver";
2
+ import { ITenantMigrationRunner, TenantMigrationRunnerOptions, TenantSyncResult } from "../ITenantMigrationRunner";
3
+ export declare class PostgresTenantMigrationRunner implements ITenantMigrationRunner {
4
+ private readonly driver;
5
+ private readonly provisionedSchemas;
6
+ private readonly provisioningLocks;
7
+ private readonly sourceSchema;
8
+ private readonly logger;
9
+ constructor(driver: PostgresDriver, options?: TenantMigrationRunnerOptions);
10
+ discoverSchemas(): Promise<string[]>;
11
+ ensureSchema(tenantId: string): Promise<void>;
12
+ syncTenantSchemas(tenantIds: string[]): Promise<TenantSyncResult>;
13
+ isProvisioned(tenantId: string): boolean;
14
+ getProvisionedSchemas(): string[];
15
+ reset(): void;
16
+ private provision;
17
+ }
18
+ //# sourceMappingURL=PostgresTenantMigrationRunner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PostgresTenantMigrationRunner.d.ts","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresTenantMigrationRunner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,EACL,sBAAsB,EACtB,4BAA4B,EAC5B,gBAAgB,EACjB,MAAM,2BAA2B,CAAC;AAYnC,qBAAa,6BAA8B,YAAW,sBAAsB;IAOxE,OAAO,CAAC,QAAQ,CAAC,MAAM;IANzB,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAqB;IACxD,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAoC;IACtE,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+C;gBAGnD,MAAM,EAAE,cAAc,EACvC,OAAO,CAAC,EAAE,4BAA4B;IAKlC,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAKpC,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAsB7C,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC;IA0BvE,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAIxC,qBAAqB,IAAI,MAAM,EAAE;IAIjC,KAAK,IAAI,IAAI;YAKC,SAAS;CAoBxB"}
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PostgresTenantMigrationRunner = void 0;
4
+ const utils_1 = require("../../utils");
5
+ class PostgresTenantMigrationRunner {
6
+ constructor(driver, options) {
7
+ this.driver = driver;
8
+ this.provisionedSchemas = new Set();
9
+ this.provisioningLocks = new Map();
10
+ this.logger = new utils_1.Logger("PostgresTenantMigrationRunner");
11
+ this.sourceSchema = options?.sourceSchema ?? "public";
12
+ }
13
+ async discoverSchemas() {
14
+ const rows = await this.driver.listSchemas();
15
+ return rows.map((r) => r.schema_name);
16
+ }
17
+ async ensureSchema(tenantId) {
18
+ if (tenantId === this.sourceSchema ||
19
+ this.provisionedSchemas.has(tenantId)) {
20
+ return;
21
+ }
22
+ const existing = this.provisioningLocks.get(tenantId);
23
+ if (existing) {
24
+ return existing;
25
+ }
26
+ const promise = this.provision(tenantId).then(() => {
27
+ this.provisionedSchemas.add(tenantId);
28
+ this.provisioningLocks.delete(tenantId);
29
+ });
30
+ this.provisioningLocks.set(tenantId, promise);
31
+ return promise;
32
+ }
33
+ async syncTenantSchemas(tenantIds) {
34
+ const existingSchemas = new Set(await this.discoverSchemas());
35
+ const created = [];
36
+ const skipped = [];
37
+ for (const tenantId of tenantIds) {
38
+ if (tenantId === this.sourceSchema) {
39
+ skipped.push(tenantId);
40
+ continue;
41
+ }
42
+ if (existingSchemas.has(tenantId)) {
43
+ this.provisionedSchemas.add(tenantId);
44
+ skipped.push(tenantId);
45
+ continue;
46
+ }
47
+ this.logger.info(`Provisioning schema: ${tenantId}`);
48
+ await this.provision(tenantId);
49
+ this.provisionedSchemas.add(tenantId);
50
+ created.push(tenantId);
51
+ }
52
+ return { created, skipped };
53
+ }
54
+ isProvisioned(tenantId) {
55
+ return this.provisionedSchemas.has(tenantId);
56
+ }
57
+ getProvisionedSchemas() {
58
+ return Array.from(this.provisionedSchemas);
59
+ }
60
+ reset() {
61
+ this.provisionedSchemas.clear();
62
+ this.provisioningLocks.clear();
63
+ }
64
+ async provision(tenantId) {
65
+ await this.driver.createSchema(tenantId);
66
+ const tables = await this.driver.listTables(this.sourceSchema);
67
+ for (const row of tables) {
68
+ const tableName = row.tablename;
69
+ const escapedTenant = tenantId.replace(/"/g, '""');
70
+ const escapedTable = tableName.replace(/"/g, '""');
71
+ const escapedSource = this.sourceSchema.replace(/"/g, '""');
72
+ await this.driver.executeRaw(`CREATE TABLE IF NOT EXISTS "${escapedTenant}"."${escapedTable}" (LIKE "${escapedSource}"."${escapedTable}" INCLUDING ALL)`);
73
+ }
74
+ this.logger.info(`Schema "${tenantId}" provisioned with ${tables.length} tables`);
75
+ }
76
+ }
77
+ exports.PostgresTenantMigrationRunner = PostgresTenantMigrationRunner;
78
+ //# sourceMappingURL=PostgresTenantMigrationRunner.js.map