typeorm 0.2.42-dev.f3e2b0e → 0.2.43-dev.a5493fb

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 (530) hide show
  1. package/README.md +38 -0
  2. package/browser/cache/RedisQueryResultCache.js +40 -35
  3. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  4. package/browser/common/DeepPartial.d.ts +3 -3
  5. package/browser/common/DeepPartial.js.map +1 -1
  6. package/browser/common/RelationType.d.ts +14 -0
  7. package/browser/common/RelationType.js +3 -0
  8. package/browser/common/RelationType.js.map +1 -0
  9. package/browser/connection/BaseConnectionOptions.d.ts +5 -0
  10. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  11. package/browser/connection/Connection.d.ts +7 -3
  12. package/browser/connection/Connection.js +80 -55
  13. package/browser/connection/Connection.js.map +1 -1
  14. package/browser/connection/ConnectionMetadataBuilder.d.ts +3 -3
  15. package/browser/connection/ConnectionMetadataBuilder.js +54 -22
  16. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  17. package/browser/connection/ConnectionOptionsReader.js +36 -29
  18. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  19. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  20. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  21. package/browser/decorator/Unique.d.ts +5 -4
  22. package/browser/decorator/Unique.js +7 -3
  23. package/browser/decorator/Unique.js.map +1 -1
  24. package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +2 -1
  25. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  26. package/browser/decorator/listeners/AfterRecover.d.ts +4 -0
  27. package/browser/decorator/listeners/AfterRecover.js +16 -0
  28. package/browser/decorator/listeners/AfterRecover.js.map +1 -0
  29. package/browser/decorator/listeners/AfterSoftRemove.d.ts +4 -0
  30. package/browser/decorator/listeners/AfterSoftRemove.js +16 -0
  31. package/browser/decorator/listeners/AfterSoftRemove.js.map +1 -0
  32. package/browser/decorator/listeners/BeforeRecover.d.ts +4 -0
  33. package/browser/decorator/listeners/BeforeRecover.js +16 -0
  34. package/browser/decorator/listeners/BeforeRecover.js.map +1 -0
  35. package/browser/decorator/listeners/BeforeSoftRemove.d.ts +4 -0
  36. package/browser/decorator/listeners/BeforeSoftRemove.js +16 -0
  37. package/browser/decorator/listeners/BeforeSoftRemove.js.map +1 -0
  38. package/browser/decorator/options/ColumnOptions.d.ts +4 -0
  39. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  40. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +22 -0
  41. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js +3 -0
  42. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -0
  43. package/browser/decorator/options/RelationOptions.d.ts +1 -1
  44. package/browser/decorator/options/RelationOptions.js.map +1 -1
  45. package/browser/decorator/options/UniqueOptions.d.ts +10 -0
  46. package/browser/decorator/options/UniqueOptions.js +3 -0
  47. package/browser/decorator/options/UniqueOptions.js.map +1 -0
  48. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +2 -2
  49. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  50. package/browser/driver/better-sqlite3/BetterSqlite3Driver.d.ts +14 -1
  51. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +94 -9
  52. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  53. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +10 -0
  54. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js +64 -1
  55. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  56. package/browser/driver/capacitor/CapacitorQueryRunner.d.ts +8 -0
  57. package/browser/driver/capacitor/CapacitorQueryRunner.js +30 -0
  58. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  59. package/browser/driver/cockroachdb/CockroachQueryRunner.js +1 -1
  60. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  61. package/browser/driver/cordova/CordovaQueryRunner.d.ts +8 -0
  62. package/browser/driver/cordova/CordovaQueryRunner.js +30 -0
  63. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  64. package/browser/driver/expo/ExpoQueryRunner.d.ts +8 -0
  65. package/browser/driver/expo/ExpoQueryRunner.js +30 -0
  66. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  67. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +1 -1
  68. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  69. package/browser/driver/mongodb/MongoQueryRunner.d.ts +8 -0
  70. package/browser/driver/mongodb/MongoQueryRunner.js +20 -0
  71. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  72. package/browser/driver/mysql/MysqlQueryRunner.js +1 -1
  73. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  74. package/browser/driver/nativescript/NativescriptQueryRunner.d.ts +8 -0
  75. package/browser/driver/nativescript/NativescriptQueryRunner.js +30 -0
  76. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  77. package/browser/driver/oracle/OracleQueryRunner.js +1 -1
  78. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  79. package/browser/driver/postgres/PostgresQueryRunner.js +52 -19
  80. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  81. package/browser/driver/react-native/ReactNativeQueryRunner.d.ts +8 -0
  82. package/browser/driver/react-native/ReactNativeQueryRunner.js +30 -0
  83. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  84. package/browser/driver/sap/SapQueryRunner.js +1 -1
  85. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  86. package/browser/driver/sqlite/SqliteDriver.d.ts +13 -0
  87. package/browser/driver/sqlite/SqliteDriver.js +95 -11
  88. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  89. package/browser/driver/sqlite/SqliteQueryRunner.d.ts +8 -0
  90. package/browser/driver/sqlite/SqliteQueryRunner.js +30 -0
  91. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  92. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +13 -0
  93. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +25 -2
  94. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  95. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +11 -1
  96. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +119 -58
  97. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  98. package/browser/driver/sqljs/SqljsQueryRunner.d.ts +8 -0
  99. package/browser/driver/sqljs/SqljsQueryRunner.js +30 -0
  100. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  101. package/browser/entity-manager/EntityManager.d.ts +2 -2
  102. package/browser/entity-manager/EntityManager.js +2 -12
  103. package/browser/entity-manager/EntityManager.js.map +1 -1
  104. package/browser/entity-manager/MongoEntityManager.d.ts +2 -0
  105. package/browser/entity-manager/MongoEntityManager.js +37 -5
  106. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  107. package/browser/entity-schema/EntitySchemaOptions.d.ts +6 -0
  108. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  109. package/browser/entity-schema/EntitySchemaRelationOptions.d.ts +7 -1
  110. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  111. package/browser/entity-schema/EntitySchemaTransformer.js +4 -1
  112. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  113. package/browser/entity-schema/EntitySchemaUniqueOptions.d.ts +5 -0
  114. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  115. package/browser/find-options/FindOneOptions.d.ts +6 -0
  116. package/browser/find-options/FindOneOptions.js.map +1 -1
  117. package/browser/find-options/FindOptionsUtils.js +4 -0
  118. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  119. package/browser/find-options/operator/Like.d.ts +1 -1
  120. package/browser/find-options/operator/Like.js +1 -1
  121. package/browser/find-options/operator/Like.js.map +1 -1
  122. package/browser/find-options/operator/Not.d.ts +1 -1
  123. package/browser/find-options/operator/Not.js +1 -1
  124. package/browser/find-options/operator/Not.js.map +1 -1
  125. package/browser/globals.js +34 -7
  126. package/browser/globals.js.map +1 -1
  127. package/browser/index.d.ts +6 -0
  128. package/browser/index.js +6 -0
  129. package/browser/index.js.map +1 -1
  130. package/browser/metadata/ColumnMetadata.d.ts +4 -0
  131. package/browser/metadata/ColumnMetadata.js +2 -0
  132. package/browser/metadata/ColumnMetadata.js.map +1 -1
  133. package/browser/metadata/EntityMetadata.d.ts +16 -0
  134. package/browser/metadata/EntityMetadata.js +16 -0
  135. package/browser/metadata/EntityMetadata.js.map +1 -1
  136. package/browser/metadata/RelationMetadata.d.ts +1 -1
  137. package/browser/metadata/RelationMetadata.js.map +1 -1
  138. package/browser/metadata/UniqueMetadata.d.ts +5 -0
  139. package/browser/metadata/UniqueMetadata.js +1 -0
  140. package/browser/metadata/UniqueMetadata.js.map +1 -1
  141. package/browser/metadata/types/EventListenerTypes.d.ts +5 -1
  142. package/browser/metadata/types/EventListenerTypes.js +4 -0
  143. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  144. package/browser/metadata-args/UniqueMetadataArgs.d.ts +5 -0
  145. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  146. package/browser/metadata-builder/EntityMetadataBuilder.js +4 -0
  147. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  148. package/browser/metadata-builder/EntityMetadataValidator.js +2 -1
  149. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  150. package/browser/migration/MigrationExecutor.js +38 -26
  151. package/browser/migration/MigrationExecutor.js.map +1 -1
  152. package/browser/persistence/SubjectExecutor.d.ts +4 -2
  153. package/browser/persistence/SubjectExecutor.js +105 -13
  154. package/browser/persistence/SubjectExecutor.js.map +1 -1
  155. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js +3 -0
  156. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  157. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js +1 -1
  158. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  159. package/browser/platform/PlatformTools.d.ts +1 -0
  160. package/browser/platform/PlatformTools.js +5 -0
  161. package/browser/platform/PlatformTools.js.map +1 -1
  162. package/browser/query-builder/DeleteQueryBuilder.d.ts +4 -2
  163. package/browser/query-builder/DeleteQueryBuilder.js +4 -2
  164. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  165. package/browser/query-builder/InsertQueryBuilder.d.ts +1 -1
  166. package/browser/query-builder/InsertQueryBuilder.js +12 -3
  167. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  168. package/browser/query-builder/NotBrackets.d.ts +7 -0
  169. package/browser/query-builder/NotBrackets.js +16 -0
  170. package/browser/query-builder/NotBrackets.js.map +1 -0
  171. package/browser/query-builder/QueryBuilder.d.ts +3 -2
  172. package/browser/query-builder/QueryBuilder.js +2 -1
  173. package/browser/query-builder/QueryBuilder.js.map +1 -1
  174. package/browser/query-builder/RelationLoader.js +11 -6
  175. package/browser/query-builder/RelationLoader.js.map +1 -1
  176. package/browser/query-builder/RelationQueryBuilder.d.ts +1 -1
  177. package/browser/query-builder/RelationQueryBuilder.js +1 -1
  178. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  179. package/browser/query-builder/SelectQueryBuilder.d.ts +10 -1
  180. package/browser/query-builder/SelectQueryBuilder.js +28 -21
  181. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  182. package/browser/query-builder/SoftDeleteQueryBuilder.d.ts +1 -1
  183. package/browser/query-builder/SoftDeleteQueryBuilder.js +45 -31
  184. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  185. package/browser/query-builder/UpdateQueryBuilder.d.ts +4 -2
  186. package/browser/query-builder/UpdateQueryBuilder.js +11 -6
  187. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  188. package/browser/query-builder/WhereExpressionBuilder.d.ts +3 -1
  189. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  190. package/browser/query-builder/relation-id/RelationIdLoader.js +9 -9
  191. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  192. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +13 -0
  193. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +94 -50
  194. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  195. package/browser/query-runner/BaseQueryRunner.d.ts +10 -2
  196. package/browser/query-runner/BaseQueryRunner.js +23 -3
  197. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  198. package/browser/query-runner/QueryRunner.d.ts +8 -0
  199. package/browser/query-runner/QueryRunner.js.map +1 -1
  200. package/browser/repository/AbstractRepository.d.ts +2 -2
  201. package/browser/repository/AbstractRepository.js +2 -2
  202. package/browser/repository/AbstractRepository.js.map +1 -1
  203. package/browser/repository/BaseEntity.d.ts +1 -1
  204. package/browser/repository/BaseEntity.js +1 -1
  205. package/browser/repository/BaseEntity.js.map +1 -1
  206. package/browser/repository/Repository.d.ts +1 -1
  207. package/browser/repository/Repository.js +1 -1
  208. package/browser/repository/Repository.js.map +1 -1
  209. package/browser/repository/TreeRepository.js +3 -2
  210. package/browser/repository/TreeRepository.js.map +1 -1
  211. package/browser/schema-builder/RdbmsSchemaBuilder.js +37 -31
  212. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  213. package/browser/schema-builder/options/TableColumnOptions.d.ts +4 -0
  214. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  215. package/browser/schema-builder/options/TableUniqueOptions.d.ts +5 -0
  216. package/browser/schema-builder/options/TableUniqueOptions.js.map +1 -1
  217. package/browser/schema-builder/table/TableColumn.d.ts +4 -0
  218. package/browser/schema-builder/table/TableColumn.js +2 -0
  219. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  220. package/browser/schema-builder/table/TableUnique.d.ts +5 -0
  221. package/browser/schema-builder/table/TableUnique.js +5 -2
  222. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  223. package/browser/schema-builder/util/TableUtils.js +1 -0
  224. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  225. package/browser/subscriber/Broadcaster.d.ts +40 -0
  226. package/browser/subscriber/Broadcaster.js +191 -31
  227. package/browser/subscriber/Broadcaster.js.map +1 -1
  228. package/browser/subscriber/EntitySubscriberInterface.d.ts +18 -0
  229. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  230. package/browser/subscriber/event/RecoverEvent.d.ts +6 -0
  231. package/browser/subscriber/event/RecoverEvent.js +3 -0
  232. package/browser/subscriber/event/RecoverEvent.js.map +1 -0
  233. package/browser/subscriber/event/SoftRemoveEvent.d.ts +6 -0
  234. package/browser/subscriber/event/SoftRemoveEvent.js +3 -0
  235. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -0
  236. package/browser/util/DirectoryExportedClassesLoader.d.ts +1 -1
  237. package/browser/util/DirectoryExportedClassesLoader.js +55 -31
  238. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  239. package/browser/util/ImportUtils.d.ts +1 -0
  240. package/browser/util/ImportUtils.js +90 -0
  241. package/browser/util/ImportUtils.js.map +1 -0
  242. package/browser/util/PathUtils.d.ts +10 -0
  243. package/browser/util/PathUtils.js +28 -0
  244. package/browser/util/PathUtils.js.map +1 -0
  245. package/browser/util/RandomGenerator.d.ts +0 -4
  246. package/browser/util/RandomGenerator.js +0 -9
  247. package/browser/util/RandomGenerator.js.map +1 -1
  248. package/cache/RedisQueryResultCache.js +39 -34
  249. package/cache/RedisQueryResultCache.js.map +1 -1
  250. package/commands/CacheClearCommand.js +3 -3
  251. package/commands/CacheClearCommand.js.map +1 -1
  252. package/commands/CommandUtils.d.ts +4 -0
  253. package/commands/CommandUtils.js +10 -0
  254. package/commands/CommandUtils.js.map +1 -1
  255. package/commands/EntityCreateCommand.js +2 -2
  256. package/commands/EntityCreateCommand.js.map +1 -1
  257. package/commands/InitCommand.d.ts +9 -7
  258. package/commands/InitCommand.js +74 -45
  259. package/commands/InitCommand.js.map +1 -1
  260. package/commands/MigrationCreateCommand.d.ts +2 -0
  261. package/commands/MigrationCreateCommand.js +9 -3
  262. package/commands/MigrationCreateCommand.js.map +1 -1
  263. package/commands/MigrationGenerateCommand.d.ts +2 -0
  264. package/commands/MigrationGenerateCommand.js +9 -3
  265. package/commands/MigrationGenerateCommand.js.map +1 -1
  266. package/commands/MigrationRevertCommand.js +2 -3
  267. package/commands/MigrationRevertCommand.js.map +1 -1
  268. package/commands/MigrationRunCommand.js +2 -3
  269. package/commands/MigrationRunCommand.js.map +1 -1
  270. package/commands/MigrationShowCommand.js +5 -7
  271. package/commands/MigrationShowCommand.js.map +1 -1
  272. package/commands/QueryCommand.d.ts +1 -1
  273. package/commands/QueryCommand.js +2 -3
  274. package/commands/QueryCommand.js.map +1 -1
  275. package/commands/SchemaDropCommand.js +2 -2
  276. package/commands/SchemaDropCommand.js.map +1 -1
  277. package/commands/SchemaLogCommand.js +2 -2
  278. package/commands/SchemaLogCommand.js.map +1 -1
  279. package/commands/SchemaSyncCommand.js +2 -2
  280. package/commands/SchemaSyncCommand.js.map +1 -1
  281. package/commands/SubscriberCreateCommand.js +3 -3
  282. package/commands/SubscriberCreateCommand.js.map +1 -1
  283. package/common/DeepPartial.d.ts +3 -3
  284. package/common/DeepPartial.js.map +1 -1
  285. package/common/RelationType.d.ts +14 -0
  286. package/common/RelationType.js +4 -0
  287. package/common/RelationType.js.map +1 -0
  288. package/connection/BaseConnectionOptions.d.ts +5 -0
  289. package/connection/BaseConnectionOptions.js.map +1 -1
  290. package/connection/Connection.d.ts +7 -3
  291. package/connection/Connection.js +80 -55
  292. package/connection/Connection.js.map +1 -1
  293. package/connection/ConnectionMetadataBuilder.d.ts +3 -3
  294. package/connection/ConnectionMetadataBuilder.js +53 -21
  295. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  296. package/connection/ConnectionOptionsReader.js +35 -28
  297. package/connection/ConnectionOptionsReader.js.map +1 -1
  298. package/connection/options-reader/ConnectionOptionsEnvReader.js +1 -0
  299. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  300. package/decorator/Unique.d.ts +5 -4
  301. package/decorator/Unique.js +7 -3
  302. package/decorator/Unique.js.map +1 -1
  303. package/decorator/columns/PrimaryGeneratedColumn.d.ts +2 -1
  304. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  305. package/decorator/listeners/AfterRecover.d.ts +4 -0
  306. package/decorator/listeners/AfterRecover.js +20 -0
  307. package/decorator/listeners/AfterRecover.js.map +1 -0
  308. package/decorator/listeners/AfterSoftRemove.d.ts +4 -0
  309. package/decorator/listeners/AfterSoftRemove.js +20 -0
  310. package/decorator/listeners/AfterSoftRemove.js.map +1 -0
  311. package/decorator/listeners/BeforeRecover.d.ts +4 -0
  312. package/decorator/listeners/BeforeRecover.js +20 -0
  313. package/decorator/listeners/BeforeRecover.js.map +1 -0
  314. package/decorator/listeners/BeforeSoftRemove.d.ts +4 -0
  315. package/decorator/listeners/BeforeSoftRemove.js +20 -0
  316. package/decorator/listeners/BeforeSoftRemove.js.map +1 -0
  317. package/decorator/options/ColumnOptions.d.ts +4 -0
  318. package/decorator/options/ColumnOptions.js.map +1 -1
  319. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.d.ts +22 -0
  320. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js +4 -0
  321. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -0
  322. package/decorator/options/RelationOptions.d.ts +1 -1
  323. package/decorator/options/RelationOptions.js.map +1 -1
  324. package/decorator/options/UniqueOptions.d.ts +10 -0
  325. package/decorator/options/UniqueOptions.js +4 -0
  326. package/decorator/options/UniqueOptions.js.map +1 -0
  327. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +2 -2
  328. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  329. package/driver/better-sqlite3/BetterSqlite3Driver.d.ts +14 -1
  330. package/driver/better-sqlite3/BetterSqlite3Driver.js +93 -8
  331. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  332. package/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +10 -0
  333. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js +63 -0
  334. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  335. package/driver/capacitor/CapacitorQueryRunner.d.ts +8 -0
  336. package/driver/capacitor/CapacitorQueryRunner.js +30 -0
  337. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  338. package/driver/cockroachdb/CockroachQueryRunner.js +1 -1
  339. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  340. package/driver/cordova/CordovaQueryRunner.d.ts +8 -0
  341. package/driver/cordova/CordovaQueryRunner.js +30 -0
  342. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  343. package/driver/expo/ExpoQueryRunner.d.ts +8 -0
  344. package/driver/expo/ExpoQueryRunner.js +30 -0
  345. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  346. package/driver/mongodb/MongoConnectionOptions.d.ts +1 -1
  347. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  348. package/driver/mongodb/MongoQueryRunner.d.ts +8 -0
  349. package/driver/mongodb/MongoQueryRunner.js +20 -0
  350. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  351. package/driver/mysql/MysqlQueryRunner.js +1 -1
  352. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  353. package/driver/nativescript/NativescriptQueryRunner.d.ts +8 -0
  354. package/driver/nativescript/NativescriptQueryRunner.js +30 -0
  355. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  356. package/driver/oracle/OracleQueryRunner.js +1 -1
  357. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  358. package/driver/postgres/PostgresQueryRunner.js +52 -19
  359. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  360. package/driver/react-native/ReactNativeQueryRunner.d.ts +8 -0
  361. package/driver/react-native/ReactNativeQueryRunner.js +30 -0
  362. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  363. package/driver/sap/SapQueryRunner.js +1 -1
  364. package/driver/sap/SapQueryRunner.js.map +1 -1
  365. package/driver/sqlite/SqliteDriver.d.ts +13 -0
  366. package/driver/sqlite/SqliteDriver.js +94 -10
  367. package/driver/sqlite/SqliteDriver.js.map +1 -1
  368. package/driver/sqlite/SqliteQueryRunner.d.ts +8 -0
  369. package/driver/sqlite/SqliteQueryRunner.js +30 -0
  370. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  371. package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +13 -0
  372. package/driver/sqlite-abstract/AbstractSqliteDriver.js +25 -2
  373. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  374. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +11 -1
  375. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +119 -58
  376. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  377. package/driver/sqljs/SqljsQueryRunner.d.ts +8 -0
  378. package/driver/sqljs/SqljsQueryRunner.js +30 -0
  379. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  380. package/entity-manager/EntityManager.d.ts +2 -2
  381. package/entity-manager/EntityManager.js +2 -12
  382. package/entity-manager/EntityManager.js.map +1 -1
  383. package/entity-manager/MongoEntityManager.d.ts +2 -0
  384. package/entity-manager/MongoEntityManager.js +37 -5
  385. package/entity-manager/MongoEntityManager.js.map +1 -1
  386. package/entity-schema/EntitySchemaOptions.d.ts +6 -0
  387. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  388. package/entity-schema/EntitySchemaRelationOptions.d.ts +7 -1
  389. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  390. package/entity-schema/EntitySchemaTransformer.js +4 -1
  391. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  392. package/entity-schema/EntitySchemaUniqueOptions.d.ts +5 -0
  393. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  394. package/find-options/FindOneOptions.d.ts +6 -0
  395. package/find-options/FindOneOptions.js.map +1 -1
  396. package/find-options/FindOptionsUtils.js +4 -0
  397. package/find-options/FindOptionsUtils.js.map +1 -1
  398. package/find-options/operator/Like.d.ts +1 -1
  399. package/find-options/operator/Like.js +1 -1
  400. package/find-options/operator/Like.js.map +1 -1
  401. package/find-options/operator/Not.d.ts +1 -1
  402. package/find-options/operator/Not.js +1 -1
  403. package/find-options/operator/Not.js.map +1 -1
  404. package/globals.js +33 -6
  405. package/globals.js.map +1 -1
  406. package/index.d.ts +6 -0
  407. package/index.js +8 -1
  408. package/index.js.map +1 -1
  409. package/index.mjs +360 -0
  410. package/metadata/ColumnMetadata.d.ts +4 -0
  411. package/metadata/ColumnMetadata.js +2 -0
  412. package/metadata/ColumnMetadata.js.map +1 -1
  413. package/metadata/EntityMetadata.d.ts +16 -0
  414. package/metadata/EntityMetadata.js +16 -0
  415. package/metadata/EntityMetadata.js.map +1 -1
  416. package/metadata/RelationMetadata.d.ts +1 -1
  417. package/metadata/RelationMetadata.js.map +1 -1
  418. package/metadata/UniqueMetadata.d.ts +5 -0
  419. package/metadata/UniqueMetadata.js +1 -0
  420. package/metadata/UniqueMetadata.js.map +1 -1
  421. package/metadata/types/EventListenerTypes.d.ts +5 -1
  422. package/metadata/types/EventListenerTypes.js +4 -0
  423. package/metadata/types/EventListenerTypes.js.map +1 -1
  424. package/metadata-args/UniqueMetadataArgs.d.ts +5 -0
  425. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  426. package/metadata-builder/EntityMetadataBuilder.js +4 -0
  427. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  428. package/metadata-builder/EntityMetadataValidator.js +2 -1
  429. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  430. package/migration/MigrationExecutor.js +38 -26
  431. package/migration/MigrationExecutor.js.map +1 -1
  432. package/package.json +1 -1
  433. package/persistence/SubjectExecutor.d.ts +4 -2
  434. package/persistence/SubjectExecutor.js +105 -13
  435. package/persistence/SubjectExecutor.js.map +1 -1
  436. package/persistence/subject-builder/OneToManySubjectBuilder.js +3 -0
  437. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  438. package/persistence/tree/MaterializedPathSubjectExecutor.js +1 -1
  439. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  440. package/platform/PlatformTools.d.ts +1 -0
  441. package/platform/PlatformTools.js +5 -0
  442. package/platform/PlatformTools.js.map +1 -1
  443. package/query-builder/DeleteQueryBuilder.d.ts +4 -2
  444. package/query-builder/DeleteQueryBuilder.js +4 -2
  445. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  446. package/query-builder/InsertQueryBuilder.d.ts +1 -1
  447. package/query-builder/InsertQueryBuilder.js +12 -3
  448. package/query-builder/InsertQueryBuilder.js.map +1 -1
  449. package/query-builder/NotBrackets.d.ts +7 -0
  450. package/query-builder/NotBrackets.js +19 -0
  451. package/query-builder/NotBrackets.js.map +1 -0
  452. package/query-builder/QueryBuilder.d.ts +3 -2
  453. package/query-builder/QueryBuilder.js +2 -1
  454. package/query-builder/QueryBuilder.js.map +1 -1
  455. package/query-builder/RelationLoader.js +11 -6
  456. package/query-builder/RelationLoader.js.map +1 -1
  457. package/query-builder/RelationQueryBuilder.d.ts +1 -1
  458. package/query-builder/RelationQueryBuilder.js +1 -1
  459. package/query-builder/RelationQueryBuilder.js.map +1 -1
  460. package/query-builder/SelectQueryBuilder.d.ts +10 -1
  461. package/query-builder/SelectQueryBuilder.js +28 -21
  462. package/query-builder/SelectQueryBuilder.js.map +1 -1
  463. package/query-builder/SoftDeleteQueryBuilder.d.ts +1 -1
  464. package/query-builder/SoftDeleteQueryBuilder.js +45 -31
  465. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  466. package/query-builder/UpdateQueryBuilder.d.ts +4 -2
  467. package/query-builder/UpdateQueryBuilder.js +11 -6
  468. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  469. package/query-builder/WhereExpressionBuilder.d.ts +3 -1
  470. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  471. package/query-builder/relation-id/RelationIdLoader.js +9 -9
  472. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  473. package/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +13 -0
  474. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +94 -50
  475. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  476. package/query-runner/BaseQueryRunner.d.ts +10 -2
  477. package/query-runner/BaseQueryRunner.js +23 -3
  478. package/query-runner/BaseQueryRunner.js.map +1 -1
  479. package/query-runner/QueryRunner.d.ts +8 -0
  480. package/query-runner/QueryRunner.js.map +1 -1
  481. package/repository/AbstractRepository.d.ts +2 -2
  482. package/repository/AbstractRepository.js +2 -2
  483. package/repository/AbstractRepository.js.map +1 -1
  484. package/repository/BaseEntity.d.ts +1 -1
  485. package/repository/BaseEntity.js +1 -1
  486. package/repository/BaseEntity.js.map +1 -1
  487. package/repository/Repository.d.ts +1 -1
  488. package/repository/Repository.js +1 -1
  489. package/repository/Repository.js.map +1 -1
  490. package/repository/TreeRepository.js +3 -2
  491. package/repository/TreeRepository.js.map +1 -1
  492. package/schema-builder/RdbmsSchemaBuilder.js +37 -31
  493. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  494. package/schema-builder/options/TableColumnOptions.d.ts +4 -0
  495. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  496. package/schema-builder/options/TableUniqueOptions.d.ts +5 -0
  497. package/schema-builder/options/TableUniqueOptions.js.map +1 -1
  498. package/schema-builder/table/TableColumn.d.ts +4 -0
  499. package/schema-builder/table/TableColumn.js +2 -0
  500. package/schema-builder/table/TableColumn.js.map +1 -1
  501. package/schema-builder/table/TableUnique.d.ts +5 -0
  502. package/schema-builder/table/TableUnique.js +5 -2
  503. package/schema-builder/table/TableUnique.js.map +1 -1
  504. package/schema-builder/util/TableUtils.js +1 -0
  505. package/schema-builder/util/TableUtils.js.map +1 -1
  506. package/subscriber/Broadcaster.d.ts +40 -0
  507. package/subscriber/Broadcaster.js +191 -31
  508. package/subscriber/Broadcaster.js.map +1 -1
  509. package/subscriber/EntitySubscriberInterface.d.ts +18 -0
  510. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  511. package/subscriber/event/RecoverEvent.d.ts +6 -0
  512. package/subscriber/event/RecoverEvent.js +4 -0
  513. package/subscriber/event/RecoverEvent.js.map +1 -0
  514. package/subscriber/event/SoftRemoveEvent.d.ts +6 -0
  515. package/subscriber/event/SoftRemoveEvent.js +4 -0
  516. package/subscriber/event/SoftRemoveEvent.js.map +1 -0
  517. package/typeorm-class-transformer-shim.js +20 -0
  518. package/typeorm-model-shim.js +20 -0
  519. package/util/DirectoryExportedClassesLoader.d.ts +1 -1
  520. package/util/DirectoryExportedClassesLoader.js +54 -31
  521. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  522. package/util/ImportUtils.d.ts +1 -0
  523. package/util/ImportUtils.js +94 -0
  524. package/util/ImportUtils.js.map +1 -0
  525. package/util/PathUtils.d.ts +10 -0
  526. package/util/PathUtils.js +34 -0
  527. package/util/PathUtils.js.map +1 -0
  528. package/util/RandomGenerator.d.ts +0 -4
  529. package/util/RandomGenerator.js +0 -9
  530. package/util/RandomGenerator.js.map +1 -1
@@ -31,6 +31,11 @@ export declare class BetterSqlite3Driver extends AbstractSqliteDriver {
31
31
  precision?: number | null;
32
32
  scale?: number;
33
33
  }): string;
34
+ afterConnect(): Promise<void>;
35
+ /**
36
+ * For SQLite, the database may be added in the decorator metadata. It will be a filepath to a database file.
37
+ */
38
+ buildTableName(tableName: string, _schema?: string, database?: string): string;
34
39
  /**
35
40
  * Creates connection with the database.
36
41
  */
@@ -42,5 +47,13 @@ export declare class BetterSqlite3Driver extends AbstractSqliteDriver {
42
47
  /**
43
48
  * Auto creates database directory if it does not exist.
44
49
  */
45
- protected createDatabaseDirectory(fullPath: string): Promise<void>;
50
+ protected createDatabaseDirectory(dbPath: string): Promise<void>;
51
+ /**
52
+ * Performs the attaching of the database files. The attachedDatabase should have been populated during calls to #buildTableName
53
+ * during EntityMetadata production (see EntityMetadata#buildTablePath)
54
+ *
55
+ * https://sqlite.org/lang_attach.html
56
+ */
57
+ protected attachDatabases(): Promise<void>;
58
+ protected getMainDatabasePath(): string;
46
59
  }
@@ -9,6 +9,7 @@ var DriverOptionNotSetError_1 = require("../../error/DriverOptionNotSetError");
9
9
  var PlatformTools_1 = require("../../platform/PlatformTools");
10
10
  var AbstractSqliteDriver_1 = require("../sqlite-abstract/AbstractSqliteDriver");
11
11
  var BetterSqlite3QueryRunner_1 = require("./BetterSqlite3QueryRunner");
12
+ var PathUtils_1 = require("../../util/PathUtils");
12
13
  /**
13
14
  * Organizes communication with sqlite DBMS.
14
15
  */
@@ -58,6 +59,34 @@ var BetterSqlite3Driver = /** @class */ (function (_super) {
58
59
  }
59
60
  return _super.prototype.normalizeType.call(this, column);
60
61
  };
62
+ BetterSqlite3Driver.prototype.afterConnect = function () {
63
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
64
+ return (0, tslib_1.__generator)(this, function (_a) {
65
+ return [2 /*return*/, this.attachDatabases()];
66
+ });
67
+ });
68
+ };
69
+ /**
70
+ * For SQLite, the database may be added in the decorator metadata. It will be a filepath to a database file.
71
+ */
72
+ BetterSqlite3Driver.prototype.buildTableName = function (tableName, _schema, database) {
73
+ if (!database)
74
+ return tableName;
75
+ if (this.getAttachedDatabaseHandleByRelativePath(database))
76
+ return this.getAttachedDatabaseHandleByRelativePath(database) + "." + tableName;
77
+ if (database === this.options.database)
78
+ return tableName;
79
+ // we use the decorated name as supplied when deriving attach handle (ideally without non-portable absolute path)
80
+ var identifierHash = (0, PathUtils_1.filepathToName)(database);
81
+ // decorated name will be assumed relative to main database file when non absolute. Paths supplied as absolute won't be portable
82
+ var absFilepath = (0, PathUtils_1.isAbsolute)(database) ? database : path_1.default.join(this.getMainDatabasePath(), database);
83
+ this.attachedDatabases[database] = {
84
+ attachFilepathAbsolute: absFilepath,
85
+ attachFilepathRelative: database,
86
+ attachHandle: identifierHash,
87
+ };
88
+ return identifierHash + "." + tableName;
89
+ };
61
90
  // -------------------------------------------------------------------------
62
91
  // Protected Methods
63
92
  // -------------------------------------------------------------------------
@@ -71,25 +100,27 @@ var BetterSqlite3Driver = /** @class */ (function (_super) {
71
100
  switch (_f.label) {
72
101
  case 0:
73
102
  if (!(this.options.database !== ":memory:")) return [3 /*break*/, 2];
74
- return [4 /*yield*/, this.createDatabaseDirectory(this.options.database)];
103
+ return [4 /*yield*/, this.createDatabaseDirectory(path_1.default.dirname(this.options.database))];
75
104
  case 1:
76
105
  _f.sent();
77
106
  _f.label = 2;
78
107
  case 2:
79
108
  _a = this.options, database = _a.database, _b = _a.readonly, readonly = _b === void 0 ? false : _b, _c = _a.fileMustExist, fileMustExist = _c === void 0 ? false : _c, _d = _a.timeout, timeout = _d === void 0 ? 5000 : _d, _e = _a.verbose, verbose = _e === void 0 ? null : _e, prepareDatabase = _a.prepareDatabase;
80
109
  databaseConnection = this.sqlite(database, { readonly: readonly, fileMustExist: fileMustExist, timeout: timeout, verbose: verbose });
81
- // we need to enable foreign keys in sqlite to make sure all foreign key related features
82
- // working properly. this also makes onDelete to work with sqlite.
83
- databaseConnection.exec("PRAGMA foreign_keys = ON");
84
- // turn on WAL mode to enhance performance
85
- databaseConnection.exec("PRAGMA journal_mode = WAL");
86
110
  // in the options, if encryption key for SQLCipher is setted.
111
+ // Must invoke key pragma before trying to do any other interaction with the database.
87
112
  if (this.options.key) {
88
113
  databaseConnection.exec("PRAGMA key = " + JSON.stringify(this.options.key));
89
114
  }
115
+ // function to run before a database is used in typeorm.
90
116
  if (typeof prepareDatabase === "function") {
91
117
  prepareDatabase(databaseConnection);
92
118
  }
119
+ // we need to enable foreign keys in sqlite to make sure all foreign key related features
120
+ // working properly. this also makes onDelete to work with sqlite.
121
+ databaseConnection.exec("PRAGMA foreign_keys = ON");
122
+ // turn on WAL mode to enhance performance
123
+ databaseConnection.exec("PRAGMA journal_mode = WAL");
93
124
  return [2 /*return*/, databaseConnection];
94
125
  }
95
126
  });
@@ -110,11 +141,11 @@ var BetterSqlite3Driver = /** @class */ (function (_super) {
110
141
  /**
111
142
  * Auto creates database directory if it does not exist.
112
143
  */
113
- BetterSqlite3Driver.prototype.createDatabaseDirectory = function (fullPath) {
144
+ BetterSqlite3Driver.prototype.createDatabaseDirectory = function (dbPath) {
114
145
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
115
146
  return (0, tslib_1.__generator)(this, function (_a) {
116
147
  switch (_a.label) {
117
- case 0: return [4 /*yield*/, (0, mkdirp_1.default)(path_1.default.dirname(fullPath))];
148
+ case 0: return [4 /*yield*/, (0, mkdirp_1.default)(dbPath)];
118
149
  case 1:
119
150
  _a.sent();
120
151
  return [2 /*return*/];
@@ -122,6 +153,60 @@ var BetterSqlite3Driver = /** @class */ (function (_super) {
122
153
  });
123
154
  });
124
155
  };
156
+ /**
157
+ * Performs the attaching of the database files. The attachedDatabase should have been populated during calls to #buildTableName
158
+ * during EntityMetadata production (see EntityMetadata#buildTablePath)
159
+ *
160
+ * https://sqlite.org/lang_attach.html
161
+ */
162
+ BetterSqlite3Driver.prototype.attachDatabases = function () {
163
+ var e_1, _a;
164
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
165
+ var _b, _c, _d, attachHandle, attachFilepathAbsolute, e_1_1;
166
+ return (0, tslib_1.__generator)(this, function (_e) {
167
+ switch (_e.label) {
168
+ case 0:
169
+ _e.trys.push([0, 7, 8, 13]);
170
+ _b = (0, tslib_1.__asyncValues)(Object.values(this.attachedDatabases));
171
+ _e.label = 1;
172
+ case 1: return [4 /*yield*/, _b.next()];
173
+ case 2:
174
+ if (!(_c = _e.sent(), !_c.done)) return [3 /*break*/, 6];
175
+ _d = _c.value, attachHandle = _d.attachHandle, attachFilepathAbsolute = _d.attachFilepathAbsolute;
176
+ return [4 /*yield*/, this.createDatabaseDirectory(path_1.default.dirname(attachFilepathAbsolute))];
177
+ case 3:
178
+ _e.sent();
179
+ return [4 /*yield*/, this.connection.query("ATTACH \"" + attachFilepathAbsolute + "\" AS \"" + attachHandle + "\"")];
180
+ case 4:
181
+ _e.sent();
182
+ _e.label = 5;
183
+ case 5: return [3 /*break*/, 1];
184
+ case 6: return [3 /*break*/, 13];
185
+ case 7:
186
+ e_1_1 = _e.sent();
187
+ e_1 = { error: e_1_1 };
188
+ return [3 /*break*/, 13];
189
+ case 8:
190
+ _e.trys.push([8, , 11, 12]);
191
+ if (!(_c && !_c.done && (_a = _b.return))) return [3 /*break*/, 10];
192
+ return [4 /*yield*/, _a.call(_b)];
193
+ case 9:
194
+ _e.sent();
195
+ _e.label = 10;
196
+ case 10: return [3 /*break*/, 12];
197
+ case 11:
198
+ if (e_1) throw e_1.error;
199
+ return [7 /*endfinally*/];
200
+ case 12: return [7 /*endfinally*/];
201
+ case 13: return [2 /*return*/];
202
+ }
203
+ });
204
+ });
205
+ };
206
+ BetterSqlite3Driver.prototype.getMainDatabasePath = function () {
207
+ var optionsDb = this.options.database;
208
+ return path_1.default.dirname((0, PathUtils_1.isAbsolute)(optionsDb) ? optionsDb : path_1.default.join(this.options.baseDirectory, optionsDb));
209
+ };
125
210
  return BetterSqlite3Driver;
126
211
  }(AbstractSqliteDriver_1.AbstractSqliteDriver));
127
212
  exports.BetterSqlite3Driver = BetterSqlite3Driver;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/better-sqlite3/BetterSqlite3Driver.ts"],"names":[],"mappings":"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","file":"BetterSqlite3Driver.js","sourcesContent":["import mkdirp from \"mkdirp\";\nimport path from \"path\";\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\";\nimport { DriverOptionNotSetError } from \"../../error/DriverOptionNotSetError\";\nimport { PlatformTools } from \"../../platform/PlatformTools\";\nimport { Connection } from \"../../connection/Connection\";\nimport { ColumnType } from \"../types/ColumnTypes\";\nimport { QueryRunner } from \"../../query-runner/QueryRunner\";\nimport { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\";\nimport { BetterSqlite3ConnectionOptions } from \"./BetterSqlite3ConnectionOptions\";\nimport { BetterSqlite3QueryRunner } from \"./BetterSqlite3QueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\n\n/**\n * Organizes communication with sqlite DBMS.\n */\nexport class BetterSqlite3Driver extends AbstractSqliteDriver {\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: BetterSqlite3ConnectionOptions;\n\n /**\n * SQLite underlying library.\n */\n sqlite: any;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n super(connection);\n\n this.connection = connection;\n this.options = connection.options as BetterSqlite3ConnectionOptions;\n this.database = this.options.database;\n\n // validate options to make sure everything is set\n if (!this.options.database)\n throw new DriverOptionNotSetError(\"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 this.queryRunner = undefined;\n this.databaseConnection.close();\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode): QueryRunner {\n if (!this.queryRunner)\n this.queryRunner = new BetterSqlite3QueryRunner(this);\n\n return this.queryRunner;\n }\n\n normalizeType(column: { type?: ColumnType, length?: number | string, precision?: number | null, scale?: number }): string {\n if ((column.type as any) === Buffer) {\n return \"blob\";\n }\n\n return super.normalizeType(column);\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates connection with the database.\n */\n protected async createDatabaseConnection() {\n // not to create database directory if is in memory\n if (this.options.database !== \":memory:\")\n await this.createDatabaseDirectory(this.options.database);\n\n const {\n database,\n readonly = false,\n fileMustExist = false,\n timeout = 5000,\n verbose = null,\n prepareDatabase\n } = this.options;\n const databaseConnection = this.sqlite(database, { readonly, fileMustExist, timeout, verbose });\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 databaseConnection.exec(`PRAGMA foreign_keys = ON`);\n\n // turn on WAL mode to enhance performance\n databaseConnection.exec(`PRAGMA journal_mode = WAL`);\n\n // in the options, if encryption key for SQLCipher is setted.\n if (this.options.key) {\n databaseConnection.exec(`PRAGMA key = ${JSON.stringify(this.options.key)}`);\n }\n\n if (typeof prepareDatabase === \"function\") {\n prepareDatabase(databaseConnection);\n }\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(\"better-sqlite3\");\n this.sqlite = sqlite;\n\n } catch (e) {\n throw new DriverPackageNotInstalledError(\"SQLite\", \"better-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"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/better-sqlite3/BetterSqlite3Driver.ts"],"names":[],"mappings":"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","file":"BetterSqlite3Driver.js","sourcesContent":["import mkdirp from \"mkdirp\";\nimport path from \"path\";\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\";\nimport { DriverOptionNotSetError } from \"../../error/DriverOptionNotSetError\";\nimport { PlatformTools } from \"../../platform/PlatformTools\";\nimport { Connection } from \"../../connection/Connection\";\nimport { ColumnType } from \"../types/ColumnTypes\";\nimport { QueryRunner } from \"../../query-runner/QueryRunner\";\nimport { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\";\nimport { BetterSqlite3ConnectionOptions } from \"./BetterSqlite3ConnectionOptions\";\nimport { BetterSqlite3QueryRunner } from \"./BetterSqlite3QueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\nimport { filepathToName, isAbsolute } from \"../../util/PathUtils\";\n\n/**\n * Organizes communication with sqlite DBMS.\n */\nexport class BetterSqlite3Driver extends AbstractSqliteDriver {\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: BetterSqlite3ConnectionOptions;\n\n /**\n * SQLite underlying library.\n */\n sqlite: any;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n super(connection);\n\n this.connection = connection;\n this.options = connection.options as BetterSqlite3ConnectionOptions;\n this.database = this.options.database;\n\n // validate options to make sure everything is set\n if (!this.options.database)\n throw new DriverOptionNotSetError(\"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 this.queryRunner = undefined;\n this.databaseConnection.close();\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode): QueryRunner {\n if (!this.queryRunner)\n this.queryRunner = new BetterSqlite3QueryRunner(this);\n\n return this.queryRunner;\n }\n\n normalizeType(column: { type?: ColumnType, length?: number | string, precision?: number | null, scale?: number }): 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(tableName: string, _schema?: string, database?: string): string {\n\n if (!database) return tableName;\n if (this.getAttachedDatabaseHandleByRelativePath(database)) return `${this.getAttachedDatabaseHandleByRelativePath(database)}.${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) ? database : 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 // not to create database directory if is in memory\n if (this.options.database !== \":memory:\")\n await this.createDatabaseDirectory(path.dirname(this.options.database));\n\n const {\n database,\n readonly = false,\n fileMustExist = false,\n timeout = 5000,\n verbose = null,\n prepareDatabase\n } = this.options;\n const databaseConnection = this.sqlite(database, { readonly, fileMustExist, timeout, verbose });\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 databaseConnection.exec(`PRAGMA key = ${JSON.stringify(this.options.key)}`);\n }\n\n // function to run before a database is used in typeorm.\n if (typeof prepareDatabase === \"function\") {\n prepareDatabase(databaseConnection);\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 databaseConnection.exec(`PRAGMA foreign_keys = ON`);\n\n // turn on WAL mode to enhance performance\n databaseConnection.exec(`PRAGMA journal_mode = WAL`);\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(\"better-sqlite3\");\n this.sqlite = sqlite;\n\n } catch (e) {\n throw new DriverPackageNotInstalledError(\"SQLite\", \"better-sqlite3\");\n }\n }\n\n /**\n * Auto creates database directory if it does not exist.\n */\n protected async createDatabaseDirectory(dbPath: string): Promise<void> {\n await mkdirp(dbPath);\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\n // @todo - possibly check number of databases (but unqueriable at runtime sadly) - https://www.sqlite.org/limits.html#max_attached\n for await (const {attachHandle, attachFilepathAbsolute} of Object.values(this.attachedDatabases)) {\n await this.createDatabaseDirectory(path.dirname(attachFilepathAbsolute));\n await this.connection.query(`ATTACH \"${attachFilepathAbsolute}\" AS \"${attachHandle}\"`);\n }\n }\n\n protected getMainDatabasePath(): string {\n const optionsDb = this.options.database;\n return path.dirname(isAbsolute(optionsDb) ? optionsDb : path.join(this.options.baseDirectory!, optionsDb));\n }\n\n}\n"],"sourceRoot":"../.."}
@@ -15,8 +15,18 @@ export declare class BetterSqlite3QueryRunner extends AbstractSqliteQueryRunner
15
15
  private cacheSize;
16
16
  private stmtCache;
17
17
  private getStmt;
18
+ /**
19
+ * Called before migrations are run.
20
+ */
21
+ beforeMigration(): Promise<void>;
22
+ /**
23
+ * Called after migrations are run.
24
+ */
25
+ afterMigration(): Promise<void>;
18
26
  /**
19
27
  * Executes a given SQL query.
20
28
  */
21
29
  query(query: string, parameters?: any[], useStructuredResult?: boolean): Promise<any>;
30
+ protected loadTableRecords(tablePath: string, tableOrIndex: "table" | "index"): Promise<any>;
31
+ protected loadPragmaRecords(tablePath: string, pragma: string): Promise<any>;
22
32
  }
@@ -60,6 +60,36 @@ var BetterSqlite3QueryRunner = /** @class */ (function (_super) {
60
60
  });
61
61
  });
62
62
  };
63
+ /**
64
+ * Called before migrations are run.
65
+ */
66
+ BetterSqlite3QueryRunner.prototype.beforeMigration = function () {
67
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
68
+ return (0, tslib_1.__generator)(this, function (_a) {
69
+ switch (_a.label) {
70
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = OFF")];
71
+ case 1:
72
+ _a.sent();
73
+ return [2 /*return*/];
74
+ }
75
+ });
76
+ });
77
+ };
78
+ /**
79
+ * Called after migrations are run.
80
+ */
81
+ BetterSqlite3QueryRunner.prototype.afterMigration = function () {
82
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
83
+ return (0, tslib_1.__generator)(this, function (_a) {
84
+ switch (_a.label) {
85
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = ON")];
86
+ case 1:
87
+ _a.sent();
88
+ return [2 /*return*/];
89
+ }
90
+ });
91
+ });
92
+ };
63
93
  /**
64
94
  * Executes a given SQL query.
65
95
  */
@@ -117,6 +147,39 @@ var BetterSqlite3QueryRunner = /** @class */ (function (_super) {
117
147
  });
118
148
  });
119
149
  };
150
+ // -------------------------------------------------------------------------
151
+ // Protected Methods
152
+ // -------------------------------------------------------------------------
153
+ BetterSqlite3QueryRunner.prototype.loadTableRecords = function (tablePath, tableOrIndex) {
154
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
155
+ var _a, database, tableName, res;
156
+ return (0, tslib_1.__generator)(this, function (_b) {
157
+ switch (_b.label) {
158
+ case 0:
159
+ _a = (0, tslib_1.__read)(this.splitTablePath(tablePath), 2), database = _a[0], tableName = _a[1];
160
+ return [4 /*yield*/, this.query("SELECT " + (database ? "'" + database + "'" : null) + " as database, * FROM " + this.escapePath((database ? database + "." : "") + "sqlite_master") + " WHERE \"type\" = '" + tableOrIndex + "' AND \"" + (tableOrIndex === "table" ? "name" : "tbl_name") + "\" IN ('" + tableName + "')")];
161
+ case 1:
162
+ res = _b.sent();
163
+ return [2 /*return*/, res];
164
+ }
165
+ });
166
+ });
167
+ };
168
+ BetterSqlite3QueryRunner.prototype.loadPragmaRecords = function (tablePath, pragma) {
169
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
170
+ var _a, database, tableName, res;
171
+ return (0, tslib_1.__generator)(this, function (_b) {
172
+ switch (_b.label) {
173
+ case 0:
174
+ _a = (0, tslib_1.__read)(this.splitTablePath(tablePath), 2), database = _a[0], tableName = _a[1];
175
+ return [4 /*yield*/, this.query("PRAGMA " + (database ? "\"" + database + "\"." : "") + pragma + "(\"" + tableName + "\")")];
176
+ case 1:
177
+ res = _b.sent();
178
+ return [2 /*return*/, res];
179
+ }
180
+ });
181
+ });
182
+ };
120
183
  return BetterSqlite3QueryRunner;
121
184
  }(AbstractSqliteQueryRunner_1.AbstractSqliteQueryRunner));
122
185
  exports.BetterSqlite3QueryRunner = BetterSqlite3QueryRunner;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/better-sqlite3/BetterSqlite3QueryRunner.ts"],"names":[],"mappings":"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","file":"BetterSqlite3QueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport { QueryFailedError } from \"../../error/QueryFailedError\";\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport { Broadcaster } from \"../../subscriber/Broadcaster\";\nimport { BetterSqlite3Driver } from \"./BetterSqlite3Driver\";\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 BetterSqlite3QueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: BetterSqlite3Driver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: BetterSqlite3Driver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n if (typeof this.driver.options.statementCacheSize === \"number\") {\n this.cacheSize = this.driver.options.statementCacheSize;\n } else {\n this.cacheSize = 100;\n }\n }\n\n private cacheSize: number;\n private stmtCache = new Map<string, any>();\n\n private async getStmt(query: string) {\n if (this.cacheSize > 0) {\n let stmt = this.stmtCache.get(query);\n if (!stmt) {\n const databaseConnection = await this.connect();\n stmt = databaseConnection.prepare(query);\n this.stmtCache.set(query, stmt);\n while (this.stmtCache.size > this.cacheSize) {\n // since es6 map keeps the insertion order,\n // it comes to be FIFO cache\n const key = this.stmtCache.keys().next().value;\n this.stmtCache.delete(key);\n }\n }\n return stmt;\n } else {\n const databaseConnection = await this.connect();\n return databaseConnection.prepare(query);\n }\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n const connection = this.driver.connection;\n\n parameters = parameters || [];\n for (let i = 0; i < parameters.length; i++) {\n // in \"where\" clauses the parameters are not escaped by the driver\n if (typeof parameters[i] === \"boolean\")\n parameters[i] = +parameters[i];\n }\n\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n\n const stmt = await this.getStmt(query);\n\n try {\n const result = new QueryResult();\n\n if (stmt.reader) {\n const raw = stmt.all.apply(stmt, parameters);\n\n result.raw = raw;\n\n if (Array.isArray(raw)) {\n result.records = raw;\n }\n\n } else {\n const raw = stmt.run.apply(stmt, parameters);\n result.affected = raw.changes;\n result.raw = raw.lastInsertRowid;\n }\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n } catch (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n throw new QueryFailedError(query, parameters, err);\n }\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/better-sqlite3/BetterSqlite3QueryRunner.ts"],"names":[],"mappings":"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","file":"BetterSqlite3QueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport { QueryFailedError } from \"../../error/QueryFailedError\";\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport { Broadcaster } from \"../../subscriber/Broadcaster\";\nimport { BetterSqlite3Driver } from \"./BetterSqlite3Driver\";\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 BetterSqlite3QueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: BetterSqlite3Driver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: BetterSqlite3Driver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n if (typeof this.driver.options.statementCacheSize === \"number\") {\n this.cacheSize = this.driver.options.statementCacheSize;\n } else {\n this.cacheSize = 100;\n }\n }\n\n private cacheSize: number;\n private stmtCache = new Map<string, any>();\n\n private async getStmt(query: string) {\n if (this.cacheSize > 0) {\n let stmt = this.stmtCache.get(query);\n if (!stmt) {\n const databaseConnection = await this.connect();\n stmt = databaseConnection.prepare(query);\n this.stmtCache.set(query, stmt);\n while (this.stmtCache.size > this.cacheSize) {\n // since es6 map keeps the insertion order,\n // it comes to be FIFO cache\n const key = this.stmtCache.keys().next().value;\n this.stmtCache.delete(key);\n }\n }\n return stmt;\n } else {\n const databaseConnection = await this.connect();\n return databaseConnection.prepare(query);\n }\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 async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n const connection = this.driver.connection;\n\n parameters = parameters || [];\n for (let i = 0; i < parameters.length; i++) {\n // in \"where\" clauses the parameters are not escaped by the driver\n if (typeof parameters[i] === \"boolean\")\n parameters[i] = +parameters[i];\n }\n\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n\n const stmt = await this.getStmt(query);\n\n try {\n const result = new QueryResult();\n\n if (stmt.reader) {\n const raw = stmt.all.apply(stmt, parameters);\n\n result.raw = raw;\n\n if (Array.isArray(raw)) {\n result.records = raw;\n }\n\n } else {\n const raw = stmt.run.apply(stmt, parameters);\n result.affected = raw.changes;\n result.raw = raw.lastInsertRowid;\n }\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n } catch (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n throw new QueryFailedError(query, parameters, err);\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n protected async loadTableRecords(tablePath: string, tableOrIndex: \"table\" | \"index\") {\n const [database, tableName] = this.splitTablePath(tablePath);\n const res = await this.query(`SELECT ${database ? `'${database}'` : null} as database, * FROM ${this.escapePath(`${database ? `${database}.` : \"\"}sqlite_master`)} WHERE \"type\" = '${tableOrIndex}' AND \"${tableOrIndex === \"table\" ? \"name\" : \"tbl_name\"}\" IN ('${tableName}')`);\n return res;\n }\n protected async loadPragmaRecords(tablePath: string, pragma: string) {\n const [database, tableName] = this.splitTablePath(tablePath);\n const res = await this.query(`PRAGMA ${database ? `\"${database}\".` : \"\"}${pragma}(\"${tableName}\")`);\n return res;\n }\n}\n"],"sourceRoot":"../.."}
@@ -10,6 +10,14 @@ export declare class CapacitorQueryRunner extends AbstractSqliteQueryRunner {
10
10
  */
11
11
  driver: CapacitorDriver;
12
12
  constructor(driver: CapacitorDriver);
13
+ /**
14
+ * Called before migrations are run.
15
+ */
16
+ beforeMigration(): Promise<void>;
17
+ /**
18
+ * Called after migrations are run.
19
+ */
20
+ afterMigration(): Promise<void>;
13
21
  executeSet(set: {
14
22
  statement: string;
15
23
  values?: any[];
@@ -22,6 +22,36 @@ var CapacitorQueryRunner = /** @class */ (function (_super) {
22
22
  _this.broadcaster = new Broadcaster_1.Broadcaster(_this);
23
23
  return _this;
24
24
  }
25
+ /**
26
+ * Called before migrations are run.
27
+ */
28
+ CapacitorQueryRunner.prototype.beforeMigration = function () {
29
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
30
+ return (0, tslib_1.__generator)(this, function (_a) {
31
+ switch (_a.label) {
32
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = OFF")];
33
+ case 1:
34
+ _a.sent();
35
+ return [2 /*return*/];
36
+ }
37
+ });
38
+ });
39
+ };
40
+ /**
41
+ * Called after migrations are run.
42
+ */
43
+ CapacitorQueryRunner.prototype.afterMigration = function () {
44
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
45
+ return (0, tslib_1.__generator)(this, function (_a) {
46
+ switch (_a.label) {
47
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = ON")];
48
+ case 1:
49
+ _a.sent();
50
+ return [2 /*return*/];
51
+ }
52
+ });
53
+ });
54
+ };
25
55
  CapacitorQueryRunner.prototype.executeSet = function (set) {
26
56
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
27
57
  var databaseConnection;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/capacitor/CapacitorQueryRunner.ts"],"names":[],"mappings":"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","file":"CapacitorQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport { QueryFailedError } from \"../../error/QueryFailedError\";\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport { CapacitorDriver } from \"./CapacitorDriver\";\nimport { Broadcaster } from \"../../subscriber/Broadcaster\";\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class CapacitorQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: CapacitorDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: CapacitorDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n async executeSet(set: { statement: string; values?: any[] }[]) {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError();\n\n const databaseConnection = await this.connect();\n\n return databaseConnection.executeSet(set, false);\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError();\n\n const databaseConnection = await this.connect();\n\n this.driver.connection.logger.logQuery(query, parameters, this);\n\n const command = query.substr(0, query.indexOf(\" \"));\n\n try {\n let raw: any;\n\n if (\n [ \"BEGIN\", \"ROLLBACK\", \"COMMIT\", \"CREATE\", \"ALTER\", \"DROP\" ].indexOf(\n command\n ) !== -1\n ) {\n raw = await databaseConnection.execute(query, false);\n } else if ([ \"INSERT\", \"UPDATE\", \"DELETE\" ].indexOf(command) !== -1) {\n raw = await databaseConnection.run(query, parameters, false);\n } else {\n raw = await databaseConnection.query(query, parameters || []);\n }\n\n const result = new QueryResult();\n\n if (raw?.hasOwnProperty('values')) {\n result.raw = raw.values;\n result.records = raw.values;\n }\n\n if (raw?.hasOwnProperty('changes')) {\n result.affected = raw.changes.changes;\n result.raw = raw.changes.lastId || raw.changes.changes;\n }\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n } catch (err) {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this\n );\n\n throw new QueryFailedError(query, parameters, err);\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral): string[] {\n return Object.keys(objectLiteral).map((key) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/capacitor/CapacitorQueryRunner.ts"],"names":[],"mappings":"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","file":"CapacitorQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport { QueryFailedError } from \"../../error/QueryFailedError\";\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport { CapacitorDriver } from \"./CapacitorDriver\";\nimport { Broadcaster } from \"../../subscriber/Broadcaster\";\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class CapacitorQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: CapacitorDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: CapacitorDriver) {\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 async executeSet(set: { statement: string; values?: any[] }[]) {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError();\n\n const databaseConnection = await this.connect();\n\n return databaseConnection.executeSet(set, false);\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError();\n\n const databaseConnection = await this.connect();\n\n this.driver.connection.logger.logQuery(query, parameters, this);\n\n const command = query.substr(0, query.indexOf(\" \"));\n\n try {\n let raw: any;\n\n if (\n [ \"BEGIN\", \"ROLLBACK\", \"COMMIT\", \"CREATE\", \"ALTER\", \"DROP\" ].indexOf(\n command\n ) !== -1\n ) {\n raw = await databaseConnection.execute(query, false);\n } else if ([ \"INSERT\", \"UPDATE\", \"DELETE\" ].indexOf(command) !== -1) {\n raw = await databaseConnection.run(query, parameters, false);\n } else {\n raw = await databaseConnection.query(query, parameters || []);\n }\n\n const result = new QueryResult();\n\n if (raw?.hasOwnProperty('values')) {\n result.raw = raw.values;\n result.records = raw.values;\n }\n\n if (raw?.hasOwnProperty('changes')) {\n result.affected = raw.changes.changes;\n result.raw = raw.changes.lastId || raw.changes.changes;\n }\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n } catch (err) {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this\n );\n\n throw new QueryFailedError(query, parameters, err);\n }\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral): string[] {\n return Object.keys(objectLiteral).map((key) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
@@ -1947,7 +1947,7 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
1947
1947
  table = _a;
1948
1948
  index = indexOrName instanceof TableIndex_1.TableIndex ? indexOrName : table.indices.find(function (i) { return i.name === indexOrName; });
1949
1949
  if (!index)
1950
- throw new error_1.TypeORMError("Supplied index was not found in table " + table.name);
1950
+ throw new error_1.TypeORMError("Supplied index " + indexOrName + " was not found in table " + table.name);
1951
1951
  up = this.dropIndexSql(table, index);
1952
1952
  down = this.createIndexSql(table, index);
1953
1953
  return [4 /*yield*/, this.executeQueries(up, down)];