typeorm 0.2.39-dev.d8c5812 → 0.2.39-dev.f79ae58

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 (280) hide show
  1. package/README.md +60 -59
  2. package/browser/connection/ConnectionOptionsReader.js +2 -1
  3. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  4. package/browser/decorator/entity-view/ViewEntity.js +1 -0
  5. package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
  6. package/browser/decorator/options/ViewEntityOptions.d.ts +5 -0
  7. package/browser/decorator/options/ViewEntityOptions.js.map +1 -1
  8. package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +5 -0
  9. package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
  10. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js +6 -5
  11. package/browser/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  12. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +17 -46
  13. package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  14. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +5 -0
  15. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
  16. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +2 -1
  17. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -1
  18. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +17 -46
  19. package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
  20. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +5 -0
  21. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  22. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +4 -3
  23. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  24. package/browser/driver/cockroachdb/CockroachConnectionOptions.d.ts +10 -0
  25. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  26. package/browser/driver/cockroachdb/CockroachDriver.js +27 -17
  27. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  28. package/browser/driver/cockroachdb/CockroachQueryRunner.js +107 -144
  29. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  30. package/browser/driver/cordova/CordovaConnectionOptions.d.ts +5 -0
  31. package/browser/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  32. package/browser/driver/cordova/CordovaDriver.d.ts +1 -1
  33. package/browser/driver/cordova/CordovaDriver.js +27 -19
  34. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  35. package/browser/driver/cordova/CordovaQueryRunner.js +50 -43
  36. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  37. package/browser/driver/expo/ExpoQueryRunner.js +12 -43
  38. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  39. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +5 -0
  40. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  41. package/browser/driver/mongodb/MongoDriver.js +2 -1
  42. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  43. package/browser/driver/mysql/MysqlConnectionOptions.d.ts +6 -0
  44. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  45. package/browser/driver/mysql/MysqlDriver.js +4 -2
  46. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  47. package/browser/driver/mysql/MysqlQueryRunner.js +22 -52
  48. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  49. package/browser/driver/nativescript/NativescriptQueryRunner.js +45 -37
  50. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  51. package/browser/driver/oracle/OracleConnectionOptions.d.ts +5 -0
  52. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  53. package/browser/driver/oracle/OracleDriver.js +5 -4
  54. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  55. package/browser/driver/oracle/OracleQueryRunner.js +18 -46
  56. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  57. package/browser/driver/postgres/PostgresConnectionOptions.d.ts +10 -0
  58. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  59. package/browser/driver/postgres/PostgresDriver.d.ts +2 -2
  60. package/browser/driver/postgres/PostgresDriver.js +36 -44
  61. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  62. package/browser/driver/postgres/PostgresQueryRunner.js +26 -64
  63. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  64. package/browser/driver/react-native/ReactNativeConnectionOptions.d.ts +5 -0
  65. package/browser/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  66. package/browser/driver/react-native/ReactNativeDriver.js +2 -1
  67. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  68. package/browser/driver/sap/SapConnectionOptions.d.ts +16 -6
  69. package/browser/driver/sap/SapConnectionOptions.js.map +1 -1
  70. package/browser/driver/sap/SapDriver.js +6 -3
  71. package/browser/driver/sap/SapDriver.js.map +1 -1
  72. package/browser/driver/sap/SapQueryRunner.js +28 -76
  73. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  74. package/browser/driver/sqlite/SqliteConnectionOptions.d.ts +5 -0
  75. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  76. package/browser/driver/sqlite/SqliteDriver.js +4 -3
  77. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  78. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +17 -47
  79. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  80. package/browser/driver/sqljs/SqljsConnectionOptions.d.ts +5 -0
  81. package/browser/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  82. package/browser/driver/sqljs/SqljsDriver.js +9 -24
  83. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  84. package/browser/driver/sqljs/SqljsQueryRunner.js +9 -10
  85. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  86. package/browser/driver/sqlserver/SqlServerConnectionOptions.d.ts +5 -0
  87. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  88. package/browser/driver/sqlserver/SqlServerDriver.js +7 -6
  89. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  90. package/browser/driver/sqlserver/SqlServerQueryRunner.js +74 -106
  91. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  92. package/browser/entity-manager/MongoEntityManager.js +8 -13
  93. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  94. package/browser/find-options/FindOptionsUtils.d.ts +2 -0
  95. package/browser/find-options/FindOptionsUtils.js +19 -1
  96. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  97. package/browser/metadata/EntityMetadata.d.ts +5 -0
  98. package/browser/metadata/EntityMetadata.js +1 -0
  99. package/browser/metadata/EntityMetadata.js.map +1 -1
  100. package/browser/metadata-args/TableMetadataArgs.d.ts +4 -0
  101. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  102. package/browser/migration/MigrationExecutor.d.ts +1 -1
  103. package/browser/migration/MigrationExecutor.js +6 -14
  104. package/browser/migration/MigrationExecutor.js.map +1 -1
  105. package/browser/persistence/SubjectExecutor.js +3 -3
  106. package/browser/persistence/SubjectExecutor.js.map +1 -1
  107. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js +10 -4
  108. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  109. package/browser/query-builder/DeleteQueryBuilder.js +3 -10
  110. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  111. package/browser/query-builder/InsertQueryBuilder.js +2 -4
  112. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  113. package/browser/query-builder/QueryExpressionMap.d.ts +6 -0
  114. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  115. package/browser/query-builder/SelectQueryBuilder.d.ts +7 -1
  116. package/browser/query-builder/SelectQueryBuilder.js +43 -11
  117. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  118. package/browser/query-builder/SoftDeleteQueryBuilder.js +3 -10
  119. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  120. package/browser/query-builder/UpdateQueryBuilder.js +3 -10
  121. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  122. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +2 -8
  123. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  124. package/browser/query-runner/BaseQueryRunner.js +3 -2
  125. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  126. package/browser/repository/TreeRepository.d.ts +3 -3
  127. package/browser/repository/TreeRepository.js +28 -39
  128. package/browser/repository/TreeRepository.js.map +1 -1
  129. package/browser/schema-builder/RdbmsSchemaBuilder.js +223 -148
  130. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  131. package/browser/schema-builder/util/ViewUtils.d.ts +7 -0
  132. package/browser/schema-builder/util/ViewUtils.js +25 -0
  133. package/browser/schema-builder/util/ViewUtils.js.map +1 -0
  134. package/browser/subscriber/Broadcaster.d.ts +23 -2
  135. package/browser/subscriber/Broadcaster.js +35 -2
  136. package/browser/subscriber/Broadcaster.js.map +1 -1
  137. package/browser/subscriber/BroadcasterResult.d.ts +4 -0
  138. package/browser/subscriber/BroadcasterResult.js +19 -0
  139. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  140. package/commands/InitCommand.js +2 -1
  141. package/commands/InitCommand.js.map +1 -1
  142. package/connection/ConnectionOptionsReader.js +2 -1
  143. package/connection/ConnectionOptionsReader.js.map +1 -1
  144. package/decorator/entity-view/ViewEntity.js +1 -0
  145. package/decorator/entity-view/ViewEntity.js.map +1 -1
  146. package/decorator/options/ViewEntityOptions.d.ts +5 -0
  147. package/decorator/options/ViewEntityOptions.js.map +1 -1
  148. package/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +5 -0
  149. package/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
  150. package/driver/aurora-data-api/AuroraDataApiDriver.js +6 -5
  151. package/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
  152. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +17 -46
  153. package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
  154. package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +5 -0
  155. package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
  156. package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +2 -1
  157. package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -1
  158. package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +17 -46
  159. package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
  160. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +5 -0
  161. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  162. package/driver/better-sqlite3/BetterSqlite3Driver.js +2 -1
  163. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  164. package/driver/cockroachdb/CockroachConnectionOptions.d.ts +10 -0
  165. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  166. package/driver/cockroachdb/CockroachDriver.js +27 -17
  167. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  168. package/driver/cockroachdb/CockroachQueryRunner.js +107 -144
  169. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  170. package/driver/cordova/CordovaConnectionOptions.d.ts +5 -0
  171. package/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  172. package/driver/cordova/CordovaDriver.d.ts +1 -1
  173. package/driver/cordova/CordovaDriver.js +27 -19
  174. package/driver/cordova/CordovaDriver.js.map +1 -1
  175. package/driver/cordova/CordovaQueryRunner.js +50 -43
  176. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  177. package/driver/expo/ExpoQueryRunner.js +12 -43
  178. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  179. package/driver/mongodb/MongoConnectionOptions.d.ts +5 -0
  180. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  181. package/driver/mongodb/MongoDriver.js +2 -1
  182. package/driver/mongodb/MongoDriver.js.map +1 -1
  183. package/driver/mysql/MysqlConnectionOptions.d.ts +6 -0
  184. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  185. package/driver/mysql/MysqlDriver.js +4 -2
  186. package/driver/mysql/MysqlDriver.js.map +1 -1
  187. package/driver/mysql/MysqlQueryRunner.js +22 -52
  188. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  189. package/driver/nativescript/NativescriptQueryRunner.js +45 -37
  190. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  191. package/driver/oracle/OracleConnectionOptions.d.ts +5 -0
  192. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  193. package/driver/oracle/OracleDriver.js +5 -4
  194. package/driver/oracle/OracleDriver.js.map +1 -1
  195. package/driver/oracle/OracleQueryRunner.js +18 -46
  196. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  197. package/driver/postgres/PostgresConnectionOptions.d.ts +10 -0
  198. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  199. package/driver/postgres/PostgresDriver.d.ts +2 -2
  200. package/driver/postgres/PostgresDriver.js +36 -44
  201. package/driver/postgres/PostgresDriver.js.map +1 -1
  202. package/driver/postgres/PostgresQueryRunner.js +26 -64
  203. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  204. package/driver/react-native/ReactNativeConnectionOptions.d.ts +5 -0
  205. package/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  206. package/driver/react-native/ReactNativeDriver.js +2 -1
  207. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  208. package/driver/sap/SapConnectionOptions.d.ts +16 -6
  209. package/driver/sap/SapConnectionOptions.js.map +1 -1
  210. package/driver/sap/SapDriver.js +6 -3
  211. package/driver/sap/SapDriver.js.map +1 -1
  212. package/driver/sap/SapQueryRunner.js +28 -76
  213. package/driver/sap/SapQueryRunner.js.map +1 -1
  214. package/driver/sqlite/SqliteConnectionOptions.d.ts +5 -0
  215. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  216. package/driver/sqlite/SqliteDriver.js +2 -1
  217. package/driver/sqlite/SqliteDriver.js.map +1 -1
  218. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +17 -47
  219. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  220. package/driver/sqljs/SqljsConnectionOptions.d.ts +5 -0
  221. package/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  222. package/driver/sqljs/SqljsDriver.js +9 -24
  223. package/driver/sqljs/SqljsDriver.js.map +1 -1
  224. package/driver/sqljs/SqljsQueryRunner.js +9 -10
  225. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  226. package/driver/sqlserver/SqlServerConnectionOptions.d.ts +5 -0
  227. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  228. package/driver/sqlserver/SqlServerDriver.js +7 -6
  229. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  230. package/driver/sqlserver/SqlServerQueryRunner.js +74 -106
  231. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  232. package/entity-manager/MongoEntityManager.js +8 -13
  233. package/entity-manager/MongoEntityManager.js.map +1 -1
  234. package/find-options/FindOptionsUtils.d.ts +2 -0
  235. package/find-options/FindOptionsUtils.js +19 -1
  236. package/find-options/FindOptionsUtils.js.map +1 -1
  237. package/metadata/EntityMetadata.d.ts +5 -0
  238. package/metadata/EntityMetadata.js +1 -0
  239. package/metadata/EntityMetadata.js.map +1 -1
  240. package/metadata-args/TableMetadataArgs.d.ts +4 -0
  241. package/metadata-args/TableMetadataArgs.js.map +1 -1
  242. package/migration/MigrationExecutor.d.ts +1 -1
  243. package/migration/MigrationExecutor.js +6 -14
  244. package/migration/MigrationExecutor.js.map +1 -1
  245. package/package.json +1 -1
  246. package/persistence/SubjectExecutor.js +3 -3
  247. package/persistence/SubjectExecutor.js.map +1 -1
  248. package/persistence/subject-builder/OneToManySubjectBuilder.js +10 -4
  249. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  250. package/query-builder/DeleteQueryBuilder.js +3 -10
  251. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  252. package/query-builder/InsertQueryBuilder.js +2 -4
  253. package/query-builder/InsertQueryBuilder.js.map +1 -1
  254. package/query-builder/QueryExpressionMap.d.ts +6 -0
  255. package/query-builder/QueryExpressionMap.js.map +1 -1
  256. package/query-builder/SelectQueryBuilder.d.ts +7 -1
  257. package/query-builder/SelectQueryBuilder.js +43 -11
  258. package/query-builder/SelectQueryBuilder.js.map +1 -1
  259. package/query-builder/SoftDeleteQueryBuilder.js +3 -10
  260. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  261. package/query-builder/UpdateQueryBuilder.js +3 -10
  262. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  263. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +2 -8
  264. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  265. package/query-runner/BaseQueryRunner.js +3 -2
  266. package/query-runner/BaseQueryRunner.js.map +1 -1
  267. package/repository/TreeRepository.d.ts +3 -3
  268. package/repository/TreeRepository.js +27 -38
  269. package/repository/TreeRepository.js.map +1 -1
  270. package/schema-builder/RdbmsSchemaBuilder.js +222 -147
  271. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  272. package/schema-builder/util/ViewUtils.d.ts +7 -0
  273. package/schema-builder/util/ViewUtils.js +28 -0
  274. package/schema-builder/util/ViewUtils.js.map +1 -0
  275. package/subscriber/Broadcaster.d.ts +23 -2
  276. package/subscriber/Broadcaster.js +35 -2
  277. package/subscriber/Broadcaster.js.map +1 -1
  278. package/subscriber/BroadcasterResult.d.ts +4 -0
  279. package/subscriber/BroadcasterResult.js +19 -0
  280. package/subscriber/BroadcasterResult.js.map +1 -1
@@ -11,6 +11,11 @@ export interface AuroraDataApiPostgresConnectionOptions extends BaseConnectionOp
11
11
  readonly secretArn: string;
12
12
  readonly resourceArn: string;
13
13
  readonly database: string;
14
+ /**
15
+ * The driver object
16
+ * This defaults to require("typeorm-aurora-data-api-driver")
17
+ */
18
+ readonly driver?: any;
14
19
  /**
15
20
  * The Postgres extension to use to generate UUID columns. Defaults to uuid-ossp.
16
21
  * If pgcrypto is selected, TypeORM will use the gen_random_uuid() function from this extension.
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.ts"],"names":[],"mappings":"","file":"AuroraDataApiPostgresConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\n\n/**\n * Postgres-specific connection options.\n */\nexport interface AuroraDataApiPostgresConnectionOptions extends BaseConnectionOptions {\n\n /**\n * Database type.\n */\n readonly type: \"aurora-data-api-pg\";\n\n readonly region: string;\n\n readonly secretArn: string;\n\n readonly resourceArn: string;\n\n readonly database: string;\n\n /**\n * The Postgres extension to use to generate UUID columns. Defaults to uuid-ossp.\n * If pgcrypto is selected, TypeORM will use the gen_random_uuid() function from this extension.\n * If uuid-ossp is selected, TypeORM will use the uuid_generate_v4() function from this extension.\n */\n readonly uuidExtension?: \"pgcrypto\" | \"uuid-ossp\";\n\n readonly transformParameters?: boolean;\n\n /*\n * Function handling errors thrown by drivers pool.\n * Defaults to logging error with `warn` level.\n */\n readonly poolErrorHandler?: (err: any) => any;\n\n readonly serviceConfigOptions?: { [key: string]: any };\n\n readonly formatOptions?: { [key: string]: any, castParameters: boolean };\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.ts"],"names":[],"mappings":"","file":"AuroraDataApiPostgresConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\n\n/**\n * Postgres-specific connection options.\n */\nexport interface AuroraDataApiPostgresConnectionOptions extends BaseConnectionOptions {\n\n /**\n * Database type.\n */\n readonly type: \"aurora-data-api-pg\";\n\n readonly region: string;\n\n readonly secretArn: string;\n\n readonly resourceArn: string;\n\n readonly database: string;\n\n /**\n * The driver object\n * This defaults to require(\"typeorm-aurora-data-api-driver\")\n */\n readonly driver?: any;\n\n /**\n * The Postgres extension to use to generate UUID columns. Defaults to uuid-ossp.\n * If pgcrypto is selected, TypeORM will use the gen_random_uuid() function from this extension.\n * If uuid-ossp is selected, TypeORM will use the uuid_generate_v4() function from this extension.\n */\n readonly uuidExtension?: \"pgcrypto\" | \"uuid-ossp\";\n\n readonly transformParameters?: boolean;\n\n /*\n * Function handling errors thrown by drivers pool.\n * Defaults to logging error with `warn` level.\n */\n readonly poolErrorHandler?: (err: any) => any;\n\n readonly serviceConfigOptions?: { [key: string]: any };\n\n readonly formatOptions?: { [key: string]: any, castParameters: boolean };\n}\n"],"sourceRoot":"../.."}
@@ -88,7 +88,8 @@ var AuroraDataApiPostgresDriver = /** @class */ (function (_super) {
88
88
  * If driver dependency is not given explicitly, then try to load it via "require".
89
89
  */
90
90
  AuroraDataApiPostgresDriver.prototype.loadDependencies = function () {
91
- var pg = PlatformTools.load("typeorm-aurora-data-api-driver").pg;
91
+ var driver = this.options.driver || PlatformTools.load("typeorm-aurora-data-api-driver");
92
+ var pg = driver.pg;
92
93
  this.DataApiDriver = pg;
93
94
  };
94
95
  /**
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.ts"],"names":[],"mappings":"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","file":"AuroraDataApiPostgresDriver.js","sourcesContent":["import {Driver} from \"../Driver\";\nimport {PostgresDriver} from \"../postgres/PostgresDriver\";\nimport {PlatformTools} from \"../../platform/PlatformTools\";\nimport {Connection} from \"../../connection/Connection\";\nimport {AuroraDataApiPostgresConnectionOptions} from \"../aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions\";\nimport {AuroraDataApiPostgresQueryRunner} from \"../aurora-data-api-pg/AuroraDataApiPostgresQueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\nimport {ColumnMetadata} from \"../../metadata/ColumnMetadata\";\nimport {ApplyValueTransformers} from \"../../util/ApplyValueTransformers\";\nimport {DriverUtils} from \"../DriverUtils\";\n\nabstract class PostgresWrapper extends PostgresDriver {\n options: any;\n\n abstract createQueryRunner(mode: ReplicationMode): any;\n}\n\nexport class AuroraDataApiPostgresDriver extends PostgresWrapper implements Driver {\n\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: Connection;\n\n /**\n * Aurora Data API underlying library.\n */\n DataApiDriver: any;\n\n client: any;\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: AuroraDataApiPostgresConnectionOptions;\n\n /**\n * Master database used to perform all write queries.\n */\n database?: string;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n super();\n this.connection = connection;\n this.options = connection.options as AuroraDataApiPostgresConnectionOptions;\n this.isReplicated = false;\n\n // load data-api package\n this.loadDependencies();\n\n this.client = new this.DataApiDriver(\n this.options.region,\n this.options.secretArn,\n this.options.resourceArn,\n this.options.database,\n (query: string, parameters?: any[]) => this.connection.logger.logQuery(query, parameters),\n this.options.serviceConfigOptions,\n this.options.formatOptions,\n );\n\n this.database = DriverUtils.buildDriverOptions(this.options).database;\n }\n\n // -------------------------------------------------------------------------\n // Public Implemented Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n * Based on pooling options, it can either create connection immediately,\n * either create a pool and create connection when needed.\n */\n async connect(): Promise<void> {\n }\n\n /**\n * Closes connection with database.\n */\n async disconnect(): Promise<void> {\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode) {\n return new AuroraDataApiPostgresQueryRunner(\n this,\n new this.DataApiDriver(\n this.options.region,\n this.options.secretArn,\n this.options.resourceArn,\n this.options.database,\n (query: string, parameters?: any[]) => this.connection.logger.logQuery(query, parameters),\n this.options.serviceConfigOptions,\n this.options.formatOptions,\n ),\n mode\n );\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (this.options.formatOptions && this.options.formatOptions.castParameters === false) {\n return super.preparePersistentValue(value, columnMetadata)\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(columnMetadata.transformer, value);\n\n return this.client.preparePersistentValue(value, columnMetadata)\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (this.options.formatOptions && this.options.formatOptions.castParameters === false) {\n return super.prepareHydratedValue(value, columnMetadata)\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);\n\n return this.client.prepareHydratedValue(value, columnMetadata)\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * If driver dependency is not given explicitly, then try to load it via \"require\".\n */\n protected loadDependencies(): void {\n const { pg } = PlatformTools.load(\"typeorm-aurora-data-api-driver\");\n\n this.DataApiDriver = pg;\n }\n\n /**\n * Executes given query.\n */\n protected executeQuery(connection: any, query: string) {\n return this.connection.query(query);\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n async afterConnect(): Promise<void> {\n const extensionsMetadata = await this.checkMetadataForExtensions();\n\n if (extensionsMetadata.hasExtensions) {\n await this.enableExtensions(extensionsMetadata, this.connection);\n }\n\n return Promise.resolve();\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.ts"],"names":[],"mappings":"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","file":"AuroraDataApiPostgresDriver.js","sourcesContent":["import {Driver} from \"../Driver\";\nimport {PostgresDriver} from \"../postgres/PostgresDriver\";\nimport {PlatformTools} from \"../../platform/PlatformTools\";\nimport {Connection} from \"../../connection/Connection\";\nimport {AuroraDataApiPostgresConnectionOptions} from \"../aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions\";\nimport {AuroraDataApiPostgresQueryRunner} from \"../aurora-data-api-pg/AuroraDataApiPostgresQueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\nimport {ColumnMetadata} from \"../../metadata/ColumnMetadata\";\nimport {ApplyValueTransformers} from \"../../util/ApplyValueTransformers\";\nimport {DriverUtils} from \"../DriverUtils\";\n\nabstract class PostgresWrapper extends PostgresDriver {\n options: any;\n\n abstract createQueryRunner(mode: ReplicationMode): any;\n}\n\nexport class AuroraDataApiPostgresDriver extends PostgresWrapper implements Driver {\n\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: Connection;\n\n /**\n * Aurora Data API underlying library.\n */\n DataApiDriver: any;\n\n client: any;\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: AuroraDataApiPostgresConnectionOptions;\n\n /**\n * Master database used to perform all write queries.\n */\n database?: string;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: Connection) {\n super();\n this.connection = connection;\n this.options = connection.options as AuroraDataApiPostgresConnectionOptions;\n this.isReplicated = false;\n\n // load data-api package\n this.loadDependencies();\n\n this.client = new this.DataApiDriver(\n this.options.region,\n this.options.secretArn,\n this.options.resourceArn,\n this.options.database,\n (query: string, parameters?: any[]) => this.connection.logger.logQuery(query, parameters),\n this.options.serviceConfigOptions,\n this.options.formatOptions,\n );\n\n this.database = DriverUtils.buildDriverOptions(this.options).database;\n }\n\n // -------------------------------------------------------------------------\n // Public Implemented Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n * Based on pooling options, it can either create connection immediately,\n * either create a pool and create connection when needed.\n */\n async connect(): Promise<void> {\n }\n\n /**\n * Closes connection with database.\n */\n async disconnect(): Promise<void> {\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode) {\n return new AuroraDataApiPostgresQueryRunner(\n this,\n new this.DataApiDriver(\n this.options.region,\n this.options.secretArn,\n this.options.resourceArn,\n this.options.database,\n (query: string, parameters?: any[]) => this.connection.logger.logQuery(query, parameters),\n this.options.serviceConfigOptions,\n this.options.formatOptions,\n ),\n mode\n );\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (this.options.formatOptions && this.options.formatOptions.castParameters === false) {\n return super.preparePersistentValue(value, columnMetadata);\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(columnMetadata.transformer, value);\n\n return this.client.preparePersistentValue(value, columnMetadata);\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (this.options.formatOptions && this.options.formatOptions.castParameters === false) {\n return super.prepareHydratedValue(value, columnMetadata);\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);\n\n return this.client.prepareHydratedValue(value, columnMetadata);\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * If driver dependency is not given explicitly, then try to load it via \"require\".\n */\n protected loadDependencies(): void {\n const driver = this.options.driver || PlatformTools.load(\"typeorm-aurora-data-api-driver\");\n const { pg } = driver;\n\n this.DataApiDriver = pg;\n }\n\n /**\n * Executes given query.\n */\n protected executeQuery(connection: any, query: string) {\n return this.connection.query(query);\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n async afterConnect(): Promise<void> {\n const extensionsMetadata = await this.checkMetadataForExtensions();\n\n if (extensionsMetadata.hasExtensions) {\n await this.enableExtensions(extensionsMetadata, this.connection);\n }\n\n return Promise.resolve();\n }\n}\n"],"sourceRoot":"../.."}
@@ -3,7 +3,6 @@ import { QueryRunnerAlreadyReleasedError } from "../../error/QueryRunnerAlreadyR
3
3
  import { TransactionAlreadyStartedError } from "../../error/TransactionAlreadyStartedError";
4
4
  import { TransactionNotStartedError } from "../../error/TransactionNotStartedError";
5
5
  import { PostgresQueryRunner } from "../postgres/PostgresQueryRunner";
6
- import { BroadcasterResult } from "../../subscriber/BroadcasterResult";
7
6
  import { QueryResult } from "../../query-runner/QueryResult";
8
7
  var PostgresQueryRunnerWrapper = /** @class */ (function (_super) {
9
8
  __extends(PostgresQueryRunnerWrapper, _super);
@@ -63,32 +62,22 @@ var AuroraDataApiPostgresQueryRunner = /** @class */ (function (_super) {
63
62
  */
64
63
  AuroraDataApiPostgresQueryRunner.prototype.startTransaction = function (isolationLevel) {
65
64
  return __awaiter(this, void 0, void 0, function () {
66
- var beforeBroadcastResult, afterBroadcastResult;
67
65
  return __generator(this, function (_a) {
68
66
  switch (_a.label) {
69
67
  case 0:
70
68
  if (this.isTransactionActive)
71
69
  throw new TransactionAlreadyStartedError();
72
- beforeBroadcastResult = new BroadcasterResult();
73
- this.broadcaster.broadcastBeforeTransactionStartEvent(beforeBroadcastResult);
74
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
75
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
70
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionStart')];
76
71
  case 1:
77
72
  _a.sent();
78
- _a.label = 2;
79
- case 2:
80
73
  this.isTransactionActive = true;
81
74
  return [4 /*yield*/, this.client.startTransaction()];
82
- case 3:
75
+ case 2:
83
76
  _a.sent();
84
- afterBroadcastResult = new BroadcasterResult();
85
- this.broadcaster.broadcastAfterTransactionStartEvent(afterBroadcastResult);
86
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
87
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
88
- case 4:
77
+ return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionStart')];
78
+ case 3:
89
79
  _a.sent();
90
- _a.label = 5;
91
- case 5: return [2 /*return*/];
80
+ return [2 /*return*/];
92
81
  }
93
82
  });
94
83
  });
@@ -99,31 +88,22 @@ var AuroraDataApiPostgresQueryRunner = /** @class */ (function (_super) {
99
88
  */
100
89
  AuroraDataApiPostgresQueryRunner.prototype.commitTransaction = function () {
101
90
  return __awaiter(this, void 0, void 0, function () {
102
- var beforeBroadcastResult, afterBroadcastResult;
103
91
  return __generator(this, function (_a) {
104
92
  switch (_a.label) {
105
93
  case 0:
106
94
  if (!this.isTransactionActive)
107
95
  throw new TransactionNotStartedError();
108
- beforeBroadcastResult = new BroadcasterResult();
109
- this.broadcaster.broadcastBeforeTransactionCommitEvent(beforeBroadcastResult);
110
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
111
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
96
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionCommit')];
112
97
  case 1:
113
98
  _a.sent();
114
- _a.label = 2;
115
- case 2: return [4 /*yield*/, this.client.commitTransaction()];
116
- case 3:
99
+ return [4 /*yield*/, this.client.commitTransaction()];
100
+ case 2:
117
101
  _a.sent();
118
102
  this.isTransactionActive = false;
119
- afterBroadcastResult = new BroadcasterResult();
120
- this.broadcaster.broadcastAfterTransactionCommitEvent(afterBroadcastResult);
121
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
122
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
123
- case 4:
103
+ return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionCommit')];
104
+ case 3:
124
105
  _a.sent();
125
- _a.label = 5;
126
- case 5: return [2 /*return*/];
106
+ return [2 /*return*/];
127
107
  }
128
108
  });
129
109
  });
@@ -134,30 +114,21 @@ var AuroraDataApiPostgresQueryRunner = /** @class */ (function (_super) {
134
114
  */
135
115
  AuroraDataApiPostgresQueryRunner.prototype.rollbackTransaction = function () {
136
116
  return __awaiter(this, void 0, void 0, function () {
137
- var beforeBroadcastResult, afterBroadcastResult;
138
117
  return __generator(this, function (_a) {
139
118
  switch (_a.label) {
140
119
  case 0:
141
120
  if (!this.isTransactionActive)
142
121
  throw new TransactionNotStartedError();
143
- beforeBroadcastResult = new BroadcasterResult();
144
- this.broadcaster.broadcastBeforeTransactionRollbackEvent(beforeBroadcastResult);
145
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
146
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
122
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionRollback')];
147
123
  case 1:
148
124
  _a.sent();
149
- _a.label = 2;
150
- case 2: return [4 /*yield*/, this.client.rollbackTransaction()];
151
- case 3:
125
+ return [4 /*yield*/, this.client.rollbackTransaction()];
126
+ case 2:
152
127
  _a.sent();
153
- afterBroadcastResult = new BroadcasterResult();
154
- this.broadcaster.broadcastAfterTransactionRollbackEvent(afterBroadcastResult);
155
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
156
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
157
- case 4:
128
+ return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionRollback')];
129
+ case 3:
158
130
  _a.sent();
159
- _a.label = 5;
160
- case 5: return [2 /*return*/];
131
+ return [2 /*return*/];
161
132
  }
162
133
  });
163
134
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.ts"],"names":[],"mappings":"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","file":"AuroraDataApiPostgresQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {TransactionAlreadyStartedError} from \"../../error/TransactionAlreadyStartedError\";\nimport {TransactionNotStartedError} from \"../../error/TransactionNotStartedError\";\nimport {QueryRunner} from \"../../query-runner/QueryRunner\";\nimport {IsolationLevel} from \"../types/IsolationLevel\";\nimport {AuroraDataApiPostgresDriver} from \"./AuroraDataApiPostgresDriver\";\nimport {PostgresQueryRunner} from \"../postgres/PostgresQueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\nimport {BroadcasterResult} from \"../../subscriber/BroadcasterResult\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\nclass PostgresQueryRunnerWrapper extends PostgresQueryRunner {\n driver: any;\n\n constructor(driver: any, mode: ReplicationMode) {\n super(driver, mode);\n }\n}\n\n/**\n * Runs queries on a single postgres database connection.\n */\nexport class AuroraDataApiPostgresQueryRunner extends PostgresQueryRunnerWrapper implements QueryRunner {\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Database driver used by connection.\n */\n driver: AuroraDataApiPostgresDriver;\n\n protected client: any;\n\n // -------------------------------------------------------------------------\n // Protected Properties\n // -------------------------------------------------------------------------\n\n /**\n * Promise used to obtain a database connection for a first time.\n */\n protected databaseConnectionPromise: Promise<any>;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: AuroraDataApiPostgresDriver, client: any, mode: ReplicationMode) {\n super(driver, mode);\n\n this.client = client\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates/uses database connection from the connection pool to perform further operations.\n * Returns obtained database connection.\n */\n connect(): Promise<any> {\n if (this.databaseConnection)\n return Promise.resolve(this.databaseConnection);\n\n if (this.databaseConnectionPromise)\n return this.databaseConnectionPromise;\n\n if (this.mode === \"slave\" && this.driver.isReplicated) {\n this.databaseConnectionPromise = this.driver.obtainSlaveConnection().then(([ connection, release]: any[]) => {\n this.driver.connectedQueryRunners.push(this);\n this.databaseConnection = connection;\n this.releaseCallback = release;\n return this.databaseConnection;\n });\n\n } else { // master\n this.databaseConnectionPromise = this.driver.obtainMasterConnection().then(([connection, release]: any[]) => {\n this.driver.connectedQueryRunners.push(this);\n this.databaseConnection = connection;\n this.releaseCallback = release;\n return this.databaseConnection;\n });\n }\n\n return this.databaseConnectionPromise;\n }\n\n /**\n * Starts transaction on the current connection.\n */\n async startTransaction(isolationLevel?: IsolationLevel): Promise<void> {\n if (this.isTransactionActive)\n throw new TransactionAlreadyStartedError();\n\n const beforeBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastBeforeTransactionStartEvent(beforeBroadcastResult);\n if (beforeBroadcastResult.promises.length > 0) await Promise.all(beforeBroadcastResult.promises);\n\n this.isTransactionActive = true;\n \n await this.client.startTransaction();\n\n const afterBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastAfterTransactionStartEvent(afterBroadcastResult);\n if (afterBroadcastResult.promises.length > 0) await Promise.all(afterBroadcastResult.promises);\n }\n\n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n if (!this.isTransactionActive)\n throw new TransactionNotStartedError();\n \n const beforeBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastBeforeTransactionCommitEvent(beforeBroadcastResult);\n if (beforeBroadcastResult.promises.length > 0) await Promise.all(beforeBroadcastResult.promises);\n\n await this.client.commitTransaction();\n\n this.isTransactionActive = false;\n\n const afterBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastAfterTransactionCommitEvent(afterBroadcastResult);\n if (afterBroadcastResult.promises.length > 0) await Promise.all(afterBroadcastResult.promises);\n }\n\n /**\n * Rollbacks transaction.\n * Error will be thrown if transaction was not started.\n */\n async rollbackTransaction(): Promise<void> {\n if (!this.isTransactionActive)\n throw new TransactionNotStartedError();\n\n const beforeBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastBeforeTransactionRollbackEvent(beforeBroadcastResult);\n if (beforeBroadcastResult.promises.length > 0) await Promise.all(beforeBroadcastResult.promises);\n\n await this.client.rollbackTransaction();\n\n const afterBroadcastResult = new BroadcasterResult();\n this.broadcaster.broadcastAfterTransactionRollbackEvent(afterBroadcastResult);\n if (afterBroadcastResult.promises.length > 0) await Promise.all(afterBroadcastResult.promises);\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 raw = await this.client.query(query, parameters);\n\n const result = new QueryResult();\n\n result.raw = raw;\n\n if (raw?.hasOwnProperty('records') && Array.isArray(raw.records)) {\n result.records = raw.records;\n }\n\n if (raw?.hasOwnProperty('numberOfRecordsUpdated')) {\n result.affected = raw.numberOfRecordsUpdated;\n }\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.ts"],"names":[],"mappings":"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","file":"AuroraDataApiPostgresQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {TransactionAlreadyStartedError} from \"../../error/TransactionAlreadyStartedError\";\nimport {TransactionNotStartedError} from \"../../error/TransactionNotStartedError\";\nimport {QueryRunner} from \"../../query-runner/QueryRunner\";\nimport {IsolationLevel} from \"../types/IsolationLevel\";\nimport {AuroraDataApiPostgresDriver} from \"./AuroraDataApiPostgresDriver\";\nimport {PostgresQueryRunner} from \"../postgres/PostgresQueryRunner\";\nimport {ReplicationMode} from \"../types/ReplicationMode\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\nclass PostgresQueryRunnerWrapper extends PostgresQueryRunner {\n driver: any;\n\n constructor(driver: any, mode: ReplicationMode) {\n super(driver, mode);\n }\n}\n\n/**\n * Runs queries on a single postgres database connection.\n */\nexport class AuroraDataApiPostgresQueryRunner extends PostgresQueryRunnerWrapper implements QueryRunner {\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Database driver used by connection.\n */\n driver: AuroraDataApiPostgresDriver;\n\n protected client: any;\n\n // -------------------------------------------------------------------------\n // Protected Properties\n // -------------------------------------------------------------------------\n\n /**\n * Promise used to obtain a database connection for a first time.\n */\n protected databaseConnectionPromise: Promise<any>;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: AuroraDataApiPostgresDriver, client: any, mode: ReplicationMode) {\n super(driver, mode);\n\n this.client = client\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Creates/uses database connection from the connection pool to perform further operations.\n * Returns obtained database connection.\n */\n connect(): Promise<any> {\n if (this.databaseConnection)\n return Promise.resolve(this.databaseConnection);\n\n if (this.databaseConnectionPromise)\n return this.databaseConnectionPromise;\n\n if (this.mode === \"slave\" && this.driver.isReplicated) {\n this.databaseConnectionPromise = this.driver.obtainSlaveConnection().then(([ connection, release]: any[]) => {\n this.driver.connectedQueryRunners.push(this);\n this.databaseConnection = connection;\n this.releaseCallback = release;\n return this.databaseConnection;\n });\n\n } else { // master\n this.databaseConnectionPromise = this.driver.obtainMasterConnection().then(([connection, release]: any[]) => {\n this.driver.connectedQueryRunners.push(this);\n this.databaseConnection = connection;\n this.releaseCallback = release;\n return this.databaseConnection;\n });\n }\n\n return this.databaseConnectionPromise;\n }\n\n /**\n * Starts transaction on the current connection.\n */\n async startTransaction(isolationLevel?: IsolationLevel): Promise<void> {\n if (this.isTransactionActive)\n throw new TransactionAlreadyStartedError();\n\n await this.broadcaster.broadcast('BeforeTransactionStart')\n\n this.isTransactionActive = true;\n\n await this.client.startTransaction();\n\n await this.broadcaster.broadcast('AfterTransactionStart')\n }\n\n /**\n * Commits transaction.\n * Error will be thrown if transaction was not started.\n */\n async commitTransaction(): Promise<void> {\n if (!this.isTransactionActive)\n throw new TransactionNotStartedError();\n\n await this.broadcaster.broadcast('BeforeTransactionCommit');\n\n await this.client.commitTransaction();\n\n this.isTransactionActive = false;\n\n await this.broadcaster.broadcast('AfterTransactionCommit');\n }\n\n /**\n * Rollbacks transaction.\n * Error will be thrown if transaction was not started.\n */\n async rollbackTransaction(): Promise<void> {\n if (!this.isTransactionActive)\n throw new TransactionNotStartedError();\n\n await this.broadcaster.broadcast('BeforeTransactionRollback');\n\n await this.client.rollbackTransaction();\n\n await this.broadcaster.broadcast('AfterTransactionRollback');\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 raw = await this.client.query(query, parameters);\n\n const result = new QueryResult();\n\n result.raw = raw;\n\n if (raw?.hasOwnProperty('records') && Array.isArray(raw.records)) {\n result.records = raw.records;\n }\n\n if (raw?.hasOwnProperty('numberOfRecordsUpdated')) {\n result.affected = raw.numberOfRecordsUpdated;\n }\n\n if (!useStructuredResult) {\n return result.raw;\n }\n\n return result;\n }\n}\n"],"sourceRoot":"../.."}
@@ -11,6 +11,11 @@ export interface BetterSqlite3ConnectionOptions extends BaseConnectionOptions {
11
11
  * Storage type or path to the storage.
12
12
  */
13
13
  readonly database: string;
14
+ /**
15
+ * The driver object
16
+ * This defaults to require("better-sqlite3")
17
+ */
18
+ readonly driver?: any;
14
19
  /**
15
20
  * Encryption key for for SQLCipher.
16
21
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/better-sqlite3/BetterSqlite3ConnectionOptions.ts"],"names":[],"mappings":"","file":"BetterSqlite3ConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\n\n/**\n * Sqlite-specific connection options.\n */\nexport interface BetterSqlite3ConnectionOptions extends BaseConnectionOptions {\n\n /**\n * Database type.\n */\n readonly type: \"better-sqlite3\";\n\n /**\n * Storage type or path to the storage.\n */\n readonly database: string;\n\n /**\n * Encryption key for for SQLCipher.\n */\n readonly key?: string;\n\n /**\n * Cache size of sqlite statement to speed up queries.\n * Default: 100.\n */\n readonly statementCacheSize?: number;\n\n /**\n * Function to run before a database is used in typeorm.\n * You can set pragmas, register plugins or register\n * functions or aggregates in this function. \n */\n readonly prepareDatabase?: (db: any) => void | Promise<void>;\n\n /**\n * Open the database connection in readonly mode.\n * Default: false.\n */\n readonly readonly?: boolean;\n\n /**\n * If the database does not exist, an Error will be thrown instead of creating a new file.\n * This option does not affect in-memory or readonly database connections.\n * Default: false.\n */\n readonly fileMustExist?: boolean;\n\n /**\n * The number of milliseconds to wait when executing queries\n * on a locked database, before throwing a SQLITE_BUSY error.\n * Default: 5000.\n */\n readonly timeout?: number;\n\n /**\n * Provide a function that gets called with every SQL string executed by the database connection.\n */\n readonly verbose?: Function;\n}"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/better-sqlite3/BetterSqlite3ConnectionOptions.ts"],"names":[],"mappings":"","file":"BetterSqlite3ConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\n\n/**\n * Sqlite-specific connection options.\n */\nexport interface BetterSqlite3ConnectionOptions extends BaseConnectionOptions {\n\n /**\n * Database type.\n */\n readonly type: \"better-sqlite3\";\n\n /**\n * Storage type or path to the storage.\n */\n readonly database: string;\n\n /**\n * The driver object\n * This defaults to require(\"better-sqlite3\")\n */\n readonly driver?: any;\n\n /**\n * Encryption key for for SQLCipher.\n */\n readonly key?: string;\n\n /**\n * Cache size of sqlite statement to speed up queries.\n * Default: 100.\n */\n readonly statementCacheSize?: number;\n\n /**\n * Function to run before a database is used in typeorm.\n * You can set pragmas, register plugins or register\n * functions or aggregates in this function.\n */\n readonly prepareDatabase?: (db: any) => void | Promise<void>;\n\n /**\n * Open the database connection in readonly mode.\n * Default: false.\n */\n readonly readonly?: boolean;\n\n /**\n * If the database does not exist, an Error will be thrown instead of creating a new file.\n * This option does not affect in-memory or readonly database connections.\n * Default: false.\n */\n readonly fileMustExist?: boolean;\n\n /**\n * The number of milliseconds to wait when executing queries\n * on a locked database, before throwing a SQLITE_BUSY error.\n * Default: 5000.\n */\n readonly timeout?: number;\n\n /**\n * Provide a function that gets called with every SQL string executed by the database connection.\n */\n readonly verbose?: Function;\n}"],"sourceRoot":"../.."}
@@ -1,6 +1,6 @@
1
1
  import { __awaiter, __extends, __generator } from "tslib";
2
- import mkdirp from 'mkdirp';
3
- import path from 'path';
2
+ import mkdirp from "mkdirp";
3
+ import path from "path";
4
4
  import { DriverPackageNotInstalledError } from "../../error/DriverPackageNotInstalledError";
5
5
  import { DriverOptionNotSetError } from "../../error/DriverOptionNotSetError";
6
6
  import { PlatformTools } from "../../platform/PlatformTools";
@@ -97,7 +97,8 @@ var BetterSqlite3Driver = /** @class */ (function (_super) {
97
97
  */
98
98
  BetterSqlite3Driver.prototype.loadDependencies = function () {
99
99
  try {
100
- this.sqlite = PlatformTools.load("better-sqlite3");
100
+ var sqlite = this.options.driver || PlatformTools.load("better-sqlite3");
101
+ this.sqlite = sqlite;
101
102
  }
102
103
  catch (e) {
103
104
  throw new DriverPackageNotInstalledError("SQLite", "better-sqlite3");
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/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 this.sqlite = PlatformTools.load(\"better-sqlite3\");\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":["../browser/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":"../.."}
@@ -12,6 +12,16 @@ export interface CockroachConnectionOptions extends BaseConnectionOptions, Cockr
12
12
  * Schema name.
13
13
  */
14
14
  readonly schema?: string;
15
+ /**
16
+ * The driver object
17
+ * This defaults to `require("pg")`.
18
+ */
19
+ readonly driver?: any;
20
+ /**
21
+ * The driver object
22
+ * This defaults to `require("pg-native")`.
23
+ */
24
+ readonly nativeDriver?: any;
15
25
  /**
16
26
  * Replication setup.
17
27
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../browser/src/driver/cockroachdb/CockroachConnectionOptions.ts"],"names":[],"mappings":"","file":"CockroachConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\nimport {CockroachConnectionCredentialsOptions} from \"./CockroachConnectionCredentialsOptions\";\n\n/**\n * Cockroachdb-specific connection options.\n */\nexport interface CockroachConnectionOptions extends BaseConnectionOptions, CockroachConnectionCredentialsOptions {\n\n /**\n * Database type.\n */\n readonly type: \"cockroachdb\";\n\n /**\n * Schema name.\n */\n readonly schema?: string;\n\n /**\n * Replication setup.\n */\n readonly replication?: {\n\n /**\n * Master server used by orm to perform writes.\n */\n readonly master: CockroachConnectionCredentialsOptions;\n\n /**\n * List of read-from severs (slaves).\n */\n readonly slaves: CockroachConnectionCredentialsOptions[];\n\n };\n\n\n /*\n * Function handling errors thrown by drivers pool.\n * Defaults to logging error with `warn` level.\n */\n readonly poolErrorHandler?: (err: any) => any;\n\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../browser/src/driver/cockroachdb/CockroachConnectionOptions.ts"],"names":[],"mappings":"","file":"CockroachConnectionOptions.js","sourcesContent":["import {BaseConnectionOptions} from \"../../connection/BaseConnectionOptions\";\nimport {CockroachConnectionCredentialsOptions} from \"./CockroachConnectionCredentialsOptions\";\n\n/**\n * Cockroachdb-specific connection options.\n */\nexport interface CockroachConnectionOptions extends BaseConnectionOptions, CockroachConnectionCredentialsOptions {\n\n /**\n * Database type.\n */\n readonly type: \"cockroachdb\";\n\n /**\n * Schema name.\n */\n readonly schema?: string;\n\n /**\n * The driver object\n * This defaults to `require(\"pg\")`.\n */\n readonly driver?: any;\n\n /**\n * The driver object\n * This defaults to `require(\"pg-native\")`.\n */\n readonly nativeDriver?: any;\n\n /**\n * Replication setup.\n */\n readonly replication?: {\n\n /**\n * Master server used by orm to perform writes.\n */\n readonly master: CockroachConnectionCredentialsOptions;\n\n /**\n * List of read-from severs (slaves).\n */\n readonly slaves: CockroachConnectionCredentialsOptions[];\n\n };\n\n\n /*\n * Function handling errors thrown by drivers pool.\n * Defaults to logging error with `warn` level.\n */\n readonly poolErrorHandler?: (err: any) => any;\n\n}\n"],"sourceRoot":"../.."}
@@ -397,7 +397,7 @@ var CockroachDriver = /** @class */ (function () {
397
397
  if (schema) {
398
398
  tablePath.unshift(schema);
399
399
  }
400
- return tablePath.join('.');
400
+ return tablePath.join(".");
401
401
  };
402
402
  /**
403
403
  * Parse a target table name or other types and return a normalized table definition.
@@ -557,13 +557,17 @@ var CockroachDriver = /** @class */ (function () {
557
557
  * If replication is not setup then returns default connection's database connection.
558
558
  */
559
559
  CockroachDriver.prototype.obtainMasterConnection = function () {
560
- var _this = this;
561
- return new Promise(function (ok, fail) {
562
- if (!_this.master) {
563
- return fail(new TypeORMError("Driver not Connected"));
564
- }
565
- _this.master.connect(function (err, connection, release) {
566
- err ? fail(err) : ok([connection, release]);
560
+ return __awaiter(this, void 0, void 0, function () {
561
+ var _this = this;
562
+ return __generator(this, function (_a) {
563
+ if (!this.master) {
564
+ throw new TypeORMError("Driver not Connected");
565
+ }
566
+ return [2 /*return*/, new Promise(function (ok, fail) {
567
+ _this.master.connect(function (err, connection, release) {
568
+ err ? fail(err) : ok([connection, release]);
569
+ });
570
+ })];
567
571
  });
568
572
  });
569
573
  };
@@ -573,13 +577,18 @@ var CockroachDriver = /** @class */ (function () {
573
577
  * If replication is not setup then returns master (default) connection's database connection.
574
578
  */
575
579
  CockroachDriver.prototype.obtainSlaveConnection = function () {
576
- var _this = this;
577
- if (!this.slaves.length)
578
- return this.obtainMasterConnection();
579
- return new Promise(function (ok, fail) {
580
- var random = Math.floor(Math.random() * _this.slaves.length);
581
- _this.slaves[random].connect(function (err, connection, release) {
582
- err ? fail(err) : ok([connection, release]);
580
+ return __awaiter(this, void 0, void 0, function () {
581
+ var random;
582
+ var _this = this;
583
+ return __generator(this, function (_a) {
584
+ if (!this.slaves.length)
585
+ return [2 /*return*/, this.obtainMasterConnection()];
586
+ random = Math.floor(Math.random() * this.slaves.length);
587
+ return [2 /*return*/, new Promise(function (ok, fail) {
588
+ _this.slaves[random].connect(function (err, connection, release) {
589
+ err ? fail(err) : ok([connection, release]);
590
+ });
591
+ })];
583
592
  });
584
593
  });
585
594
  };
@@ -692,9 +701,10 @@ var CockroachDriver = /** @class */ (function () {
692
701
  */
693
702
  CockroachDriver.prototype.loadDependencies = function () {
694
703
  try {
695
- this.postgres = PlatformTools.load("pg");
704
+ var postgres = this.options.driver || PlatformTools.load("pg");
705
+ this.postgres = postgres;
696
706
  try {
697
- var pgNative = PlatformTools.load("pg-native");
707
+ var pgNative = this.options.nativeDriver || PlatformTools.load("pg-native");
698
708
  if (pgNative && this.postgres.native)
699
709
  this.postgres = this.postgres.native;
700
710
  }