typeorm 0.3.18-dev.ff6e875 → 0.3.18

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 (469) hide show
  1. package/README.md +23 -23
  2. package/browser/cache/DbQueryResultCache.js +3 -0
  3. package/browser/cache/DbQueryResultCache.js.map +1 -1
  4. package/browser/data-source/BaseDataSourceOptions.d.ts +4 -0
  5. package/browser/data-source/BaseDataSourceOptions.js.map +1 -1
  6. package/browser/data-source/DataSource.d.ts +4 -0
  7. package/browser/data-source/DataSource.js +15 -0
  8. package/browser/data-source/DataSource.js.map +1 -1
  9. package/browser/decorator/Index.js +1 -0
  10. package/browser/decorator/Index.js.map +1 -1
  11. package/browser/decorator/entity/Entity.js +1 -0
  12. package/browser/decorator/entity/Entity.js.map +1 -1
  13. package/browser/decorator/options/EntityOptions.d.ts +4 -0
  14. package/browser/decorator/options/EntityOptions.js.map +1 -1
  15. package/browser/decorator/options/IndexOptions.d.ts +5 -0
  16. package/browser/decorator/options/IndexOptions.js.map +1 -1
  17. package/browser/driver/Driver.d.ts +4 -0
  18. package/browser/driver/Driver.js.map +1 -1
  19. package/browser/driver/DriverUtils.js +2 -5
  20. package/browser/driver/DriverUtils.js.map +1 -1
  21. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +4 -0
  22. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +15 -6
  23. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  24. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.d.ts +5 -0
  25. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js +16 -6
  26. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  27. package/browser/driver/capacitor/CapacitorDriver.js +2 -2
  28. package/browser/driver/capacitor/CapacitorDriver.js.map +1 -1
  29. package/browser/driver/capacitor/CapacitorQueryRunner.js +2 -2
  30. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  31. package/browser/driver/cockroachdb/CockroachConnectionOptions.d.ts +6 -0
  32. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  33. package/browser/driver/cockroachdb/CockroachDriver.d.ts +4 -0
  34. package/browser/driver/cockroachdb/CockroachDriver.js +30 -11
  35. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  36. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +10 -1
  37. package/browser/driver/cockroachdb/CockroachQueryRunner.js +55 -19
  38. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  39. package/browser/driver/cordova/CordovaDriver.js +2 -2
  40. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  41. package/browser/driver/cordova/CordovaQueryRunner.js +8 -0
  42. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  43. package/browser/driver/expo/ExpoQueryRunner.js +9 -2
  44. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  45. package/browser/driver/mongodb/MongoQueryRunner.d.ts +7 -3
  46. package/browser/driver/mongodb/MongoQueryRunner.js +6 -0
  47. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  48. package/browser/driver/mongodb/typings.d.ts +3 -3
  49. package/browser/driver/mongodb/typings.js.map +1 -1
  50. package/browser/driver/mysql/MysqlConnectionOptions.d.ts +6 -0
  51. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  52. package/browser/driver/mysql/MysqlQueryRunner.d.ts +4 -0
  53. package/browser/driver/mysql/MysqlQueryRunner.js +47 -10
  54. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  55. package/browser/driver/oracle/OracleConnectionOptions.d.ts +14 -0
  56. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  57. package/browser/driver/oracle/OracleDriver.d.ts +4 -0
  58. package/browser/driver/oracle/OracleDriver.js +17 -2
  59. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  60. package/browser/driver/oracle/OracleQueryRunner.d.ts +4 -0
  61. package/browser/driver/oracle/OracleQueryRunner.js +55 -7
  62. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  63. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +5 -0
  64. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  65. package/browser/driver/postgres/PostgresConnectionOptions.d.ts +6 -5
  66. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  67. package/browser/driver/postgres/PostgresDriver.d.ts +4 -0
  68. package/browser/driver/postgres/PostgresDriver.js +14 -8
  69. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  70. package/browser/driver/postgres/PostgresQueryRunner.d.ts +4 -0
  71. package/browser/driver/postgres/PostgresQueryRunner.js +53 -24
  72. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  73. package/browser/driver/react-native/ReactNativeQueryRunner.js +10 -2
  74. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  75. package/browser/driver/sap/SapDriver.d.ts +8 -0
  76. package/browser/driver/sap/SapDriver.js +14 -3
  77. package/browser/driver/sap/SapDriver.js.map +1 -1
  78. package/browser/driver/sap/SapQueryRunner.d.ts +8 -13
  79. package/browser/driver/sap/SapQueryRunner.js +81 -65
  80. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  81. package/browser/driver/spanner/SpannerConnectionOptions.d.ts +6 -0
  82. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  83. package/browser/driver/spanner/SpannerDriver.d.ts +4 -0
  84. package/browser/driver/spanner/SpannerDriver.js +10 -1
  85. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  86. package/browser/driver/spanner/SpannerQueryRunner.d.ts +4 -0
  87. package/browser/driver/spanner/SpannerQueryRunner.js +13 -1
  88. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  89. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  90. package/browser/driver/sqlite/SqliteQueryRunner.js +60 -46
  91. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  92. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +4 -0
  93. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +17 -17
  94. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  95. package/browser/driver/sqljs/SqljsQueryRunner.js +11 -3
  96. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  97. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +2 -1
  98. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  99. package/browser/driver/sqlserver/SqlServerConnectionOptions.d.ts +11 -5
  100. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  101. package/browser/driver/sqlserver/SqlServerDriver.d.ts +4 -0
  102. package/browser/driver/sqlserver/SqlServerDriver.js +10 -1
  103. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  104. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +4 -0
  105. package/browser/driver/sqlserver/SqlServerQueryRunner.js +32 -6
  106. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  107. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.d.ts +12 -0
  108. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js +3 -0
  109. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -0
  110. package/browser/entity-manager/EntityManager.d.ts +5 -1
  111. package/browser/entity-manager/EntityManager.js +15 -2
  112. package/browser/entity-manager/EntityManager.js.map +1 -1
  113. package/browser/entity-manager/MongoEntityManager.d.ts +8 -4
  114. package/browser/entity-manager/MongoEntityManager.js +12 -10
  115. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  116. package/browser/entity-schema/EntitySchemaOptions.d.ts +4 -0
  117. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  118. package/browser/entity-schema/EntitySchemaTransformer.js +7 -0
  119. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  120. package/browser/error/EntityNotFoundError.d.ts +2 -0
  121. package/browser/error/EntityNotFoundError.js +2 -0
  122. package/browser/error/EntityNotFoundError.js.map +1 -1
  123. package/browser/error/QueryFailedError.d.ts +3 -3
  124. package/browser/error/QueryFailedError.js.map +1 -1
  125. package/browser/find-options/FindOperatorType.d.ts +1 -1
  126. package/browser/find-options/FindOperatorType.js.map +1 -1
  127. package/browser/find-options/FindOptionsUtils.js +1 -1
  128. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  129. package/browser/find-options/FindOptionsWhere.d.ts +1 -1
  130. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  131. package/browser/find-options/operator/Or.d.ts +2 -0
  132. package/browser/find-options/operator/Or.js +6 -0
  133. package/browser/find-options/operator/Or.js.map +1 -0
  134. package/browser/index.d.ts +2 -0
  135. package/browser/index.js +2 -0
  136. package/browser/index.js.map +1 -1
  137. package/browser/logger/AbstractLogger.js +1 -1
  138. package/browser/logger/AbstractLogger.js.map +1 -1
  139. package/browser/metadata/ColumnMetadata.js +4 -0
  140. package/browser/metadata/ColumnMetadata.js.map +1 -1
  141. package/browser/metadata/EntityMetadata.d.ts +7 -3
  142. package/browser/metadata/EntityMetadata.js +8 -3
  143. package/browser/metadata/EntityMetadata.js.map +1 -1
  144. package/browser/metadata/IndexMetadata.d.ts +5 -0
  145. package/browser/metadata/IndexMetadata.js +1 -0
  146. package/browser/metadata/IndexMetadata.js.map +1 -1
  147. package/browser/metadata-args/IndexMetadataArgs.d.ts +5 -0
  148. package/browser/metadata-args/IndexMetadataArgs.js.map +1 -1
  149. package/browser/metadata-args/TableMetadataArgs.d.ts +4 -0
  150. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  151. package/browser/metadata-builder/EntityMetadataBuilder.js +22 -0
  152. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  153. package/browser/naming-strategy/DefaultNamingStrategy.d.ts +0 -1
  154. package/browser/naming-strategy/DefaultNamingStrategy.js +0 -3
  155. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  156. package/browser/naming-strategy/NamingStrategyInterface.d.ts +0 -4
  157. package/browser/naming-strategy/NamingStrategyInterface.js.map +1 -1
  158. package/browser/persistence/Subject.js +2 -1
  159. package/browser/persistence/Subject.js.map +1 -1
  160. package/browser/persistence/SubjectExecutor.js +5 -2
  161. package/browser/persistence/SubjectExecutor.js.map +1 -1
  162. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js +6 -2
  163. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  164. package/browser/platform/BrowserPlatformTools.d.ts +0 -7
  165. package/browser/platform/BrowserPlatformTools.js +3 -2
  166. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  167. package/browser/platform/PlatformTools.js +2 -0
  168. package/browser/platform/PlatformTools.js.map +1 -1
  169. package/browser/query-builder/InsertQueryBuilder.js +19 -6
  170. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  171. package/browser/query-builder/QueryBuilder.d.ts +5 -0
  172. package/browser/query-builder/QueryBuilder.js +36 -24
  173. package/browser/query-builder/QueryBuilder.js.map +1 -1
  174. package/browser/query-builder/QueryExpressionMap.d.ts +2 -1
  175. package/browser/query-builder/QueryExpressionMap.js +0 -4
  176. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  177. package/browser/query-builder/SelectQueryBuilder.js +14 -4
  178. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  179. package/browser/query-builder/WhereClause.d.ts +1 -1
  180. package/browser/query-builder/WhereClause.js.map +1 -1
  181. package/browser/query-builder/index.d.ts +1 -0
  182. package/browser/query-builder/index.js +17 -0
  183. package/browser/query-builder/index.js.map +1 -0
  184. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -0
  185. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +28 -0
  186. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  187. package/browser/query-runner/BaseQueryRunner.js +1 -0
  188. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  189. package/browser/query-runner/QueryRunner.d.ts +4 -0
  190. package/browser/query-runner/QueryRunner.js.map +1 -1
  191. package/browser/repository/BaseEntity.d.ts +12 -0
  192. package/browser/repository/BaseEntity.js +12 -0
  193. package/browser/repository/BaseEntity.js.map +1 -1
  194. package/browser/repository/MongoRepository.d.ts +8 -4
  195. package/browser/repository/MongoRepository.js +6 -0
  196. package/browser/repository/MongoRepository.js.map +1 -1
  197. package/browser/repository/Repository.d.ts +14 -2
  198. package/browser/repository/Repository.js +26 -6
  199. package/browser/repository/Repository.js.map +1 -1
  200. package/browser/schema-builder/RdbmsSchemaBuilder.d.ts +4 -0
  201. package/browser/schema-builder/RdbmsSchemaBuilder.js +15 -0
  202. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  203. package/browser/schema-builder/options/TableIndexOptions.d.ts +5 -0
  204. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  205. package/browser/schema-builder/options/TableOptions.d.ts +4 -0
  206. package/browser/schema-builder/options/TableOptions.js.map +1 -1
  207. package/browser/schema-builder/table/Table.d.ts +4 -0
  208. package/browser/schema-builder/table/Table.js +3 -0
  209. package/browser/schema-builder/table/Table.js.map +1 -1
  210. package/browser/schema-builder/table/TableIndex.d.ts +5 -0
  211. package/browser/schema-builder/table/TableIndex.js +3 -0
  212. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  213. package/browser/subscriber/Broadcaster.d.ts +11 -1
  214. package/browser/subscriber/Broadcaster.js +48 -1
  215. package/browser/subscriber/Broadcaster.js.map +1 -1
  216. package/browser/subscriber/EntitySubscriberInterface.d.ts +9 -0
  217. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  218. package/browser/subscriber/event/InsertEvent.d.ts +5 -0
  219. package/browser/subscriber/event/InsertEvent.js.map +1 -1
  220. package/browser/subscriber/event/QueryEvent.d.ts +50 -0
  221. package/browser/subscriber/event/QueryEvent.js +3 -0
  222. package/browser/subscriber/event/QueryEvent.js.map +1 -0
  223. package/browser/util/DateUtils.js +4 -2
  224. package/browser/util/DateUtils.js.map +1 -1
  225. package/browser/util/OrmUtils.d.ts +6 -0
  226. package/browser/util/OrmUtils.js +66 -0
  227. package/browser/util/OrmUtils.js.map +1 -1
  228. package/cache/DbQueryResultCache.js +3 -0
  229. package/cache/DbQueryResultCache.js.map +1 -1
  230. package/commands/CommandUtils.js +6 -1
  231. package/commands/CommandUtils.js.map +1 -1
  232. package/commands/EntityCreateCommand.d.ts +3 -0
  233. package/commands/EntityCreateCommand.js +7 -0
  234. package/commands/EntityCreateCommand.js.map +1 -1
  235. package/commands/InitCommand.js +1 -1
  236. package/commands/InitCommand.js.map +1 -1
  237. package/commands/MigrationCreateCommand.d.ts +5 -1
  238. package/commands/MigrationCreateCommand.js +6 -1
  239. package/commands/MigrationCreateCommand.js.map +1 -1
  240. package/commands/MigrationGenerateCommand.d.ts +5 -1
  241. package/commands/MigrationGenerateCommand.js +8 -1
  242. package/commands/MigrationGenerateCommand.js.map +1 -1
  243. package/commands/SubscriberCreateCommand.d.ts +3 -0
  244. package/commands/SubscriberCreateCommand.js +7 -0
  245. package/commands/SubscriberCreateCommand.js.map +1 -1
  246. package/data-source/BaseDataSourceOptions.d.ts +4 -0
  247. package/data-source/BaseDataSourceOptions.js.map +1 -1
  248. package/data-source/DataSource.d.ts +4 -0
  249. package/data-source/DataSource.js +15 -0
  250. package/data-source/DataSource.js.map +1 -1
  251. package/decorator/Index.js +1 -0
  252. package/decorator/Index.js.map +1 -1
  253. package/decorator/entity/Entity.js +1 -0
  254. package/decorator/entity/Entity.js.map +1 -1
  255. package/decorator/options/EntityOptions.d.ts +4 -0
  256. package/decorator/options/EntityOptions.js.map +1 -1
  257. package/decorator/options/IndexOptions.d.ts +5 -0
  258. package/decorator/options/IndexOptions.js.map +1 -1
  259. package/driver/Driver.d.ts +4 -0
  260. package/driver/Driver.js.map +1 -1
  261. package/driver/DriverUtils.js +2 -5
  262. package/driver/DriverUtils.js.map +1 -1
  263. package/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +4 -0
  264. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +15 -6
  265. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  266. package/driver/aurora-postgres/AuroraPostgresQueryRunner.d.ts +5 -0
  267. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js +16 -6
  268. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  269. package/driver/capacitor/CapacitorDriver.js +2 -2
  270. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  271. package/driver/capacitor/CapacitorQueryRunner.js +2 -2
  272. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  273. package/driver/cockroachdb/CockroachConnectionOptions.d.ts +6 -0
  274. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  275. package/driver/cockroachdb/CockroachDriver.d.ts +4 -0
  276. package/driver/cockroachdb/CockroachDriver.js +30 -11
  277. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  278. package/driver/cockroachdb/CockroachQueryRunner.d.ts +10 -1
  279. package/driver/cockroachdb/CockroachQueryRunner.js +55 -19
  280. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  281. package/driver/cordova/CordovaDriver.js +2 -2
  282. package/driver/cordova/CordovaDriver.js.map +1 -1
  283. package/driver/cordova/CordovaQueryRunner.js +8 -0
  284. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  285. package/driver/expo/ExpoQueryRunner.js +9 -2
  286. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  287. package/driver/mongodb/MongoQueryRunner.d.ts +7 -3
  288. package/driver/mongodb/MongoQueryRunner.js +6 -0
  289. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  290. package/driver/mongodb/typings.d.ts +3 -3
  291. package/driver/mongodb/typings.js.map +1 -1
  292. package/driver/mysql/MysqlConnectionOptions.d.ts +6 -0
  293. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  294. package/driver/mysql/MysqlQueryRunner.d.ts +4 -0
  295. package/driver/mysql/MysqlQueryRunner.js +47 -10
  296. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  297. package/driver/oracle/OracleConnectionOptions.d.ts +14 -0
  298. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  299. package/driver/oracle/OracleDriver.d.ts +4 -0
  300. package/driver/oracle/OracleDriver.js +17 -2
  301. package/driver/oracle/OracleDriver.js.map +1 -1
  302. package/driver/oracle/OracleQueryRunner.d.ts +4 -0
  303. package/driver/oracle/OracleQueryRunner.js +55 -7
  304. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  305. package/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +5 -0
  306. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  307. package/driver/postgres/PostgresConnectionOptions.d.ts +6 -5
  308. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  309. package/driver/postgres/PostgresDriver.d.ts +4 -0
  310. package/driver/postgres/PostgresDriver.js +14 -8
  311. package/driver/postgres/PostgresDriver.js.map +1 -1
  312. package/driver/postgres/PostgresQueryRunner.d.ts +4 -0
  313. package/driver/postgres/PostgresQueryRunner.js +53 -24
  314. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  315. package/driver/react-native/ReactNativeQueryRunner.js +10 -2
  316. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  317. package/driver/sap/SapDriver.d.ts +8 -0
  318. package/driver/sap/SapDriver.js +15 -4
  319. package/driver/sap/SapDriver.js.map +1 -1
  320. package/driver/sap/SapQueryRunner.d.ts +8 -13
  321. package/driver/sap/SapQueryRunner.js +81 -65
  322. package/driver/sap/SapQueryRunner.js.map +1 -1
  323. package/driver/spanner/SpannerConnectionOptions.d.ts +6 -0
  324. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  325. package/driver/spanner/SpannerDriver.d.ts +4 -0
  326. package/driver/spanner/SpannerDriver.js +10 -1
  327. package/driver/spanner/SpannerDriver.js.map +1 -1
  328. package/driver/spanner/SpannerQueryRunner.d.ts +4 -0
  329. package/driver/spanner/SpannerQueryRunner.js +13 -1
  330. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  331. package/driver/sqlite/SqliteDriver.js.map +1 -1
  332. package/driver/sqlite/SqliteQueryRunner.js +60 -46
  333. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  334. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +4 -0
  335. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +17 -17
  336. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  337. package/driver/sqljs/SqljsQueryRunner.js +11 -3
  338. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  339. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +2 -1
  340. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  341. package/driver/sqlserver/SqlServerConnectionOptions.d.ts +11 -5
  342. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  343. package/driver/sqlserver/SqlServerDriver.d.ts +4 -0
  344. package/driver/sqlserver/SqlServerDriver.js +10 -1
  345. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  346. package/driver/sqlserver/SqlServerQueryRunner.d.ts +4 -0
  347. package/driver/sqlserver/SqlServerQueryRunner.js +32 -6
  348. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  349. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.d.ts +12 -0
  350. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js +4 -0
  351. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -0
  352. package/entity-manager/EntityManager.d.ts +5 -1
  353. package/entity-manager/EntityManager.js +15 -2
  354. package/entity-manager/EntityManager.js.map +1 -1
  355. package/entity-manager/MongoEntityManager.d.ts +8 -4
  356. package/entity-manager/MongoEntityManager.js +12 -10
  357. package/entity-manager/MongoEntityManager.js.map +1 -1
  358. package/entity-schema/EntitySchemaOptions.d.ts +4 -0
  359. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  360. package/entity-schema/EntitySchemaTransformer.js +7 -0
  361. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  362. package/error/EntityNotFoundError.d.ts +2 -0
  363. package/error/EntityNotFoundError.js +2 -0
  364. package/error/EntityNotFoundError.js.map +1 -1
  365. package/error/QueryFailedError.d.ts +3 -3
  366. package/error/QueryFailedError.js.map +1 -1
  367. package/find-options/FindOperatorType.d.ts +1 -1
  368. package/find-options/FindOperatorType.js.map +1 -1
  369. package/find-options/FindOptionsUtils.js +1 -1
  370. package/find-options/FindOptionsUtils.js.map +1 -1
  371. package/find-options/FindOptionsWhere.d.ts +1 -1
  372. package/find-options/FindOptionsWhere.js.map +1 -1
  373. package/find-options/operator/Or.d.ts +2 -0
  374. package/find-options/operator/Or.js +10 -0
  375. package/find-options/operator/Or.js.map +1 -0
  376. package/index.d.ts +2 -0
  377. package/index.js +2 -0
  378. package/index.js.map +1 -1
  379. package/index.mjs +4 -0
  380. package/logger/AbstractLogger.js +1 -1
  381. package/logger/AbstractLogger.js.map +1 -1
  382. package/metadata/ColumnMetadata.js +4 -0
  383. package/metadata/ColumnMetadata.js.map +1 -1
  384. package/metadata/EntityMetadata.d.ts +7 -3
  385. package/metadata/EntityMetadata.js +8 -3
  386. package/metadata/EntityMetadata.js.map +1 -1
  387. package/metadata/IndexMetadata.d.ts +5 -0
  388. package/metadata/IndexMetadata.js +1 -0
  389. package/metadata/IndexMetadata.js.map +1 -1
  390. package/metadata-args/IndexMetadataArgs.d.ts +5 -0
  391. package/metadata-args/IndexMetadataArgs.js.map +1 -1
  392. package/metadata-args/TableMetadataArgs.d.ts +4 -0
  393. package/metadata-args/TableMetadataArgs.js.map +1 -1
  394. package/metadata-builder/EntityMetadataBuilder.js +22 -0
  395. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  396. package/naming-strategy/DefaultNamingStrategy.d.ts +0 -1
  397. package/naming-strategy/DefaultNamingStrategy.js +0 -3
  398. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  399. package/naming-strategy/NamingStrategyInterface.d.ts +0 -4
  400. package/naming-strategy/NamingStrategyInterface.js.map +1 -1
  401. package/package.json +273 -1
  402. package/persistence/Subject.js +2 -1
  403. package/persistence/Subject.js.map +1 -1
  404. package/persistence/SubjectExecutor.js +5 -2
  405. package/persistence/SubjectExecutor.js.map +1 -1
  406. package/persistence/subject-builder/ManyToManySubjectBuilder.js +6 -2
  407. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  408. package/platform/PlatformTools.js +2 -0
  409. package/platform/PlatformTools.js.map +1 -1
  410. package/query-builder/InsertQueryBuilder.js +19 -6
  411. package/query-builder/InsertQueryBuilder.js.map +1 -1
  412. package/query-builder/QueryBuilder.d.ts +5 -0
  413. package/query-builder/QueryBuilder.js +36 -24
  414. package/query-builder/QueryBuilder.js.map +1 -1
  415. package/query-builder/QueryExpressionMap.d.ts +2 -1
  416. package/query-builder/QueryExpressionMap.js +0 -4
  417. package/query-builder/QueryExpressionMap.js.map +1 -1
  418. package/query-builder/SelectQueryBuilder.js +14 -4
  419. package/query-builder/SelectQueryBuilder.js.map +1 -1
  420. package/query-builder/WhereClause.d.ts +1 -1
  421. package/query-builder/WhereClause.js.map +1 -1
  422. package/query-builder/index.d.ts +1 -0
  423. package/query-builder/index.js +21 -0
  424. package/query-builder/index.js.map +1 -0
  425. package/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -0
  426. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +28 -0
  427. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  428. package/query-runner/BaseQueryRunner.js +1 -0
  429. package/query-runner/BaseQueryRunner.js.map +1 -1
  430. package/query-runner/QueryRunner.d.ts +4 -0
  431. package/query-runner/QueryRunner.js.map +1 -1
  432. package/repository/BaseEntity.d.ts +12 -0
  433. package/repository/BaseEntity.js +12 -0
  434. package/repository/BaseEntity.js.map +1 -1
  435. package/repository/MongoRepository.d.ts +8 -4
  436. package/repository/MongoRepository.js +6 -0
  437. package/repository/MongoRepository.js.map +1 -1
  438. package/repository/Repository.d.ts +14 -2
  439. package/repository/Repository.js +26 -6
  440. package/repository/Repository.js.map +1 -1
  441. package/schema-builder/RdbmsSchemaBuilder.d.ts +4 -0
  442. package/schema-builder/RdbmsSchemaBuilder.js +15 -0
  443. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  444. package/schema-builder/options/TableIndexOptions.d.ts +5 -0
  445. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  446. package/schema-builder/options/TableOptions.d.ts +4 -0
  447. package/schema-builder/options/TableOptions.js.map +1 -1
  448. package/schema-builder/table/Table.d.ts +4 -0
  449. package/schema-builder/table/Table.js +3 -0
  450. package/schema-builder/table/Table.js.map +1 -1
  451. package/schema-builder/table/TableIndex.d.ts +5 -0
  452. package/schema-builder/table/TableIndex.js +3 -0
  453. package/schema-builder/table/TableIndex.js.map +1 -1
  454. package/subscriber/Broadcaster.d.ts +11 -1
  455. package/subscriber/Broadcaster.js +48 -1
  456. package/subscriber/Broadcaster.js.map +1 -1
  457. package/subscriber/EntitySubscriberInterface.d.ts +9 -0
  458. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  459. package/subscriber/event/InsertEvent.d.ts +5 -0
  460. package/subscriber/event/InsertEvent.js.map +1 -1
  461. package/subscriber/event/QueryEvent.d.ts +50 -0
  462. package/subscriber/event/QueryEvent.js +4 -0
  463. package/subscriber/event/QueryEvent.js.map +1 -0
  464. package/typeorm-model-shim.js +61 -53
  465. package/util/DateUtils.js +5 -2
  466. package/util/DateUtils.js.map +1 -1
  467. package/util/OrmUtils.d.ts +6 -0
  468. package/util/OrmUtils.js +66 -0
  469. package/util/OrmUtils.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/sqlite/SqliteDriver.ts"],"names":[],"mappings":"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","file":"SqliteDriver.js","sourcesContent":["import mkdirp from \"mkdirp\"\nimport path from \"path\"\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\nimport { SqliteQueryRunner } from \"./SqliteQueryRunner\"\nimport { PlatformTools } from \"../../platform/PlatformTools\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { SqliteConnectionOptions } from \"./SqliteConnectionOptions\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { filepathToName, isAbsolute } from \"../../util/PathUtils\"\n\n/**\n * Organizes communication with sqlite DBMS.\n */\nexport class SqliteDriver extends AbstractSqliteDriver {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: SqliteConnectionOptions\n\n /**\n * SQLite underlying library.\n */\n sqlite: any\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n super(connection)\n\n this.connection = connection\n this.options = connection.options as SqliteConnectionOptions\n this.database = this.options.database\n\n // load sqlite package\n this.loadDependencies()\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Closes connection with database.\n */\n async disconnect(): Promise<void> {\n return new Promise<void>((ok, fail) => {\n this.queryRunner = undefined\n this.databaseConnection.close((err: any) =>\n err ? fail(err) : ok(),\n )\n })\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode): QueryRunner {\n if (!this.queryRunner) this.queryRunner = new SqliteQueryRunner(this)\n\n return this.queryRunner\n }\n\n normalizeType(column: {\n type?: ColumnType\n length?: number | string\n precision?: number | null\n scale?: number\n }): string {\n if ((column.type as any) === Buffer) {\n return \"blob\"\n }\n\n return super.normalizeType(column)\n }\n\n async afterConnect(): Promise<void> {\n return this.attachDatabases()\n }\n\n /**\n * For SQLite, the database may be added in the decorator metadata. It will be a filepath to a database file.\n */\n buildTableName(\n tableName: string,\n _schema?: string,\n database?: string,\n ): string {\n if (!database) return tableName\n if (this.getAttachedDatabaseHandleByRelativePath(database))\n return `${this.getAttachedDatabaseHandleByRelativePath(\n database,\n )}.${tableName}`\n\n if (database === this.options.database) return tableName\n\n // we use the decorated name as supplied when deriving attach handle (ideally without non-portable absolute path)\n const identifierHash = filepathToName(database)\n // decorated name will be assumed relative to main database file when non absolute. Paths supplied as absolute won't be portable\n const absFilepath = isAbsolute(database)\n ? database\n : path.join(this.getMainDatabasePath(), database)\n\n this.attachedDatabases[database] = {\n attachFilepathAbsolute: absFilepath,\n attachFilepathRelative: database,\n attachHandle: identifierHash,\n }\n\n return `${identifierHash}.${tableName}`\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates connection with the database.\n */\n protected async createDatabaseConnection() {\n if (\n this.options.flags === undefined ||\n !(this.options.flags & this.sqlite.OPEN_URI)\n ) {\n await this.createDatabaseDirectory(this.options.database)\n }\n\n const databaseConnection: any = await new Promise((ok, fail) => {\n if (this.options.flags === undefined) {\n const connection = new this.sqlite.Database(\n this.options.database,\n (err: any) => {\n if (err) return fail(err)\n ok(connection)\n },\n )\n } else {\n const connection = new this.sqlite.Database(\n this.options.database,\n this.options.flags,\n (err: any) => {\n if (err) return fail(err)\n ok(connection)\n },\n )\n }\n })\n\n // Internal function to run a command on the connection and fail if an error occured.\n function run(line: string): Promise<void> {\n return new Promise((ok, fail) => {\n databaseConnection.run(line, (err: any) => {\n if (err) return fail(err)\n ok()\n })\n })\n }\n // in the options, if encryption key for SQLCipher is setted.\n // Must invoke key pragma before trying to do any other interaction with the database.\n if (this.options.key) {\n await run(`PRAGMA key = ${JSON.stringify(this.options.key)}`)\n }\n\n if (this.options.enableWAL) {\n await run(`PRAGMA journal_mode = WAL`)\n }\n\n if (\n this.options.busyTimeout &&\n typeof this.options.busyTimeout === \"number\" &&\n this.options.busyTimeout > 0\n ) {\n await run(`PRAGMA busy_timeout = ${this.options.busyTimeout}`)\n }\n\n // we need to enable foreign keys in sqlite to make sure all foreign key related features\n // working properly. this also makes onDelete to work with sqlite.\n await run(`PRAGMA foreign_keys = ON`)\n\n return databaseConnection\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 const sqlite = this.options.driver || PlatformTools.load(\"sqlite3\")\n this.sqlite = sqlite.verbose()\n } catch (e) {\n throw new DriverPackageNotInstalledError(\"SQLite\", \"sqlite3\")\n }\n }\n\n /**\n * Auto creates database directory if it does not exist.\n */\n protected async createDatabaseDirectory(fullPath: string): Promise<void> {\n await mkdirp(path.dirname(fullPath))\n }\n\n /**\n * Performs the attaching of the database files. The attachedDatabase should have been populated during calls to #buildTableName\n * during EntityMetadata production (see EntityMetadata#buildTablePath)\n *\n * https://sqlite.org/lang_attach.html\n */\n protected async attachDatabases() {\n // @todo - possibly check number of databases (but unqueriable at runtime sadly) - https://www.sqlite.org/limits.html#max_attached\n for await (const {\n attachHandle,\n attachFilepathAbsolute,\n } of Object.values(this.attachedDatabases)) {\n await this.createDatabaseDirectory(attachFilepathAbsolute)\n await this.connection.query(\n `ATTACH \"${attachFilepathAbsolute}\" AS \"${attachHandle}\"`,\n )\n }\n }\n\n protected getMainDatabasePath(): string {\n const optionsDb = this.options.database\n return path.dirname(\n isAbsolute(optionsDb)\n ? optionsDb\n : path.join(process.cwd(), optionsDb),\n )\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/sqlite/SqliteDriver.ts"],"names":[],"mappings":"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","file":"SqliteDriver.js","sourcesContent":["import mkdirp from \"mkdirp\"\nimport path from \"path\"\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\nimport { SqliteQueryRunner } from \"./SqliteQueryRunner\"\nimport { PlatformTools } from \"../../platform/PlatformTools\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { SqliteConnectionOptions } from \"./SqliteConnectionOptions\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { filepathToName, isAbsolute } from \"../../util/PathUtils\"\n\n/**\n * Organizes communication with sqlite DBMS.\n */\nexport class SqliteDriver extends AbstractSqliteDriver {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: SqliteConnectionOptions\n\n /**\n * SQLite underlying library.\n */\n sqlite: any\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n super(connection)\n this.connection = connection\n this.options = connection.options as SqliteConnectionOptions\n this.database = this.options.database\n\n // load sqlite package\n this.loadDependencies()\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Closes connection with database.\n */\n async disconnect(): Promise<void> {\n return new Promise<void>((ok, fail) => {\n this.queryRunner = undefined\n this.databaseConnection.close((err: any) =>\n err ? fail(err) : ok(),\n )\n })\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode): QueryRunner {\n if (!this.queryRunner) this.queryRunner = new SqliteQueryRunner(this)\n\n return this.queryRunner\n }\n\n normalizeType(column: {\n type?: ColumnType\n length?: number | string\n precision?: number | null\n scale?: number\n }): string {\n if ((column.type as any) === Buffer) {\n return \"blob\"\n }\n\n return super.normalizeType(column)\n }\n\n async afterConnect(): Promise<void> {\n return this.attachDatabases()\n }\n\n /**\n * For SQLite, the database may be added in the decorator metadata. It will be a filepath to a database file.\n */\n buildTableName(\n tableName: string,\n _schema?: string,\n database?: string,\n ): string {\n if (!database) return tableName\n if (this.getAttachedDatabaseHandleByRelativePath(database))\n return `${this.getAttachedDatabaseHandleByRelativePath(\n database,\n )}.${tableName}`\n\n if (database === this.options.database) return tableName\n\n // we use the decorated name as supplied when deriving attach handle (ideally without non-portable absolute path)\n const identifierHash = filepathToName(database)\n // decorated name will be assumed relative to main database file when non absolute. Paths supplied as absolute won't be portable\n const absFilepath = isAbsolute(database)\n ? database\n : path.join(this.getMainDatabasePath(), database)\n\n this.attachedDatabases[database] = {\n attachFilepathAbsolute: absFilepath,\n attachFilepathRelative: database,\n attachHandle: identifierHash,\n }\n\n return `${identifierHash}.${tableName}`\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates connection with the database.\n */\n protected async createDatabaseConnection() {\n if (\n this.options.flags === undefined ||\n !(this.options.flags & this.sqlite.OPEN_URI)\n ) {\n await this.createDatabaseDirectory(this.options.database)\n }\n\n const databaseConnection: any = await new Promise((ok, fail) => {\n if (this.options.flags === undefined) {\n const connection = new this.sqlite.Database(\n this.options.database,\n (err: any) => {\n if (err) return fail(err)\n ok(connection)\n },\n )\n } else {\n const connection = new this.sqlite.Database(\n this.options.database,\n this.options.flags,\n (err: any) => {\n if (err) return fail(err)\n ok(connection)\n },\n )\n }\n })\n\n // Internal function to run a command on the connection and fail if an error occured.\n function run(line: string): Promise<void> {\n return new Promise((ok, fail) => {\n databaseConnection.run(line, (err: any) => {\n if (err) return fail(err)\n ok()\n })\n })\n }\n // in the options, if encryption key for SQLCipher is setted.\n // Must invoke key pragma before trying to do any other interaction with the database.\n if (this.options.key) {\n await run(`PRAGMA key = ${JSON.stringify(this.options.key)}`)\n }\n\n if (this.options.enableWAL) {\n await run(`PRAGMA journal_mode = WAL`)\n }\n\n if (\n this.options.busyTimeout &&\n typeof this.options.busyTimeout === \"number\" &&\n this.options.busyTimeout > 0\n ) {\n await run(`PRAGMA busy_timeout = ${this.options.busyTimeout}`)\n }\n\n // we need to enable foreign keys in sqlite to make sure all foreign key related features\n // working properly. this also makes onDelete to work with sqlite.\n await run(`PRAGMA foreign_keys = ON`)\n\n return databaseConnection\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 const sqlite = this.options.driver || PlatformTools.load(\"sqlite3\")\n this.sqlite = sqlite.verbose()\n } catch (e) {\n throw new DriverPackageNotInstalledError(\"SQLite\", \"sqlite3\")\n }\n }\n\n /**\n * Auto creates database directory if it does not exist.\n */\n protected async createDatabaseDirectory(fullPath: string): Promise<void> {\n await mkdirp(path.dirname(fullPath))\n }\n\n /**\n * Performs the attaching of the database files. The attachedDatabase should have been populated during calls to #buildTableName\n * during EntityMetadata production (see EntityMetadata#buildTablePath)\n *\n * https://sqlite.org/lang_attach.html\n */\n protected async attachDatabases() {\n // @todo - possibly check number of databases (but unqueriable at runtime sadly) - https://www.sqlite.org/limits.html#max_attached\n for await (const {\n attachHandle,\n attachFilepathAbsolute,\n } of Object.values(this.attachedDatabases)) {\n await this.createDatabaseDirectory(attachFilepathAbsolute)\n await this.connection.query(\n `ATTACH \"${attachFilepathAbsolute}\" AS \"${attachHandle}\"`,\n )\n }\n }\n\n protected getMainDatabasePath(): string {\n const optionsDb = this.options.database\n return path.dirname(\n isAbsolute(optionsDb)\n ? optionsDb\n : path.join(process.cwd(), optionsDb),\n )\n }\n}\n"],"sourceRoot":"../.."}
@@ -4,6 +4,7 @@ import { AbstractSqliteQueryRunner } from "../sqlite-abstract/AbstractSqliteQuer
4
4
  import { Broadcaster } from "../../subscriber/Broadcaster";
5
5
  import { ConnectionIsNotSetError } from "../../error/ConnectionIsNotSetError";
6
6
  import { QueryResult } from "../../query-runner/QueryResult";
7
+ import { BroadcasterResult } from "../../subscriber/BroadcasterResult";
7
8
  /**
8
9
  * Runs queries on a single sqlite database connection.
9
10
  *
@@ -41,63 +42,76 @@ export class SqliteQueryRunner extends AbstractSqliteQueryRunner {
41
42
  const connection = this.driver.connection;
42
43
  const options = connection.options;
43
44
  const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;
45
+ const broadcasterResult = new BroadcasterResult();
46
+ const broadcaster = this.broadcaster;
47
+ broadcaster.broadcastBeforeQueryEvent(broadcasterResult, query, parameters);
44
48
  if (!connection.isInitialized) {
45
49
  throw new ConnectionIsNotSetError("sqlite");
46
50
  }
47
51
  return new Promise(async (ok, fail) => {
48
- const databaseConnection = await this.connect();
49
- this.driver.connection.logger.logQuery(query, parameters, this);
50
- const queryStartTime = +new Date();
51
- const isInsertQuery = query.startsWith("INSERT ");
52
- const isDeleteQuery = query.startsWith("DELETE ");
53
- const isUpdateQuery = query.startsWith("UPDATE ");
54
- const execute = async () => {
55
- if (isInsertQuery || isDeleteQuery || isUpdateQuery) {
56
- await databaseConnection.run(query, parameters, handler);
57
- }
58
- else {
59
- await databaseConnection.all(query, parameters, handler);
60
- }
61
- };
62
- const handler = function (err, rows) {
63
- if (err && err.toString().indexOf("SQLITE_BUSY:") !== -1) {
64
- if (typeof options.busyErrorRetry === "number" &&
65
- options.busyErrorRetry > 0) {
66
- setTimeout(execute, options.busyErrorRetry);
67
- return;
68
- }
69
- }
70
- // log slow queries if maxQueryExecution time is set
71
- const queryEndTime = +new Date();
72
- const queryExecutionTime = queryEndTime - queryStartTime;
73
- if (maxQueryExecutionTime &&
74
- queryExecutionTime > maxQueryExecutionTime)
75
- connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
76
- if (err) {
77
- connection.logger.logQueryError(err, query, parameters, this);
78
- fail(new QueryFailedError(query, parameters, err));
79
- }
80
- else {
81
- const result = new QueryResult();
82
- if (isInsertQuery) {
83
- result.raw = this["lastID"];
52
+ try {
53
+ const databaseConnection = await this.connect();
54
+ this.driver.connection.logger.logQuery(query, parameters, this);
55
+ const queryStartTime = +new Date();
56
+ const isInsertQuery = query.startsWith("INSERT ");
57
+ const isDeleteQuery = query.startsWith("DELETE ");
58
+ const isUpdateQuery = query.startsWith("UPDATE ");
59
+ const execute = async () => {
60
+ if (isInsertQuery || isDeleteQuery || isUpdateQuery) {
61
+ await databaseConnection.run(query, parameters, handler);
84
62
  }
85
63
  else {
86
- result.raw = rows;
64
+ await databaseConnection.all(query, parameters, handler);
87
65
  }
88
- if (Array.isArray(rows)) {
89
- result.records = rows;
66
+ };
67
+ const handler = function (err, rows) {
68
+ if (err && err.toString().indexOf("SQLITE_BUSY:") !== -1) {
69
+ if (typeof options.busyErrorRetry === "number" &&
70
+ options.busyErrorRetry > 0) {
71
+ setTimeout(execute, options.busyErrorRetry);
72
+ return;
73
+ }
90
74
  }
91
- result.affected = this["changes"];
92
- if (useStructuredResult) {
93
- ok(result);
75
+ // log slow queries if maxQueryExecution time is set
76
+ const queryEndTime = +new Date();
77
+ const queryExecutionTime = queryEndTime - queryStartTime;
78
+ if (maxQueryExecutionTime &&
79
+ queryExecutionTime > maxQueryExecutionTime)
80
+ connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
81
+ if (err) {
82
+ connection.logger.logQueryError(err, query, parameters, this);
83
+ broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, false, undefined, undefined, err);
84
+ return fail(new QueryFailedError(query, parameters, err));
94
85
  }
95
86
  else {
96
- ok(result.raw);
87
+ const result = new QueryResult();
88
+ if (isInsertQuery) {
89
+ result.raw = this["lastID"];
90
+ }
91
+ else {
92
+ result.raw = rows;
93
+ }
94
+ broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, true, queryExecutionTime, result.raw, undefined);
95
+ if (Array.isArray(rows)) {
96
+ result.records = rows;
97
+ }
98
+ result.affected = this["changes"];
99
+ if (useStructuredResult) {
100
+ ok(result);
101
+ }
102
+ else {
103
+ ok(result.raw);
104
+ }
97
105
  }
98
- }
99
- };
100
- await execute();
106
+ };
107
+ await execute();
108
+ }
109
+ catch (err) {
110
+ fail(err);
111
+ }
112
+ finally {
113
+ await broadcasterResult.wait();
114
+ }
101
115
  });
102
116
  }
103
117
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/sqlite/SqliteQueryRunner.ts"],"names":[],"mappings":"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","file":"SqliteQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { SqliteConnectionOptions } from \"./SqliteConnectionOptions\"\nimport { SqliteDriver } from \"./SqliteDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n *\n * Does not support compose primary keys with autoincrement field.\n * todo: need to throw exception for this case.\n */\nexport class SqliteQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: SqliteDriver\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqliteDriver) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`)\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`)\n }\n\n /**\n * Executes a given SQL query.\n */\n query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n const connection = this.driver.connection\n const options = connection.options as SqliteConnectionOptions\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime\n\n if (!connection.isInitialized) {\n throw new ConnectionIsNotSetError(\"sqlite\")\n }\n\n return new Promise(async (ok, fail) => {\n const databaseConnection = await this.connect()\n this.driver.connection.logger.logQuery(query, parameters, this)\n const queryStartTime = +new Date()\n const isInsertQuery = query.startsWith(\"INSERT \")\n const isDeleteQuery = query.startsWith(\"DELETE \")\n const isUpdateQuery = query.startsWith(\"UPDATE \")\n\n const execute = async () => {\n if (isInsertQuery || isDeleteQuery || isUpdateQuery) {\n await databaseConnection.run(query, parameters, handler)\n } else {\n await databaseConnection.all(query, parameters, handler)\n }\n }\n\n const handler = function (err: any, rows: any) {\n if (err && err.toString().indexOf(\"SQLITE_BUSY:\") !== -1) {\n if (\n typeof options.busyErrorRetry === \"number\" &&\n options.busyErrorRetry > 0\n ) {\n setTimeout(execute, options.busyErrorRetry)\n return\n }\n }\n\n // log slow queries if maxQueryExecution time is set\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n )\n connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n\n if (err) {\n connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n fail(new QueryFailedError(query, parameters, err))\n } else {\n const result = new QueryResult()\n\n if (isInsertQuery) {\n result.raw = this[\"lastID\"]\n } else {\n result.raw = rows\n }\n\n if (Array.isArray(rows)) {\n result.records = rows\n }\n\n result.affected = this[\"changes\"]\n\n if (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n }\n }\n\n await execute()\n })\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/sqlite/SqliteQueryRunner.ts"],"names":[],"mappings":"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","file":"SqliteQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { SqliteConnectionOptions } from \"./SqliteConnectionOptions\"\nimport { SqliteDriver } from \"./SqliteDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n *\n * Does not support compose primary keys with autoincrement field.\n * todo: need to throw exception for this case.\n */\nexport class SqliteQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: SqliteDriver\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqliteDriver) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`)\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`)\n }\n\n /**\n * Executes a given SQL query.\n */\n query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n const connection = this.driver.connection\n const options = connection.options as SqliteConnectionOptions\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime\n const broadcasterResult = new BroadcasterResult()\n const broadcaster = this.broadcaster\n\n broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n if (!connection.isInitialized) {\n throw new ConnectionIsNotSetError(\"sqlite\")\n }\n\n return new Promise(async (ok, fail) => {\n try {\n const databaseConnection = await this.connect()\n this.driver.connection.logger.logQuery(query, parameters, this)\n const queryStartTime = +new Date()\n const isInsertQuery = query.startsWith(\"INSERT \")\n const isDeleteQuery = query.startsWith(\"DELETE \")\n const isUpdateQuery = query.startsWith(\"UPDATE \")\n\n const execute = async () => {\n if (isInsertQuery || isDeleteQuery || isUpdateQuery) {\n await databaseConnection.run(query, parameters, handler)\n } else {\n await databaseConnection.all(query, parameters, handler)\n }\n }\n\n const handler = function (err: any, rows: any) {\n if (err && err.toString().indexOf(\"SQLITE_BUSY:\") !== -1) {\n if (\n typeof options.busyErrorRetry === \"number\" &&\n options.busyErrorRetry > 0\n ) {\n setTimeout(execute, options.busyErrorRetry)\n return\n }\n }\n\n // log slow queries if maxQueryExecution time is set\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n )\n connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n\n if (err) {\n connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n undefined,\n undefined,\n err,\n )\n\n return fail(\n new QueryFailedError(query, parameters, err),\n )\n } else {\n const result = new QueryResult()\n\n if (isInsertQuery) {\n result.raw = this[\"lastID\"]\n } else {\n result.raw = rows\n }\n\n broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n result.raw,\n undefined,\n )\n\n if (Array.isArray(rows)) {\n result.records = rows\n }\n\n result.affected = this[\"changes\"]\n\n if (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n }\n }\n\n await execute()\n } catch (err) {\n fail(err)\n } finally {\n await broadcasterResult.wait()\n }\n })\n }\n}\n"],"sourceRoot":"../.."}
@@ -299,4 +299,8 @@ export declare abstract class AbstractSqliteQueryRunner extends BaseQueryRunner
299
299
  * Escapes given table or view path. Tolerates leading/trailing dots
300
300
  */
301
301
  protected escapePath(target: Table | View | string, disableEscape?: boolean): string;
302
+ /**
303
+ * Change table comment.
304
+ */
305
+ changeTableComment(tableOrName: Table | string, comment?: string): Promise<void>;
302
306
  }
@@ -64,6 +64,7 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
64
64
  throw err;
65
65
  }
66
66
  if (this.transactionDepth === 0) {
67
+ this.transactionDepth += 1;
67
68
  if (isolationLevel) {
68
69
  if (isolationLevel === "READ UNCOMMITTED") {
69
70
  await this.query("PRAGMA read_uncommitted = true");
@@ -75,9 +76,9 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
75
76
  await this.query("BEGIN TRANSACTION");
76
77
  }
77
78
  else {
78
- await this.query(`SAVEPOINT typeorm_${this.transactionDepth}`);
79
+ this.transactionDepth += 1;
80
+ await this.query(`SAVEPOINT typeorm_${this.transactionDepth - 1}`);
79
81
  }
80
- this.transactionDepth += 1;
81
82
  await this.broadcaster.broadcast("AfterTransactionStart");
82
83
  }
83
84
  /**
@@ -89,13 +90,14 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
89
90
  throw new TransactionNotStartedError();
90
91
  await this.broadcaster.broadcast("BeforeTransactionCommit");
91
92
  if (this.transactionDepth > 1) {
92
- await this.query(`RELEASE SAVEPOINT typeorm_${this.transactionDepth - 1}`);
93
+ this.transactionDepth -= 1;
94
+ await this.query(`RELEASE SAVEPOINT typeorm_${this.transactionDepth}`);
93
95
  }
94
96
  else {
97
+ this.transactionDepth -= 1;
95
98
  await this.query("COMMIT");
96
99
  this.isTransactionActive = false;
97
100
  }
98
- this.transactionDepth -= 1;
99
101
  await this.broadcaster.broadcast("AfterTransactionCommit");
100
102
  }
101
103
  /**
@@ -107,13 +109,14 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
107
109
  throw new TransactionNotStartedError();
108
110
  await this.broadcaster.broadcast("BeforeTransactionRollback");
109
111
  if (this.transactionDepth > 1) {
110
- await this.query(`ROLLBACK TO SAVEPOINT typeorm_${this.transactionDepth - 1}`);
112
+ this.transactionDepth -= 1;
113
+ await this.query(`ROLLBACK TO SAVEPOINT typeorm_${this.transactionDepth}`);
111
114
  }
112
115
  else {
116
+ this.transactionDepth -= 1;
113
117
  await this.query("ROLLBACK");
114
118
  this.isTransactionActive = false;
115
119
  }
116
- this.transactionDepth -= 1;
117
120
  await this.broadcaster.broadcast("AfterTransactionRollback");
118
121
  }
119
122
  /**
@@ -960,7 +963,7 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
960
963
  dbColumn["hidden"] === 3) {
961
964
  tableColumn.generatedType =
962
965
  dbColumn["hidden"] === 2 ? "VIRTUAL" : "STORED";
963
- const asExpressionQuery = await this.selectTypeormMetadataSql({
966
+ const asExpressionQuery = this.selectTypeormMetadataSql({
964
967
  table: table.name,
965
968
  type: MetadataTableType.GENERATED_COLUMN,
966
969
  name: tableColumn.name,
@@ -974,16 +977,7 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
974
977
  }
975
978
  }
976
979
  if (tableColumn.type === "varchar") {
977
- // Check if this is an enum
978
- const enumMatch = sql.match(new RegExp('"(' +
979
- tableColumn.name +
980
- ")\" varchar CHECK\\s*\\(\\s*\"\\1\"\\s+IN\\s*\\(('[^']+'(?:\\s*,\\s*'[^']+')+)\\s*\\)\\s*\\)"));
981
- if (enumMatch) {
982
- // This is an enum
983
- tableColumn.enum = enumMatch[2]
984
- .substr(1, enumMatch[2].length - 2)
985
- .split("','");
986
- }
980
+ tableColumn.enum = OrmUtils.parseSqlCheckExpression(sql, tableColumn.name);
987
981
  }
988
982
  // parse datatype and attempt to retrieve length, precision and scale
989
983
  let pos = tableColumn.type.indexOf("(");
@@ -1505,6 +1499,12 @@ export class AbstractSqliteQueryRunner extends BaseQueryRunner {
1505
1499
  .map((i) => (disableEscape ? i : `"${i}"`))
1506
1500
  .join(".");
1507
1501
  }
1502
+ /**
1503
+ * Change table comment.
1504
+ */
1505
+ changeTableComment(tableOrName, comment) {
1506
+ throw new TypeORMError(`sqlit driver does not support change comment.`);
1507
+ }
1508
1508
  }
1509
1509
 
1510
1510
  //# sourceMappingURL=AbstractSqliteQueryRunner.js.map