typeorm 0.2.25 → 0.2.29

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 (1014) hide show
  1. package/README.md +16 -7
  2. package/browser/cache/DbQueryResultCache.js +14 -14
  3. package/browser/cache/DbQueryResultCache.js.map +1 -1
  4. package/browser/cache/RedisQueryResultCache.js +19 -14
  5. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  6. package/browser/common/DeepPartial.d.ts +1 -1
  7. package/browser/common/DeepPartial.js.map +1 -1
  8. package/browser/common/EntityTarget.d.ts +9 -0
  9. package/browser/common/EntityTarget.js +3 -0
  10. package/browser/common/EntityTarget.js.map +1 -0
  11. package/browser/connection/Connection.d.ts +11 -10
  12. package/browser/connection/Connection.js +63 -40
  13. package/browser/connection/Connection.js.map +1 -1
  14. package/browser/connection/ConnectionMetadataBuilder.js +8 -8
  15. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  16. package/browser/connection/ConnectionOptions.d.ts +2 -1
  17. package/browser/connection/ConnectionOptions.js.map +1 -1
  18. package/browser/connection/ConnectionOptionsReader.js +48 -43
  19. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  20. package/browser/connection/options-reader/ConnectionOptionsEnvReader.d.ts +5 -1
  21. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js +45 -31
  22. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  23. package/browser/connection/options-reader/ConnectionOptionsXmlReader.js +4 -4
  24. package/browser/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
  25. package/browser/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
  26. package/browser/connection/options-reader/ConnectionOptionsYmlReader.js +15 -4
  27. package/browser/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
  28. package/browser/decorator/Check.d.ts +2 -2
  29. package/browser/decorator/Check.js.map +1 -1
  30. package/browser/decorator/EntityRepository.d.ts +1 -1
  31. package/browser/decorator/EntityRepository.js.map +1 -1
  32. package/browser/decorator/Exclusion.d.ts +2 -2
  33. package/browser/decorator/Exclusion.js.map +1 -1
  34. package/browser/decorator/Generated.d.ts +1 -1
  35. package/browser/decorator/Generated.js.map +1 -1
  36. package/browser/decorator/Index.d.ts +7 -7
  37. package/browser/decorator/Index.js.map +1 -1
  38. package/browser/decorator/Unique.d.ts +4 -4
  39. package/browser/decorator/Unique.js +12 -1
  40. package/browser/decorator/Unique.js.map +1 -1
  41. package/browser/decorator/columns/Column.d.ts +12 -12
  42. package/browser/decorator/columns/Column.js.map +1 -1
  43. package/browser/decorator/columns/CreateDateColumn.d.ts +1 -1
  44. package/browser/decorator/columns/CreateDateColumn.js.map +1 -1
  45. package/browser/decorator/columns/DeleteDateColumn.d.ts +1 -1
  46. package/browser/decorator/columns/DeleteDateColumn.js.map +1 -1
  47. package/browser/decorator/columns/ObjectIdColumn.d.ts +1 -1
  48. package/browser/decorator/columns/ObjectIdColumn.js.map +1 -1
  49. package/browser/decorator/columns/PrimaryColumn.d.ts +2 -2
  50. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  51. package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +5 -5
  52. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  53. package/browser/decorator/columns/UpdateDateColumn.d.ts +1 -1
  54. package/browser/decorator/columns/UpdateDateColumn.js.map +1 -1
  55. package/browser/decorator/columns/VersionColumn.d.ts +1 -1
  56. package/browser/decorator/columns/VersionColumn.js.map +1 -1
  57. package/browser/decorator/columns/ViewColumn.d.ts +1 -1
  58. package/browser/decorator/columns/ViewColumn.js.map +1 -1
  59. package/browser/decorator/entity/ChildEntity.d.ts +1 -1
  60. package/browser/decorator/entity/ChildEntity.js +1 -1
  61. package/browser/decorator/entity/ChildEntity.js.map +1 -1
  62. package/browser/decorator/entity/TableInheritance.d.ts +1 -1
  63. package/browser/decorator/entity/TableInheritance.js.map +1 -1
  64. package/browser/decorator/entity-view/ViewEntity.d.ts +2 -2
  65. package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
  66. package/browser/decorator/listeners/AfterInsert.d.ts +1 -1
  67. package/browser/decorator/listeners/AfterInsert.js.map +1 -1
  68. package/browser/decorator/listeners/AfterLoad.d.ts +1 -1
  69. package/browser/decorator/listeners/AfterLoad.js.map +1 -1
  70. package/browser/decorator/listeners/AfterRemove.d.ts +1 -1
  71. package/browser/decorator/listeners/AfterRemove.js.map +1 -1
  72. package/browser/decorator/listeners/AfterUpdate.d.ts +1 -1
  73. package/browser/decorator/listeners/AfterUpdate.js.map +1 -1
  74. package/browser/decorator/listeners/BeforeInsert.d.ts +1 -1
  75. package/browser/decorator/listeners/BeforeInsert.js.map +1 -1
  76. package/browser/decorator/listeners/BeforeRemove.d.ts +1 -1
  77. package/browser/decorator/listeners/BeforeRemove.js.map +1 -1
  78. package/browser/decorator/listeners/BeforeUpdate.d.ts +1 -1
  79. package/browser/decorator/listeners/BeforeUpdate.js.map +1 -1
  80. package/browser/decorator/listeners/EventSubscriber.d.ts +1 -1
  81. package/browser/decorator/listeners/EventSubscriber.js.map +1 -1
  82. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  83. package/browser/decorator/options/TransactionOptions.js.map +1 -1
  84. package/browser/decorator/relations/JoinColumn.d.ts +3 -3
  85. package/browser/decorator/relations/JoinColumn.js.map +1 -1
  86. package/browser/decorator/relations/JoinTable.d.ts +3 -3
  87. package/browser/decorator/relations/JoinTable.js.map +1 -1
  88. package/browser/decorator/relations/ManyToMany.d.ts +2 -2
  89. package/browser/decorator/relations/ManyToMany.js.map +1 -1
  90. package/browser/decorator/relations/ManyToOne.d.ts +2 -2
  91. package/browser/decorator/relations/ManyToOne.js.map +1 -1
  92. package/browser/decorator/relations/OneToMany.d.ts +3 -3
  93. package/browser/decorator/relations/OneToMany.js +2 -2
  94. package/browser/decorator/relations/OneToMany.js.map +1 -1
  95. package/browser/decorator/relations/OneToOne.d.ts +2 -2
  96. package/browser/decorator/relations/OneToOne.js.map +1 -1
  97. package/browser/decorator/relations/RelationCount.d.ts +1 -1
  98. package/browser/decorator/relations/RelationCount.js.map +1 -1
  99. package/browser/decorator/relations/RelationId.d.ts +1 -1
  100. package/browser/decorator/relations/RelationId.js.map +1 -1
  101. package/browser/decorator/transaction/Transaction.js +4 -4
  102. package/browser/decorator/transaction/Transaction.js.map +1 -1
  103. package/browser/decorator/transaction/TransactionManager.d.ts +1 -1
  104. package/browser/decorator/transaction/TransactionManager.js.map +1 -1
  105. package/browser/decorator/tree/Tree.d.ts +1 -1
  106. package/browser/decorator/tree/Tree.js.map +1 -1
  107. package/browser/decorator/tree/TreeChildren.d.ts +1 -1
  108. package/browser/decorator/tree/TreeChildren.js.map +1 -1
  109. package/browser/decorator/tree/TreeLevelColumn.d.ts +1 -1
  110. package/browser/decorator/tree/TreeLevelColumn.js.map +1 -1
  111. package/browser/decorator/tree/TreeParent.d.ts +1 -1
  112. package/browser/decorator/tree/TreeParent.js.map +1 -1
  113. package/browser/driver/Driver.d.ts +7 -2
  114. package/browser/driver/Driver.js.map +1 -1
  115. package/browser/driver/DriverFactory.js +4 -1
  116. package/browser/driver/DriverFactory.js.map +1 -1
  117. package/browser/driver/DriverUtils.d.ts +2 -2
  118. package/browser/driver/DriverUtils.js +27 -15
  119. package/browser/driver/DriverUtils.js.map +1 -1
  120. package/browser/driver/aurora-data-api/AuroraDataApiConnection.d.ts +2 -1
  121. package/browser/driver/aurora-data-api/AuroraDataApiConnection.js +2 -3
  122. package/browser/driver/aurora-data-api/AuroraDataApiConnection.js.map +1 -1
  123. package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +3 -0
  124. package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
  125. package/browser/driver/aurora-data-api/AuroraDataApiDriver.d.ts +6 -1
  126. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js +14 -9
  127. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  128. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.d.ts +5 -0
  129. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +283 -149
  130. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  131. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +6 -0
  132. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
  133. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.d.ts +57 -0
  134. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +99 -0
  135. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -0
  136. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.d.ts +4 -3
  137. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +66 -20
  138. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
  139. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +50 -0
  140. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js +3 -0
  141. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -0
  142. package/browser/driver/better-sqlite3/BetterSqlite3Driver.d.ts +46 -0
  143. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +125 -0
  144. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -0
  145. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +22 -0
  146. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js +113 -0
  147. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -0
  148. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  149. package/browser/driver/cockroachdb/CockroachDriver.d.ts +6 -1
  150. package/browser/driver/cockroachdb/CockroachDriver.js +21 -16
  151. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  152. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +7 -1
  153. package/browser/driver/cockroachdb/CockroachQueryRunner.js +509 -211
  154. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  155. package/browser/driver/cordova/CordovaDriver.d.ts +2 -1
  156. package/browser/driver/cordova/CordovaDriver.js +4 -5
  157. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  158. package/browser/driver/cordova/CordovaQueryRunner.js +4 -4
  159. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  160. package/browser/driver/expo/ExpoDriver.d.ts +2 -1
  161. package/browser/driver/expo/ExpoDriver.js +4 -5
  162. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  163. package/browser/driver/expo/ExpoQueryRunner.js +82 -24
  164. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  165. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  166. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  167. package/browser/driver/mongodb/MongoDriver.d.ts +13 -4
  168. package/browser/driver/mongodb/MongoDriver.js +24 -18
  169. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  170. package/browser/driver/mongodb/MongoQueryRunner.d.ts +4 -3
  171. package/browser/driver/mongodb/MongoQueryRunner.js +175 -175
  172. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  173. package/browser/driver/mongodb/typings.js.map +1 -1
  174. package/browser/driver/mysql/MysqlDriver.d.ts +7 -2
  175. package/browser/driver/mysql/MysqlDriver.js +20 -13
  176. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  177. package/browser/driver/mysql/MysqlQueryRunner.d.ts +11 -1
  178. package/browser/driver/mysql/MysqlQueryRunner.js +351 -185
  179. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  180. package/browser/driver/nativescript/NativescriptDriver.d.ts +2 -1
  181. package/browser/driver/nativescript/NativescriptDriver.js +4 -5
  182. package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
  183. package/browser/driver/nativescript/NativescriptQueryRunner.js +2 -2
  184. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  185. package/browser/driver/oracle/OracleDriver.d.ts +6 -1
  186. package/browser/driver/oracle/OracleDriver.js +17 -12
  187. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  188. package/browser/driver/oracle/OracleQueryRunner.d.ts +3 -1
  189. package/browser/driver/oracle/OracleQueryRunner.js +247 -134
  190. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  191. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  192. package/browser/driver/postgres/PostgresConnectionOptions.d.ts +9 -0
  193. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  194. package/browser/driver/postgres/PostgresDriver.d.ts +18 -55
  195. package/browser/driver/postgres/PostgresDriver.js +196 -206
  196. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  197. package/browser/driver/postgres/PostgresQueryRunner.d.ts +11 -1
  198. package/browser/driver/postgres/PostgresQueryRunner.js +517 -209
  199. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  200. package/browser/driver/react-native/ReactNativeDriver.d.ts +2 -1
  201. package/browser/driver/react-native/ReactNativeDriver.js +4 -5
  202. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  203. package/browser/driver/react-native/ReactNativeQueryRunner.js +4 -4
  204. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  205. package/browser/driver/sap/SapDriver.d.ts +6 -1
  206. package/browser/driver/sap/SapDriver.js +12 -7
  207. package/browser/driver/sap/SapDriver.js.map +1 -1
  208. package/browser/driver/sap/SapQueryRunner.d.ts +3 -1
  209. package/browser/driver/sap/SapQueryRunner.js +276 -160
  210. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  211. package/browser/driver/sqlite/SqliteConnectionOptions.d.ts +18 -0
  212. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  213. package/browser/driver/sqlite/SqliteDriver.d.ts +2 -1
  214. package/browser/driver/sqlite/SqliteDriver.js +31 -17
  215. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  216. package/browser/driver/sqlite/SqliteQueryRunner.js +37 -18
  217. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  218. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +7 -2
  219. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +36 -9
  220. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  221. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +1 -0
  222. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +189 -127
  223. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  224. package/browser/driver/sqljs/SqljsDriver.d.ts +2 -1
  225. package/browser/driver/sqljs/SqljsDriver.js +14 -15
  226. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  227. package/browser/driver/sqljs/SqljsQueryRunner.js +7 -6
  228. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  229. package/browser/driver/sqlserver/SqlServerDriver.d.ts +6 -1
  230. package/browser/driver/sqlserver/SqlServerDriver.js +13 -8
  231. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  232. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +3 -1
  233. package/browser/driver/sqlserver/SqlServerQueryRunner.js +368 -230
  234. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  235. package/browser/driver/types/ColumnTypes.d.ts +1 -1
  236. package/browser/driver/types/ColumnTypes.js.map +1 -1
  237. package/browser/driver/types/DatabaseType.d.ts +1 -1
  238. package/browser/driver/types/DatabaseType.js.map +1 -1
  239. package/browser/driver/types/ReplicationMode.d.ts +1 -0
  240. package/browser/driver/types/ReplicationMode.js +3 -0
  241. package/browser/driver/types/ReplicationMode.js.map +1 -0
  242. package/browser/entity-manager/EntityManager.d.ts +41 -256
  243. package/browser/entity-manager/EntityManager.js +32 -42
  244. package/browser/entity-manager/EntityManager.js.map +1 -1
  245. package/browser/entity-manager/MongoEntityManager.d.ts +46 -46
  246. package/browser/entity-manager/MongoEntityManager.js +31 -20
  247. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  248. package/browser/entity-manager/SqljsEntityManager.js +6 -6
  249. package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
  250. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  251. package/browser/entity-schema/EntitySchemaRelationOptions.d.ts +1 -1
  252. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  253. package/browser/entity-schema/EntitySchemaTransformer.js +22 -7
  254. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  255. package/browser/error/AlreadyHasActiveConnectionError.js +2 -2
  256. package/browser/error/AlreadyHasActiveConnectionError.js.map +1 -1
  257. package/browser/error/CannotAttachTreeChildrenEntityError.js +2 -2
  258. package/browser/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  259. package/browser/error/CannotConnectAlreadyConnectedError.js +2 -2
  260. package/browser/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  261. package/browser/error/CannotCreateEntityIdMapError.js +2 -2
  262. package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
  263. package/browser/error/CannotDetermineEntityError.js +2 -2
  264. package/browser/error/CannotDetermineEntityError.js.map +1 -1
  265. package/browser/error/CannotExecuteNotConnectedError.js +2 -2
  266. package/browser/error/CannotExecuteNotConnectedError.js.map +1 -1
  267. package/browser/error/CannotGetEntityManagerNotConnectedError.js +2 -2
  268. package/browser/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  269. package/browser/error/CannotReflectMethodParameterTypeError.js +2 -2
  270. package/browser/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  271. package/browser/error/CircularRelationsError.js +2 -2
  272. package/browser/error/CircularRelationsError.js.map +1 -1
  273. package/browser/error/ColumnTypeUndefinedError.js +2 -2
  274. package/browser/error/ColumnTypeUndefinedError.js.map +1 -1
  275. package/browser/error/ConnectionIsNotSetError.js +2 -2
  276. package/browser/error/ConnectionIsNotSetError.js.map +1 -1
  277. package/browser/error/ConnectionNotFoundError.js +2 -2
  278. package/browser/error/ConnectionNotFoundError.js.map +1 -1
  279. package/browser/error/CustomRepositoryCannotInheritRepositoryError.js +2 -2
  280. package/browser/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  281. package/browser/error/CustomRepositoryDoesNotHaveEntityError.js +2 -2
  282. package/browser/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  283. package/browser/error/CustomRepositoryNotFoundError.js +2 -2
  284. package/browser/error/CustomRepositoryNotFoundError.js.map +1 -1
  285. package/browser/error/DataTypeNotSupportedError.js +2 -2
  286. package/browser/error/DataTypeNotSupportedError.js.map +1 -1
  287. package/browser/error/DriverOptionNotSetError.js +2 -2
  288. package/browser/error/DriverOptionNotSetError.js.map +1 -1
  289. package/browser/error/DriverPackageNotInstalledError.js +2 -2
  290. package/browser/error/DriverPackageNotInstalledError.js.map +1 -1
  291. package/browser/error/EntityColumnNotFound.js +2 -2
  292. package/browser/error/EntityColumnNotFound.js.map +1 -1
  293. package/browser/error/EntityMetadataNotFoundError.d.ts +2 -2
  294. package/browser/error/EntityMetadataNotFoundError.js +5 -2
  295. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  296. package/browser/error/EntityNotFoundError.d.ts +2 -3
  297. package/browser/error/EntityNotFoundError.js +5 -2
  298. package/browser/error/EntityNotFoundError.js.map +1 -1
  299. package/browser/error/FindRelationsNotFoundError.js +4 -4
  300. package/browser/error/FindRelationsNotFoundError.js.map +1 -1
  301. package/browser/error/InitializedRelationError.js +2 -2
  302. package/browser/error/InitializedRelationError.js.map +1 -1
  303. package/browser/error/InsertValuesMissingError.js +2 -2
  304. package/browser/error/InsertValuesMissingError.js.map +1 -1
  305. package/browser/error/LimitOnUpdateNotSupportedError.js +2 -2
  306. package/browser/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  307. package/browser/error/LockNotSupportedOnGivenDriverError.js +2 -2
  308. package/browser/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  309. package/browser/error/MetadataAlreadyExistsError.js +2 -2
  310. package/browser/error/MetadataAlreadyExistsError.js.map +1 -1
  311. package/browser/error/MetadataWithSuchNameAlreadyExistsError.js +2 -2
  312. package/browser/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  313. package/browser/error/MissingDeleteDateColumnError.js +2 -2
  314. package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
  315. package/browser/error/MissingDriverError.js +3 -3
  316. package/browser/error/MissingDriverError.js.map +1 -1
  317. package/browser/error/MissingJoinColumnError.js +2 -2
  318. package/browser/error/MissingJoinColumnError.js.map +1 -1
  319. package/browser/error/MissingJoinTableError.js +2 -2
  320. package/browser/error/MissingJoinTableError.js.map +1 -1
  321. package/browser/error/MissingPrimaryColumnError.js +2 -2
  322. package/browser/error/MissingPrimaryColumnError.js.map +1 -1
  323. package/browser/error/MustBeEntityError.js +2 -2
  324. package/browser/error/MustBeEntityError.js.map +1 -1
  325. package/browser/error/NamingStrategyNotFoundError.js +2 -2
  326. package/browser/error/NamingStrategyNotFoundError.js.map +1 -1
  327. package/browser/error/NoConnectionForRepositoryError.js +2 -2
  328. package/browser/error/NoConnectionForRepositoryError.js.map +1 -1
  329. package/browser/error/NoConnectionOptionError.js +2 -2
  330. package/browser/error/NoConnectionOptionError.js.map +1 -1
  331. package/browser/error/NoNeedToReleaseEntityManagerError.js +2 -2
  332. package/browser/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  333. package/browser/error/NoVersionOrUpdateDateColumnError.js +2 -2
  334. package/browser/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  335. package/browser/error/OffsetWithoutLimitNotSupportedError.js +2 -2
  336. package/browser/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  337. package/browser/error/OptimisticLockCanNotBeUsedError.js +2 -2
  338. package/browser/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  339. package/browser/error/OptimisticLockVersionMismatchError.js +2 -2
  340. package/browser/error/OptimisticLockVersionMismatchError.js.map +1 -1
  341. package/browser/error/PersistedEntityNotFoundError.js +2 -2
  342. package/browser/error/PersistedEntityNotFoundError.js.map +1 -1
  343. package/browser/error/PessimisticLockTransactionRequiredError.js +2 -2
  344. package/browser/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  345. package/browser/error/PrimaryColumnCannotBeNullableError.js +2 -2
  346. package/browser/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  347. package/browser/error/QueryFailedError.js +3 -3
  348. package/browser/error/QueryFailedError.js.map +1 -1
  349. package/browser/error/QueryRunnerAlreadyReleasedError.js +2 -2
  350. package/browser/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  351. package/browser/error/QueryRunnerProviderAlreadyReleasedError.js +2 -2
  352. package/browser/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  353. package/browser/error/RepositoryNotFoundError.d.ts +2 -2
  354. package/browser/error/RepositoryNotFoundError.js +5 -2
  355. package/browser/error/RepositoryNotFoundError.js.map +1 -1
  356. package/browser/error/RepositoryNotTreeError.d.ts +2 -2
  357. package/browser/error/RepositoryNotTreeError.js +11 -8
  358. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  359. package/browser/error/ReturningStatementNotSupportedError.js +2 -2
  360. package/browser/error/ReturningStatementNotSupportedError.js.map +1 -1
  361. package/browser/error/SubjectRemovedAndUpdatedError.js +2 -2
  362. package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  363. package/browser/error/SubjectWithoutIdentifierError.js +2 -2
  364. package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
  365. package/browser/error/TransactionAlreadyStartedError.js +2 -2
  366. package/browser/error/TransactionAlreadyStartedError.js.map +1 -1
  367. package/browser/error/TransactionNotStartedError.js +2 -2
  368. package/browser/error/TransactionNotStartedError.js.map +1 -1
  369. package/browser/error/TreeRepositoryNotSupportedError.js +2 -2
  370. package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
  371. package/browser/error/UpdateValuesMissingError.js +2 -2
  372. package/browser/error/UpdateValuesMissingError.js.map +1 -1
  373. package/browser/error/UsingJoinColumnIsNotAllowedError.js +2 -2
  374. package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  375. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js +2 -2
  376. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  377. package/browser/error/UsingJoinTableIsNotAllowedError.js +2 -2
  378. package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  379. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js +2 -2
  380. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  381. package/browser/find-options/FindOneOptions.d.ts +4 -0
  382. package/browser/find-options/FindOneOptions.js.map +1 -1
  383. package/browser/find-options/FindOperator.d.ts +26 -4
  384. package/browser/find-options/FindOperator.js +49 -50
  385. package/browser/find-options/FindOperator.js.map +1 -1
  386. package/browser/find-options/FindOperatorType.d.ts +1 -1
  387. package/browser/find-options/FindOperatorType.js.map +1 -1
  388. package/browser/find-options/FindOptionsUtils.d.ts +2 -2
  389. package/browser/find-options/FindOptionsUtils.js +5 -1
  390. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  391. package/browser/find-options/operator/Any.d.ts +1 -1
  392. package/browser/find-options/operator/Any.js.map +1 -1
  393. package/browser/find-options/operator/Between.d.ts +1 -1
  394. package/browser/find-options/operator/Between.js.map +1 -1
  395. package/browser/find-options/operator/ILike.d.ts +6 -0
  396. package/browser/find-options/operator/ILike.js +10 -0
  397. package/browser/find-options/operator/ILike.js.map +1 -0
  398. package/browser/find-options/operator/In.d.ts +1 -1
  399. package/browser/find-options/operator/In.js.map +1 -1
  400. package/browser/find-options/operator/Raw.d.ts +14 -2
  401. package/browser/find-options/operator/Raw.js +5 -6
  402. package/browser/find-options/operator/Raw.js.map +1 -1
  403. package/browser/index.d.ts +10 -11
  404. package/browser/index.js +9 -15
  405. package/browser/index.js.map +1 -1
  406. package/browser/logger/DebugLogger.d.ts +0 -1
  407. package/browser/logger/DebugLogger.js +9 -9
  408. package/browser/logger/DebugLogger.js.map +1 -1
  409. package/browser/logger/FileLogger.d.ts +3 -1
  410. package/browser/logger/FileLogger.js +9 -3
  411. package/browser/logger/FileLogger.js.map +1 -1
  412. package/browser/logger/Logger.d.ts +1 -1
  413. package/browser/logger/Logger.js.map +1 -1
  414. package/browser/logger/LoggerOptions.d.ts +9 -0
  415. package/browser/logger/LoggerOptions.js.map +1 -1
  416. package/browser/metadata/ColumnMetadata.js +29 -19
  417. package/browser/metadata/ColumnMetadata.js.map +1 -1
  418. package/browser/metadata/EmbeddedMetadata.js +2 -2
  419. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  420. package/browser/metadata/EntityMetadata.d.ts +1 -0
  421. package/browser/metadata/EntityMetadata.js +13 -5
  422. package/browser/metadata/EntityMetadata.js.map +1 -1
  423. package/browser/metadata/RelationMetadata.js +7 -7
  424. package/browser/metadata/RelationMetadata.js.map +1 -1
  425. package/browser/metadata/types/EventListenerTypes.d.ts +7 -7
  426. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  427. package/browser/metadata-args/EntityRepositoryMetadataArgs.d.ts +2 -2
  428. package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  429. package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  430. package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  431. package/browser/metadata-builder/EntityMetadataBuilder.js +21 -15
  432. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  433. package/browser/metadata-builder/EntityMetadataValidator.js +8 -5
  434. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  435. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js +3 -2
  436. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  437. package/browser/migration/MigrationExecutor.js +132 -103
  438. package/browser/migration/MigrationExecutor.js.map +1 -1
  439. package/browser/naming-strategy/DefaultNamingStrategy.js +6 -6
  440. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  441. package/browser/persistence/EntityPersistExecutor.js +65 -47
  442. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  443. package/browser/persistence/Subject.js +4 -3
  444. package/browser/persistence/Subject.js.map +1 -1
  445. package/browser/persistence/SubjectDatabaseEntityLoader.js +9 -8
  446. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  447. package/browser/persistence/SubjectExecutor.js +263 -206
  448. package/browser/persistence/SubjectExecutor.js.map +1 -1
  449. package/browser/persistence/SubjectTopoligicalSorter.js +6 -6
  450. package/browser/persistence/SubjectTopoligicalSorter.js.map +1 -1
  451. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js +2 -2
  452. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  453. package/browser/persistence/tree/ClosureSubjectExecutor.js +4 -4
  454. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  455. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js +5 -4
  456. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  457. package/browser/persistence/tree/NestedSetSubjectExecutor.js +3 -3
  458. package/browser/platform/BrowserConnectionOptionsReaderDummy.d.ts +38 -0
  459. package/browser/platform/BrowserConnectionOptionsReaderDummy.js +93 -0
  460. package/browser/platform/BrowserConnectionOptionsReaderDummy.js.map +1 -0
  461. package/browser/platform/BrowserDirectoryExportedClassesLoader.d.ts +15 -0
  462. package/browser/platform/BrowserDirectoryExportedClassesLoader.js +22 -0
  463. package/browser/platform/BrowserDirectoryExportedClassesLoader.js.map +1 -0
  464. package/browser/platform/BrowserDisabledDriversDummy.d.ts +32 -2
  465. package/browser/platform/BrowserDisabledDriversDummy.js +52 -2
  466. package/browser/platform/BrowserDisabledDriversDummy.js.map +1 -1
  467. package/browser/platform/BrowserFileLoggerDummy.d.ts +33 -0
  468. package/browser/platform/BrowserFileLoggerDummy.js +58 -0
  469. package/browser/platform/BrowserFileLoggerDummy.js.map +1 -0
  470. package/browser/platform/BrowserPlatformTools.d.ts +74 -0
  471. package/browser/platform/BrowserPlatformTools.js +157 -0
  472. package/browser/platform/BrowserPlatformTools.js.map +1 -0
  473. package/browser/platform/PlatformTools.d.ts +15 -21
  474. package/browser/platform/PlatformTools.js +142 -81
  475. package/browser/platform/PlatformTools.js.map +1 -1
  476. package/browser/query-builder/Alias.js.map +1 -1
  477. package/browser/query-builder/DeleteQueryBuilder.d.ts +2 -3
  478. package/browser/query-builder/DeleteQueryBuilder.js +12 -6
  479. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  480. package/browser/query-builder/InsertQueryBuilder.d.ts +2 -3
  481. package/browser/query-builder/InsertQueryBuilder.js +49 -16
  482. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  483. package/browser/query-builder/JoinAttribute.js +2 -2
  484. package/browser/query-builder/JoinAttribute.js.map +1 -1
  485. package/browser/query-builder/QueryBuilder.d.ts +18 -15
  486. package/browser/query-builder/QueryBuilder.js +205 -55
  487. package/browser/query-builder/QueryBuilder.js.map +1 -1
  488. package/browser/query-builder/QueryBuilderUtils.js +2 -2
  489. package/browser/query-builder/QueryBuilderUtils.js.map +1 -1
  490. package/browser/query-builder/QueryExpressionMap.d.ts +4 -0
  491. package/browser/query-builder/QueryExpressionMap.js +4 -4
  492. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  493. package/browser/query-builder/QueryPartialEntity.d.ts +1 -1
  494. package/browser/query-builder/QueryPartialEntity.js.map +1 -1
  495. package/browser/query-builder/RelationIdLoader.js +5 -5
  496. package/browser/query-builder/RelationLoader.js +3 -3
  497. package/browser/query-builder/RelationLoader.js.map +1 -1
  498. package/browser/query-builder/RelationQueryBuilder.js +14 -14
  499. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  500. package/browser/query-builder/RelationRemover.js +7 -7
  501. package/browser/query-builder/RelationRemover.js.map +1 -1
  502. package/browser/query-builder/RelationUpdater.js +3 -3
  503. package/browser/query-builder/ReturningResultsEntityUpdator.js +30 -31
  504. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  505. package/browser/query-builder/SelectQueryBuilder.d.ts +9 -3
  506. package/browser/query-builder/SelectQueryBuilder.js +116 -68
  507. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  508. package/browser/query-builder/SoftDeleteQueryBuilder.d.ts +2 -3
  509. package/browser/query-builder/SoftDeleteQueryBuilder.js +6 -6
  510. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  511. package/browser/query-builder/UpdateQueryBuilder.js +13 -7
  512. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  513. package/browser/query-builder/relation-count/RelationCountAttribute.js +3 -3
  514. package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  515. package/browser/query-builder/relation-count/RelationCountLoader.js +5 -5
  516. package/browser/query-builder/relation-id/RelationIdAttribute.js +2 -2
  517. package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  518. package/browser/query-builder/relation-id/RelationIdLoader.js +6 -6
  519. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  520. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js +4 -4
  521. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  522. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +9 -6
  523. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  524. package/browser/query-runner/BaseQueryRunner.d.ts +2 -5
  525. package/browser/query-runner/BaseQueryRunner.js +106 -56
  526. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  527. package/browser/query-runner/QueryRunner.d.ts +2 -1
  528. package/browser/query-runner/QueryRunner.js.map +1 -1
  529. package/browser/repository/AbstractRepository.js.map +1 -1
  530. package/browser/repository/BaseEntity.js +5 -5
  531. package/browser/repository/BaseEntity.js.map +1 -1
  532. package/browser/repository/MongoRepository.js +2 -2
  533. package/browser/repository/MongoRepository.js.map +1 -1
  534. package/browser/repository/Repository.js +3 -3
  535. package/browser/repository/Repository.js.map +1 -1
  536. package/browser/repository/TreeRepository.js +6 -6
  537. package/browser/repository/TreeRepository.js.map +1 -1
  538. package/browser/schema-builder/MongoSchemaBuilder.js +4 -4
  539. package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
  540. package/browser/schema-builder/RdbmsSchemaBuilder.js +924 -368
  541. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  542. package/browser/schema-builder/options/TableIndexOptions.d.ts +1 -1
  543. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  544. package/browser/schema-builder/table/TableCheck.js +2 -2
  545. package/browser/schema-builder/table/TableCheck.js.map +1 -1
  546. package/browser/schema-builder/table/TableForeignKey.js +3 -3
  547. package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
  548. package/browser/schema-builder/table/TableIndex.js +2 -2
  549. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  550. package/browser/schema-builder/table/TableUnique.js +2 -2
  551. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  552. package/browser/schema-builder/view/View.d.ts +1 -2
  553. package/browser/schema-builder/view/View.js.map +1 -1
  554. package/browser/subscriber/Broadcaster.d.ts +24 -0
  555. package/browser/subscriber/Broadcaster.js +120 -0
  556. package/browser/subscriber/Broadcaster.js.map +1 -1
  557. package/browser/subscriber/EntitySubscriberInterface.d.ts +27 -0
  558. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  559. package/browser/subscriber/event/TransactionCommitEvent.d.ts +22 -0
  560. package/browser/subscriber/event/TransactionCommitEvent.js +3 -0
  561. package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -0
  562. package/browser/subscriber/event/TransactionRollbackEvent.d.ts +22 -0
  563. package/browser/subscriber/event/TransactionRollbackEvent.js +3 -0
  564. package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -0
  565. package/browser/subscriber/event/TransactionStartEvent.d.ts +22 -0
  566. package/browser/subscriber/event/TransactionStartEvent.js +3 -0
  567. package/browser/subscriber/event/TransactionStartEvent.js.map +1 -0
  568. package/browser/util/ApplyValueTransformers.js.map +1 -1
  569. package/browser/util/DateUtils.js +3 -9
  570. package/browser/util/DateUtils.js.map +1 -1
  571. package/browser/util/DirectoryExportedClassesLoader.js +6 -5
  572. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  573. package/browser/util/ObjectUtils.js +4 -4
  574. package/browser/util/ObjectUtils.js.map +1 -1
  575. package/browser/util/OrmUtils.js +5 -8
  576. package/browser/util/OrmUtils.js.map +1 -1
  577. package/cache/DbQueryResultCache.js +1 -1
  578. package/cache/DbQueryResultCache.js.map +1 -1
  579. package/cache/RedisQueryResultCache.js +6 -1
  580. package/cache/RedisQueryResultCache.js.map +1 -1
  581. package/commands/CacheClearCommand.js +4 -4
  582. package/commands/CacheClearCommand.js.map +1 -1
  583. package/commands/CommandUtils.d.ts +1 -1
  584. package/commands/CommandUtils.js +2 -2
  585. package/commands/CommandUtils.js.map +1 -1
  586. package/commands/EntityCreateCommand.js +9 -6
  587. package/commands/EntityCreateCommand.js.map +1 -1
  588. package/commands/InitCommand.js +15 -5
  589. package/commands/InitCommand.js.map +1 -1
  590. package/commands/MigrationCreateCommand.js +8 -5
  591. package/commands/MigrationCreateCommand.js.map +1 -1
  592. package/commands/MigrationGenerateCommand.d.ts +7 -1
  593. package/commands/MigrationGenerateCommand.js +53 -32
  594. package/commands/MigrationGenerateCommand.js.map +1 -1
  595. package/commands/MigrationRevertCommand.js +2 -2
  596. package/commands/MigrationRevertCommand.js.map +1 -1
  597. package/commands/MigrationRunCommand.js +2 -2
  598. package/commands/MigrationRunCommand.js.map +1 -1
  599. package/commands/MigrationShowCommand.js +2 -2
  600. package/commands/MigrationShowCommand.js.map +1 -1
  601. package/commands/QueryCommand.d.ts +2 -0
  602. package/commands/QueryCommand.js +16 -7
  603. package/commands/QueryCommand.js.map +1 -1
  604. package/commands/SchemaDropCommand.js +3 -3
  605. package/commands/SchemaDropCommand.js.map +1 -1
  606. package/commands/SchemaLogCommand.js +6 -6
  607. package/commands/SchemaLogCommand.js.map +1 -1
  608. package/commands/SchemaSyncCommand.js +3 -3
  609. package/commands/SchemaSyncCommand.js.map +1 -1
  610. package/commands/SubscriberCreateCommand.js +8 -5
  611. package/commands/SubscriberCreateCommand.js.map +1 -1
  612. package/commands/VersionCommand.js +2 -2
  613. package/commands/VersionCommand.js.map +1 -1
  614. package/common/DeepPartial.d.ts +1 -1
  615. package/common/DeepPartial.js.map +1 -1
  616. package/common/EntityTarget.d.ts +9 -0
  617. package/common/EntityTarget.js +4 -0
  618. package/common/EntityTarget.js.map +1 -0
  619. package/connection/Connection.d.ts +11 -10
  620. package/connection/Connection.js +45 -22
  621. package/connection/Connection.js.map +1 -1
  622. package/connection/ConnectionOptions.d.ts +2 -1
  623. package/connection/ConnectionOptions.js.map +1 -1
  624. package/connection/ConnectionOptionsReader.js +39 -34
  625. package/connection/ConnectionOptionsReader.js.map +1 -1
  626. package/connection/options-reader/ConnectionOptionsEnvReader.d.ts +5 -1
  627. package/connection/options-reader/ConnectionOptionsEnvReader.js +45 -31
  628. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  629. package/connection/options-reader/ConnectionOptionsXmlReader.js +2 -2
  630. package/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
  631. package/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
  632. package/connection/options-reader/ConnectionOptionsYmlReader.js +15 -4
  633. package/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
  634. package/decorator/Check.d.ts +2 -2
  635. package/decorator/Check.js.map +1 -1
  636. package/decorator/EntityRepository.d.ts +1 -1
  637. package/decorator/EntityRepository.js.map +1 -1
  638. package/decorator/Exclusion.d.ts +2 -2
  639. package/decorator/Exclusion.js.map +1 -1
  640. package/decorator/Generated.d.ts +1 -1
  641. package/decorator/Generated.js.map +1 -1
  642. package/decorator/Index.d.ts +7 -7
  643. package/decorator/Index.js.map +1 -1
  644. package/decorator/Unique.d.ts +4 -4
  645. package/decorator/Unique.js +12 -1
  646. package/decorator/Unique.js.map +1 -1
  647. package/decorator/columns/Column.d.ts +12 -12
  648. package/decorator/columns/Column.js.map +1 -1
  649. package/decorator/columns/CreateDateColumn.d.ts +1 -1
  650. package/decorator/columns/CreateDateColumn.js.map +1 -1
  651. package/decorator/columns/DeleteDateColumn.d.ts +1 -1
  652. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  653. package/decorator/columns/ObjectIdColumn.d.ts +1 -1
  654. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  655. package/decorator/columns/PrimaryColumn.d.ts +2 -2
  656. package/decorator/columns/PrimaryColumn.js.map +1 -1
  657. package/decorator/columns/PrimaryGeneratedColumn.d.ts +5 -5
  658. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  659. package/decorator/columns/UpdateDateColumn.d.ts +1 -1
  660. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  661. package/decorator/columns/VersionColumn.d.ts +1 -1
  662. package/decorator/columns/VersionColumn.js.map +1 -1
  663. package/decorator/columns/ViewColumn.d.ts +1 -1
  664. package/decorator/columns/ViewColumn.js.map +1 -1
  665. package/decorator/entity/ChildEntity.d.ts +1 -1
  666. package/decorator/entity/ChildEntity.js +1 -1
  667. package/decorator/entity/ChildEntity.js.map +1 -1
  668. package/decorator/entity/TableInheritance.d.ts +1 -1
  669. package/decorator/entity/TableInheritance.js.map +1 -1
  670. package/decorator/entity-view/ViewEntity.d.ts +2 -2
  671. package/decorator/entity-view/ViewEntity.js.map +1 -1
  672. package/decorator/listeners/AfterInsert.d.ts +1 -1
  673. package/decorator/listeners/AfterInsert.js.map +1 -1
  674. package/decorator/listeners/AfterLoad.d.ts +1 -1
  675. package/decorator/listeners/AfterLoad.js.map +1 -1
  676. package/decorator/listeners/AfterRemove.d.ts +1 -1
  677. package/decorator/listeners/AfterRemove.js.map +1 -1
  678. package/decorator/listeners/AfterUpdate.d.ts +1 -1
  679. package/decorator/listeners/AfterUpdate.js.map +1 -1
  680. package/decorator/listeners/BeforeInsert.d.ts +1 -1
  681. package/decorator/listeners/BeforeInsert.js.map +1 -1
  682. package/decorator/listeners/BeforeRemove.d.ts +1 -1
  683. package/decorator/listeners/BeforeRemove.js.map +1 -1
  684. package/decorator/listeners/BeforeUpdate.d.ts +1 -1
  685. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  686. package/decorator/listeners/EventSubscriber.d.ts +1 -1
  687. package/decorator/listeners/EventSubscriber.js.map +1 -1
  688. package/decorator/options/ColumnOptions.js.map +1 -1
  689. package/decorator/options/TransactionOptions.js.map +1 -1
  690. package/decorator/relations/JoinColumn.d.ts +3 -3
  691. package/decorator/relations/JoinColumn.js.map +1 -1
  692. package/decorator/relations/JoinTable.d.ts +3 -3
  693. package/decorator/relations/JoinTable.js.map +1 -1
  694. package/decorator/relations/ManyToMany.d.ts +2 -2
  695. package/decorator/relations/ManyToMany.js.map +1 -1
  696. package/decorator/relations/ManyToOne.d.ts +2 -2
  697. package/decorator/relations/ManyToOne.js.map +1 -1
  698. package/decorator/relations/OneToMany.d.ts +3 -3
  699. package/decorator/relations/OneToMany.js +2 -2
  700. package/decorator/relations/OneToMany.js.map +1 -1
  701. package/decorator/relations/OneToOne.d.ts +2 -2
  702. package/decorator/relations/OneToOne.js.map +1 -1
  703. package/decorator/relations/RelationCount.d.ts +1 -1
  704. package/decorator/relations/RelationCount.js.map +1 -1
  705. package/decorator/relations/RelationId.d.ts +1 -1
  706. package/decorator/relations/RelationId.js.map +1 -1
  707. package/decorator/transaction/TransactionManager.d.ts +1 -1
  708. package/decorator/transaction/TransactionManager.js.map +1 -1
  709. package/decorator/tree/Tree.d.ts +1 -1
  710. package/decorator/tree/Tree.js.map +1 -1
  711. package/decorator/tree/TreeChildren.d.ts +1 -1
  712. package/decorator/tree/TreeChildren.js.map +1 -1
  713. package/decorator/tree/TreeLevelColumn.d.ts +1 -1
  714. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  715. package/decorator/tree/TreeParent.d.ts +1 -1
  716. package/decorator/tree/TreeParent.js.map +1 -1
  717. package/driver/Driver.d.ts +7 -2
  718. package/driver/Driver.js.map +1 -1
  719. package/driver/DriverFactory.js +5 -2
  720. package/driver/DriverFactory.js.map +1 -1
  721. package/driver/DriverUtils.d.ts +2 -2
  722. package/driver/DriverUtils.js +25 -13
  723. package/driver/DriverUtils.js.map +1 -1
  724. package/driver/aurora-data-api/AuroraDataApiConnection.d.ts +2 -1
  725. package/driver/aurora-data-api/AuroraDataApiConnection.js +0 -1
  726. package/driver/aurora-data-api/AuroraDataApiConnection.js.map +1 -1
  727. package/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +3 -0
  728. package/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
  729. package/driver/aurora-data-api/AuroraDataApiDriver.d.ts +6 -1
  730. package/driver/aurora-data-api/AuroraDataApiDriver.js +7 -2
  731. package/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  732. package/driver/aurora-data-api/AuroraDataApiQueryRunner.d.ts +4 -0
  733. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +159 -25
  734. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  735. package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +6 -0
  736. package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
  737. package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.d.ts +57 -0
  738. package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +101 -0
  739. package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -0
  740. package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.d.ts +4 -3
  741. package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +53 -7
  742. package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
  743. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +50 -0
  744. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js +4 -0
  745. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -0
  746. package/driver/better-sqlite3/BetterSqlite3Driver.d.ts +46 -0
  747. package/driver/better-sqlite3/BetterSqlite3Driver.js +127 -0
  748. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -0
  749. package/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +22 -0
  750. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js +115 -0
  751. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -0
  752. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  753. package/driver/cockroachdb/CockroachDriver.d.ts +6 -1
  754. package/driver/cockroachdb/CockroachDriver.js +9 -4
  755. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  756. package/driver/cockroachdb/CockroachQueryRunner.d.ts +6 -1
  757. package/driver/cockroachdb/CockroachQueryRunner.js +392 -94
  758. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  759. package/driver/cordova/CordovaDriver.d.ts +2 -1
  760. package/driver/cordova/CordovaDriver.js +0 -1
  761. package/driver/cordova/CordovaDriver.js.map +1 -1
  762. package/driver/expo/ExpoDriver.d.ts +2 -1
  763. package/driver/expo/ExpoDriver.js +0 -1
  764. package/driver/expo/ExpoDriver.js.map +1 -1
  765. package/driver/expo/ExpoQueryRunner.js +72 -14
  766. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  767. package/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
  768. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  769. package/driver/mongodb/MongoDriver.d.ts +13 -4
  770. package/driver/mongodb/MongoDriver.js +21 -15
  771. package/driver/mongodb/MongoDriver.js.map +1 -1
  772. package/driver/mongodb/MongoQueryRunner.d.ts +3 -3
  773. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  774. package/driver/mongodb/typings.js.map +1 -1
  775. package/driver/mysql/MysqlDriver.d.ts +7 -2
  776. package/driver/mysql/MysqlDriver.js +14 -7
  777. package/driver/mysql/MysqlDriver.js.map +1 -1
  778. package/driver/mysql/MysqlQueryRunner.d.ts +10 -1
  779. package/driver/mysql/MysqlQueryRunner.js +227 -61
  780. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  781. package/driver/nativescript/NativescriptDriver.d.ts +2 -1
  782. package/driver/nativescript/NativescriptDriver.js +0 -1
  783. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  784. package/driver/oracle/OracleDriver.d.ts +6 -1
  785. package/driver/oracle/OracleDriver.js +8 -3
  786. package/driver/oracle/OracleDriver.js.map +1 -1
  787. package/driver/oracle/OracleQueryRunner.d.ts +2 -1
  788. package/driver/oracle/OracleQueryRunner.js +139 -26
  789. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  790. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  791. package/driver/postgres/PostgresConnectionOptions.d.ts +9 -0
  792. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  793. package/driver/postgres/PostgresDriver.d.ts +18 -55
  794. package/driver/postgres/PostgresDriver.js +181 -191
  795. package/driver/postgres/PostgresDriver.js.map +1 -1
  796. package/driver/postgres/PostgresQueryRunner.d.ts +10 -1
  797. package/driver/postgres/PostgresQueryRunner.js +389 -81
  798. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  799. package/driver/react-native/ReactNativeDriver.d.ts +2 -1
  800. package/driver/react-native/ReactNativeDriver.js +0 -1
  801. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  802. package/driver/sap/SapDriver.d.ts +6 -1
  803. package/driver/sap/SapDriver.js +6 -1
  804. package/driver/sap/SapDriver.js.map +1 -1
  805. package/driver/sap/SapQueryRunner.d.ts +2 -1
  806. package/driver/sap/SapQueryRunner.js +143 -27
  807. package/driver/sap/SapQueryRunner.js.map +1 -1
  808. package/driver/sqlite/SqliteConnectionOptions.d.ts +18 -0
  809. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  810. package/driver/sqlite/SqliteDriver.d.ts +2 -1
  811. package/driver/sqlite/SqliteDriver.js +25 -11
  812. package/driver/sqlite/SqliteDriver.js.map +1 -1
  813. package/driver/sqlite/SqliteQueryRunner.js +33 -14
  814. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  815. package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +7 -2
  816. package/driver/sqlite-abstract/AbstractSqliteDriver.js +31 -4
  817. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  818. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +72 -10
  819. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  820. package/driver/sqljs/SqljsDriver.d.ts +2 -1
  821. package/driver/sqljs/SqljsDriver.js +0 -1
  822. package/driver/sqljs/SqljsDriver.js.map +1 -1
  823. package/driver/sqljs/SqljsQueryRunner.js +1 -0
  824. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  825. package/driver/sqlserver/SqlServerDriver.d.ts +6 -1
  826. package/driver/sqlserver/SqlServerDriver.js +6 -1
  827. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  828. package/driver/sqlserver/SqlServerQueryRunner.d.ts +2 -1
  829. package/driver/sqlserver/SqlServerQueryRunner.js +224 -86
  830. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  831. package/driver/types/ColumnTypes.d.ts +1 -1
  832. package/driver/types/ColumnTypes.js.map +1 -1
  833. package/driver/types/DatabaseType.d.ts +1 -1
  834. package/driver/types/DatabaseType.js.map +1 -1
  835. package/driver/types/ReplicationMode.d.ts +1 -0
  836. package/driver/types/ReplicationMode.js +4 -0
  837. package/driver/types/ReplicationMode.js.map +1 -0
  838. package/entity-manager/EntityManager.d.ts +41 -256
  839. package/entity-manager/EntityManager.js +3 -13
  840. package/entity-manager/EntityManager.js.map +1 -1
  841. package/entity-manager/MongoEntityManager.d.ts +46 -46
  842. package/entity-manager/MongoEntityManager.js +14 -3
  843. package/entity-manager/MongoEntityManager.js.map +1 -1
  844. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  845. package/entity-schema/EntitySchemaRelationOptions.d.ts +1 -1
  846. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  847. package/entity-schema/EntitySchemaTransformer.js +22 -7
  848. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  849. package/error/EntityMetadataNotFoundError.d.ts +2 -2
  850. package/error/EntityMetadataNotFoundError.js +3 -0
  851. package/error/EntityMetadataNotFoundError.js.map +1 -1
  852. package/error/EntityNotFoundError.d.ts +2 -3
  853. package/error/EntityNotFoundError.js +3 -0
  854. package/error/EntityNotFoundError.js.map +1 -1
  855. package/error/FindRelationsNotFoundError.js +2 -2
  856. package/error/FindRelationsNotFoundError.js.map +1 -1
  857. package/error/MissingDriverError.js +1 -1
  858. package/error/MissingDriverError.js.map +1 -1
  859. package/error/QueryFailedError.js +1 -1
  860. package/error/QueryFailedError.js.map +1 -1
  861. package/error/RepositoryNotFoundError.d.ts +2 -2
  862. package/error/RepositoryNotFoundError.js +3 -0
  863. package/error/RepositoryNotFoundError.js.map +1 -1
  864. package/error/RepositoryNotTreeError.d.ts +2 -2
  865. package/error/RepositoryNotTreeError.js +9 -6
  866. package/error/RepositoryNotTreeError.js.map +1 -1
  867. package/find-options/FindOneOptions.d.ts +4 -0
  868. package/find-options/FindOneOptions.js.map +1 -1
  869. package/find-options/FindOperator.d.ts +26 -4
  870. package/find-options/FindOperator.js +49 -50
  871. package/find-options/FindOperator.js.map +1 -1
  872. package/find-options/FindOperatorType.d.ts +1 -1
  873. package/find-options/FindOperatorType.js.map +1 -1
  874. package/find-options/FindOptionsUtils.d.ts +2 -2
  875. package/find-options/FindOptionsUtils.js +5 -1
  876. package/find-options/FindOptionsUtils.js.map +1 -1
  877. package/find-options/operator/Any.d.ts +1 -1
  878. package/find-options/operator/Any.js.map +1 -1
  879. package/find-options/operator/Between.d.ts +1 -1
  880. package/find-options/operator/Between.js.map +1 -1
  881. package/find-options/operator/ILike.d.ts +6 -0
  882. package/find-options/operator/ILike.js +13 -0
  883. package/find-options/operator/ILike.js.map +1 -0
  884. package/find-options/operator/In.d.ts +1 -1
  885. package/find-options/operator/In.js.map +1 -1
  886. package/find-options/operator/Raw.d.ts +14 -2
  887. package/find-options/operator/Raw.js +5 -6
  888. package/find-options/operator/Raw.js.map +1 -1
  889. package/index.d.ts +10 -11
  890. package/index.js +2 -14
  891. package/index.js.map +1 -1
  892. package/logger/DebugLogger.d.ts +0 -1
  893. package/logger/DebugLogger.js +10 -9
  894. package/logger/DebugLogger.js.map +1 -1
  895. package/logger/FileLogger.d.ts +3 -1
  896. package/logger/FileLogger.js +10 -3
  897. package/logger/FileLogger.js.map +1 -1
  898. package/logger/Logger.d.ts +1 -1
  899. package/logger/Logger.js.map +1 -1
  900. package/logger/LoggerOptions.d.ts +9 -0
  901. package/logger/LoggerOptions.js.map +1 -1
  902. package/metadata/ColumnMetadata.js +24 -14
  903. package/metadata/ColumnMetadata.js.map +1 -1
  904. package/metadata/EntityMetadata.d.ts +1 -0
  905. package/metadata/EntityMetadata.js +11 -3
  906. package/metadata/EntityMetadata.js.map +1 -1
  907. package/metadata/RelationMetadata.js +2 -2
  908. package/metadata/RelationMetadata.js.map +1 -1
  909. package/metadata/types/EventListenerTypes.d.ts +7 -7
  910. package/metadata/types/EventListenerTypes.js.map +1 -1
  911. package/metadata-args/EntityRepositoryMetadataArgs.d.ts +2 -2
  912. package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  913. package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  914. package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  915. package/metadata-builder/EntityMetadataBuilder.js +15 -9
  916. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  917. package/metadata-builder/EntityMetadataValidator.js +8 -5
  918. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  919. package/metadata-builder/JunctionEntityMetadataBuilder.js +1 -0
  920. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  921. package/migration/MigrationExecutor.js +103 -74
  922. package/migration/MigrationExecutor.js.map +1 -1
  923. package/package.json +72 -51
  924. package/persistence/EntityPersistExecutor.js +61 -43
  925. package/persistence/EntityPersistExecutor.js.map +1 -1
  926. package/persistence/Subject.js +2 -1
  927. package/persistence/Subject.js.map +1 -1
  928. package/persistence/SubjectDatabaseEntityLoader.js +2 -1
  929. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  930. package/persistence/SubjectExecutor.js +244 -187
  931. package/persistence/SubjectExecutor.js.map +1 -1
  932. package/persistence/tree/MaterializedPathSubjectExecutor.js +2 -1
  933. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  934. package/platform/PlatformTools.d.ts +7 -1
  935. package/platform/PlatformTools.js +42 -41
  936. package/platform/PlatformTools.js.map +1 -1
  937. package/query-builder/Alias.js.map +1 -1
  938. package/query-builder/DeleteQueryBuilder.d.ts +2 -3
  939. package/query-builder/DeleteQueryBuilder.js +7 -1
  940. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  941. package/query-builder/InsertQueryBuilder.d.ts +2 -3
  942. package/query-builder/InsertQueryBuilder.js +44 -11
  943. package/query-builder/InsertQueryBuilder.js.map +1 -1
  944. package/query-builder/QueryBuilder.d.ts +18 -15
  945. package/query-builder/QueryBuilder.js +198 -48
  946. package/query-builder/QueryBuilder.js.map +1 -1
  947. package/query-builder/QueryExpressionMap.d.ts +4 -0
  948. package/query-builder/QueryExpressionMap.js.map +1 -1
  949. package/query-builder/QueryPartialEntity.d.ts +1 -1
  950. package/query-builder/QueryPartialEntity.js.map +1 -1
  951. package/query-builder/ReturningResultsEntityUpdator.js +23 -24
  952. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  953. package/query-builder/SelectQueryBuilder.d.ts +8 -3
  954. package/query-builder/SelectQueryBuilder.js +80 -32
  955. package/query-builder/SelectQueryBuilder.js.map +1 -1
  956. package/query-builder/SoftDeleteQueryBuilder.d.ts +2 -3
  957. package/query-builder/SoftDeleteQueryBuilder.js +1 -1
  958. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  959. package/query-builder/UpdateQueryBuilder.js +8 -2
  960. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  961. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +6 -3
  962. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  963. package/query-runner/BaseQueryRunner.d.ts +2 -5
  964. package/query-runner/BaseQueryRunner.js +90 -40
  965. package/query-runner/BaseQueryRunner.js.map +1 -1
  966. package/query-runner/QueryRunner.d.ts +1 -1
  967. package/query-runner/QueryRunner.js.map +1 -1
  968. package/repository/AbstractRepository.js.map +1 -1
  969. package/repository/BaseEntity.js +1 -1
  970. package/repository/BaseEntity.js.map +1 -1
  971. package/repository/MongoRepository.js.map +1 -1
  972. package/repository/Repository.js +1 -1
  973. package/repository/Repository.js.map +1 -1
  974. package/repository/TreeRepository.js +2 -2
  975. package/repository/TreeRepository.js.map +1 -1
  976. package/schema-builder/MongoSchemaBuilder.js +1 -1
  977. package/schema-builder/MongoSchemaBuilder.js.map +1 -1
  978. package/schema-builder/RdbmsSchemaBuilder.js +875 -319
  979. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  980. package/schema-builder/options/TableIndexOptions.d.ts +1 -1
  981. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  982. package/schema-builder/view/View.d.ts +1 -2
  983. package/schema-builder/view/View.js.map +1 -1
  984. package/subscriber/Broadcaster.d.ts +24 -0
  985. package/subscriber/Broadcaster.js +120 -0
  986. package/subscriber/Broadcaster.js.map +1 -1
  987. package/subscriber/EntitySubscriberInterface.d.ts +27 -0
  988. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  989. package/subscriber/event/TransactionCommitEvent.d.ts +22 -0
  990. package/subscriber/event/TransactionCommitEvent.js +4 -0
  991. package/subscriber/event/TransactionCommitEvent.js.map +1 -0
  992. package/subscriber/event/TransactionRollbackEvent.d.ts +22 -0
  993. package/subscriber/event/TransactionRollbackEvent.js +4 -0
  994. package/subscriber/event/TransactionRollbackEvent.js.map +1 -0
  995. package/subscriber/event/TransactionStartEvent.d.ts +22 -0
  996. package/subscriber/event/TransactionStartEvent.js +4 -0
  997. package/subscriber/event/TransactionStartEvent.js.map +1 -0
  998. package/typeorm-class-transformer-shim.js +16 -2
  999. package/typeorm-model-shim.js +146 -111
  1000. package/util/ApplyValueTransformers.js.map +1 -1
  1001. package/util/DateUtils.js +1 -7
  1002. package/util/DateUtils.js.map +1 -1
  1003. package/util/DirectoryExportedClassesLoader.js +7 -5
  1004. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  1005. package/util/ObjectUtils.js +2 -2
  1006. package/util/ObjectUtils.js.map +1 -1
  1007. package/util/OrmUtils.js +3 -6
  1008. package/util/OrmUtils.js.map +1 -1
  1009. package/browser/util/PromiseUtils.d.ts +0 -24
  1010. package/browser/util/PromiseUtils.js +0 -62
  1011. package/browser/util/PromiseUtils.js.map +0 -1
  1012. package/util/PromiseUtils.d.ts +0 -24
  1013. package/util/PromiseUtils.js +0 -64
  1014. package/util/PromiseUtils.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/sqljs/SqljsQueryRunner.ts"],"names":[],"mappings":";;;AAAA,+FAA4F;AAC5F,0FAAuF;AAEvF,4DAAyD;AACzD,iEAA8D;AAE9D;;GAEG;AACH;IAAsC,4CAAyB;IAO3D,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,0BAAY,MAAmB;QAA/B,YACI,iBAAO,SAIV;QAHG,KAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,KAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;QACpC,KAAI,CAAC,WAAW,GAAG,IAAI,yBAAW,CAAC,KAAI,CAAC,CAAC;;IAC7C,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E;;;OAGG;IACG,4CAAiB,GAAvB;;;;4BACI,qBAAM,iBAAM,iBAAiB,WAAE,EAAA;;wBAA/B,SAA+B,CAAC;wBAChC,qBAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAA;;wBAA5B,SAA4B,CAAC;;;;;KAChC;IAED;;OAEG;IACH,gCAAK,GAAL,UAAM,KAAa,EAAE,UAAsB;QAA3C,iBAwCC;QAxCoB,2BAAA,EAAA,eAAsB;QACvC,IAAI,IAAI,CAAC,UAAU;YACf,MAAM,IAAI,iEAA+B,EAAE,CAAC;QAEhD,OAAO,IAAI,OAAO,CAAQ,UAAO,EAAE,EAAE,IAAI;;;gBAC/B,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,kBAAkB,CAAC;gBAC1D,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;gBAC1D,cAAc,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;gBAEnC,IAAI;oBACA,SAAS,GAAG,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;oBAC9C,IAAI,UAAU,EAAE;wBACZ,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;qBAC9B;oBAGK,qBAAqB,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,qBAAqB,CAAC;oBAC7E,YAAY,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;oBAC3B,kBAAkB,GAAG,YAAY,GAAG,cAAc,CAAC;oBACzD,IAAI,qBAAqB,IAAI,kBAAkB,GAAG,qBAAqB;wBACnE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,kBAAkB,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;oBAEtF,MAAM,GAAU,EAAE,CAAC;oBAEzB,OAAO,SAAS,CAAC,IAAI,EAAE,EAAE;wBACrB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;qBACxC;oBAED,SAAS,CAAC,IAAI,EAAE,CAAC;oBACjB,EAAE,CAAC,MAAM,CAAC,CAAC;iBACd;gBACD,OAAO,CAAC,EAAE;oBACN,IAAI,SAAS,EAAE;wBACX,SAAS,CAAC,IAAI,EAAE,CAAC;qBACpB;oBAED,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,CAAC;oBACxE,IAAI,CAAC,IAAI,mCAAgB,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;iBACpD;;;aACJ,CAAC,CAAC;IACP,CAAC;IACL,uBAAC;AAAD,CA3EA,AA2EC,CA3EqC,qDAAyB,GA2E9D;AA3EY,4CAAgB","file":"SqljsQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {SqljsDriver} from \"./SqljsDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class SqljsQueryRunner extends AbstractSqliteQueryRunner {\n \n /**\n * Database driver used by connection.\n */\n driver: SqljsDriver;\n \n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqljsDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n // -------------------------------------------------------------------------\n // Public methods\n // -------------------------------------------------------------------------\n \n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n await super.commitTransaction();\n await this.driver.autoSave();\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters: any[] = []): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n return new Promise<any[]>(async (ok, fail) => {\n const databaseConnection = this.driver.databaseConnection;\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n let statement: any;\n try {\n statement = databaseConnection.prepare(query);\n if (parameters) {\n statement.bind(parameters);\n }\n \n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.connection.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n const result: any[] = [];\n\n while (statement.step()) {\n result.push(statement.getAsObject());\n }\n \n statement.free();\n ok(result);\n }\n catch (e) {\n if (statement) {\n statement.free();\n }\n\n this.driver.connection.logger.logQueryError(e, query, parameters, this);\n fail(new QueryFailedError(query, parameters, e));\n }\n });\n }\n}"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/sqljs/SqljsQueryRunner.ts"],"names":[],"mappings":"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","file":"SqljsQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {SqljsDriver} from \"./SqljsDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class SqljsQueryRunner extends AbstractSqliteQueryRunner {\n \n /**\n * Database driver used by connection.\n */\n driver: SqljsDriver;\n \n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqljsDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n // -------------------------------------------------------------------------\n // Public methods\n // -------------------------------------------------------------------------\n \n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n await super.commitTransaction();\n await this.driver.autoSave();\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters: any[] = []): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n return new Promise<any[]>(async (ok, fail) => {\n const databaseConnection = this.driver.databaseConnection;\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n let statement: any;\n try {\n statement = databaseConnection.prepare(query);\n if (parameters) {\n parameters = parameters.map(p => typeof p !== 'undefined' ? p : null);\n\n statement.bind(parameters);\n }\n \n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.connection.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n const result: any[] = [];\n\n while (statement.step()) {\n result.push(statement.getAsObject());\n }\n \n statement.free();\n ok(result);\n }\n catch (e) {\n if (statement) {\n statement.free();\n }\n\n this.driver.connection.logger.logQueryError(e, query, parameters, this);\n fail(new QueryFailedError(query, parameters, e));\n }\n });\n }\n}"],"sourceRoot":"../.."}
@@ -12,6 +12,7 @@ import { MssqlParameter } from "./MssqlParameter";
12
12
  import { TableColumn } from "../../schema-builder/table/TableColumn";
13
13
  import { SqlServerConnectionCredentialsOptions } from "./SqlServerConnectionCredentialsOptions";
14
14
  import { EntityMetadata } from "../../metadata/EntityMetadata";
15
+ import { ReplicationMode } from "../types/ReplicationMode";
15
16
  /**
16
17
  * Organizes communication with SQL Server DBMS.
17
18
  */
@@ -112,7 +113,7 @@ export declare class SqlServerDriver implements Driver {
112
113
  /**
113
114
  * Creates a query runner used to execute database queries.
114
115
  */
115
- createQueryRunner(mode?: "master" | "slave"): SqlServerQueryRunner;
116
+ createQueryRunner(mode: ReplicationMode): SqlServerQueryRunner;
116
117
  /**
117
118
  * Replaces parameters in the given sql with special escaping character
118
119
  * and an array of parameter names to be passed to a query.
@@ -190,6 +191,10 @@ export declare class SqlServerDriver implements Driver {
190
191
  * Returns true if driver supports uuid values generation on its own.
191
192
  */
192
193
  isUUIDGenerationSupported(): boolean;
194
+ /**
195
+ * Returns true if driver supports fulltext indices.
196
+ */
197
+ isFullTextColumnTypeSupported(): boolean;
193
198
  /**
194
199
  * Creates an escaped parameter.
195
200
  */
@@ -266,7 +266,6 @@ var SqlServerDriver = /** @class */ (function () {
266
266
  * Creates a query runner used to execute database queries.
267
267
  */
268
268
  SqlServerDriver.prototype.createQueryRunner = function (mode) {
269
- if (mode === void 0) { mode = "master"; }
270
269
  return new SqlServerQueryRunner_1.SqlServerQueryRunner(this, mode);
271
270
  };
272
271
  /**
@@ -578,6 +577,12 @@ var SqlServerDriver = /** @class */ (function () {
578
577
  SqlServerDriver.prototype.isUUIDGenerationSupported = function () {
579
578
  return true;
580
579
  };
580
+ /**
581
+ * Returns true if driver supports fulltext indices.
582
+ */
583
+ SqlServerDriver.prototype.isFullTextColumnTypeSupported = function () {
584
+ return false;
585
+ };
581
586
  /**
582
587
  * Creates an escaped parameter.
583
588
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/sqlserver/SqlServerDriver.ts"],"names":[],"mappings":"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","file":"SqlServerDriver.js","sourcesContent":["import {Driver} from \"../Driver\";\nimport {ConnectionIsNotSetError} from \"../../error/ConnectionIsNotSetError\";\nimport {DriverPackageNotInstalledError} from \"../../error/DriverPackageNotInstalledError\";\nimport {DriverUtils} from \"../DriverUtils\";\nimport {SqlServerQueryRunner} from \"./SqlServerQueryRunner\";\nimport {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {ColumnMetadata} from \"../../metadata/ColumnMetadata\";\nimport {DateUtils} from \"../../util/DateUtils\";\nimport {PlatformTools} from \"../../platform/PlatformTools\";\nimport {Connection} from \"../../connection/Connection\";\nimport {RdbmsSchemaBuilder} from \"../../schema-builder/RdbmsSchemaBuilder\";\nimport {SqlServerConnectionOptions} from \"./SqlServerConnectionOptions\";\nimport {MappedColumnTypes} from \"../types/MappedColumnTypes\";\nimport {ColumnType} from \"../types/ColumnTypes\";\nimport {DataTypeDefaults} from \"../types/DataTypeDefaults\";\nimport {MssqlParameter} from \"./MssqlParameter\";\nimport {TableColumn} from \"../../schema-builder/table/TableColumn\";\nimport {SqlServerConnectionCredentialsOptions} from \"./SqlServerConnectionCredentialsOptions\";\nimport {EntityMetadata} from \"../../metadata/EntityMetadata\";\nimport {OrmUtils} from \"../../util/OrmUtils\";\nimport {ApplyValueTransformers} from \"../../util/ApplyValueTransformers\";\n\n/**\n * Organizes communication with SQL Server DBMS.\n */\nexport class SqlServerDriver implements Driver {\n\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: Connection;\n\n /**\n * SQL Server library.\n */\n mssql: any;\n\n /**\n * Pool for master database.\n */\n master: any;\n\n /**\n * Pool for slave databases.\n * Used in replication.\n */\n slaves: any[] = [];\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: SqlServerConnectionOptions;\n\n /**\n * Master database used to perform all write queries.\n */\n database?: string;\n\n /**\n * Indicates if replication is enabled.\n */\n isReplicated: boolean = false;\n\n /**\n * Indicates if tree tables are supported by this driver.\n */\n treeSupport = true;\n\n /**\n * Gets list of supported column data types by a driver.\n *\n * @see https://docs.microsoft.com/en-us/sql/t-sql/data-types/data-types-transact-sql\n */\n supportedDataTypes: ColumnType[] = [\n \"int\",\n \"bigint\",\n \"bit\",\n \"decimal\",\n \"money\",\n \"numeric\",\n \"smallint\",\n \"smallmoney\",\n \"tinyint\",\n \"float\",\n \"real\",\n \"date\",\n \"datetime2\",\n \"datetime\",\n \"datetimeoffset\",\n \"smalldatetime\",\n \"time\",\n \"char\",\n \"varchar\",\n \"text\",\n \"nchar\",\n \"nvarchar\",\n \"ntext\",\n \"binary\",\n \"image\",\n \"varbinary\",\n \"hierarchyid\",\n \"sql_variant\",\n \"timestamp\",\n \"uniqueidentifier\",\n \"xml\",\n \"geometry\",\n \"geography\",\n \"rowversion\"\n ];\n\n /**\n * Gets list of spatial column data types.\n */\n spatialTypes: ColumnType[] = [\n \"geometry\",\n \"geography\"\n ];\n\n /**\n * Gets list of column data types that support length by a driver.\n */\n withLengthColumnTypes: ColumnType[] = [\n \"char\",\n \"varchar\",\n \"nchar\",\n \"nvarchar\",\n \"binary\",\n \"varbinary\"\n ];\n\n /**\n * Gets list of column data types that support precision by a driver.\n */\n withPrecisionColumnTypes: ColumnType[] = [\n \"decimal\",\n \"numeric\",\n \"time\",\n \"datetime2\",\n \"datetimeoffset\"\n ];\n\n /**\n * Gets list of column data types that support scale by a driver.\n */\n withScaleColumnTypes: ColumnType[] = [\n \"decimal\",\n \"numeric\"\n ];\n\n /**\n * Orm has special columns and we need to know what database column types should be for those types.\n * Column types are driver dependant.\n */\n mappedDataTypes: MappedColumnTypes = {\n createDate: \"datetime2\",\n createDateDefault: \"getdate()\",\n updateDate: \"datetime2\",\n updateDateDefault: \"getdate()\",\n deleteDate: \"datetime2\",\n deleteDateNullable: true,\n version: \"int\",\n treeLevel: \"int\",\n migrationId: \"int\",\n migrationName: \"varchar\",\n migrationTimestamp: \"bigint\",\n cacheId: \"int\",\n cacheIdentifier: \"nvarchar\",\n cacheTime: \"bigint\",\n cacheDuration: \"int\",\n cacheQuery: \"nvarchar(MAX)\" as any,\n cacheResult: \"nvarchar(MAX)\" as any,\n metadataType: \"varchar\",\n metadataDatabase: \"varchar\",\n metadataSchema: \"varchar\",\n metadataTable: \"varchar\",\n metadataName: \"varchar\",\n metadataValue: \"nvarchar(MAX)\" as any,\n };\n\n /**\n * Default values of length, precision and scale depends on column data type.\n * Used in the cases when length/precision/scale is not specified by user.\n */\n dataTypeDefaults: DataTypeDefaults = {\n \"char\": { length: 1 },\n \"nchar\": { length: 1 },\n \"varchar\": { length: 255 },\n \"nvarchar\": { length: 255 },\n \"binary\": { length: 1 },\n \"varbinary\": { length: 1 },\n \"decimal\": { precision: 18, scale: 0 },\n \"numeric\": { precision: 18, scale: 0 },\n \"time\": { precision: 7 },\n \"datetime2\": { precision: 7 },\n \"datetimeoffset\": { precision: 7 }\n };\n\n /**\n * Max length allowed by MSSQL Server for aliases (identifiers).\n * @see https://docs.microsoft.com/en-us/sql/sql-server/maximum-capacity-specifications-for-sql-server\n */\n maxAliasLength = 128;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n this.connection = connection;\n this.options = connection.options as SqlServerConnectionOptions;\n this.isReplicated = this.options.replication ? true : false;\n\n // load mssql package\n this.loadDependencies();\n\n // Object.assign(connection.options, DriverUtils.buildDriverOptions(connection.options)); // todo: do it better way\n // validate options to make sure everything is set\n // if (!this.options.host)\n // throw new DriverOptionNotSetError(\"host\");\n // if (!this.options.username)\n // throw new DriverOptionNotSetError(\"username\");\n // if (!this.options.database)\n // throw new DriverOptionNotSetError(\"database\");\n }\n\n // -------------------------------------------------------------------------\n // Public Implemented Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n * Based on pooling options, it can either create connection immediately,\n * either create a pool and create connection when needed.\n */\n async connect(): Promise<void> {\n\n if (this.options.replication) {\n this.slaves = await Promise.all(this.options.replication.slaves.map(slave => {\n return this.createPool(this.options, slave);\n }));\n this.master = await this.createPool(this.options, this.options.replication.master);\n this.database = this.options.replication.master.database;\n\n } else {\n this.master = await this.createPool(this.options, this.options);\n this.database = this.options.database;\n }\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n afterConnect(): Promise<void> {\n return Promise.resolve();\n }\n\n /**\n * Closes connection with the database.\n */\n async disconnect(): Promise<void> {\n if (!this.master)\n return Promise.reject(new ConnectionIsNotSetError(\"mssql\"));\n\n await this.closePool(this.master);\n await Promise.all(this.slaves.map(slave => this.closePool(slave)));\n this.master = undefined;\n this.slaves = [];\n }\n\n\n /**\n * Closes connection pool.\n */\n protected async closePool(pool: any): Promise<void> {\n return new Promise<void>((ok, fail) => {\n pool.close((err: any) => err ? fail(err) : ok());\n });\n }\n\n\n /**\n * Creates a schema builder used to build and sync a schema.\n */\n createSchemaBuilder() {\n return new RdbmsSchemaBuilder(this.connection);\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: \"master\"|\"slave\" = \"master\") {\n return new SqlServerQueryRunner(this, mode);\n }\n\n /**\n * Replaces parameters in the given sql with special escaping character\n * and an array of parameter names to be passed to a query.\n */\n escapeQueryWithParameters(sql: string, parameters: ObjectLiteral, nativeParameters: ObjectLiteral): [string, any[]] {\n const escapedParameters: any[] = Object.keys(nativeParameters).map(key => nativeParameters[key]);\n if (!parameters || !Object.keys(parameters).length)\n return [sql, escapedParameters];\n\n const keys = Object.keys(parameters).map(parameter => \"(:(\\\\.\\\\.\\\\.)?\" + parameter + \"\\\\b)\").join(\"|\");\n sql = sql.replace(new RegExp(keys, \"g\"), (key: string) => {\n let value: any;\n let isArray = false;\n if (key.substr(0, 4) === \":...\") {\n isArray = true;\n value = parameters[key.substr(4)];\n } else {\n value = parameters[key.substr(1)];\n }\n\n if (isArray) {\n return value.map((v: any) => {\n escapedParameters.push(v);\n return \"@\" + (escapedParameters.length - 1);\n }).join(\", \");\n\n } else if (value instanceof Function) {\n return value();\n\n } else {\n escapedParameters.push(value);\n return \"@\" + (escapedParameters.length - 1);\n }\n }); // todo: make replace only in value statements, otherwise problems\n return [sql, escapedParameters];\n }\n\n /**\n * Escapes a column name.\n */\n escape(columnName: string): string {\n return `\"${columnName}\"`;\n }\n\n /**\n * Build full table name with database name, schema name and table name.\n * E.g. \"myDB\".\"mySchema\".\"myTable\"\n */\n buildTableName(tableName: string, schema?: string, database?: string): string {\n let fullName = tableName;\n if (schema)\n fullName = schema + \".\" + tableName;\n if (database) {\n if (!schema) {\n fullName = database + \"..\" + tableName;\n } else {\n fullName = database + \".\" + fullName;\n }\n }\n\n return fullName;\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(columnMetadata.transformer, value);\n\n if (value === null || value === undefined)\n return value;\n\n if (columnMetadata.type === Boolean) {\n return value === true ? 1 : 0;\n\n } else if (columnMetadata.type === \"date\") {\n return DateUtils.mixedDateToDate(value);\n\n } else if (columnMetadata.type === \"time\") {\n return DateUtils.mixedTimeToDate(value);\n\n } else if (columnMetadata.type === \"datetime\"\n || columnMetadata.type === \"smalldatetime\"\n || columnMetadata.type === Date) {\n return DateUtils.mixedDateToDate(value, false, false);\n\n } else if (columnMetadata.type === \"datetime2\"\n || columnMetadata.type === \"datetimeoffset\") {\n return DateUtils.mixedDateToDate(value, false, true);\n\n } else if (columnMetadata.type === \"simple-array\") {\n return DateUtils.simpleArrayToString(value);\n\n } else if (columnMetadata.type === \"simple-json\") {\n return DateUtils.simpleJsonToString(value);\n\n } else if (columnMetadata.type === \"simple-enum\") {\n return DateUtils.simpleEnumToString(value);\n\n }\n\n return value;\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type or metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (value === null || value === undefined)\n return columnMetadata.transformer ? ApplyValueTransformers.transformFrom(columnMetadata.transformer, value) : value;\n\n if (columnMetadata.type === Boolean) {\n value = value ? true : false;\n\n } else if (columnMetadata.type === \"datetime\"\n || columnMetadata.type === Date\n || columnMetadata.type === \"datetime2\"\n || columnMetadata.type === \"smalldatetime\"\n || columnMetadata.type === \"datetimeoffset\") {\n value = DateUtils.normalizeHydratedDate(value);\n\n } else if (columnMetadata.type === \"date\") {\n value = DateUtils.mixedDateToDateString(value);\n\n } else if (columnMetadata.type === \"time\") {\n value = DateUtils.mixedTimeToString(value);\n\n } else if (columnMetadata.type === \"simple-array\") {\n value = DateUtils.stringToSimpleArray(value);\n\n } else if (columnMetadata.type === \"simple-json\") {\n value = DateUtils.stringToSimpleJson(value);\n\n } else if (columnMetadata.type === \"simple-enum\") {\n value = DateUtils.stringToSimpleEnum(value, columnMetadata);\n\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);\n\n return value;\n }\n\n /**\n * Creates a database type from a given column metadata.\n */\n normalizeType(column: { type?: ColumnType, length?: number | string, precision?: number|null, scale?: number }): string {\n if (column.type === Number || column.type === \"integer\") {\n return \"int\";\n\n } else if (column.type === String) {\n return \"nvarchar\";\n\n } else if (column.type === Date) {\n return \"datetime\";\n\n } else if (column.type === Boolean) {\n return \"bit\";\n\n } else if ((column.type as any) === Buffer) {\n return \"binary\";\n\n } else if (column.type === \"uuid\") {\n return \"uniqueidentifier\";\n\n } else if (column.type === \"simple-array\" || column.type === \"simple-json\") {\n return \"ntext\";\n\n } else if (column.type === \"simple-enum\") {\n return \"nvarchar\";\n\n } else if (column.type === \"dec\") {\n return \"decimal\";\n\n } else if (column.type === \"double precision\") {\n return \"float\";\n\n } else if (column.type === \"rowversion\") {\n return \"timestamp\"; // the rowversion type's name in SQL server metadata is timestamp\n\n } else {\n return column.type as string || \"\";\n }\n }\n\n /**\n * Normalizes \"default\" value of the column.\n */\n normalizeDefault(columnMetadata: ColumnMetadata): string {\n const defaultValue = columnMetadata.default;\n\n if (typeof defaultValue === \"number\") {\n return \"\" + defaultValue;\n\n } else if (typeof defaultValue === \"boolean\") {\n return defaultValue === true ? \"1\" : \"0\";\n\n } else if (typeof defaultValue === \"function\") {\n return /*\"(\" + */defaultValue()/* + \")\"*/;\n\n } else if (typeof defaultValue === \"string\") {\n return `'${defaultValue}'`;\n\n } else {\n return defaultValue;\n }\n }\n\n /**\n * Normalizes \"isUnique\" value of the column.\n */\n normalizeIsUnique(column: ColumnMetadata): boolean {\n return column.entityMetadata.uniques.some(uq => uq.columns.length === 1 && uq.columns[0] === column);\n }\n\n /**\n * Returns default column lengths, which is required on column creation.\n */\n getColumnLength(column: ColumnMetadata|TableColumn): string {\n if (column.length)\n return column.length.toString();\n\n if (column.type === \"varchar\" || column.type === \"nvarchar\" || column.type === String)\n return \"255\";\n\n return \"\";\n }\n\n /**\n * Creates column type definition including length, precision and scale\n */\n createFullType(column: TableColumn): string {\n let type = column.type;\n\n // used 'getColumnLength()' method, because SqlServer sets `varchar` and `nvarchar` length to 1 by default.\n if (this.getColumnLength(column)) {\n type += `(${this.getColumnLength(column)})`;\n\n } else if (column.precision !== null && column.precision !== undefined && column.scale !== null && column.scale !== undefined) {\n type += `(${column.precision},${column.scale})`;\n\n } else if (column.precision !== null && column.precision !== undefined) {\n type += `(${column.precision})`;\n }\n\n if (column.isArray)\n type += \" array\";\n\n return type;\n }\n\n /**\n * Obtains a new database connection to a master server.\n * Used for replication.\n * If replication is not setup then returns default connection's database connection.\n */\n obtainMasterConnection(): Promise<any> {\n return Promise.resolve(this.master);\n }\n\n /**\n * Obtains a new database connection to a slave server.\n * Used for replication.\n * If replication is not setup then returns master (default) connection's database connection.\n */\n obtainSlaveConnection(): Promise<any> {\n if (!this.slaves.length)\n return this.obtainMasterConnection();\n\n const random = Math.floor(Math.random() * this.slaves.length);\n return Promise.resolve(this.slaves[random]);\n }\n\n /**\n * Creates generated map of values generated or returned by database after INSERT query.\n */\n createGeneratedMap(metadata: EntityMetadata, insertResult: ObjectLiteral) {\n if (!insertResult)\n return undefined;\n\n return Object.keys(insertResult).reduce((map, key) => {\n const column = metadata.findColumnWithDatabaseName(key);\n if (column) {\n OrmUtils.mergeDeep(map, column.createValueMap(this.prepareHydratedValue(insertResult[key], column)));\n }\n return map;\n }, {} as ObjectLiteral);\n }\n\n /**\n * Differentiate columns of this table and columns from the given column metadatas columns\n * and returns only changed.\n */\n findChangedColumns(tableColumns: TableColumn[], columnMetadatas: ColumnMetadata[]): ColumnMetadata[] {\n return columnMetadatas.filter(columnMetadata => {\n const tableColumn = tableColumns.find(c => c.name === columnMetadata.databaseName);\n if (!tableColumn)\n return false; // we don't need new columns, we only need exist and changed\n\n return tableColumn.name !== columnMetadata.databaseName\n || tableColumn.type !== this.normalizeType(columnMetadata)\n || tableColumn.length !== columnMetadata.length\n || tableColumn.precision !== columnMetadata.precision\n || tableColumn.scale !== columnMetadata.scale\n // || tableColumn.comment !== columnMetadata.comment || // todo\n || (!tableColumn.isGenerated && this.lowerDefaultValueIfNessesary(this.normalizeDefault(columnMetadata)) !== this.lowerDefaultValueIfNessesary(tableColumn.default)) // we included check for generated here, because generated columns already can have default values\n || tableColumn.isPrimary !== columnMetadata.isPrimary\n || tableColumn.isNullable !== columnMetadata.isNullable\n || tableColumn.isUnique !== this.normalizeIsUnique(columnMetadata)\n || tableColumn.isGenerated !== columnMetadata.isGenerated;\n });\n }\n private lowerDefaultValueIfNessesary(value: string | undefined) {\n // SqlServer saves function calls in default value as lowercase https://github.com/typeorm/typeorm/issues/2733\n if (!value) {\n return value;\n }\n return value.split(`'`).map((v, i) => {\n return i % 2 === 1 ? v : v.toLowerCase();\n }).join(`'`);\n }\n /**\n * Returns true if driver supports RETURNING / OUTPUT statement.\n */\n isReturningSqlSupported(): boolean {\n if (this.options.options && this.options.options.disableOutputReturning) {\n return false;\n }\n return true;\n }\n\n /**\n * Returns true if driver supports uuid values generation on its own.\n */\n isUUIDGenerationSupported(): boolean {\n return true;\n }\n\n /**\n * Creates an escaped parameter.\n */\n createParameter(parameterName: string, index: number): string {\n return \"@\" + index;\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Sql server's parameters needs to be wrapped into special object with type information about this value.\n * This method wraps given value into MssqlParameter based on its column definition.\n */\n parametrizeValue(column: ColumnMetadata, value: any) {\n\n // if its already MssqlParameter then simply return it\n if (value instanceof MssqlParameter)\n return value;\n\n const normalizedType = this.normalizeType({ type: column.type });\n if (column.length) {\n return new MssqlParameter(value, normalizedType as any, column.length as any);\n\n } else if (column.precision !== null && column.precision !== undefined && column.scale !== null && column.scale !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.precision, column.scale);\n\n } else if (column.precision !== null && column.precision !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.precision);\n\n } else if (column.scale !== null && column.scale !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.scale);\n }\n\n return new MssqlParameter(value, normalizedType as any);\n }\n\n /**\n * Sql server's parameters needs to be wrapped into special object with type information about this value.\n * This method wraps all values of the given object into MssqlParameter based on their column definitions in the given table.\n */\n parametrizeMap(tablePath: string, map: ObjectLiteral): ObjectLiteral {\n\n // find metadata for the given table\n if (!this.connection.hasMetadata(tablePath)) // if no metadata found then we can't proceed because we don't have columns and their types\n return map;\n const metadata = this.connection.getMetadata(tablePath);\n\n return Object.keys(map).reduce((newMap, key) => {\n const value = map[key];\n\n // find column metadata\n const column = metadata.findColumnWithDatabaseName(key);\n if (!column) // if we didn't find a column then we can't proceed because we don't have a column type\n return value;\n\n newMap[key] = this.parametrizeValue(column, value);\n return newMap;\n }, {} as ObjectLiteral);\n }\n\n buildTableVariableDeclaration(identifier: string, columns: ColumnMetadata[]): string {\n const outputColumns = columns.map(column => {\n return `${this.escape(column.databaseName)} ${this.createFullType(new TableColumn({\n name: column.databaseName,\n type: this.normalizeType(column),\n length: column.length,\n isNullable: column.isNullable,\n isArray: column.isArray,\n }))}`;\n });\n\n return `DECLARE ${identifier} TABLE (${outputColumns.join(\", \")})`;\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * If driver dependency is not given explicitly, then try to load it via \"require\".\n */\n protected loadDependencies(): void {\n try {\n this.mssql = PlatformTools.load(\"mssql\");\n\n } catch (e) { // todo: better error for browser env\n throw new DriverPackageNotInstalledError(\"SQL Server\", \"mssql\");\n }\n }\n\n /**\n * Creates a new connection pool for a given database credentials.\n */\n protected createPool(options: SqlServerConnectionOptions, credentials: SqlServerConnectionCredentialsOptions): Promise<any> {\n\n credentials = Object.assign({}, credentials, DriverUtils.buildDriverOptions(credentials)); // todo: do it better way\n\n // build connection options for the driver\n const connectionOptions = Object.assign({}, {\n connectionTimeout: this.options.connectionTimeout,\n requestTimeout: this.options.requestTimeout,\n stream: this.options.stream,\n pool: this.options.pool,\n options: this.options.options,\n }, {\n server: credentials.host,\n user: credentials.username,\n password: credentials.password,\n database: credentials.database,\n port: credentials.port,\n domain: credentials.domain,\n }, options.extra || {});\n\n // set default useUTC option if it hasn't been set\n if (!connectionOptions.options) connectionOptions.options = { useUTC: false };\n else if (!connectionOptions.options.useUTC) connectionOptions.options.useUTC = false;\n\n // pooling is enabled either when its set explicitly to true,\n // either when its not defined at all (e.g. enabled by default)\n return new Promise<void>((ok, fail) => {\n const pool = new this.mssql.ConnectionPool(connectionOptions);\n\n const { logger } = this.connection;\n\n const poolErrorHandler = (options.pool && options.pool.errorHandler) || ((error: any) => logger.log(\"warn\", `MSSQL pool raised an error. ${error}`));\n /*\n Attaching an error handler to pool errors is essential, as, otherwise, errors raised will go unhandled and\n cause the hosting app to crash.\n */\n pool.on(\"error\", poolErrorHandler);\n\n const connection = pool.connect((err: any) => {\n if (err) return fail(err);\n ok(connection);\n });\n });\n }\n\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/sqlserver/SqlServerDriver.ts"],"names":[],"mappings":"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","file":"SqlServerDriver.js","sourcesContent":["import {Driver} from \"../Driver\";\nimport {ConnectionIsNotSetError} from \"../../error/ConnectionIsNotSetError\";\nimport {DriverPackageNotInstalledError} from \"../../error/DriverPackageNotInstalledError\";\nimport {DriverUtils} from \"../DriverUtils\";\nimport {SqlServerQueryRunner} from \"./SqlServerQueryRunner\";\nimport {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {ColumnMetadata} from \"../../metadata/ColumnMetadata\";\nimport {DateUtils} from \"../../util/DateUtils\";\nimport {PlatformTools} from \"../../platform/PlatformTools\";\nimport {Connection} from \"../../connection/Connection\";\nimport {RdbmsSchemaBuilder} from \"../../schema-builder/RdbmsSchemaBuilder\";\nimport {SqlServerConnectionOptions} from \"./SqlServerConnectionOptions\";\nimport {MappedColumnTypes} from \"../types/MappedColumnTypes\";\nimport {ColumnType} from \"../types/ColumnTypes\";\nimport {DataTypeDefaults} from \"../types/DataTypeDefaults\";\nimport {MssqlParameter} from \"./MssqlParameter\";\nimport {TableColumn} from \"../../schema-builder/table/TableColumn\";\nimport {SqlServerConnectionCredentialsOptions} from \"./SqlServerConnectionCredentialsOptions\";\nimport {EntityMetadata} from \"../../metadata/EntityMetadata\";\nimport {OrmUtils} from \"../../util/OrmUtils\";\nimport {ApplyValueTransformers} from \"../../util/ApplyValueTransformers\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\n\n/**\n * Organizes communication with SQL Server DBMS.\n */\nexport class SqlServerDriver implements Driver {\n\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: Connection;\n\n /**\n * SQL Server library.\n */\n mssql: any;\n\n /**\n * Pool for master database.\n */\n master: any;\n\n /**\n * Pool for slave databases.\n * Used in replication.\n */\n slaves: any[] = [];\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: SqlServerConnectionOptions;\n\n /**\n * Master database used to perform all write queries.\n */\n database?: string;\n\n /**\n * Indicates if replication is enabled.\n */\n isReplicated: boolean = false;\n\n /**\n * Indicates if tree tables are supported by this driver.\n */\n treeSupport = true;\n\n /**\n * Gets list of supported column data types by a driver.\n *\n * @see https://docs.microsoft.com/en-us/sql/t-sql/data-types/data-types-transact-sql\n */\n supportedDataTypes: ColumnType[] = [\n \"int\",\n \"bigint\",\n \"bit\",\n \"decimal\",\n \"money\",\n \"numeric\",\n \"smallint\",\n \"smallmoney\",\n \"tinyint\",\n \"float\",\n \"real\",\n \"date\",\n \"datetime2\",\n \"datetime\",\n \"datetimeoffset\",\n \"smalldatetime\",\n \"time\",\n \"char\",\n \"varchar\",\n \"text\",\n \"nchar\",\n \"nvarchar\",\n \"ntext\",\n \"binary\",\n \"image\",\n \"varbinary\",\n \"hierarchyid\",\n \"sql_variant\",\n \"timestamp\",\n \"uniqueidentifier\",\n \"xml\",\n \"geometry\",\n \"geography\",\n \"rowversion\"\n ];\n\n /**\n * Gets list of spatial column data types.\n */\n spatialTypes: ColumnType[] = [\n \"geometry\",\n \"geography\"\n ];\n\n /**\n * Gets list of column data types that support length by a driver.\n */\n withLengthColumnTypes: ColumnType[] = [\n \"char\",\n \"varchar\",\n \"nchar\",\n \"nvarchar\",\n \"binary\",\n \"varbinary\"\n ];\n\n /**\n * Gets list of column data types that support precision by a driver.\n */\n withPrecisionColumnTypes: ColumnType[] = [\n \"decimal\",\n \"numeric\",\n \"time\",\n \"datetime2\",\n \"datetimeoffset\"\n ];\n\n /**\n * Gets list of column data types that support scale by a driver.\n */\n withScaleColumnTypes: ColumnType[] = [\n \"decimal\",\n \"numeric\"\n ];\n\n /**\n * Orm has special columns and we need to know what database column types should be for those types.\n * Column types are driver dependant.\n */\n mappedDataTypes: MappedColumnTypes = {\n createDate: \"datetime2\",\n createDateDefault: \"getdate()\",\n updateDate: \"datetime2\",\n updateDateDefault: \"getdate()\",\n deleteDate: \"datetime2\",\n deleteDateNullable: true,\n version: \"int\",\n treeLevel: \"int\",\n migrationId: \"int\",\n migrationName: \"varchar\",\n migrationTimestamp: \"bigint\",\n cacheId: \"int\",\n cacheIdentifier: \"nvarchar\",\n cacheTime: \"bigint\",\n cacheDuration: \"int\",\n cacheQuery: \"nvarchar(MAX)\" as any,\n cacheResult: \"nvarchar(MAX)\" as any,\n metadataType: \"varchar\",\n metadataDatabase: \"varchar\",\n metadataSchema: \"varchar\",\n metadataTable: \"varchar\",\n metadataName: \"varchar\",\n metadataValue: \"nvarchar(MAX)\" as any,\n };\n\n /**\n * Default values of length, precision and scale depends on column data type.\n * Used in the cases when length/precision/scale is not specified by user.\n */\n dataTypeDefaults: DataTypeDefaults = {\n \"char\": { length: 1 },\n \"nchar\": { length: 1 },\n \"varchar\": { length: 255 },\n \"nvarchar\": { length: 255 },\n \"binary\": { length: 1 },\n \"varbinary\": { length: 1 },\n \"decimal\": { precision: 18, scale: 0 },\n \"numeric\": { precision: 18, scale: 0 },\n \"time\": { precision: 7 },\n \"datetime2\": { precision: 7 },\n \"datetimeoffset\": { precision: 7 }\n };\n\n /**\n * Max length allowed by MSSQL Server for aliases (identifiers).\n * @see https://docs.microsoft.com/en-us/sql/sql-server/maximum-capacity-specifications-for-sql-server\n */\n maxAliasLength = 128;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n this.connection = connection;\n this.options = connection.options as SqlServerConnectionOptions;\n this.isReplicated = this.options.replication ? true : false;\n\n // load mssql package\n this.loadDependencies();\n\n // Object.assign(connection.options, DriverUtils.buildDriverOptions(connection.options)); // todo: do it better way\n // validate options to make sure everything is set\n // if (!this.options.host)\n // throw new DriverOptionNotSetError(\"host\");\n // if (!this.options.username)\n // throw new DriverOptionNotSetError(\"username\");\n // if (!this.options.database)\n // throw new DriverOptionNotSetError(\"database\");\n }\n\n // -------------------------------------------------------------------------\n // Public Implemented Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n * Based on pooling options, it can either create connection immediately,\n * either create a pool and create connection when needed.\n */\n async connect(): Promise<void> {\n\n if (this.options.replication) {\n this.slaves = await Promise.all(this.options.replication.slaves.map(slave => {\n return this.createPool(this.options, slave);\n }));\n this.master = await this.createPool(this.options, this.options.replication.master);\n this.database = this.options.replication.master.database;\n\n } else {\n this.master = await this.createPool(this.options, this.options);\n this.database = this.options.database;\n }\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n afterConnect(): Promise<void> {\n return Promise.resolve();\n }\n\n /**\n * Closes connection with the database.\n */\n async disconnect(): Promise<void> {\n if (!this.master)\n return Promise.reject(new ConnectionIsNotSetError(\"mssql\"));\n\n await this.closePool(this.master);\n await Promise.all(this.slaves.map(slave => this.closePool(slave)));\n this.master = undefined;\n this.slaves = [];\n }\n\n\n /**\n * Closes connection pool.\n */\n protected async closePool(pool: any): Promise<void> {\n return new Promise<void>((ok, fail) => {\n pool.close((err: any) => err ? fail(err) : ok());\n });\n }\n\n\n /**\n * Creates a schema builder used to build and sync a schema.\n */\n createSchemaBuilder() {\n return new RdbmsSchemaBuilder(this.connection);\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode) {\n return new SqlServerQueryRunner(this, mode);\n }\n\n /**\n * Replaces parameters in the given sql with special escaping character\n * and an array of parameter names to be passed to a query.\n */\n escapeQueryWithParameters(sql: string, parameters: ObjectLiteral, nativeParameters: ObjectLiteral): [string, any[]] {\n const escapedParameters: any[] = Object.keys(nativeParameters).map(key => nativeParameters[key]);\n if (!parameters || !Object.keys(parameters).length)\n return [sql, escapedParameters];\n\n const keys = Object.keys(parameters).map(parameter => \"(:(\\\\.\\\\.\\\\.)?\" + parameter + \"\\\\b)\").join(\"|\");\n sql = sql.replace(new RegExp(keys, \"g\"), (key: string) => {\n let value: any;\n let isArray = false;\n if (key.substr(0, 4) === \":...\") {\n isArray = true;\n value = parameters[key.substr(4)];\n } else {\n value = parameters[key.substr(1)];\n }\n\n if (isArray) {\n return value.map((v: any) => {\n escapedParameters.push(v);\n return \"@\" + (escapedParameters.length - 1);\n }).join(\", \");\n\n } else if (value instanceof Function) {\n return value();\n\n } else {\n escapedParameters.push(value);\n return \"@\" + (escapedParameters.length - 1);\n }\n }); // todo: make replace only in value statements, otherwise problems\n return [sql, escapedParameters];\n }\n\n /**\n * Escapes a column name.\n */\n escape(columnName: string): string {\n return `\"${columnName}\"`;\n }\n\n /**\n * Build full table name with database name, schema name and table name.\n * E.g. \"myDB\".\"mySchema\".\"myTable\"\n */\n buildTableName(tableName: string, schema?: string, database?: string): string {\n let fullName = tableName;\n if (schema)\n fullName = schema + \".\" + tableName;\n if (database) {\n if (!schema) {\n fullName = database + \"..\" + tableName;\n } else {\n fullName = database + \".\" + fullName;\n }\n }\n\n return fullName;\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(columnMetadata.transformer, value);\n\n if (value === null || value === undefined)\n return value;\n\n if (columnMetadata.type === Boolean) {\n return value === true ? 1 : 0;\n\n } else if (columnMetadata.type === \"date\") {\n return DateUtils.mixedDateToDate(value);\n\n } else if (columnMetadata.type === \"time\") {\n return DateUtils.mixedTimeToDate(value);\n\n } else if (columnMetadata.type === \"datetime\"\n || columnMetadata.type === \"smalldatetime\"\n || columnMetadata.type === Date) {\n return DateUtils.mixedDateToDate(value, false, false);\n\n } else if (columnMetadata.type === \"datetime2\"\n || columnMetadata.type === \"datetimeoffset\") {\n return DateUtils.mixedDateToDate(value, false, true);\n\n } else if (columnMetadata.type === \"simple-array\") {\n return DateUtils.simpleArrayToString(value);\n\n } else if (columnMetadata.type === \"simple-json\") {\n return DateUtils.simpleJsonToString(value);\n\n } else if (columnMetadata.type === \"simple-enum\") {\n return DateUtils.simpleEnumToString(value);\n\n }\n\n return value;\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type or metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (value === null || value === undefined)\n return columnMetadata.transformer ? ApplyValueTransformers.transformFrom(columnMetadata.transformer, value) : value;\n\n if (columnMetadata.type === Boolean) {\n value = value ? true : false;\n\n } else if (columnMetadata.type === \"datetime\"\n || columnMetadata.type === Date\n || columnMetadata.type === \"datetime2\"\n || columnMetadata.type === \"smalldatetime\"\n || columnMetadata.type === \"datetimeoffset\") {\n value = DateUtils.normalizeHydratedDate(value);\n\n } else if (columnMetadata.type === \"date\") {\n value = DateUtils.mixedDateToDateString(value);\n\n } else if (columnMetadata.type === \"time\") {\n value = DateUtils.mixedTimeToString(value);\n\n } else if (columnMetadata.type === \"simple-array\") {\n value = DateUtils.stringToSimpleArray(value);\n\n } else if (columnMetadata.type === \"simple-json\") {\n value = DateUtils.stringToSimpleJson(value);\n\n } else if (columnMetadata.type === \"simple-enum\") {\n value = DateUtils.stringToSimpleEnum(value, columnMetadata);\n\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);\n\n return value;\n }\n\n /**\n * Creates a database type from a given column metadata.\n */\n normalizeType(column: { type?: ColumnType, length?: number | string, precision?: number|null, scale?: number }): string {\n if (column.type === Number || column.type === \"integer\") {\n return \"int\";\n\n } else if (column.type === String) {\n return \"nvarchar\";\n\n } else if (column.type === Date) {\n return \"datetime\";\n\n } else if (column.type === Boolean) {\n return \"bit\";\n\n } else if ((column.type as any) === Buffer) {\n return \"binary\";\n\n } else if (column.type === \"uuid\") {\n return \"uniqueidentifier\";\n\n } else if (column.type === \"simple-array\" || column.type === \"simple-json\") {\n return \"ntext\";\n\n } else if (column.type === \"simple-enum\") {\n return \"nvarchar\";\n\n } else if (column.type === \"dec\") {\n return \"decimal\";\n\n } else if (column.type === \"double precision\") {\n return \"float\";\n\n } else if (column.type === \"rowversion\") {\n return \"timestamp\"; // the rowversion type's name in SQL server metadata is timestamp\n\n } else {\n return column.type as string || \"\";\n }\n }\n\n /**\n * Normalizes \"default\" value of the column.\n */\n normalizeDefault(columnMetadata: ColumnMetadata): string {\n const defaultValue = columnMetadata.default;\n\n if (typeof defaultValue === \"number\") {\n return \"\" + defaultValue;\n\n } else if (typeof defaultValue === \"boolean\") {\n return defaultValue === true ? \"1\" : \"0\";\n\n } else if (typeof defaultValue === \"function\") {\n return /*\"(\" + */defaultValue()/* + \")\"*/;\n\n } else if (typeof defaultValue === \"string\") {\n return `'${defaultValue}'`;\n\n } else {\n return defaultValue;\n }\n }\n\n /**\n * Normalizes \"isUnique\" value of the column.\n */\n normalizeIsUnique(column: ColumnMetadata): boolean {\n return column.entityMetadata.uniques.some(uq => uq.columns.length === 1 && uq.columns[0] === column);\n }\n\n /**\n * Returns default column lengths, which is required on column creation.\n */\n getColumnLength(column: ColumnMetadata|TableColumn): string {\n if (column.length)\n return column.length.toString();\n\n if (column.type === \"varchar\" || column.type === \"nvarchar\" || column.type === String)\n return \"255\";\n\n return \"\";\n }\n\n /**\n * Creates column type definition including length, precision and scale\n */\n createFullType(column: TableColumn): string {\n let type = column.type;\n\n // used 'getColumnLength()' method, because SqlServer sets `varchar` and `nvarchar` length to 1 by default.\n if (this.getColumnLength(column)) {\n type += `(${this.getColumnLength(column)})`;\n\n } else if (column.precision !== null && column.precision !== undefined && column.scale !== null && column.scale !== undefined) {\n type += `(${column.precision},${column.scale})`;\n\n } else if (column.precision !== null && column.precision !== undefined) {\n type += `(${column.precision})`;\n }\n\n if (column.isArray)\n type += \" array\";\n\n return type;\n }\n\n /**\n * Obtains a new database connection to a master server.\n * Used for replication.\n * If replication is not setup then returns default connection's database connection.\n */\n obtainMasterConnection(): Promise<any> {\n return Promise.resolve(this.master);\n }\n\n /**\n * Obtains a new database connection to a slave server.\n * Used for replication.\n * If replication is not setup then returns master (default) connection's database connection.\n */\n obtainSlaveConnection(): Promise<any> {\n if (!this.slaves.length)\n return this.obtainMasterConnection();\n\n const random = Math.floor(Math.random() * this.slaves.length);\n return Promise.resolve(this.slaves[random]);\n }\n\n /**\n * Creates generated map of values generated or returned by database after INSERT query.\n */\n createGeneratedMap(metadata: EntityMetadata, insertResult: ObjectLiteral) {\n if (!insertResult)\n return undefined;\n\n return Object.keys(insertResult).reduce((map, key) => {\n const column = metadata.findColumnWithDatabaseName(key);\n if (column) {\n OrmUtils.mergeDeep(map, column.createValueMap(this.prepareHydratedValue(insertResult[key], column)));\n }\n return map;\n }, {} as ObjectLiteral);\n }\n\n /**\n * Differentiate columns of this table and columns from the given column metadatas columns\n * and returns only changed.\n */\n findChangedColumns(tableColumns: TableColumn[], columnMetadatas: ColumnMetadata[]): ColumnMetadata[] {\n return columnMetadatas.filter(columnMetadata => {\n const tableColumn = tableColumns.find(c => c.name === columnMetadata.databaseName);\n if (!tableColumn)\n return false; // we don't need new columns, we only need exist and changed\n\n return tableColumn.name !== columnMetadata.databaseName\n || tableColumn.type !== this.normalizeType(columnMetadata)\n || tableColumn.length !== columnMetadata.length\n || tableColumn.precision !== columnMetadata.precision\n || tableColumn.scale !== columnMetadata.scale\n // || tableColumn.comment !== columnMetadata.comment || // todo\n || (!tableColumn.isGenerated && this.lowerDefaultValueIfNessesary(this.normalizeDefault(columnMetadata)) !== this.lowerDefaultValueIfNessesary(tableColumn.default)) // we included check for generated here, because generated columns already can have default values\n || tableColumn.isPrimary !== columnMetadata.isPrimary\n || tableColumn.isNullable !== columnMetadata.isNullable\n || tableColumn.isUnique !== this.normalizeIsUnique(columnMetadata)\n || tableColumn.isGenerated !== columnMetadata.isGenerated;\n });\n }\n private lowerDefaultValueIfNessesary(value: string | undefined) {\n // SqlServer saves function calls in default value as lowercase https://github.com/typeorm/typeorm/issues/2733\n if (!value) {\n return value;\n }\n return value.split(`'`).map((v, i) => {\n return i % 2 === 1 ? v : v.toLowerCase();\n }).join(`'`);\n }\n /**\n * Returns true if driver supports RETURNING / OUTPUT statement.\n */\n isReturningSqlSupported(): boolean {\n if (this.options.options && this.options.options.disableOutputReturning) {\n return false;\n }\n return true;\n }\n\n /**\n * Returns true if driver supports uuid values generation on its own.\n */\n isUUIDGenerationSupported(): boolean {\n return true;\n }\n\n /**\n * Returns true if driver supports fulltext indices.\n */\n isFullTextColumnTypeSupported(): boolean {\n return false;\n }\n\n /**\n * Creates an escaped parameter.\n */\n createParameter(parameterName: string, index: number): string {\n return \"@\" + index;\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Sql server's parameters needs to be wrapped into special object with type information about this value.\n * This method wraps given value into MssqlParameter based on its column definition.\n */\n parametrizeValue(column: ColumnMetadata, value: any) {\n\n // if its already MssqlParameter then simply return it\n if (value instanceof MssqlParameter)\n return value;\n\n const normalizedType = this.normalizeType({ type: column.type });\n if (column.length) {\n return new MssqlParameter(value, normalizedType as any, column.length as any);\n\n } else if (column.precision !== null && column.precision !== undefined && column.scale !== null && column.scale !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.precision, column.scale);\n\n } else if (column.precision !== null && column.precision !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.precision);\n\n } else if (column.scale !== null && column.scale !== undefined) {\n return new MssqlParameter(value, normalizedType as any, column.scale);\n }\n\n return new MssqlParameter(value, normalizedType as any);\n }\n\n /**\n * Sql server's parameters needs to be wrapped into special object with type information about this value.\n * This method wraps all values of the given object into MssqlParameter based on their column definitions in the given table.\n */\n parametrizeMap(tablePath: string, map: ObjectLiteral): ObjectLiteral {\n\n // find metadata for the given table\n if (!this.connection.hasMetadata(tablePath)) // if no metadata found then we can't proceed because we don't have columns and their types\n return map;\n const metadata = this.connection.getMetadata(tablePath);\n\n return Object.keys(map).reduce((newMap, key) => {\n const value = map[key];\n\n // find column metadata\n const column = metadata.findColumnWithDatabaseName(key);\n if (!column) // if we didn't find a column then we can't proceed because we don't have a column type\n return value;\n\n newMap[key] = this.parametrizeValue(column, value);\n return newMap;\n }, {} as ObjectLiteral);\n }\n\n buildTableVariableDeclaration(identifier: string, columns: ColumnMetadata[]): string {\n const outputColumns = columns.map(column => {\n return `${this.escape(column.databaseName)} ${this.createFullType(new TableColumn({\n name: column.databaseName,\n type: this.normalizeType(column),\n length: column.length,\n isNullable: column.isNullable,\n isArray: column.isArray,\n }))}`;\n });\n\n return `DECLARE ${identifier} TABLE (${outputColumns.join(\", \")})`;\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * If driver dependency is not given explicitly, then try to load it via \"require\".\n */\n protected loadDependencies(): void {\n try {\n this.mssql = PlatformTools.load(\"mssql\");\n\n } catch (e) { // todo: better error for browser env\n throw new DriverPackageNotInstalledError(\"SQL Server\", \"mssql\");\n }\n }\n\n /**\n * Creates a new connection pool for a given database credentials.\n */\n protected createPool(options: SqlServerConnectionOptions, credentials: SqlServerConnectionCredentialsOptions): Promise<any> {\n\n credentials = Object.assign({}, credentials, DriverUtils.buildDriverOptions(credentials)); // todo: do it better way\n\n // build connection options for the driver\n const connectionOptions = Object.assign({}, {\n connectionTimeout: this.options.connectionTimeout,\n requestTimeout: this.options.requestTimeout,\n stream: this.options.stream,\n pool: this.options.pool,\n options: this.options.options,\n }, {\n server: credentials.host,\n user: credentials.username,\n password: credentials.password,\n database: credentials.database,\n port: credentials.port,\n domain: credentials.domain,\n }, options.extra || {});\n\n // set default useUTC option if it hasn't been set\n if (!connectionOptions.options) connectionOptions.options = { useUTC: false };\n else if (!connectionOptions.options.useUTC) connectionOptions.options.useUTC = false;\n\n // pooling is enabled either when its set explicitly to true,\n // either when its not defined at all (e.g. enabled by default)\n return new Promise<void>((ok, fail) => {\n const pool = new this.mssql.ConnectionPool(connectionOptions);\n\n const { logger } = this.connection;\n\n const poolErrorHandler = (options.pool && options.pool.errorHandler) || ((error: any) => logger.log(\"warn\", `MSSQL pool raised an error. ${error}`));\n /*\n Attaching an error handler to pool errors is essential, as, otherwise, errors raised will go unhandled and\n cause the hosting app to crash.\n */\n pool.on(\"error\", poolErrorHandler);\n\n const connection = pool.connect((err: any) => {\n if (err) return fail(err);\n ok(connection);\n });\n });\n }\n\n}\n"],"sourceRoot":"../.."}
@@ -14,6 +14,7 @@ import { Query } from "../Query";
14
14
  import { IsolationLevel } from "../types/IsolationLevel";
15
15
  import { MssqlParameter } from "./MssqlParameter";
16
16
  import { SqlServerDriver } from "./SqlServerDriver";
17
+ import { ReplicationMode } from "../types/ReplicationMode";
17
18
  /**
18
19
  * Runs queries on a single SQL Server database connection.
19
20
  */
@@ -30,7 +31,7 @@ export declare class SqlServerQueryRunner extends BaseQueryRunner implements Que
30
31
  * @see https://github.com/patriksimek/node-mssql/issues/491
31
32
  */
32
33
  protected queryResponsibilityChain: Promise<any>[];
33
- constructor(driver: SqlServerDriver, mode?: "master" | "slave");
34
+ constructor(driver: SqlServerDriver, mode: ReplicationMode);
34
35
  /**
35
36
  * Creates/uses database connection from the connection pool to perform further operations.
36
37
  * Returns obtained database connection.