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
@@ -19,7 +19,6 @@ var BaseQueryRunner_1 = require("../../query-runner/BaseQueryRunner");
19
19
  var OrmUtils_1 = require("../../util/OrmUtils");
20
20
  var TableCheck_1 = require("../../schema-builder/table/TableCheck");
21
21
  var TableExclusion_1 = require("../../schema-builder/table/TableExclusion");
22
- var BroadcasterResult_1 = require("../../subscriber/BroadcasterResult");
23
22
  var error_1 = require("../../error");
24
23
  /**
25
24
  * Runs queries on a single postgres database connection.
@@ -96,42 +95,32 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
96
95
  */
97
96
  CockroachQueryRunner.prototype.startTransaction = function (isolationLevel) {
98
97
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
99
- var beforeBroadcastResult, afterBroadcastResult;
100
98
  return (0, tslib_1.__generator)(this, function (_a) {
101
99
  switch (_a.label) {
102
100
  case 0:
103
101
  if (this.isTransactionActive)
104
102
  throw new TransactionAlreadyStartedError_1.TransactionAlreadyStartedError();
105
- beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
106
- this.broadcaster.broadcastBeforeTransactionStartEvent(beforeBroadcastResult);
107
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
108
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
103
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionStart')];
109
104
  case 1:
110
105
  _a.sent();
111
- _a.label = 2;
112
- case 2:
113
106
  this.isTransactionActive = true;
114
107
  return [4 /*yield*/, this.query("START TRANSACTION")];
115
- case 3:
108
+ case 2:
116
109
  _a.sent();
117
110
  return [4 /*yield*/, this.query("SAVEPOINT cockroach_restart")];
118
- case 4:
111
+ case 3:
119
112
  _a.sent();
120
- if (!isolationLevel) return [3 /*break*/, 6];
113
+ if (!isolationLevel) return [3 /*break*/, 5];
121
114
  return [4 /*yield*/, this.query("SET TRANSACTION ISOLATION LEVEL " + isolationLevel)];
122
- case 5:
115
+ case 4:
123
116
  _a.sent();
124
- _a.label = 6;
125
- case 6:
117
+ _a.label = 5;
118
+ case 5:
126
119
  this.storeQueries = true;
127
- afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
128
- this.broadcaster.broadcastAfterTransactionStartEvent(afterBroadcastResult);
129
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 8];
130
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
131
- case 7:
120
+ return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionStart')];
121
+ case 6:
132
122
  _a.sent();
133
- _a.label = 8;
134
- case 8: return [2 /*return*/];
123
+ return [2 /*return*/];
135
124
  }
136
125
  });
137
126
  });
@@ -142,80 +131,70 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
142
131
  */
143
132
  CockroachQueryRunner.prototype.commitTransaction = function () {
144
133
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
145
- var beforeBroadcastResult, e_1, _a, _b, q, e_2_1, afterBroadcastResult;
134
+ var e_1, _a, _b, q, e_2_1;
146
135
  var e_2, _c;
147
136
  return (0, tslib_1.__generator)(this, function (_d) {
148
137
  switch (_d.label) {
149
138
  case 0:
150
139
  if (!this.isTransactionActive)
151
140
  throw new TransactionNotStartedError_1.TransactionNotStartedError();
152
- beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
153
- this.broadcaster.broadcastBeforeTransactionCommitEvent(beforeBroadcastResult);
154
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
155
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
141
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionCommit')];
156
142
  case 1:
157
143
  _d.sent();
144
+ this.storeQueries = false;
158
145
  _d.label = 2;
159
146
  case 2:
160
- this.storeQueries = false;
161
- _d.label = 3;
162
- case 3:
163
- _d.trys.push([3, 6, , 18]);
147
+ _d.trys.push([2, 5, , 17]);
164
148
  return [4 /*yield*/, this.query("RELEASE SAVEPOINT cockroach_restart")];
165
- case 4:
149
+ case 3:
166
150
  _d.sent();
167
151
  return [4 /*yield*/, this.query("COMMIT")];
168
- case 5:
152
+ case 4:
169
153
  _d.sent();
170
154
  this.queries = [];
171
155
  this.isTransactionActive = false;
172
- return [3 /*break*/, 18];
173
- case 6:
156
+ return [3 /*break*/, 17];
157
+ case 5:
174
158
  e_1 = _d.sent();
175
- if (!(e_1.code === "40001")) return [3 /*break*/, 17];
159
+ if (!(e_1.code === "40001")) return [3 /*break*/, 16];
176
160
  return [4 /*yield*/, this.query("ROLLBACK TO SAVEPOINT cockroach_restart")];
177
- case 7:
161
+ case 6:
178
162
  _d.sent();
163
+ _d.label = 7;
164
+ case 7:
165
+ _d.trys.push([7, 12, 13, 14]);
166
+ _a = (0, tslib_1.__values)(this.queries), _b = _a.next();
179
167
  _d.label = 8;
180
168
  case 8:
181
- _d.trys.push([8, 13, 14, 15]);
182
- _a = (0, tslib_1.__values)(this.queries), _b = _a.next();
183
- _d.label = 9;
184
- case 9:
185
- if (!!_b.done) return [3 /*break*/, 12];
169
+ if (!!_b.done) return [3 /*break*/, 11];
186
170
  q = _b.value;
187
171
  return [4 /*yield*/, this.query(q.query, q.parameters)];
188
- case 10:
172
+ case 9:
189
173
  _d.sent();
190
- _d.label = 11;
191
- case 11:
174
+ _d.label = 10;
175
+ case 10:
192
176
  _b = _a.next();
193
- return [3 /*break*/, 9];
194
- case 12: return [3 /*break*/, 15];
195
- case 13:
177
+ return [3 /*break*/, 8];
178
+ case 11: return [3 /*break*/, 14];
179
+ case 12:
196
180
  e_2_1 = _d.sent();
197
181
  e_2 = { error: e_2_1 };
198
- return [3 /*break*/, 15];
199
- case 14:
182
+ return [3 /*break*/, 14];
183
+ case 13:
200
184
  try {
201
185
  if (_b && !_b.done && (_c = _a.return)) _c.call(_a);
202
186
  }
203
187
  finally { if (e_2) throw e_2.error; }
204
188
  return [7 /*endfinally*/];
205
- case 15: return [4 /*yield*/, this.commitTransaction()];
206
- case 16:
189
+ case 14: return [4 /*yield*/, this.commitTransaction()];
190
+ case 15:
207
191
  _d.sent();
208
- _d.label = 17;
209
- case 17: return [3 /*break*/, 18];
192
+ _d.label = 16;
193
+ case 16: return [3 /*break*/, 17];
194
+ case 17: return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionCommit')];
210
195
  case 18:
211
- afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
212
- this.broadcaster.broadcastAfterTransactionCommitEvent(afterBroadcastResult);
213
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 20];
214
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
215
- case 19:
216
196
  _d.sent();
217
- _d.label = 20;
218
- case 20: return [2 /*return*/];
197
+ return [2 /*return*/];
219
198
  }
220
199
  });
221
200
  });
@@ -226,34 +205,24 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
226
205
  */
227
206
  CockroachQueryRunner.prototype.rollbackTransaction = function () {
228
207
  return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
229
- var beforeBroadcastResult, afterBroadcastResult;
230
208
  return (0, tslib_1.__generator)(this, function (_a) {
231
209
  switch (_a.label) {
232
210
  case 0:
233
211
  if (!this.isTransactionActive)
234
212
  throw new TransactionNotStartedError_1.TransactionNotStartedError();
235
- beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
236
- this.broadcaster.broadcastBeforeTransactionRollbackEvent(beforeBroadcastResult);
237
- if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
238
- return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
213
+ return [4 /*yield*/, this.broadcaster.broadcast('BeforeTransactionRollback')];
239
214
  case 1:
240
215
  _a.sent();
241
- _a.label = 2;
242
- case 2:
243
216
  this.storeQueries = false;
244
217
  return [4 /*yield*/, this.query("ROLLBACK")];
245
- case 3:
218
+ case 2:
246
219
  _a.sent();
247
220
  this.queries = [];
248
221
  this.isTransactionActive = false;
249
- afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
250
- this.broadcaster.broadcastAfterTransactionRollbackEvent(afterBroadcastResult);
251
- if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
252
- return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
253
- case 4:
222
+ return [4 /*yield*/, this.broadcaster.broadcast('AfterTransactionRollback')];
223
+ case 3:
254
224
  _a.sent();
255
- _a.label = 5;
256
- case 5: return [2 /*return*/];
225
+ return [2 /*return*/];
257
226
  }
258
227
  });
259
228
  });
@@ -262,103 +231,97 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
262
231
  * Executes a given SQL query.
263
232
  */
264
233
  CockroachQueryRunner.prototype.query = function (query, parameters, useStructuredResult) {
265
- var _this = this;
266
234
  if (useStructuredResult === void 0) { useStructuredResult = false; }
267
- if (this.isReleased)
268
- throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
269
- return new Promise(function (ok, fail) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
270
- var databaseConnection, queryStartTime_1, err_1;
271
- var _this = this;
235
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
236
+ var databaseConnection, queryStartTime, raw, maxQueryExecutionTime, queryEndTime, queryExecutionTime, result, err_1;
272
237
  return (0, tslib_1.__generator)(this, function (_a) {
273
238
  switch (_a.label) {
274
239
  case 0:
275
- _a.trys.push([0, 2, , 3]);
240
+ if (this.isReleased)
241
+ throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
276
242
  return [4 /*yield*/, this.connect()];
277
243
  case 1:
278
244
  databaseConnection = _a.sent();
279
245
  this.driver.connection.logger.logQuery(query, parameters, this);
280
- queryStartTime_1 = +new Date();
281
- databaseConnection.query(query, parameters, function (err, raw) {
282
- if (_this.isTransactionActive && _this.storeQueries)
283
- _this.queries.push({ query: query, parameters: parameters });
284
- // log slow queries if maxQueryExecution time is set
285
- var maxQueryExecutionTime = _this.driver.options.maxQueryExecutionTime;
286
- var queryEndTime = +new Date();
287
- var queryExecutionTime = queryEndTime - queryStartTime_1;
288
- if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)
289
- _this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, _this);
290
- if (err) {
291
- if (err.code !== "40001")
292
- _this.driver.connection.logger.logQueryError(err, query, parameters, _this);
293
- fail(new QueryFailedError_1.QueryFailedError(query, parameters, err));
294
- }
295
- else {
296
- var result = new QueryResult_1.QueryResult();
297
- if (raw.hasOwnProperty('rowCount')) {
298
- result.affected = raw.rowCount;
299
- }
300
- if (raw.hasOwnProperty('rows')) {
301
- result.records = raw.rows;
302
- }
303
- switch (raw.command) {
304
- case "DELETE":
305
- // for DELETE query additionally return number of affected rows
306
- result.raw = [raw.rows, raw.rowCount];
307
- break;
308
- default:
309
- result.raw = raw.rows;
310
- }
311
- if (useStructuredResult) {
312
- ok(result);
313
- }
314
- else {
315
- ok(result.raw);
316
- }
317
- }
318
- });
319
- return [3 /*break*/, 3];
246
+ queryStartTime = +new Date();
247
+ if (this.isTransactionActive && this.storeQueries) {
248
+ this.queries.push({ query: query, parameters: parameters });
249
+ }
250
+ _a.label = 2;
320
251
  case 2:
252
+ _a.trys.push([2, 4, , 5]);
253
+ return [4 /*yield*/, new Promise(function (ok, fail) {
254
+ databaseConnection.query(query, parameters, function (err, raw) { return err ? fail(err) : ok(raw); });
255
+ })];
256
+ case 3:
257
+ raw = _a.sent();
258
+ maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;
259
+ queryEndTime = +new Date();
260
+ queryExecutionTime = queryEndTime - queryStartTime;
261
+ if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime) {
262
+ this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
263
+ }
264
+ result = new QueryResult_1.QueryResult();
265
+ if (raw.hasOwnProperty('rowCount')) {
266
+ result.affected = raw.rowCount;
267
+ }
268
+ if (raw.hasOwnProperty('rows')) {
269
+ result.records = raw.rows;
270
+ }
271
+ switch (raw.command) {
272
+ case "DELETE":
273
+ // for DELETE query additionally return number of affected rows
274
+ result.raw = [raw.rows, raw.rowCount];
275
+ break;
276
+ default:
277
+ result.raw = raw.rows;
278
+ }
279
+ if (useStructuredResult) {
280
+ return [2 /*return*/, result];
281
+ }
282
+ else {
283
+ return [2 /*return*/, result.raw];
284
+ }
285
+ return [3 /*break*/, 5];
286
+ case 4:
321
287
  err_1 = _a.sent();
322
- fail(err_1);
323
- return [3 /*break*/, 3];
324
- case 3: return [2 /*return*/];
288
+ if (err_1.code !== "40001") {
289
+ this.driver.connection.logger.logQueryError(err_1, query, parameters, this);
290
+ }
291
+ throw new QueryFailedError_1.QueryFailedError(query, parameters, err_1);
292
+ case 5: return [2 /*return*/];
325
293
  }
326
294
  });
327
- }); });
295
+ });
328
296
  };
329
297
  /**
330
298
  * Returns raw data stream.
331
299
  */
332
300
  CockroachQueryRunner.prototype.stream = function (query, parameters, onEnd, onError) {
333
- var _this = this;
334
- var QueryStream = this.driver.loadStreamDependency();
335
- if (this.isReleased)
336
- throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
337
- return new Promise(function (ok, fail) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
338
- var databaseConnection, stream, err_2;
301
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
302
+ var QueryStream, databaseConnection, stream;
339
303
  return (0, tslib_1.__generator)(this, function (_a) {
340
304
  switch (_a.label) {
341
305
  case 0:
342
- _a.trys.push([0, 2, , 3]);
306
+ QueryStream = this.driver.loadStreamDependency();
307
+ if (this.isReleased) {
308
+ throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
309
+ }
343
310
  return [4 /*yield*/, this.connect()];
344
311
  case 1:
345
312
  databaseConnection = _a.sent();
346
313
  this.driver.connection.logger.logQuery(query, parameters, this);
347
314
  stream = databaseConnection.query(new QueryStream(query, parameters));
348
- if (onEnd)
315
+ if (onEnd) {
349
316
  stream.on("end", onEnd);
350
- if (onError)
317
+ }
318
+ if (onError) {
351
319
  stream.on("error", onError);
352
- ok(stream);
353
- return [3 /*break*/, 3];
354
- case 2:
355
- err_2 = _a.sent();
356
- fail(err_2);
357
- return [3 /*break*/, 3];
358
- case 3: return [2 /*return*/];
320
+ }
321
+ return [2 /*return*/, stream];
359
322
  }
360
323
  });
361
- }); });
324
+ });
362
325
  };
363
326
  /**
364
327
  * Returns all available database names including system databases.
@@ -2357,7 +2320,7 @@ var CockroachQueryRunner = /** @class */ (function (_super) {
2357
2320
  tableColumn.generationStrategy = "uuid";
2358
2321
  }
2359
2322
  else {
2360
- tableColumn.default = dbColumn["column_default"].replace(/:::.*/, "");
2323
+ tableColumn.default = dbColumn["column_default"].replace(/:::[\w\s\[\]\"]+/g, "");
2361
2324
  tableColumn.default = tableColumn.default.replace(/^(-?[\d\.]+)$/, "($1)");
2362
2325
  }
2363
2326
  }