typeorm 0.3.22-dev.72145b8 → 0.3.22-dev.7b242e1

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 (319) hide show
  1. package/browser/cache/DbQueryResultCache.js +1 -1
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/connection/ConnectionOptionsReader.js +5 -9
  4. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  5. package/browser/data-source/DataSource.js +2 -2
  6. package/browser/data-source/DataSource.js.map +1 -1
  7. package/browser/decorator/relations/RelationCount.d.ts +2 -1
  8. package/browser/decorator/relations/RelationCount.js +2 -1
  9. package/browser/decorator/relations/RelationCount.js.map +1 -1
  10. package/browser/driver/DriverFactory.js +2 -2
  11. package/browser/driver/DriverFactory.js.map +1 -1
  12. package/browser/driver/DriverUtils.js +4 -5
  13. package/browser/driver/DriverUtils.js.map +1 -1
  14. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js +3 -3
  15. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  16. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +1 -1
  17. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  18. package/browser/driver/cockroachdb/CockroachDriver.js +6 -8
  19. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  20. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +1 -1
  21. package/browser/driver/cockroachdb/CockroachQueryRunner.js +7 -4
  22. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  23. package/browser/driver/cordova/CordovaQueryRunner.js +1 -1
  24. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  25. package/browser/driver/expo/ExpoDriver.d.ts +2 -12
  26. package/browser/driver/expo/ExpoDriver.js +8 -54
  27. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  28. package/browser/driver/expo/ExpoDriverFactory.d.ts +9 -0
  29. package/browser/driver/expo/ExpoDriverFactory.js +18 -0
  30. package/browser/driver/expo/ExpoDriverFactory.js.map +1 -0
  31. package/browser/driver/expo/ExpoQueryRunner.d.ts +0 -48
  32. package/browser/driver/expo/ExpoQueryRunner.js +36 -141
  33. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  34. package/browser/driver/expo/legacy/ExpoLegacyDriver.d.ts +21 -0
  35. package/browser/driver/expo/legacy/ExpoLegacyDriver.js +71 -0
  36. package/browser/driver/expo/legacy/ExpoLegacyDriver.js.map +1 -0
  37. package/browser/driver/expo/legacy/ExpoLegacyQueryRunner.d.ts +57 -0
  38. package/browser/driver/expo/legacy/ExpoLegacyQueryRunner.js +165 -0
  39. package/browser/driver/expo/legacy/ExpoLegacyQueryRunner.js.map +1 -0
  40. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +111 -142
  41. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  42. package/browser/driver/mongodb/MongoDriver.d.ts +2 -3
  43. package/browser/driver/mongodb/MongoDriver.js +57 -65
  44. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  45. package/browser/driver/mysql/MysqlDriver.js +10 -12
  46. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  47. package/browser/driver/mysql/MysqlQueryRunner.d.ts +1 -1
  48. package/browser/driver/mysql/MysqlQueryRunner.js +9 -3
  49. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  50. package/browser/driver/oracle/OracleDriver.js +3 -3
  51. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  52. package/browser/driver/oracle/OracleQueryRunner.js +2 -2
  53. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  54. package/browser/driver/postgres/PostgresDriver.d.ts +2 -1
  55. package/browser/driver/postgres/PostgresDriver.js +15 -20
  56. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  57. package/browser/driver/postgres/PostgresQueryRunner.d.ts +1 -1
  58. package/browser/driver/postgres/PostgresQueryRunner.js +12 -8
  59. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  60. package/browser/driver/react-native/ReactNativeDriver.js +1 -1
  61. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  62. package/browser/driver/react-native/ReactNativeQueryRunner.js +1 -1
  63. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  64. package/browser/driver/sap/SapDriver.d.ts +4 -0
  65. package/browser/driver/sap/SapDriver.js +50 -43
  66. package/browser/driver/sap/SapDriver.js.map +1 -1
  67. package/browser/driver/sap/SapQueryRunner.d.ts +7 -0
  68. package/browser/driver/sap/SapQueryRunner.js +19 -22
  69. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  70. package/browser/driver/spanner/SpannerDriver.js +3 -3
  71. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  72. package/browser/driver/spanner/SpannerQueryRunner.js +7 -7
  73. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  74. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +1 -1
  75. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  76. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +7 -7
  77. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  78. package/browser/driver/sqljs/SqljsDriver.js +1 -1
  79. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  80. package/browser/driver/sqlserver/SqlServerDriver.js +3 -3
  81. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  82. package/browser/driver/sqlserver/SqlServerQueryRunner.js +4 -4
  83. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  84. package/browser/driver/types/ColumnTypes.d.ts +1 -1
  85. package/browser/driver/types/ColumnTypes.js.map +1 -1
  86. package/browser/entity-manager/EntityManager.js.map +1 -1
  87. package/browser/entity-manager/MongoEntityManager.js +1 -1
  88. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  89. package/browser/find-options/FindOptionsSelect.d.ts +1 -1
  90. package/browser/find-options/FindOptionsSelect.js.map +1 -1
  91. package/browser/find-options/FindOptionsUtils.js +1 -1
  92. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  93. package/browser/index.d.ts +1 -0
  94. package/browser/index.js +1 -0
  95. package/browser/index.js.map +1 -1
  96. package/browser/logger/AdvancedConsoleLogger.js +1 -1
  97. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  98. package/browser/logger/DebugLogger.js +1 -1
  99. package/browser/logger/DebugLogger.js.map +1 -1
  100. package/browser/logger/FileLogger.js +1 -1
  101. package/browser/logger/FileLogger.js.map +1 -1
  102. package/browser/logger/SimpleConsoleLogger.js +1 -1
  103. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  104. package/browser/metadata/ColumnMetadata.js +1 -1
  105. package/browser/metadata/ColumnMetadata.js.map +1 -1
  106. package/browser/metadata/EmbeddedMetadata.js +1 -1
  107. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  108. package/browser/migration/MigrationExecutor.js +4 -4
  109. package/browser/migration/MigrationExecutor.js.map +1 -1
  110. package/browser/persistence/EntityPersistExecutor.js +2 -2
  111. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  112. package/browser/persistence/SubjectDatabaseEntityLoader.js +1 -1
  113. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  114. package/browser/persistence/SubjectExecutor.js +1 -1
  115. package/browser/persistence/SubjectExecutor.js.map +1 -1
  116. package/browser/persistence/SubjectTopologicalSorter.js +5 -5
  117. package/browser/persistence/SubjectTopologicalSorter.js.map +1 -1
  118. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  119. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  120. package/browser/persistence/tree/NestedSetSubjectExecutor.js +2 -2
  121. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  122. package/browser/query-builder/InsertQueryBuilder.js +2 -1
  123. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  124. package/browser/query-builder/JoinAttribute.js +2 -2
  125. package/browser/query-builder/JoinAttribute.js.map +1 -1
  126. package/browser/query-builder/QueryBuilder.js +2 -2
  127. package/browser/query-builder/QueryBuilder.js.map +1 -1
  128. package/browser/query-builder/RelationIdLoader.js +2 -2
  129. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  130. package/browser/query-builder/SelectQueryBuilder.js +27 -14
  131. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  132. package/browser/query-builder/SoftDeleteQueryBuilder.js +1 -1
  133. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  134. package/browser/query-builder/UpdateQueryBuilder.js +3 -3
  135. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  136. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +2 -2
  137. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  138. package/browser/repository/Repository.js.map +1 -1
  139. package/browser/subscriber/event/QueryEvent.d.ts +1 -1
  140. package/browser/subscriber/event/QueryEvent.js.map +1 -1
  141. package/browser/util/DepGraph.js +13 -13
  142. package/browser/util/DepGraph.js.map +1 -1
  143. package/browser/util/DirectoryExportedClassesLoader.js +2 -2
  144. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  145. package/browser/util/InstanceChecker.js.map +1 -1
  146. package/browser/util/ObjectUtils.d.ts +2 -2
  147. package/browser/util/ObjectUtils.js.map +1 -1
  148. package/browser/util/OrmUtils.js +4 -4
  149. package/browser/util/OrmUtils.js.map +1 -1
  150. package/browser/util/RandomGenerator.js +6 -6
  151. package/browser/util/RandomGenerator.js.map +1 -1
  152. package/browser/util/VersionUtils.d.ts +1 -2
  153. package/browser/util/VersionUtils.js +14 -7
  154. package/browser/util/VersionUtils.js.map +1 -1
  155. package/browser/util/escapeRegExp.d.ts +1 -1
  156. package/browser/util/escapeRegExp.js.map +1 -1
  157. package/cache/DbQueryResultCache.js +1 -1
  158. package/cache/DbQueryResultCache.js.map +1 -1
  159. package/commands/CommandUtils.js +1 -0
  160. package/commands/CommandUtils.js.map +1 -1
  161. package/commands/InitCommand.js +29 -27
  162. package/commands/InitCommand.js.map +1 -1
  163. package/commands/MigrationGenerateCommand.js +2 -2
  164. package/commands/MigrationGenerateCommand.js.map +1 -1
  165. package/connection/ConnectionOptionsReader.js +5 -9
  166. package/connection/ConnectionOptionsReader.js.map +1 -1
  167. package/data-source/DataSource.js +2 -2
  168. package/data-source/DataSource.js.map +1 -1
  169. package/decorator/relations/RelationCount.d.ts +2 -1
  170. package/decorator/relations/RelationCount.js +2 -1
  171. package/decorator/relations/RelationCount.js.map +1 -1
  172. package/driver/DriverFactory.js +2 -2
  173. package/driver/DriverFactory.js.map +1 -1
  174. package/driver/DriverUtils.js +4 -5
  175. package/driver/DriverUtils.js.map +1 -1
  176. package/driver/aurora-mysql/AuroraMysqlDriver.js +3 -3
  177. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  178. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +1 -1
  179. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  180. package/driver/cockroachdb/CockroachDriver.js +6 -8
  181. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  182. package/driver/cockroachdb/CockroachQueryRunner.d.ts +1 -1
  183. package/driver/cockroachdb/CockroachQueryRunner.js +7 -4
  184. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  185. package/driver/cordova/CordovaQueryRunner.js +1 -1
  186. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  187. package/driver/expo/ExpoDriver.d.ts +2 -12
  188. package/driver/expo/ExpoDriver.js +8 -54
  189. package/driver/expo/ExpoDriver.js.map +1 -1
  190. package/driver/expo/ExpoDriverFactory.d.ts +9 -0
  191. package/driver/expo/ExpoDriverFactory.js +22 -0
  192. package/driver/expo/ExpoDriverFactory.js.map +1 -0
  193. package/driver/expo/ExpoQueryRunner.d.ts +0 -48
  194. package/driver/expo/ExpoQueryRunner.js +36 -141
  195. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  196. package/driver/expo/legacy/ExpoLegacyDriver.d.ts +21 -0
  197. package/driver/expo/legacy/ExpoLegacyDriver.js +75 -0
  198. package/driver/expo/legacy/ExpoLegacyDriver.js.map +1 -0
  199. package/driver/expo/legacy/ExpoLegacyQueryRunner.d.ts +57 -0
  200. package/driver/expo/legacy/ExpoLegacyQueryRunner.js +169 -0
  201. package/driver/expo/legacy/ExpoLegacyQueryRunner.js.map +1 -0
  202. package/driver/mongodb/MongoConnectionOptions.d.ts +111 -142
  203. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  204. package/driver/mongodb/MongoDriver.d.ts +2 -3
  205. package/driver/mongodb/MongoDriver.js +57 -65
  206. package/driver/mongodb/MongoDriver.js.map +1 -1
  207. package/driver/mysql/MysqlDriver.js +10 -12
  208. package/driver/mysql/MysqlDriver.js.map +1 -1
  209. package/driver/mysql/MysqlQueryRunner.d.ts +1 -1
  210. package/driver/mysql/MysqlQueryRunner.js +9 -3
  211. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  212. package/driver/oracle/OracleDriver.js +3 -3
  213. package/driver/oracle/OracleDriver.js.map +1 -1
  214. package/driver/oracle/OracleQueryRunner.js +2 -2
  215. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  216. package/driver/postgres/PostgresDriver.d.ts +2 -1
  217. package/driver/postgres/PostgresDriver.js +15 -20
  218. package/driver/postgres/PostgresDriver.js.map +1 -1
  219. package/driver/postgres/PostgresQueryRunner.d.ts +1 -1
  220. package/driver/postgres/PostgresQueryRunner.js +12 -8
  221. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  222. package/driver/react-native/ReactNativeDriver.js +1 -1
  223. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  224. package/driver/react-native/ReactNativeQueryRunner.js +1 -1
  225. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  226. package/driver/sap/SapDriver.d.ts +4 -0
  227. package/driver/sap/SapDriver.js +50 -43
  228. package/driver/sap/SapDriver.js.map +1 -1
  229. package/driver/sap/SapQueryRunner.d.ts +7 -0
  230. package/driver/sap/SapQueryRunner.js +19 -22
  231. package/driver/sap/SapQueryRunner.js.map +1 -1
  232. package/driver/spanner/SpannerDriver.js +3 -3
  233. package/driver/spanner/SpannerDriver.js.map +1 -1
  234. package/driver/spanner/SpannerQueryRunner.js +7 -7
  235. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  236. package/driver/sqlite-abstract/AbstractSqliteDriver.js +1 -1
  237. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  238. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +7 -7
  239. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  240. package/driver/sqljs/SqljsDriver.js +1 -1
  241. package/driver/sqljs/SqljsDriver.js.map +1 -1
  242. package/driver/sqlserver/SqlServerDriver.js +3 -3
  243. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  244. package/driver/sqlserver/SqlServerQueryRunner.js +4 -4
  245. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  246. package/driver/types/ColumnTypes.d.ts +1 -1
  247. package/driver/types/ColumnTypes.js.map +1 -1
  248. package/entity-manager/EntityManager.js.map +1 -1
  249. package/entity-manager/MongoEntityManager.js +1 -1
  250. package/entity-manager/MongoEntityManager.js.map +1 -1
  251. package/find-options/FindOptionsSelect.d.ts +1 -1
  252. package/find-options/FindOptionsSelect.js.map +1 -1
  253. package/find-options/FindOptionsUtils.js +1 -1
  254. package/find-options/FindOptionsUtils.js.map +1 -1
  255. package/index.d.ts +1 -0
  256. package/index.js +1 -0
  257. package/index.js.map +1 -1
  258. package/logger/AdvancedConsoleLogger.js +1 -1
  259. package/logger/AdvancedConsoleLogger.js.map +1 -1
  260. package/logger/DebugLogger.js +1 -1
  261. package/logger/DebugLogger.js.map +1 -1
  262. package/logger/FileLogger.js +1 -1
  263. package/logger/FileLogger.js.map +1 -1
  264. package/logger/SimpleConsoleLogger.js +1 -1
  265. package/logger/SimpleConsoleLogger.js.map +1 -1
  266. package/metadata/ColumnMetadata.js +1 -1
  267. package/metadata/ColumnMetadata.js.map +1 -1
  268. package/metadata/EmbeddedMetadata.js +1 -1
  269. package/metadata/EmbeddedMetadata.js.map +1 -1
  270. package/migration/MigrationExecutor.js +4 -4
  271. package/migration/MigrationExecutor.js.map +1 -1
  272. package/package.json +1 -1
  273. package/persistence/EntityPersistExecutor.js +2 -2
  274. package/persistence/EntityPersistExecutor.js.map +1 -1
  275. package/persistence/SubjectDatabaseEntityLoader.js +1 -1
  276. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  277. package/persistence/SubjectExecutor.js +1 -1
  278. package/persistence/SubjectExecutor.js.map +1 -1
  279. package/persistence/SubjectTopologicalSorter.js +5 -5
  280. package/persistence/SubjectTopologicalSorter.js.map +1 -1
  281. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js +1 -1
  282. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  283. package/persistence/tree/NestedSetSubjectExecutor.js +2 -2
  284. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  285. package/query-builder/InsertQueryBuilder.js +2 -1
  286. package/query-builder/InsertQueryBuilder.js.map +1 -1
  287. package/query-builder/JoinAttribute.js +2 -2
  288. package/query-builder/JoinAttribute.js.map +1 -1
  289. package/query-builder/QueryBuilder.js +2 -2
  290. package/query-builder/QueryBuilder.js.map +1 -1
  291. package/query-builder/RelationIdLoader.js +2 -2
  292. package/query-builder/RelationIdLoader.js.map +1 -1
  293. package/query-builder/SelectQueryBuilder.js +27 -14
  294. package/query-builder/SelectQueryBuilder.js.map +1 -1
  295. package/query-builder/SoftDeleteQueryBuilder.js +1 -1
  296. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  297. package/query-builder/UpdateQueryBuilder.js +3 -3
  298. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  299. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +2 -2
  300. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  301. package/repository/Repository.js.map +1 -1
  302. package/subscriber/event/QueryEvent.d.ts +1 -1
  303. package/subscriber/event/QueryEvent.js.map +1 -1
  304. package/util/DepGraph.js +13 -13
  305. package/util/DepGraph.js.map +1 -1
  306. package/util/DirectoryExportedClassesLoader.js +2 -2
  307. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  308. package/util/InstanceChecker.js.map +1 -1
  309. package/util/ObjectUtils.d.ts +2 -2
  310. package/util/ObjectUtils.js.map +1 -1
  311. package/util/OrmUtils.js +4 -4
  312. package/util/OrmUtils.js.map +1 -1
  313. package/util/RandomGenerator.js +6 -6
  314. package/util/RandomGenerator.js.map +1 -1
  315. package/util/VersionUtils.d.ts +1 -2
  316. package/util/VersionUtils.js +14 -7
  317. package/util/VersionUtils.js.map +1 -1
  318. package/util/escapeRegExp.d.ts +1 -1
  319. package/util/escapeRegExp.js.map +1 -1
@@ -62,7 +62,7 @@ class CordovaQueryRunner extends AbstractSqliteQueryRunner_1.AbstractSqliteQuery
62
62
  result.raw = raw.insertId;
63
63
  }
64
64
  else {
65
- let resultSet = [];
65
+ const resultSet = [];
66
66
  for (let i = 0; i < raw.rows.length; i++) {
67
67
  resultSet.push(raw.rows.item(i));
68
68
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/cordova/CordovaQueryRunner.ts"],"names":[],"mappings":"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","file":"CordovaQueryRunner.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { CordovaDriver } from \"./CordovaDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { TypeORMError } from \"../../error\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class CordovaQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: CordovaDriver\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: CordovaDriver) {\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 async query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n const databaseConnection = await this.connect()\n const broadcasterResult = new BroadcasterResult()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n this.broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n const queryStartTime = +new Date()\n\n try {\n const raw = await new Promise<any>(async (ok, fail) => {\n databaseConnection.executeSql(\n query,\n parameters,\n (raw: any) => ok(raw),\n (err: any) => fail(err),\n )\n })\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n raw,\n undefined,\n )\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n const result = new QueryResult()\n\n if (query.substr(0, 11) === \"INSERT INTO\") {\n result.raw = raw.insertId\n } else {\n let resultSet = []\n for (let i = 0; i < raw.rows.length; i++) {\n resultSet.push(raw.rows.item(i))\n }\n\n result.records = resultSet\n result.raw = resultSet\n }\n\n if (useStructuredResult) {\n return result\n } else {\n return result.raw\n }\n } catch (err) {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n undefined,\n undefined,\n err,\n )\n\n throw new QueryFailedError(query, parameters, err)\n } finally {\n await broadcasterResult.wait()\n }\n }\n\n /**\n * Insert a new row with given values into the given table.\n * Returns value of the generated column if given and generate column exist in the table.\n // todo: implement new syntax\n async insert(tableName: string, keyValues: ObjectLiteral): Promise<InsertResult> {\n const keys = Object.keys(keyValues);\n const columns = keys.map(key => `\"${key}\"`).join(\", \");\n const values = keys.map(key => \"?\").join(\",\");\n const generatedColumns = this.connection.hasMetadata(tableName) ? this.connection.getMetadata(tableName).generatedColumns : [];\n const sql = columns.length > 0 ? (`INSERT INTO \"${tableName}\"(${columns}) VALUES (${values})`) : `INSERT INTO \"${tableName}\" DEFAULT VALUES`;\n const parameters = keys.map(key => keyValues[key]);\n\n return new Promise<InsertResult>(async (ok, fail) => {\n this.driver.connection.logger.logQuery(sql, parameters, this);\n const __this = this;\n const databaseConnection = await this.connect();\n databaseConnection.executeSql(sql, parameters, (resultSet: any) => {\n const generatedMap = generatedColumns.reduce((map, generatedColumn) => {\n const value = generatedColumn.isPrimary && generatedColumn.generationStrategy === \"increment\" && resultSet.insertId ? resultSet.insertId : keyValues[generatedColumn.databaseName];\n if (!value) return map;\n return OrmUtils.mergeDeep(map, generatedColumn.createValueMap(value));\n }, {} as ObjectLiteral);\n\n ok({\n result: undefined,\n generatedMap: Object.keys(generatedMap).length > 0 ? generatedMap : undefined\n });\n }, (err: any) => {\n __this.driver.connection.logger.logQueryError(err, sql, parameters, this);\n fail(err);\n });\n });\n }*/\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async startTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async commitTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async rollbackTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Removes all tables from the currently connected database.\n * Be careful with using this method and avoid using it in production or migrations\n * (because it can clear all your database).\n */\n async clearDatabase(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`)\n try {\n const selectViewDropsQuery = `SELECT 'DROP VIEW \"' || name || '\";' as query FROM \"sqlite_master\" WHERE \"type\" = 'view'`\n const dropViewQueries: ObjectLiteral[] = await this.query(\n selectViewDropsQuery,\n )\n\n const selectTableDropsQuery = `SELECT 'DROP TABLE \"' || name || '\";' as query FROM \"sqlite_master\" WHERE \"type\" = 'table' AND \"name\" != 'sqlite_sequence'`\n const dropTableQueries: ObjectLiteral[] = await this.query(\n selectTableDropsQuery,\n )\n\n await Promise.all(\n dropViewQueries.map((q) => this.query(q[\"query\"])),\n )\n await Promise.all(\n dropTableQueries.map((q) => this.query(q[\"query\"])),\n )\n } finally {\n await this.query(`PRAGMA foreign_keys = ON`)\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(\n objectLiteral: ObjectLiteral,\n startIndex: number = 0,\n ): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/cordova/CordovaQueryRunner.ts"],"names":[],"mappings":"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","file":"CordovaQueryRunner.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { CordovaDriver } from \"./CordovaDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { TypeORMError } from \"../../error\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class CordovaQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: CordovaDriver\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: CordovaDriver) {\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 async query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n const databaseConnection = await this.connect()\n const broadcasterResult = new BroadcasterResult()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n this.broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n const queryStartTime = +new Date()\n\n try {\n const raw = await new Promise<any>(async (ok, fail) => {\n databaseConnection.executeSql(\n query,\n parameters,\n (raw: any) => ok(raw),\n (err: any) => fail(err),\n )\n })\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n raw,\n undefined,\n )\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n const result = new QueryResult()\n\n if (query.substr(0, 11) === \"INSERT INTO\") {\n result.raw = raw.insertId\n } else {\n const resultSet = []\n for (let i = 0; i < raw.rows.length; i++) {\n resultSet.push(raw.rows.item(i))\n }\n\n result.records = resultSet\n result.raw = resultSet\n }\n\n if (useStructuredResult) {\n return result\n } else {\n return result.raw\n }\n } catch (err) {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n undefined,\n undefined,\n err,\n )\n\n throw new QueryFailedError(query, parameters, err)\n } finally {\n await broadcasterResult.wait()\n }\n }\n\n /**\n * Insert a new row with given values into the given table.\n * Returns value of the generated column if given and generate column exist in the table.\n // todo: implement new syntax\n async insert(tableName: string, keyValues: ObjectLiteral): Promise<InsertResult> {\n const keys = Object.keys(keyValues);\n const columns = keys.map(key => `\"${key}\"`).join(\", \");\n const values = keys.map(key => \"?\").join(\",\");\n const generatedColumns = this.connection.hasMetadata(tableName) ? this.connection.getMetadata(tableName).generatedColumns : [];\n const sql = columns.length > 0 ? (`INSERT INTO \"${tableName}\"(${columns}) VALUES (${values})`) : `INSERT INTO \"${tableName}\" DEFAULT VALUES`;\n const parameters = keys.map(key => keyValues[key]);\n\n return new Promise<InsertResult>(async (ok, fail) => {\n this.driver.connection.logger.logQuery(sql, parameters, this);\n const __this = this;\n const databaseConnection = await this.connect();\n databaseConnection.executeSql(sql, parameters, (resultSet: any) => {\n const generatedMap = generatedColumns.reduce((map, generatedColumn) => {\n const value = generatedColumn.isPrimary && generatedColumn.generationStrategy === \"increment\" && resultSet.insertId ? resultSet.insertId : keyValues[generatedColumn.databaseName];\n if (!value) return map;\n return OrmUtils.mergeDeep(map, generatedColumn.createValueMap(value));\n }, {} as ObjectLiteral);\n\n ok({\n result: undefined,\n generatedMap: Object.keys(generatedMap).length > 0 ? generatedMap : undefined\n });\n }, (err: any) => {\n __this.driver.connection.logger.logQueryError(err, sql, parameters, this);\n fail(err);\n });\n });\n }*/\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async startTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async commitTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Would start a transaction but this driver does not support transactions.\n */\n async rollbackTransaction(): Promise<void> {\n throw new TypeORMError(\n \"Transactions are not supported by the Cordova driver\",\n )\n }\n\n /**\n * Removes all tables from the currently connected database.\n * Be careful with using this method and avoid using it in production or migrations\n * (because it can clear all your database).\n */\n async clearDatabase(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`)\n try {\n const selectViewDropsQuery = `SELECT 'DROP VIEW \"' || name || '\";' as query FROM \"sqlite_master\" WHERE \"type\" = 'view'`\n const dropViewQueries: ObjectLiteral[] = await this.query(\n selectViewDropsQuery,\n )\n\n const selectTableDropsQuery = `SELECT 'DROP TABLE \"' || name || '\";' as query FROM \"sqlite_master\" WHERE \"type\" = 'table' AND \"name\" != 'sqlite_sequence'`\n const dropTableQueries: ObjectLiteral[] = await this.query(\n selectTableDropsQuery,\n )\n\n await Promise.all(\n dropViewQueries.map((q) => this.query(q[\"query\"])),\n )\n await Promise.all(\n dropTableQueries.map((q) => this.query(q[\"query\"])),\n )\n } finally {\n await this.query(`PRAGMA foreign_keys = ON`)\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(\n objectLiteral: ObjectLiteral,\n startIndex: number = 0,\n ): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\n }\n}\n"],"sourceRoot":"../.."}
@@ -2,20 +2,10 @@ import { AbstractSqliteDriver } from "../sqlite-abstract/AbstractSqliteDriver";
2
2
  import { ExpoConnectionOptions } from "./ExpoConnectionOptions";
3
3
  import { QueryRunner } from "../../query-runner/QueryRunner";
4
4
  import { DataSource } from "../../data-source/DataSource";
5
- import { ReplicationMode } from "../types/ReplicationMode";
6
5
  export declare class ExpoDriver extends AbstractSqliteDriver {
7
6
  options: ExpoConnectionOptions;
8
7
  constructor(connection: DataSource);
9
- /**
10
- * Closes connection with database.
11
- */
12
8
  disconnect(): Promise<void>;
13
- /**
14
- * Creates a query runner used to execute database queries.
15
- */
16
- createQueryRunner(mode: ReplicationMode): QueryRunner;
17
- /**
18
- * Creates connection with the database.
19
- */
20
- protected createDatabaseConnection(): Promise<void>;
9
+ createQueryRunner(): QueryRunner;
10
+ protected createDatabaseConnection(): Promise<any>;
21
11
  }
@@ -4,70 +4,24 @@ exports.ExpoDriver = void 0;
4
4
  const AbstractSqliteDriver_1 = require("../sqlite-abstract/AbstractSqliteDriver");
5
5
  const ExpoQueryRunner_1 = require("./ExpoQueryRunner");
6
6
  class ExpoDriver extends AbstractSqliteDriver_1.AbstractSqliteDriver {
7
- // -------------------------------------------------------------------------
8
- // Constructor
9
- // -------------------------------------------------------------------------
10
7
  constructor(connection) {
11
8
  super(connection);
12
- this.database = this.options.database;
13
- // load sqlite package
14
9
  this.sqlite = this.options.driver;
15
10
  }
16
- // -------------------------------------------------------------------------
17
- // Public Methods
18
- // -------------------------------------------------------------------------
19
- /**
20
- * Closes connection with database.
21
- */
22
11
  async disconnect() {
23
- return new Promise((ok, fail) => {
24
- try {
25
- this.queryRunner = undefined;
26
- this.databaseConnection._db.close();
27
- this.databaseConnection = undefined;
28
- ok();
29
- }
30
- catch (error) {
31
- fail(error);
32
- }
33
- });
12
+ this.queryRunner = undefined;
13
+ await this.databaseConnection.closeAsync();
14
+ this.databaseConnection = undefined;
34
15
  }
35
- /**
36
- * Creates a query runner used to execute database queries.
37
- */
38
- createQueryRunner(mode) {
16
+ createQueryRunner() {
39
17
  if (!this.queryRunner)
40
18
  this.queryRunner = new ExpoQueryRunner_1.ExpoQueryRunner(this);
41
19
  return this.queryRunner;
42
20
  }
43
- // -------------------------------------------------------------------------
44
- // Protected Methods
45
- // -------------------------------------------------------------------------
46
- /**
47
- * Creates connection with the database.
48
- */
49
- createDatabaseConnection() {
50
- return new Promise((ok, fail) => {
51
- try {
52
- const databaseConnection = this.sqlite.openDatabase(this.options.database);
53
- /*
54
- // we need to enable foreign keys in sqlite to make sure all foreign key related features
55
- // working properly. this also makes onDelete work with sqlite.
56
- */
57
- databaseConnection.transaction((tsx) => {
58
- tsx.executeSql(`PRAGMA foreign_keys = ON`, [], (t, result) => {
59
- ok(databaseConnection);
60
- }, (t, err) => {
61
- fail({ transaction: t, error: err });
62
- });
63
- }, (err) => {
64
- fail(err);
65
- });
66
- }
67
- catch (error) {
68
- fail(error);
69
- }
70
- });
21
+ async createDatabaseConnection() {
22
+ this.databaseConnection = await this.sqlite.openDatabaseAsync(this.options.database);
23
+ await this.databaseConnection.runAsync("PRAGMA foreign_keys = ON");
24
+ return this.databaseConnection;
71
25
  }
72
26
  }
73
27
  exports.ExpoDriver = ExpoDriver;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/expo/ExpoDriver.ts"],"names":[],"mappings":";;;AAAA,kFAA8E;AAE9E,uDAAmD;AAKnD,MAAa,UAAW,SAAQ,2CAAoB;IAGhD,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAY,UAAsB;QAC9B,KAAK,CAAC,UAAU,CAAC,CAAA;QAEjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAA;QAErC,sBAAsB;QACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;IACrC,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E;;OAEG;IACH,KAAK,CAAC,UAAU;QACZ,OAAO,IAAI,OAAO,CAAO,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YAClC,IAAI,CAAC;gBACD,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA;gBAC5B,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,EAAE,CAAA;gBACnC,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAA;gBACnC,EAAE,EAAE,CAAA;YACR,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,IAAI,CAAC,KAAK,CAAC,CAAA;YACf,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,IAAqB;QACnC,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,IAAI,CAAC,WAAW,GAAG,IAAI,iCAAe,CAAC,IAAI,CAAC,CAAA;QAEnE,OAAO,IAAI,CAAC,WAAW,CAAA;IAC3B,CAAC;IAED,4EAA4E;IAC5E,oBAAoB;IACpB,4EAA4E;IAE5E;;OAEG;IACO,wBAAwB;QAC9B,OAAO,IAAI,OAAO,CAAO,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YAClC,IAAI,CAAC;gBACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAC/C,IAAI,CAAC,OAAO,CAAC,QAAQ,CACxB,CAAA;gBACD;;;kBAGE;gBACF,kBAAkB,CAAC,WAAW,CAC1B,CAAC,GAAQ,EAAE,EAAE;oBACT,GAAG,CAAC,UAAU,CACV,0BAA0B,EAC1B,EAAE,EACF,CAAC,CAAM,EAAE,MAAW,EAAE,EAAE;wBACpB,EAAE,CAAC,kBAAkB,CAAC,CAAA;oBAC1B,CAAC,EACD,CAAC,CAAM,EAAE,GAAQ,EAAE,EAAE;wBACjB,IAAI,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAA;oBACxC,CAAC,CACJ,CAAA;gBACL,CAAC,EACD,CAAC,GAAQ,EAAE,EAAE;oBACT,IAAI,CAAC,GAAG,CAAC,CAAA;gBACb,CAAC,CACJ,CAAA;YACL,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACb,IAAI,CAAC,KAAK,CAAC,CAAA;YACf,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;CACJ;AApFD,gCAoFC","file":"ExpoDriver.js","sourcesContent":["import { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\nimport { ExpoConnectionOptions } from \"./ExpoConnectionOptions\"\nimport { ExpoQueryRunner } from \"./ExpoQueryRunner\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\n\nexport class ExpoDriver extends AbstractSqliteDriver {\n options: ExpoConnectionOptions\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n super(connection)\n\n this.database = this.options.database\n\n // load sqlite package\n this.sqlite = this.options.driver\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 try {\n this.queryRunner = undefined\n this.databaseConnection._db.close()\n this.databaseConnection = undefined\n ok()\n } catch (error) {\n fail(error)\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 ExpoQueryRunner(this)\n\n return this.queryRunner\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates connection with the database.\n */\n protected createDatabaseConnection() {\n return new Promise<void>((ok, fail) => {\n try {\n const databaseConnection = this.sqlite.openDatabase(\n this.options.database,\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 work with sqlite.\n */\n databaseConnection.transaction(\n (tsx: any) => {\n tsx.executeSql(\n `PRAGMA foreign_keys = ON`,\n [],\n (t: any, result: any) => {\n ok(databaseConnection)\n },\n (t: any, err: any) => {\n fail({ transaction: t, error: err })\n },\n )\n },\n (err: any) => {\n fail(err)\n },\n )\n } catch (error) {\n fail(error)\n }\n })\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/expo/ExpoDriver.ts"],"names":[],"mappings":";;;AAAA,kFAA8E;AAE9E,uDAAmD;AAInD,MAAa,UAAW,SAAQ,2CAAoB;IAGhD,YAAY,UAAsB;QAC9B,KAAK,CAAC,UAAU,CAAC,CAAA;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;IACrC,CAAC;IAED,KAAK,CAAC,UAAU;QACZ,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA;QAC5B,MAAM,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,CAAA;QAC1C,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAA;IACvC,CAAC;IAED,iBAAiB;QACb,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,IAAI,CAAC,WAAW,GAAG,IAAI,iCAAe,CAAC,IAAI,CAAC,CAAA;QAEnE,OAAO,IAAI,CAAC,WAAW,CAAA;IAC3B,CAAC;IAES,KAAK,CAAC,wBAAwB;QACpC,IAAI,CAAC,kBAAkB,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,iBAAiB,CACzD,IAAI,CAAC,OAAO,CAAC,QAAQ,CACxB,CAAA;QACD,MAAM,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CAAA;QAClE,OAAO,IAAI,CAAC,kBAAkB,CAAA;IAClC,CAAC;CACJ;AA3BD,gCA2BC","file":"ExpoDriver.js","sourcesContent":["import { AbstractSqliteDriver } from \"../sqlite-abstract/AbstractSqliteDriver\"\nimport { ExpoConnectionOptions } from \"./ExpoConnectionOptions\"\nimport { ExpoQueryRunner } from \"./ExpoQueryRunner\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { DataSource } from \"../../data-source/DataSource\"\n\nexport class ExpoDriver extends AbstractSqliteDriver {\n options: ExpoConnectionOptions\n\n constructor(connection: DataSource) {\n super(connection)\n this.sqlite = this.options.driver\n }\n\n async disconnect(): Promise<void> {\n this.queryRunner = undefined\n await this.databaseConnection.closeAsync()\n this.databaseConnection = undefined\n }\n\n createQueryRunner(): QueryRunner {\n if (!this.queryRunner) this.queryRunner = new ExpoQueryRunner(this)\n\n return this.queryRunner\n }\n\n protected async createDatabaseConnection() {\n this.databaseConnection = await this.sqlite.openDatabaseAsync(\n this.options.database,\n )\n await this.databaseConnection.runAsync(\"PRAGMA foreign_keys = ON\")\n return this.databaseConnection\n }\n}\n"],"sourceRoot":"../.."}
@@ -0,0 +1,9 @@
1
+ import { DataSource } from "../../data-source";
2
+ import { ExpoDriver } from "./ExpoDriver";
3
+ import { ExpoLegacyDriver } from "./legacy/ExpoLegacyDriver";
4
+ export declare class ExpoDriverFactory {
5
+ connection: DataSource;
6
+ constructor(connection: DataSource);
7
+ create(): ExpoDriver | ExpoLegacyDriver;
8
+ private get isLegacyDriver();
9
+ }
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ExpoDriverFactory = void 0;
4
+ const ExpoDriver_1 = require("./ExpoDriver");
5
+ const ExpoLegacyDriver_1 = require("./legacy/ExpoLegacyDriver");
6
+ class ExpoDriverFactory {
7
+ constructor(connection) {
8
+ this.connection = connection;
9
+ }
10
+ create() {
11
+ if (this.isLegacyDriver) {
12
+ return new ExpoLegacyDriver_1.ExpoLegacyDriver(this.connection);
13
+ }
14
+ return new ExpoDriver_1.ExpoDriver(this.connection);
15
+ }
16
+ get isLegacyDriver() {
17
+ return !("openDatabaseAsync" in this.connection.options.driver);
18
+ }
19
+ }
20
+ exports.ExpoDriverFactory = ExpoDriverFactory;
21
+
22
+ //# sourceMappingURL=ExpoDriverFactory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/driver/expo/ExpoDriverFactory.ts"],"names":[],"mappings":";;;AACA,6CAAyC;AACzC,gEAA4D;AAE5D,MAAa,iBAAiB;IAG1B,YAAY,UAAsB;QAC9B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;IAChC,CAAC;IAED,MAAM;QACF,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,OAAO,IAAI,mCAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAChD,CAAC;QAED,OAAO,IAAI,uBAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAC1C,CAAC;IAED,IAAY,cAAc;QACtB,OAAO,CAAC,CAAC,mBAAmB,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;IACnE,CAAC;CACJ;AAlBD,8CAkBC","file":"ExpoDriverFactory.js","sourcesContent":["import { DataSource } from \"../../data-source\"\nimport { ExpoDriver } from \"./ExpoDriver\"\nimport { ExpoLegacyDriver } from \"./legacy/ExpoLegacyDriver\"\n\nexport class ExpoDriverFactory {\n connection: DataSource\n\n constructor(connection: DataSource) {\n this.connection = connection\n }\n\n create(): ExpoDriver | ExpoLegacyDriver {\n if (this.isLegacyDriver) {\n return new ExpoLegacyDriver(this.connection)\n }\n\n return new ExpoDriver(this.connection)\n }\n\n private get isLegacyDriver(): boolean {\n return !(\"openDatabaseAsync\" in this.connection.options.driver)\n }\n}\n"],"sourceRoot":"../.."}
@@ -1,57 +1,9 @@
1
1
  import { AbstractSqliteQueryRunner } from "../sqlite-abstract/AbstractSqliteQueryRunner";
2
2
  import { ExpoDriver } from "./ExpoDriver";
3
- /**
4
- * Runs queries on a single sqlite database connection.
5
- */
6
3
  export declare class ExpoQueryRunner extends AbstractSqliteQueryRunner {
7
- /**
8
- * Database driver used by connection.
9
- */
10
4
  driver: ExpoDriver;
11
- /**
12
- * Database transaction object
13
- */
14
- private transaction?;
15
5
  constructor(driver: ExpoDriver);
16
- /**
17
- * Starts transaction. Within Expo, all database operations happen in a
18
- * transaction context, so issuing a `BEGIN TRANSACTION` command is
19
- * redundant and will result in the following error:
20
- *
21
- * `Error: Error code 1: cannot start a transaction within a transaction`
22
- *
23
- * Instead, we keep track of a `Transaction` object in `this.transaction`
24
- * and continue using the same object until we wish to commit the
25
- * transaction.
26
- */
27
- startTransaction(): Promise<void>;
28
- /**
29
- * Commits transaction.
30
- * Error will be thrown if transaction was not started.
31
- * Since Expo will automatically commit the transaction once all the
32
- * callbacks of the transaction object have been completed, "committing" a
33
- * transaction in this driver's context means that we delete the transaction
34
- * object and set the stage for the next transaction.
35
- */
36
- commitTransaction(): Promise<void>;
37
- /**
38
- * Rollbacks transaction.
39
- * Error will be thrown if transaction was not started.
40
- * This method's functionality is identical to `commitTransaction()` because
41
- * the transaction lifecycle is handled within the Expo transaction object.
42
- * Issuing separate statements for `COMMIT` or `ROLLBACK` aren't necessary.
43
- */
44
- rollbackTransaction(): Promise<void>;
45
- /**
46
- * Called before migrations are run.
47
- */
48
6
  beforeMigration(): Promise<void>;
49
- /**
50
- * Called after migrations are run.
51
- */
52
7
  afterMigration(): Promise<void>;
53
- /**
54
- * Executes a given SQL query.
55
- */
56
8
  query(query: string, parameters?: any[], useStructuredResult?: boolean): Promise<any>;
57
9
  }
@@ -4,164 +4,59 @@ exports.ExpoQueryRunner = void 0;
4
4
  const QueryRunnerAlreadyReleasedError_1 = require("../../error/QueryRunnerAlreadyReleasedError");
5
5
  const QueryFailedError_1 = require("../../error/QueryFailedError");
6
6
  const AbstractSqliteQueryRunner_1 = require("../sqlite-abstract/AbstractSqliteQueryRunner");
7
- const TransactionNotStartedError_1 = require("../../error/TransactionNotStartedError");
8
7
  const Broadcaster_1 = require("../../subscriber/Broadcaster");
9
8
  const QueryResult_1 = require("../../query-runner/QueryResult");
10
9
  const BroadcasterResult_1 = require("../../subscriber/BroadcasterResult");
11
- /**
12
- * Runs queries on a single sqlite database connection.
13
- */
14
10
  class ExpoQueryRunner extends AbstractSqliteQueryRunner_1.AbstractSqliteQueryRunner {
15
- // -------------------------------------------------------------------------
16
- // Constructor
17
- // -------------------------------------------------------------------------
18
11
  constructor(driver) {
19
12
  super();
20
13
  this.driver = driver;
21
14
  this.connection = driver.connection;
22
15
  this.broadcaster = new Broadcaster_1.Broadcaster(this);
23
16
  }
24
- /**
25
- * Starts transaction. Within Expo, all database operations happen in a
26
- * transaction context, so issuing a `BEGIN TRANSACTION` command is
27
- * redundant and will result in the following error:
28
- *
29
- * `Error: Error code 1: cannot start a transaction within a transaction`
30
- *
31
- * Instead, we keep track of a `Transaction` object in `this.transaction`
32
- * and continue using the same object until we wish to commit the
33
- * transaction.
34
- */
35
- async startTransaction() {
36
- this.isTransactionActive = true;
37
- try {
38
- await this.broadcaster.broadcast("BeforeTransactionStart");
39
- }
40
- catch (err) {
41
- this.isTransactionActive = false;
42
- throw err;
43
- }
44
- this.transactionDepth += 1;
45
- await this.broadcaster.broadcast("AfterTransactionStart");
46
- }
47
- /**
48
- * Commits transaction.
49
- * Error will be thrown if transaction was not started.
50
- * Since Expo will automatically commit the transaction once all the
51
- * callbacks of the transaction object have been completed, "committing" a
52
- * transaction in this driver's context means that we delete the transaction
53
- * object and set the stage for the next transaction.
54
- */
55
- async commitTransaction() {
56
- if (!this.isTransactionActive &&
57
- typeof this.transaction === "undefined")
58
- throw new TransactionNotStartedError_1.TransactionNotStartedError();
59
- await this.broadcaster.broadcast("BeforeTransactionCommit");
60
- this.transaction = undefined;
61
- this.isTransactionActive = false;
62
- this.transactionDepth -= 1;
63
- await this.broadcaster.broadcast("AfterTransactionCommit");
64
- }
65
- /**
66
- * Rollbacks transaction.
67
- * Error will be thrown if transaction was not started.
68
- * This method's functionality is identical to `commitTransaction()` because
69
- * the transaction lifecycle is handled within the Expo transaction object.
70
- * Issuing separate statements for `COMMIT` or `ROLLBACK` aren't necessary.
71
- */
72
- async rollbackTransaction() {
73
- if (!this.isTransactionActive &&
74
- typeof this.transaction === "undefined")
75
- throw new TransactionNotStartedError_1.TransactionNotStartedError();
76
- await this.broadcaster.broadcast("BeforeTransactionRollback");
77
- this.transaction = undefined;
78
- this.isTransactionActive = false;
79
- this.transactionDepth -= 1;
80
- await this.broadcaster.broadcast("AfterTransactionRollback");
81
- }
82
- /**
83
- * Called before migrations are run.
84
- */
85
17
  async beforeMigration() {
86
- const databaseConnection = await this.connect();
87
- return new Promise((ok, fail) => {
88
- databaseConnection.exec([{ sql: "PRAGMA foreign_keys = OFF", args: [] }], false, (err) => (err ? fail(err) : ok()));
89
- });
18
+ await this.query("PRAGMA foreign_keys = OFF");
90
19
  }
91
- /**
92
- * Called after migrations are run.
93
- */
94
20
  async afterMigration() {
95
- const databaseConnection = await this.connect();
96
- return new Promise((ok, fail) => {
97
- databaseConnection.exec([{ sql: "PRAGMA foreign_keys = ON", args: [] }], false, (err) => (err ? fail(err) : ok()));
98
- });
21
+ await this.query("PRAGMA foreign_keys = ON");
99
22
  }
100
- /**
101
- * Executes a given SQL query.
102
- */
103
23
  async query(query, parameters, useStructuredResult = false) {
104
24
  if (this.isReleased)
105
25
  throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
106
- return new Promise(async (ok, fail) => {
107
- const databaseConnection = await this.connect();
108
- const broadcasterResult = new BroadcasterResult_1.BroadcasterResult();
109
- this.driver.connection.logger.logQuery(query, parameters, this);
110
- this.broadcaster.broadcastBeforeQueryEvent(broadcasterResult, query, parameters);
111
- const queryStartTime = +new Date();
112
- // All Expo SQL queries are executed in a transaction context
113
- databaseConnection.transaction(async (transaction) => {
114
- if (typeof this.transaction === "undefined") {
115
- await this.startTransaction();
116
- this.transaction = transaction;
117
- }
118
- this.transaction.executeSql(query, parameters, async (t, raw) => {
119
- // log slow queries if maxQueryExecution time is set
120
- const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;
121
- const queryEndTime = +new Date();
122
- const queryExecutionTime = queryEndTime - queryStartTime;
123
- this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, true, queryExecutionTime, raw, undefined);
124
- await broadcasterResult.wait();
125
- if (maxQueryExecutionTime &&
126
- queryExecutionTime > maxQueryExecutionTime) {
127
- this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
128
- }
129
- const result = new QueryResult_1.QueryResult();
130
- if (raw?.hasOwnProperty("rowsAffected")) {
131
- result.affected = raw.rowsAffected;
132
- }
133
- if (raw?.hasOwnProperty("rows")) {
134
- let resultSet = [];
135
- for (let i = 0; i < raw.rows.length; i++) {
136
- resultSet.push(raw.rows.item(i));
137
- }
138
- result.raw = resultSet;
139
- result.records = resultSet;
140
- }
141
- // return id of inserted row, if query was insert statement.
142
- if (query.startsWith("INSERT INTO")) {
143
- result.raw = raw.insertId;
144
- }
145
- if (useStructuredResult) {
146
- ok(result);
147
- }
148
- else {
149
- ok(result.raw);
150
- }
151
- }, async (t, err) => {
152
- this.driver.connection.logger.logQueryError(err, query, parameters, this);
153
- this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, false, undefined, undefined, err);
154
- await broadcasterResult.wait();
155
- fail(new QueryFailedError_1.QueryFailedError(query, parameters, err));
156
- });
157
- }, async (err) => {
158
- await this.rollbackTransaction();
159
- fail(err);
160
- }, () => {
161
- this.isTransactionActive = false;
162
- this.transaction = undefined;
163
- });
164
- });
26
+ const databaseConnection = await this.connect();
27
+ const broadcasterResult = new BroadcasterResult_1.BroadcasterResult();
28
+ this.driver.connection.logger.logQuery(query, parameters, this);
29
+ this.broadcaster.broadcastBeforeQueryEvent(broadcasterResult, query, parameters);
30
+ const queryStartTime = +new Date();
31
+ const statement = await databaseConnection.prepareAsync(query);
32
+ try {
33
+ const rawResult = await statement.executeAsync(parameters);
34
+ const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;
35
+ const queryEndTime = +new Date();
36
+ const queryExecutionTime = queryEndTime - queryStartTime;
37
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, true, queryExecutionTime, rawResult, undefined);
38
+ await broadcasterResult.wait();
39
+ if (maxQueryExecutionTime &&
40
+ queryExecutionTime > maxQueryExecutionTime) {
41
+ this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
42
+ }
43
+ const result = new QueryResult_1.QueryResult();
44
+ result.affected = rawResult.changes;
45
+ result.records = await rawResult.getAllAsync();
46
+ result.raw = query.startsWith("INSERT INTO")
47
+ ? rawResult.lastInsertRowId
48
+ : result.records;
49
+ return useStructuredResult ? result : result.raw;
50
+ }
51
+ catch (err) {
52
+ this.driver.connection.logger.logQueryError(err, query, parameters, this);
53
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, false, 0, undefined, err);
54
+ await broadcasterResult.wait();
55
+ throw new QueryFailedError_1.QueryFailedError(query, parameters, err);
56
+ }
57
+ finally {
58
+ await statement.finalizeAsync();
59
+ }
165
60
  }
166
61
  }
167
62
  exports.ExpoQueryRunner = ExpoQueryRunner;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/expo/ExpoQueryRunner.ts"],"names":[],"mappings":"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","file":"ExpoQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { TransactionNotStartedError } from \"../../error/TransactionNotStartedError\"\nimport { ExpoDriver } from \"./ExpoDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\n// Needed to satisfy the Typescript compiler\ninterface IResultSet {\n insertId: number | undefined\n rowsAffected: number\n rows: {\n length: number\n item: (idx: number) => any\n _array: any[]\n }\n}\ninterface ITransaction {\n executeSql: (\n sql: string,\n args: any[] | undefined,\n ok: (tsx: ITransaction, resultSet: IResultSet) => void,\n fail: (tsx: ITransaction, err: any) => void,\n ) => void\n}\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class ExpoQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n driver: ExpoDriver\n\n /**\n * Database transaction object\n */\n private transaction?: ITransaction\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: ExpoDriver) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n }\n\n /**\n * Starts transaction. Within Expo, all database operations happen in a\n * transaction context, so issuing a `BEGIN TRANSACTION` command is\n * redundant and will result in the following error:\n *\n * `Error: Error code 1: cannot start a transaction within a transaction`\n *\n * Instead, we keep track of a `Transaction` object in `this.transaction`\n * and continue using the same object until we wish to commit the\n * transaction.\n */\n async startTransaction(): Promise<void> {\n this.isTransactionActive = true\n try {\n await this.broadcaster.broadcast(\"BeforeTransactionStart\")\n } catch (err) {\n this.isTransactionActive = false\n throw err\n }\n\n this.transactionDepth += 1\n\n await this.broadcaster.broadcast(\"AfterTransactionStart\")\n }\n\n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n * Since Expo will automatically commit the transaction once all the\n * callbacks of the transaction object have been completed, \"committing\" a\n * transaction in this driver's context means that we delete the transaction\n * object and set the stage for the next transaction.\n */\n async commitTransaction(): Promise<void> {\n if (\n !this.isTransactionActive &&\n typeof this.transaction === \"undefined\"\n )\n throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionCommit\")\n\n this.transaction = undefined\n this.isTransactionActive = false\n\n this.transactionDepth -= 1\n\n await this.broadcaster.broadcast(\"AfterTransactionCommit\")\n }\n\n /**\n * Rollbacks transaction.\n * Error will be thrown if transaction was not started.\n * This method's functionality is identical to `commitTransaction()` because\n * the transaction lifecycle is handled within the Expo transaction object.\n * Issuing separate statements for `COMMIT` or `ROLLBACK` aren't necessary.\n */\n async rollbackTransaction(): Promise<void> {\n if (\n !this.isTransactionActive &&\n typeof this.transaction === \"undefined\"\n )\n throw new TransactionNotStartedError()\n\n await this.broadcaster.broadcast(\"BeforeTransactionRollback\")\n\n this.transaction = undefined\n this.isTransactionActive = false\n\n this.transactionDepth -= 1\n\n await this.broadcaster.broadcast(\"AfterTransactionRollback\")\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n const databaseConnection = await this.connect()\n return new Promise((ok, fail) => {\n databaseConnection.exec(\n [{ sql: \"PRAGMA foreign_keys = OFF\", args: [] }],\n false,\n (err: any) => (err ? fail(err) : ok()),\n )\n })\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n const databaseConnection = await this.connect()\n return new Promise((ok, fail) => {\n databaseConnection.exec(\n [{ sql: \"PRAGMA foreign_keys = ON\", args: [] }],\n false,\n (err: any) => (err ? fail(err) : ok()),\n )\n })\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n return new Promise<any>(async (ok, fail) => {\n const databaseConnection = await this.connect()\n const broadcasterResult = new BroadcasterResult()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n this.broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n const queryStartTime = +new Date()\n // All Expo SQL queries are executed in a transaction context\n databaseConnection.transaction(\n async (transaction: ITransaction) => {\n if (typeof this.transaction === \"undefined\") {\n await this.startTransaction()\n this.transaction = transaction\n }\n this.transaction.executeSql(\n query,\n parameters,\n async (t: ITransaction, raw: IResultSet) => {\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime =\n queryEndTime - queryStartTime\n\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n raw,\n undefined,\n )\n await broadcasterResult.wait()\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n const result = new QueryResult()\n\n if (raw?.hasOwnProperty(\"rowsAffected\")) {\n result.affected = raw.rowsAffected\n }\n\n if (raw?.hasOwnProperty(\"rows\")) {\n let resultSet = []\n for (let i = 0; i < raw.rows.length; i++) {\n resultSet.push(raw.rows.item(i))\n }\n\n result.raw = resultSet\n result.records = resultSet\n }\n\n // return id of inserted row, if query was insert statement.\n if (query.startsWith(\"INSERT INTO\")) {\n result.raw = raw.insertId\n }\n\n if (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n },\n async (t: ITransaction, err: any) => {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n undefined,\n undefined,\n err,\n )\n await broadcasterResult.wait()\n\n fail(new QueryFailedError(query, parameters, err))\n },\n )\n },\n async (err: any) => {\n await this.rollbackTransaction()\n fail(err)\n },\n () => {\n this.isTransactionActive = false\n this.transaction = undefined\n },\n )\n })\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/expo/ExpoQueryRunner.ts"],"names":[],"mappings":"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","file":"ExpoQueryRunner.js","sourcesContent":["import { QueryRunnerAlreadyReleasedError } from \"../../error/QueryRunnerAlreadyReleasedError\"\nimport { QueryFailedError } from \"../../error/QueryFailedError\"\nimport { AbstractSqliteQueryRunner } from \"../sqlite-abstract/AbstractSqliteQueryRunner\"\nimport { ExpoDriver } from \"./ExpoDriver\"\nimport { Broadcaster } from \"../../subscriber/Broadcaster\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\nexport class ExpoQueryRunner extends AbstractSqliteQueryRunner {\n driver: ExpoDriver\n\n constructor(driver: ExpoDriver) {\n super()\n this.driver = driver\n this.connection = driver.connection\n this.broadcaster = new Broadcaster(this)\n }\n\n async beforeMigration(): Promise<void> {\n await this.query(\"PRAGMA foreign_keys = OFF\")\n }\n\n async afterMigration(): Promise<void> {\n await this.query(\"PRAGMA foreign_keys = ON\")\n }\n\n async query(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n const databaseConnection = await this.connect()\n const broadcasterResult = new BroadcasterResult()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n this.broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n const queryStartTime = +new Date()\n\n const statement = await databaseConnection.prepareAsync(query)\n try {\n const rawResult = await statement.executeAsync(parameters)\n\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n rawResult,\n undefined,\n )\n await broadcasterResult.wait()\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n ) {\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n }\n\n const result = new QueryResult()\n result.affected = rawResult.changes\n result.records = await rawResult.getAllAsync()\n result.raw = query.startsWith(\"INSERT INTO\")\n ? rawResult.lastInsertRowId\n : result.records\n\n return useStructuredResult ? result : result.raw\n } catch (err) {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n 0,\n undefined,\n err,\n )\n await broadcasterResult.wait()\n\n throw new QueryFailedError(query, parameters, err)\n } finally {\n await statement.finalizeAsync()\n }\n }\n}\n"],"sourceRoot":"../.."}
@@ -0,0 +1,21 @@
1
+ import { AbstractSqliteDriver } from "../../sqlite-abstract/AbstractSqliteDriver";
2
+ import { ExpoConnectionOptions } from "../ExpoConnectionOptions";
3
+ import { QueryRunner } from "../../../query-runner/QueryRunner";
4
+ import { DataSource } from "../../../data-source/DataSource";
5
+ import { ReplicationMode } from "../../types/ReplicationMode";
6
+ export declare class ExpoLegacyDriver extends AbstractSqliteDriver {
7
+ options: ExpoConnectionOptions;
8
+ constructor(connection: DataSource);
9
+ /**
10
+ * Closes connection with database.
11
+ */
12
+ disconnect(): Promise<void>;
13
+ /**
14
+ * Creates a query runner used to execute database queries.
15
+ */
16
+ createQueryRunner(mode: ReplicationMode): QueryRunner;
17
+ /**
18
+ * Creates connection with the database.
19
+ */
20
+ protected createDatabaseConnection(): Promise<void>;
21
+ }