typeorm 0.2.42-dev.600bd4e → 0.2.42-dev.8f2ae71

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 (188) hide show
  1. package/browser/common/DeepPartial.d.ts +3 -3
  2. package/browser/common/DeepPartial.js.map +1 -1
  3. package/browser/decorator/listeners/AfterRecover.d.ts +4 -0
  4. package/browser/decorator/listeners/AfterRecover.js +16 -0
  5. package/browser/decorator/listeners/AfterRecover.js.map +1 -0
  6. package/browser/decorator/listeners/AfterSoftRemove.d.ts +4 -0
  7. package/browser/decorator/listeners/AfterSoftRemove.js +16 -0
  8. package/browser/decorator/listeners/AfterSoftRemove.js.map +1 -0
  9. package/browser/decorator/listeners/BeforeRecover.d.ts +4 -0
  10. package/browser/decorator/listeners/BeforeRecover.js +16 -0
  11. package/browser/decorator/listeners/BeforeRecover.js.map +1 -0
  12. package/browser/decorator/listeners/BeforeSoftRemove.d.ts +4 -0
  13. package/browser/decorator/listeners/BeforeSoftRemove.js +16 -0
  14. package/browser/decorator/listeners/BeforeSoftRemove.js.map +1 -0
  15. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +8 -0
  16. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js +30 -0
  17. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  18. package/browser/driver/capacitor/CapacitorQueryRunner.d.ts +8 -0
  19. package/browser/driver/capacitor/CapacitorQueryRunner.js +30 -0
  20. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  21. package/browser/driver/cordova/CordovaQueryRunner.d.ts +8 -0
  22. package/browser/driver/cordova/CordovaQueryRunner.js +30 -0
  23. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  24. package/browser/driver/expo/ExpoQueryRunner.d.ts +8 -0
  25. package/browser/driver/expo/ExpoQueryRunner.js +30 -0
  26. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  27. package/browser/driver/mongodb/MongoQueryRunner.d.ts +8 -0
  28. package/browser/driver/mongodb/MongoQueryRunner.js +20 -0
  29. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  30. package/browser/driver/nativescript/NativescriptQueryRunner.d.ts +8 -0
  31. package/browser/driver/nativescript/NativescriptQueryRunner.js +30 -0
  32. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  33. package/browser/driver/react-native/ReactNativeQueryRunner.d.ts +8 -0
  34. package/browser/driver/react-native/ReactNativeQueryRunner.js +30 -0
  35. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  36. package/browser/driver/sqlite/SqliteQueryRunner.d.ts +8 -0
  37. package/browser/driver/sqlite/SqliteQueryRunner.js +30 -0
  38. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  39. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +2 -2
  40. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  41. package/browser/driver/sqljs/SqljsQueryRunner.d.ts +8 -0
  42. package/browser/driver/sqljs/SqljsQueryRunner.js +30 -0
  43. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  44. package/browser/entity-manager/EntityManager.js.map +1 -1
  45. package/browser/entity-manager/MongoEntityManager.d.ts +2 -0
  46. package/browser/entity-manager/MongoEntityManager.js +35 -4
  47. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  48. package/browser/index.d.ts +4 -0
  49. package/browser/index.js +4 -0
  50. package/browser/index.js.map +1 -1
  51. package/browser/metadata/EntityMetadata.d.ts +16 -0
  52. package/browser/metadata/EntityMetadata.js +16 -0
  53. package/browser/metadata/EntityMetadata.js.map +1 -1
  54. package/browser/metadata/types/EventListenerTypes.d.ts +5 -1
  55. package/browser/metadata/types/EventListenerTypes.js +4 -0
  56. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  57. package/browser/metadata-builder/EntityMetadataBuilder.js +4 -0
  58. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  59. package/browser/metadata-builder/EntityMetadataValidator.js +1 -1
  60. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  61. package/browser/migration/MigrationExecutor.js +37 -25
  62. package/browser/migration/MigrationExecutor.js.map +1 -1
  63. package/browser/persistence/SubjectExecutor.d.ts +4 -2
  64. package/browser/persistence/SubjectExecutor.js +105 -13
  65. package/browser/persistence/SubjectExecutor.js.map +1 -1
  66. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js +1 -1
  67. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  68. package/browser/query-builder/InsertQueryBuilder.js +9 -0
  69. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  70. package/browser/query-builder/SoftDeleteQueryBuilder.js +44 -30
  71. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  72. package/browser/query-runner/BaseQueryRunner.d.ts +8 -0
  73. package/browser/query-runner/BaseQueryRunner.js +20 -0
  74. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  75. package/browser/query-runner/QueryRunner.d.ts +8 -0
  76. package/browser/query-runner/QueryRunner.js.map +1 -1
  77. package/browser/repository/TreeRepository.js +2 -1
  78. package/browser/repository/TreeRepository.js.map +1 -1
  79. package/browser/schema-builder/RdbmsSchemaBuilder.js +36 -30
  80. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  81. package/browser/subscriber/Broadcaster.d.ts +40 -0
  82. package/browser/subscriber/Broadcaster.js +156 -0
  83. package/browser/subscriber/Broadcaster.js.map +1 -1
  84. package/browser/subscriber/EntitySubscriberInterface.d.ts +18 -0
  85. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  86. package/browser/subscriber/event/RecoverEvent.d.ts +6 -0
  87. package/browser/subscriber/event/RecoverEvent.js +3 -0
  88. package/browser/subscriber/event/RecoverEvent.js.map +1 -0
  89. package/browser/subscriber/event/SoftRemoveEvent.d.ts +6 -0
  90. package/browser/subscriber/event/SoftRemoveEvent.js +3 -0
  91. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -0
  92. package/commands/MigrationShowCommand.js +3 -4
  93. package/commands/MigrationShowCommand.js.map +1 -1
  94. package/common/DeepPartial.d.ts +3 -3
  95. package/common/DeepPartial.js.map +1 -1
  96. package/decorator/listeners/AfterRecover.d.ts +4 -0
  97. package/decorator/listeners/AfterRecover.js +20 -0
  98. package/decorator/listeners/AfterRecover.js.map +1 -0
  99. package/decorator/listeners/AfterSoftRemove.d.ts +4 -0
  100. package/decorator/listeners/AfterSoftRemove.js +20 -0
  101. package/decorator/listeners/AfterSoftRemove.js.map +1 -0
  102. package/decorator/listeners/BeforeRecover.d.ts +4 -0
  103. package/decorator/listeners/BeforeRecover.js +20 -0
  104. package/decorator/listeners/BeforeRecover.js.map +1 -0
  105. package/decorator/listeners/BeforeSoftRemove.d.ts +4 -0
  106. package/decorator/listeners/BeforeSoftRemove.js +20 -0
  107. package/decorator/listeners/BeforeSoftRemove.js.map +1 -0
  108. package/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +8 -0
  109. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js +30 -0
  110. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  111. package/driver/capacitor/CapacitorQueryRunner.d.ts +8 -0
  112. package/driver/capacitor/CapacitorQueryRunner.js +30 -0
  113. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  114. package/driver/cordova/CordovaQueryRunner.d.ts +8 -0
  115. package/driver/cordova/CordovaQueryRunner.js +30 -0
  116. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  117. package/driver/expo/ExpoQueryRunner.d.ts +8 -0
  118. package/driver/expo/ExpoQueryRunner.js +30 -0
  119. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  120. package/driver/mongodb/MongoQueryRunner.d.ts +8 -0
  121. package/driver/mongodb/MongoQueryRunner.js +20 -0
  122. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  123. package/driver/nativescript/NativescriptQueryRunner.d.ts +8 -0
  124. package/driver/nativescript/NativescriptQueryRunner.js +30 -0
  125. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  126. package/driver/react-native/ReactNativeQueryRunner.d.ts +8 -0
  127. package/driver/react-native/ReactNativeQueryRunner.js +30 -0
  128. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  129. package/driver/sqlite/SqliteQueryRunner.d.ts +8 -0
  130. package/driver/sqlite/SqliteQueryRunner.js +30 -0
  131. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  132. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +2 -2
  133. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  134. package/driver/sqljs/SqljsQueryRunner.d.ts +8 -0
  135. package/driver/sqljs/SqljsQueryRunner.js +30 -0
  136. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  137. package/entity-manager/EntityManager.js.map +1 -1
  138. package/entity-manager/MongoEntityManager.d.ts +2 -0
  139. package/entity-manager/MongoEntityManager.js +35 -4
  140. package/entity-manager/MongoEntityManager.js.map +1 -1
  141. package/index.d.ts +4 -0
  142. package/index.js +4 -0
  143. package/index.js.map +1 -1
  144. package/index.mjs +8 -0
  145. package/metadata/EntityMetadata.d.ts +16 -0
  146. package/metadata/EntityMetadata.js +16 -0
  147. package/metadata/EntityMetadata.js.map +1 -1
  148. package/metadata/types/EventListenerTypes.d.ts +5 -1
  149. package/metadata/types/EventListenerTypes.js +4 -0
  150. package/metadata/types/EventListenerTypes.js.map +1 -1
  151. package/metadata-builder/EntityMetadataBuilder.js +4 -0
  152. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  153. package/metadata-builder/EntityMetadataValidator.js +1 -1
  154. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  155. package/migration/MigrationExecutor.js +37 -25
  156. package/migration/MigrationExecutor.js.map +1 -1
  157. package/package.json +1 -1
  158. package/persistence/SubjectExecutor.d.ts +4 -2
  159. package/persistence/SubjectExecutor.js +105 -13
  160. package/persistence/SubjectExecutor.js.map +1 -1
  161. package/persistence/tree/MaterializedPathSubjectExecutor.js +1 -1
  162. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  163. package/query-builder/InsertQueryBuilder.js +9 -0
  164. package/query-builder/InsertQueryBuilder.js.map +1 -1
  165. package/query-builder/SoftDeleteQueryBuilder.js +44 -30
  166. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  167. package/query-runner/BaseQueryRunner.d.ts +8 -0
  168. package/query-runner/BaseQueryRunner.js +20 -0
  169. package/query-runner/BaseQueryRunner.js.map +1 -1
  170. package/query-runner/QueryRunner.d.ts +8 -0
  171. package/query-runner/QueryRunner.js.map +1 -1
  172. package/repository/TreeRepository.js +2 -1
  173. package/repository/TreeRepository.js.map +1 -1
  174. package/schema-builder/RdbmsSchemaBuilder.js +36 -30
  175. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  176. package/subscriber/Broadcaster.d.ts +40 -0
  177. package/subscriber/Broadcaster.js +156 -0
  178. package/subscriber/Broadcaster.js.map +1 -1
  179. package/subscriber/EntitySubscriberInterface.d.ts +18 -0
  180. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  181. package/subscriber/event/RecoverEvent.d.ts +6 -0
  182. package/subscriber/event/RecoverEvent.js +4 -0
  183. package/subscriber/event/RecoverEvent.js.map +1 -0
  184. package/subscriber/event/SoftRemoveEvent.d.ts +6 -0
  185. package/subscriber/event/SoftRemoveEvent.js +4 -0
  186. package/subscriber/event/SoftRemoveEvent.js.map +1 -0
  187. package/typeorm-class-transformer-shim.js +20 -0
  188. package/typeorm-model-shim.js +20 -0
@@ -22,6 +22,36 @@ var NativescriptQueryRunner = /** @class */ (function (_super) {
22
22
  _this.broadcaster = new Broadcaster_1.Broadcaster(_this);
23
23
  return _this;
24
24
  }
25
+ /**
26
+ * Called before migrations are run.
27
+ */
28
+ NativescriptQueryRunner.prototype.beforeMigration = function () {
29
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
30
+ return (0, tslib_1.__generator)(this, function (_a) {
31
+ switch (_a.label) {
32
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = OFF")];
33
+ case 1:
34
+ _a.sent();
35
+ return [2 /*return*/];
36
+ }
37
+ });
38
+ });
39
+ };
40
+ /**
41
+ * Called after migrations are run.
42
+ */
43
+ NativescriptQueryRunner.prototype.afterMigration = function () {
44
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
45
+ return (0, tslib_1.__generator)(this, function (_a) {
46
+ switch (_a.label) {
47
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = ON")];
48
+ case 1:
49
+ _a.sent();
50
+ return [2 /*return*/];
51
+ }
52
+ });
53
+ });
54
+ };
25
55
  /**
26
56
  * Executes a given SQL query.
27
57
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/nativescript/NativescriptQueryRunner.ts"],"names":[],"mappings":"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","file":"NativescriptQueryRunner.js","sourcesContent":["import {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {NativescriptDriver} from \"./NativescriptDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class NativescriptQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: NativescriptDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: NativescriptDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n\n if (this.isReleased) {\n throw new QueryRunnerAlreadyReleasedError();\n }\n\n const connection = this.driver.connection;\n\n return new Promise(async (ok, fail) => {\n\n const databaseConnection = await this.connect();\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\";\n connection.logger.logQuery(query, parameters, this);\n\n const handler = (err: any, raw: any) => {\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n \n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime) {\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n }\n \n if (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n }\n\n const result = new QueryResult();\n result.raw = raw;\n\n if (!isInsertQuery && Array.isArray(raw)) {\n result.records = raw;\n }\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n \n };\n const queryStartTime = +new Date();\n\n if (isInsertQuery) {\n databaseConnection.execSQL(query, parameters, handler);\n } else {\n databaseConnection.all(query, parameters, handler);\n } \n });\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral, startIndex: number = 0): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/nativescript/NativescriptQueryRunner.ts"],"names":[],"mappings":"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","file":"NativescriptQueryRunner.js","sourcesContent":["import {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {NativescriptDriver} from \"./NativescriptDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class NativescriptQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: NativescriptDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: NativescriptDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`);\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`);\n }\n\n /**\n * Executes a given SQL query.\n */\n async query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n\n if (this.isReleased) {\n throw new QueryRunnerAlreadyReleasedError();\n }\n\n const connection = this.driver.connection;\n\n return new Promise(async (ok, fail) => {\n\n const databaseConnection = await this.connect();\n const isInsertQuery = query.substr(0, 11) === \"INSERT INTO\";\n connection.logger.logQuery(query, parameters, this);\n\n const handler = (err: any, raw: any) => {\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n \n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime) {\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n }\n \n if (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n }\n\n const result = new QueryResult();\n result.raw = raw;\n\n if (!isInsertQuery && Array.isArray(raw)) {\n result.records = raw;\n }\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n \n };\n const queryStartTime = +new Date();\n\n if (isInsertQuery) {\n databaseConnection.execSQL(query, parameters, handler);\n } else {\n databaseConnection.all(query, parameters, handler);\n } \n });\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral, startIndex: number = 0): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
@@ -10,6 +10,14 @@ export declare class ReactNativeQueryRunner extends AbstractSqliteQueryRunner {
10
10
  */
11
11
  driver: ReactNativeDriver;
12
12
  constructor(driver: ReactNativeDriver);
13
+ /**
14
+ * Called before migrations are run.
15
+ */
16
+ beforeMigration(): Promise<void>;
17
+ /**
18
+ * Called after migrations are run.
19
+ */
20
+ afterMigration(): Promise<void>;
13
21
  /**
14
22
  * Executes a given SQL query.
15
23
  */
@@ -22,6 +22,36 @@ var ReactNativeQueryRunner = /** @class */ (function (_super) {
22
22
  _this.broadcaster = new Broadcaster_1.Broadcaster(_this);
23
23
  return _this;
24
24
  }
25
+ /**
26
+ * Called before migrations are run.
27
+ */
28
+ ReactNativeQueryRunner.prototype.beforeMigration = function () {
29
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
30
+ return (0, tslib_1.__generator)(this, function (_a) {
31
+ switch (_a.label) {
32
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = OFF")];
33
+ case 1:
34
+ _a.sent();
35
+ return [2 /*return*/];
36
+ }
37
+ });
38
+ });
39
+ };
40
+ /**
41
+ * Called after migrations are run.
42
+ */
43
+ ReactNativeQueryRunner.prototype.afterMigration = function () {
44
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
45
+ return (0, tslib_1.__generator)(this, function (_a) {
46
+ switch (_a.label) {
47
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = ON")];
48
+ case 1:
49
+ _a.sent();
50
+ return [2 /*return*/];
51
+ }
52
+ });
53
+ });
54
+ };
25
55
  /**
26
56
  * Executes a given SQL query.
27
57
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/react-native/ReactNativeQueryRunner.ts"],"names":[],"mappings":"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","file":"ReactNativeQueryRunner.js","sourcesContent":["import {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {ReactNativeDriver} from \"./ReactNativeDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class ReactNativeQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: ReactNativeDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: ReactNativeDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n return new Promise(async (ok, fail) => {\n const databaseConnection = await this.connect();\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n databaseConnection.executeSql(query, parameters, (raw: any) => {\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n const result = new QueryResult();\n\n // return id of inserted row, if query was insert statement.\n if (query.substr(0, 11) === \"INSERT INTO\") {\n result.raw = raw.insertId;\n }\n\n if (raw?.hasOwnProperty('rowsAffected')) {\n result.affected = raw.rowsAffected;\n }\n\n if (raw?.hasOwnProperty('rows')) {\n let records = [];\n for (let i = 0; i < raw.rows.length; i++) {\n records.push(raw.rows.item(i));\n }\n\n result.raw = records;\n result.records = records;\n }\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n }, (err: any) => {\n this.driver.connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n });\n });\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral, startIndex: number = 0): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/react-native/ReactNativeQueryRunner.ts"],"names":[],"mappings":"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","file":"ReactNativeQueryRunner.js","sourcesContent":["import {ObjectLiteral} from \"../../common/ObjectLiteral\";\nimport {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {ReactNativeDriver} from \"./ReactNativeDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class ReactNativeQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: ReactNativeDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: ReactNativeDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`);\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`);\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n return new Promise(async (ok, fail) => {\n const databaseConnection = await this.connect();\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n databaseConnection.executeSql(query, parameters, (raw: any) => {\n\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n const result = new QueryResult();\n\n // return id of inserted row, if query was insert statement.\n if (query.substr(0, 11) === \"INSERT INTO\") {\n result.raw = raw.insertId;\n }\n\n if (raw?.hasOwnProperty('rowsAffected')) {\n result.affected = raw.rowsAffected;\n }\n\n if (raw?.hasOwnProperty('rows')) {\n let records = [];\n for (let i = 0; i < raw.rows.length; i++) {\n records.push(raw.rows.item(i));\n }\n\n result.raw = records;\n result.records = records;\n }\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n }, (err: any) => {\n this.driver.connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n });\n });\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(objectLiteral: ObjectLiteral, startIndex: number = 0): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\");\n }\n}\n"],"sourceRoot":"../.."}
@@ -12,6 +12,14 @@ export declare class SqliteQueryRunner extends AbstractSqliteQueryRunner {
12
12
  */
13
13
  driver: SqliteDriver;
14
14
  constructor(driver: SqliteDriver);
15
+ /**
16
+ * Called before migrations are run.
17
+ */
18
+ beforeMigration(): Promise<void>;
19
+ /**
20
+ * Called after migrations are run.
21
+ */
22
+ afterMigration(): Promise<void>;
15
23
  /**
16
24
  * Executes a given SQL query.
17
25
  */
@@ -26,6 +26,36 @@ var SqliteQueryRunner = /** @class */ (function (_super) {
26
26
  _this.broadcaster = new Broadcaster_1.Broadcaster(_this);
27
27
  return _this;
28
28
  }
29
+ /**
30
+ * Called before migrations are run.
31
+ */
32
+ SqliteQueryRunner.prototype.beforeMigration = function () {
33
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
34
+ return (0, tslib_1.__generator)(this, function (_a) {
35
+ switch (_a.label) {
36
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = OFF")];
37
+ case 1:
38
+ _a.sent();
39
+ return [2 /*return*/];
40
+ }
41
+ });
42
+ });
43
+ };
44
+ /**
45
+ * Called after migrations are run.
46
+ */
47
+ SqliteQueryRunner.prototype.afterMigration = function () {
48
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
49
+ return (0, tslib_1.__generator)(this, function (_a) {
50
+ switch (_a.label) {
51
+ case 0: return [4 /*yield*/, this.query("PRAGMA foreign_keys = ON")];
52
+ case 1:
53
+ _a.sent();
54
+ return [2 /*return*/];
55
+ }
56
+ });
57
+ });
58
+ };
29
59
  /**
30
60
  * Executes a given SQL query.
31
61
  */
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/sqlite/SqliteQueryRunner.ts"],"names":[],"mappings":"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","file":"SqliteQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {SqliteConnectionOptions} from \"./SqliteConnectionOptions\";\nimport {SqliteDriver} from \"./SqliteDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { ConnectionIsNotSetError } from '../../error/ConnectionIsNotSetError';\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n *\n * Does not support compose primary keys with autoincrement field.\n * todo: need to throw exception for this case.\n */\nexport class SqliteQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: SqliteDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqliteDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n const connection = this.driver.connection;\n const options = connection.options as SqliteConnectionOptions;\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n\n if (!connection.isConnected){\n throw new ConnectionIsNotSetError('sqlite')\n }\n\n return new Promise(async (ok, fail) => {\n\n const databaseConnection = await this.connect();\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n const isInsertQuery = query.startsWith(\"INSERT \");\n const isDeleteQuery = query.startsWith(\"DELETE \");\n const isUpdateQuery = query.startsWith(\"UPDATE \");\n\n const execute = async () => {\n if (isInsertQuery || isDeleteQuery || isUpdateQuery) {\n await databaseConnection.run(query, parameters, handler);\n } else {\n await databaseConnection.all(query, parameters, handler);\n }\n };\n\n const handler = function (err: any, rows: any) {\n if (err && err.toString().indexOf(\"SQLITE_BUSY:\") !== -1) {\n if (typeof options.busyErrorRetry === \"number\" && options.busyErrorRetry > 0) {\n setTimeout(execute, options.busyErrorRetry);\n return;\n }\n }\n\n // log slow queries if maxQueryExecution time is set\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n if (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n } else {\n const result = new QueryResult();\n\n if (isInsertQuery) {\n result.raw = this[\"lastID\"];\n } else {\n result.raw = rows;\n }\n\n if (Array.isArray(rows)) {\n\n result.records = rows;\n }\n\n result.affected = this[\"changes\"];\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n }\n };\n\n await execute();\n });\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/sqlite/SqliteQueryRunner.ts"],"names":[],"mappings":"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","file":"SqliteQueryRunner.js","sourcesContent":["import {QueryRunnerAlreadyReleasedError} from \"../../error/QueryRunnerAlreadyReleasedError\";\nimport {QueryFailedError} from \"../../error/QueryFailedError\";\nimport {AbstractSqliteQueryRunner} from \"../sqlite-abstract/AbstractSqliteQueryRunner\";\nimport {SqliteConnectionOptions} from \"./SqliteConnectionOptions\";\nimport {SqliteDriver} from \"./SqliteDriver\";\nimport {Broadcaster} from \"../../subscriber/Broadcaster\";\nimport { ConnectionIsNotSetError } from '../../error/ConnectionIsNotSetError';\nimport { QueryResult } from \"../../query-runner/QueryResult\";\n\n/**\n * Runs queries on a single sqlite database connection.\n *\n * Does not support compose primary keys with autoincrement field.\n * todo: need to throw exception for this case.\n */\nexport class SqliteQueryRunner extends AbstractSqliteQueryRunner {\n\n /**\n * Database driver used by connection.\n */\n driver: SqliteDriver;\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(driver: SqliteDriver) {\n super();\n this.driver = driver;\n this.connection = driver.connection;\n this.broadcaster = new Broadcaster(this);\n }\n\n /**\n * Called before migrations are run.\n */\n async beforeMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = OFF`);\n }\n\n /**\n * Called after migrations are run.\n */\n async afterMigration(): Promise<void> {\n await this.query(`PRAGMA foreign_keys = ON`);\n }\n\n /**\n * Executes a given SQL query.\n */\n query(query: string, parameters?: any[], useStructuredResult = false): Promise<any> {\n if (this.isReleased)\n throw new QueryRunnerAlreadyReleasedError();\n\n const connection = this.driver.connection;\n const options = connection.options as SqliteConnectionOptions;\n const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;\n\n if (!connection.isConnected){\n throw new ConnectionIsNotSetError('sqlite')\n }\n\n return new Promise(async (ok, fail) => {\n\n const databaseConnection = await this.connect();\n this.driver.connection.logger.logQuery(query, parameters, this);\n const queryStartTime = +new Date();\n const isInsertQuery = query.startsWith(\"INSERT \");\n const isDeleteQuery = query.startsWith(\"DELETE \");\n const isUpdateQuery = query.startsWith(\"UPDATE \");\n\n const execute = async () => {\n if (isInsertQuery || isDeleteQuery || isUpdateQuery) {\n await databaseConnection.run(query, parameters, handler);\n } else {\n await databaseConnection.all(query, parameters, handler);\n }\n };\n\n const handler = function (err: any, rows: any) {\n if (err && err.toString().indexOf(\"SQLITE_BUSY:\") !== -1) {\n if (typeof options.busyErrorRetry === \"number\" && options.busyErrorRetry > 0) {\n setTimeout(execute, options.busyErrorRetry);\n return;\n }\n }\n\n // log slow queries if maxQueryExecution time is set\n const queryEndTime = +new Date();\n const queryExecutionTime = queryEndTime - queryStartTime;\n if (maxQueryExecutionTime && queryExecutionTime > maxQueryExecutionTime)\n connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);\n\n if (err) {\n connection.logger.logQueryError(err, query, parameters, this);\n fail(new QueryFailedError(query, parameters, err));\n } else {\n const result = new QueryResult();\n\n if (isInsertQuery) {\n result.raw = this[\"lastID\"];\n } else {\n result.raw = rows;\n }\n\n if (Array.isArray(rows)) {\n\n result.records = rows;\n }\n\n result.affected = this[\"changes\"];\n\n if (useStructuredResult) {\n ok(result);\n } else {\n ok(result.raw);\n }\n }\n };\n\n await execute();\n });\n }\n}\n"],"sourceRoot":"../.."}
@@ -1434,7 +1434,7 @@ var AbstractSqliteQueryRunner = /** @class */ (function (_super) {
1434
1434
  }
1435
1435
  if (tableColumn.type === "varchar") {
1436
1436
  // Check if this is an enum
1437
- var enumMatch = sql.match(new RegExp("\"(" + tableColumn.name + ")\" varchar CHECK\\s*\\(\\s*\\1\\s+IN\\s*\\(('[^']+'(?:\\s*,\\s*'[^']+')+)\\s*\\)\\s*\\)"));
1437
+ var enumMatch = sql.match(new RegExp("\"(" + tableColumn.name + ")\" varchar CHECK\\s*\\(\\s*\"\\1\"\\s+IN\\s*\\(('[^']+'(?:\\s*,\\s*'[^']+')+)\\s*\\)\\s*\\)"));
1438
1438
  if (enumMatch) {
1439
1439
  // This is an enum
1440
1440
  tableColumn.enum = enumMatch[2].substr(1, enumMatch[2].length - 2).split("','");
@@ -1704,7 +1704,7 @@ var AbstractSqliteQueryRunner = /** @class */ (function (_super) {
1704
1704
  c += " " + this.connection.driver.createFullType(column);
1705
1705
  }
1706
1706
  if (column.enum)
1707
- c += " CHECK( " + column.name + " IN (" + column.enum.map(function (val) { return "'" + val + "'"; }).join(",") + ") )";
1707
+ c += " CHECK( \"" + column.name + "\" IN (" + column.enum.map(function (val) { return "'" + val + "'"; }).join(",") + ") )";
1708
1708
  if (column.isPrimary && !skipPrimary)
1709
1709
  c += " PRIMARY KEY";
1710
1710
  if (column.isGenerated === true && column.generationStrategy === "increment") // don't use skipPrimary here since updates can update already exist primary without auto inc.