typeorm 0.3.18-dev.0f11739 → 0.3.18-dev.15bc887

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 (142) hide show
  1. package/browser/cache/DbQueryResultCache.js +3 -0
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/driver/cockroachdb/CockroachDriver.js +20 -10
  4. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  5. package/browser/driver/cockroachdb/CockroachQueryRunner.js +11 -2
  6. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  7. package/browser/driver/cordova/CordovaDriver.js +2 -2
  8. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  9. package/browser/driver/cordova/CordovaQueryRunner.js +8 -0
  10. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  11. package/browser/driver/expo/ExpoQueryRunner.js +9 -2
  12. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  13. package/browser/driver/mysql/MysqlQueryRunner.js +10 -2
  14. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  15. package/browser/driver/oracle/OracleQueryRunner.js +9 -1
  16. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  17. package/browser/driver/postgres/PostgresDriver.js +1 -4
  18. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  19. package/browser/driver/postgres/PostgresQueryRunner.js +9 -1
  20. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  21. package/browser/driver/react-native/ReactNativeQueryRunner.js +10 -2
  22. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  23. package/browser/driver/sap/SapQueryRunner.js +10 -4
  24. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  25. package/browser/driver/spanner/SpannerQueryRunner.js +7 -1
  26. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  27. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  28. package/browser/driver/sqlite/SqliteQueryRunner.js +60 -46
  29. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  30. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +1 -1
  31. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  32. package/browser/driver/sqljs/SqljsQueryRunner.js +11 -3
  33. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  34. package/browser/driver/sqlserver/SqlServerQueryRunner.js +7 -1
  35. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  36. package/browser/find-options/FindOperatorType.d.ts +1 -1
  37. package/browser/find-options/FindOperatorType.js.map +1 -1
  38. package/browser/find-options/operator/Or.d.ts +2 -0
  39. package/browser/find-options/operator/Or.js +6 -0
  40. package/browser/find-options/operator/Or.js.map +1 -0
  41. package/browser/index.d.ts +1 -0
  42. package/browser/index.js +1 -0
  43. package/browser/index.js.map +1 -1
  44. package/browser/metadata/ColumnMetadata.js +4 -0
  45. package/browser/metadata/ColumnMetadata.js.map +1 -1
  46. package/browser/metadata/EntityMetadata.d.ts +3 -3
  47. package/browser/metadata/EntityMetadata.js +7 -3
  48. package/browser/metadata/EntityMetadata.js.map +1 -1
  49. package/browser/persistence/SubjectExecutor.js +1 -1
  50. package/browser/persistence/SubjectExecutor.js.map +1 -1
  51. package/browser/query-builder/QueryBuilder.js +9 -0
  52. package/browser/query-builder/QueryBuilder.js.map +1 -1
  53. package/browser/query-builder/QueryExpressionMap.d.ts +2 -1
  54. package/browser/query-builder/QueryExpressionMap.js +0 -4
  55. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  56. package/browser/query-builder/SelectQueryBuilder.js +1 -1
  57. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  58. package/browser/query-builder/WhereClause.d.ts +1 -1
  59. package/browser/query-builder/WhereClause.js.map +1 -1
  60. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -0
  61. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +28 -0
  62. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  63. package/browser/subscriber/Broadcaster.d.ts +10 -0
  64. package/browser/subscriber/Broadcaster.js +46 -0
  65. package/browser/subscriber/Broadcaster.js.map +1 -1
  66. package/browser/subscriber/EntitySubscriberInterface.d.ts +9 -0
  67. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  68. package/browser/subscriber/event/QueryEvent.d.ts +50 -0
  69. package/browser/subscriber/event/QueryEvent.js +3 -0
  70. package/browser/subscriber/event/QueryEvent.js.map +1 -0
  71. package/cache/DbQueryResultCache.js +3 -0
  72. package/cache/DbQueryResultCache.js.map +1 -1
  73. package/driver/cockroachdb/CockroachDriver.js +20 -10
  74. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  75. package/driver/cockroachdb/CockroachQueryRunner.js +11 -2
  76. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  77. package/driver/cordova/CordovaDriver.js +2 -2
  78. package/driver/cordova/CordovaDriver.js.map +1 -1
  79. package/driver/cordova/CordovaQueryRunner.js +8 -0
  80. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  81. package/driver/expo/ExpoQueryRunner.js +9 -2
  82. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  83. package/driver/mysql/MysqlQueryRunner.js +10 -2
  84. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  85. package/driver/oracle/OracleQueryRunner.js +9 -1
  86. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  87. package/driver/postgres/PostgresDriver.js +1 -4
  88. package/driver/postgres/PostgresDriver.js.map +1 -1
  89. package/driver/postgres/PostgresQueryRunner.js +9 -1
  90. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  91. package/driver/react-native/ReactNativeQueryRunner.js +10 -2
  92. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  93. package/driver/sap/SapQueryRunner.js +10 -4
  94. package/driver/sap/SapQueryRunner.js.map +1 -1
  95. package/driver/spanner/SpannerQueryRunner.js +7 -1
  96. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  97. package/driver/sqlite/SqliteDriver.js.map +1 -1
  98. package/driver/sqlite/SqliteQueryRunner.js +60 -46
  99. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  100. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +1 -1
  101. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  102. package/driver/sqljs/SqljsQueryRunner.js +11 -3
  103. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  104. package/driver/sqlserver/SqlServerQueryRunner.js +7 -1
  105. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  106. package/find-options/FindOperatorType.d.ts +1 -1
  107. package/find-options/FindOperatorType.js.map +1 -1
  108. package/find-options/operator/Or.d.ts +2 -0
  109. package/find-options/operator/Or.js +10 -0
  110. package/find-options/operator/Or.js.map +1 -0
  111. package/index.d.ts +1 -0
  112. package/index.js +1 -0
  113. package/index.js.map +1 -1
  114. package/index.mjs +2 -0
  115. package/metadata/ColumnMetadata.js +4 -0
  116. package/metadata/ColumnMetadata.js.map +1 -1
  117. package/metadata/EntityMetadata.d.ts +3 -3
  118. package/metadata/EntityMetadata.js +7 -3
  119. package/metadata/EntityMetadata.js.map +1 -1
  120. package/package.json +1 -1
  121. package/persistence/SubjectExecutor.js +1 -1
  122. package/persistence/SubjectExecutor.js.map +1 -1
  123. package/query-builder/QueryBuilder.js +9 -0
  124. package/query-builder/QueryBuilder.js.map +1 -1
  125. package/query-builder/QueryExpressionMap.d.ts +2 -1
  126. package/query-builder/QueryExpressionMap.js +0 -4
  127. package/query-builder/QueryExpressionMap.js.map +1 -1
  128. package/query-builder/SelectQueryBuilder.js +1 -1
  129. package/query-builder/SelectQueryBuilder.js.map +1 -1
  130. package/query-builder/WhereClause.d.ts +1 -1
  131. package/query-builder/WhereClause.js.map +1 -1
  132. package/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -0
  133. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +28 -0
  134. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  135. package/subscriber/Broadcaster.d.ts +10 -0
  136. package/subscriber/Broadcaster.js +46 -0
  137. package/subscriber/Broadcaster.js.map +1 -1
  138. package/subscriber/EntitySubscriberInterface.d.ts +9 -0
  139. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  140. package/subscriber/event/QueryEvent.d.ts +50 -0
  141. package/subscriber/event/QueryEvent.js +4 -0
  142. package/subscriber/event/QueryEvent.js.map +1 -0
@@ -6,6 +6,7 @@ const QueryFailedError_1 = require("../../error/QueryFailedError");
6
6
  const AbstractSqliteQueryRunner_1 = require("../sqlite-abstract/AbstractSqliteQueryRunner");
7
7
  const Broadcaster_1 = require("../../subscriber/Broadcaster");
8
8
  const QueryResult_1 = require("../../query-runner/QueryResult");
9
+ const BroadcasterResult_1 = require("../../subscriber/BroadcasterResult");
9
10
  /**
10
11
  * Runs queries on a single sqlite database connection.
11
12
  */
@@ -39,16 +40,21 @@ class ReactNativeQueryRunner extends AbstractSqliteQueryRunner_1.AbstractSqliteQ
39
40
  throw new QueryRunnerAlreadyReleasedError_1.QueryRunnerAlreadyReleasedError();
40
41
  return new Promise(async (ok, fail) => {
41
42
  const databaseConnection = await this.connect();
43
+ const broadcasterResult = new BroadcasterResult_1.BroadcasterResult();
42
44
  this.driver.connection.logger.logQuery(query, parameters, this);
45
+ this.broadcaster.broadcastBeforeQueryEvent(broadcasterResult, query, parameters);
43
46
  const queryStartTime = +new Date();
44
- databaseConnection.executeSql(query, parameters, (raw) => {
47
+ databaseConnection.executeSql(query, parameters, async (raw) => {
45
48
  // log slow queries if maxQueryExecution time is set
46
49
  const maxQueryExecutionTime = this.driver.options.maxQueryExecutionTime;
47
50
  const queryEndTime = +new Date();
48
51
  const queryExecutionTime = queryEndTime - queryStartTime;
52
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, true, queryExecutionTime, raw, undefined);
49
53
  if (maxQueryExecutionTime &&
50
54
  queryExecutionTime > maxQueryExecutionTime)
51
55
  this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
56
+ if (broadcasterResult.promises.length > 0)
57
+ await Promise.all(broadcasterResult.promises);
52
58
  const result = new QueryResult_1.QueryResult();
53
59
  if (raw === null || raw === void 0 ? void 0 : raw.hasOwnProperty("rowsAffected")) {
54
60
  result.affected = raw.rowsAffected;
@@ -71,8 +77,10 @@ class ReactNativeQueryRunner extends AbstractSqliteQueryRunner_1.AbstractSqliteQ
71
77
  else {
72
78
  ok(result.raw);
73
79
  }
74
- }, (err) => {
80
+ }, async (err) => {
75
81
  this.driver.connection.logger.logQueryError(err, query, parameters, this);
82
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, false, undefined, undefined, err);
83
+ await broadcasterResult.wait();
76
84
  fail(new QueryFailedError_1.QueryFailedError(query, parameters, err));
77
85
  });
78
86
  });
@@ -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 * Database driver used by connection.\n */\n // @ts-ignore temporary, we need to fix the issue with the AbstractSqliteDriver and circular errors\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(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) 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(\n query,\n parameters,\n (raw: any) => {\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n )\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n\n const result = new QueryResult()\n\n if (raw?.hasOwnProperty(\"rowsAffected\")) {\n result.affected = raw.rowsAffected\n }\n\n if (raw?.hasOwnProperty(\"rows\")) {\n let 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 // 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 (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n },\n (err: any) => {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n fail(new QueryFailedError(query, parameters, err))\n },\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(\n objectLiteral: ObjectLiteral,\n startIndex: number = 0,\n ): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\n }\n}\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/react-native/ReactNativeQueryRunner.ts"],"names":[],"mappings":";;;AACA,iGAA6F;AAC7F,mEAA+D;AAC/D,4FAAwF;AAExF,8DAA0D;AAC1D,gEAA4D;AAC5D,0EAAsE;AAEtE;;GAEG;AACH,MAAa,sBAAuB,SAAQ,qDAAyB;IAOjE,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAY,MAAyB;QACjC,KAAK,EAAE,CAAA;QACP,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAA;QACnC,IAAI,CAAC,WAAW,GAAG,IAAI,yBAAW,CAAC,IAAI,CAAC,CAAA;IAC5C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,eAAe;QACjB,MAAM,IAAI,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAA;IACjD,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,cAAc;QAChB,MAAM,IAAI,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAA;IAChD,CAAC;IAED;;OAEG;IACH,KAAK,CACD,KAAa,EACb,UAAkB,EAClB,mBAAmB,GAAG,KAAK;QAE3B,IAAI,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,iEAA+B,EAAE,CAAA;QAEhE,OAAO,IAAI,OAAO,CAAC,KAAK,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE;YAClC,MAAM,kBAAkB,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;YAC/C,MAAM,iBAAiB,GAAG,IAAI,qCAAiB,EAAE,CAAA;YAEjD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;YAC/D,IAAI,CAAC,WAAW,CAAC,yBAAyB,CACtC,iBAAiB,EACjB,KAAK,EACL,UAAU,CACb,CAAA;YAED,MAAM,cAAc,GAAG,CAAC,IAAI,IAAI,EAAE,CAAA;YAClC,kBAAkB,CAAC,UAAU,CACzB,KAAK,EACL,UAAU,EACV,KAAK,EAAE,GAAQ,EAAE,EAAE;gBACf,oDAAoD;gBACpD,MAAM,qBAAqB,GACvB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,qBAAqB,CAAA;gBAC7C,MAAM,YAAY,GAAG,CAAC,IAAI,IAAI,EAAE,CAAA;gBAChC,MAAM,kBAAkB,GAAG,YAAY,GAAG,cAAc,CAAA;gBAExD,IAAI,CAAC,WAAW,CAAC,wBAAwB,CACrC,iBAAiB,EACjB,KAAK,EACL,UAAU,EACV,IAAI,EACJ,kBAAkB,EAClB,GAAG,EACH,SAAS,CACZ,CAAA;gBAED,IACI,qBAAqB;oBACrB,kBAAkB,GAAG,qBAAqB;oBAE1C,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,YAAY,CACtC,kBAAkB,EAClB,KAAK,EACL,UAAU,EACV,IAAI,CACP,CAAA;gBAEL,IAAI,iBAAiB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;oBACrC,MAAM,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;gBAEjD,MAAM,MAAM,GAAG,IAAI,yBAAW,EAAE,CAAA;gBAEhC,IAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,cAAc,CAAC,cAAc,CAAC,EAAE;oBACrC,MAAM,CAAC,QAAQ,GAAG,GAAG,CAAC,YAAY,CAAA;iBACrC;gBAED,IAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,cAAc,CAAC,MAAM,CAAC,EAAE;oBAC7B,IAAI,OAAO,GAAG,EAAE,CAAA;oBAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;qBACjC;oBAED,MAAM,CAAC,GAAG,GAAG,OAAO,CAAA;oBACpB,MAAM,CAAC,OAAO,GAAG,OAAO,CAAA;iBAC3B;gBAED,4DAA4D;gBAC5D,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,aAAa,EAAE;oBACvC,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAA;iBAC5B;gBAED,IAAI,mBAAmB,EAAE;oBACrB,EAAE,CAAC,MAAM,CAAC,CAAA;iBACb;qBAAM;oBACH,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;iBACjB;YACL,CAAC,EACD,KAAK,EAAE,GAAQ,EAAE,EAAE;gBACf,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CACvC,GAAG,EACH,KAAK,EACL,UAAU,EACV,IAAI,CACP,CAAA;gBACD,IAAI,CAAC,WAAW,CAAC,wBAAwB,CACrC,iBAAiB,EACjB,KAAK,EACL,UAAU,EACV,KAAK,EACL,SAAS,EACT,SAAS,EACT,GAAG,CACN,CAAA;gBACD,MAAM,iBAAiB,CAAC,IAAI,EAAE,CAAA;gBAE9B,IAAI,CAAC,IAAI,mCAAgB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,CAAC,CAAC,CAAA;YACtD,CAAC,CACJ,CAAA;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4EAA4E;IAC5E,oBAAoB;IACpB,4EAA4E;IAE5E;;OAEG;IACO,WAAW,CACjB,aAA4B,EAC5B,aAAqB,CAAC;QAEtB,OAAO,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,GAAG,GAAG,GAAG,IAAI,CAAC,CAAA;IAC5E,CAAC;CACJ;AAxJD,wDAwJC","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\"\nimport { BroadcasterResult } from \"../../subscriber/BroadcasterResult\"\n\n/**\n * Runs queries on a single sqlite database connection.\n */\nexport class ReactNativeQueryRunner extends AbstractSqliteQueryRunner {\n /**\n * Database driver used by connection.\n */\n // @ts-ignore temporary, we need to fix the issue with the AbstractSqliteDriver and circular errors\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(\n query: string,\n parameters?: any[],\n useStructuredResult = false,\n ): Promise<any> {\n if (this.isReleased) throw new QueryRunnerAlreadyReleasedError()\n\n return new Promise(async (ok, fail) => {\n const databaseConnection = await this.connect()\n const broadcasterResult = new BroadcasterResult()\n\n this.driver.connection.logger.logQuery(query, parameters, this)\n this.broadcaster.broadcastBeforeQueryEvent(\n broadcasterResult,\n query,\n parameters,\n )\n\n const queryStartTime = +new Date()\n databaseConnection.executeSql(\n query,\n parameters,\n async (raw: any) => {\n // log slow queries if maxQueryExecution time is set\n const maxQueryExecutionTime =\n this.driver.options.maxQueryExecutionTime\n const queryEndTime = +new Date()\n const queryExecutionTime = queryEndTime - queryStartTime\n\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n true,\n queryExecutionTime,\n raw,\n undefined,\n )\n\n if (\n maxQueryExecutionTime &&\n queryExecutionTime > maxQueryExecutionTime\n )\n this.driver.connection.logger.logQuerySlow(\n queryExecutionTime,\n query,\n parameters,\n this,\n )\n\n if (broadcasterResult.promises.length > 0)\n await Promise.all(broadcasterResult.promises)\n\n const result = new QueryResult()\n\n if (raw?.hasOwnProperty(\"rowsAffected\")) {\n result.affected = raw.rowsAffected\n }\n\n if (raw?.hasOwnProperty(\"rows\")) {\n let 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 // 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 (useStructuredResult) {\n ok(result)\n } else {\n ok(result.raw)\n }\n },\n async (err: any) => {\n this.driver.connection.logger.logQueryError(\n err,\n query,\n parameters,\n this,\n )\n this.broadcaster.broadcastAfterQueryEvent(\n broadcasterResult,\n query,\n parameters,\n false,\n undefined,\n undefined,\n err,\n )\n await broadcasterResult.wait()\n\n fail(new QueryFailedError(query, parameters, err))\n },\n )\n })\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Parametrizes given object of values. Used to create column=value queries.\n */\n protected parametrize(\n objectLiteral: ObjectLiteral,\n startIndex: number = 0,\n ): string[] {\n return Object.keys(objectLiteral).map((key, index) => `\"${key}\"` + \"=?\")\n }\n}\n"],"sourceRoot":"../.."}
@@ -21,6 +21,7 @@ const QueryLock_1 = require("../../query-runner/QueryLock");
21
21
  const MetadataTableType_1 = require("../types/MetadataTableType");
22
22
  const InstanceChecker_1 = require("../../util/InstanceChecker");
23
23
  const util_1 = require("util");
24
+ const BroadcasterResult_1 = require("../../subscriber/BroadcasterResult");
24
25
  /**
25
26
  * Runs queries on a single SQL Server database connection.
26
27
  */
@@ -136,9 +137,11 @@ class SapQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
136
137
  const release = await this.lock.acquire();
137
138
  let statement;
138
139
  const result = new QueryResult_1.QueryResult();
140
+ const broadcasterResult = new BroadcasterResult_1.BroadcasterResult();
139
141
  try {
140
142
  const databaseConnection = await this.connect();
141
143
  this.driver.connection.logger.logQuery(query, parameters, this);
144
+ this.broadcaster.broadcastBeforeQueryEvent(broadcasterResult, query, parameters);
142
145
  const queryStartTime = +new Date();
143
146
  const isInsertQuery = query.substr(0, 11) === "INSERT INTO";
144
147
  if (parameters === null || parameters === void 0 ? void 0 : parameters.some(Array.isArray)) {
@@ -157,6 +160,7 @@ class SapQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
157
160
  const maxQueryExecutionTime = this.driver.connection.options.maxQueryExecutionTime;
158
161
  const queryEndTime = +new Date();
159
162
  const queryExecutionTime = queryEndTime - queryStartTime;
163
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, true, queryExecutionTime, raw, undefined);
160
164
  if (maxQueryExecutionTime &&
161
165
  queryExecutionTime > maxQueryExecutionTime) {
162
166
  this.driver.connection.logger.logQuerySlow(queryExecutionTime, query, parameters, this);
@@ -180,15 +184,17 @@ class SapQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
180
184
  result.records = identityValueResult;
181
185
  }
182
186
  }
183
- catch (e) {
184
- this.driver.connection.logger.logQueryError(e, query, parameters, this);
185
- throw e;
187
+ catch (err) {
188
+ this.driver.connection.logger.logQueryError(err, query, parameters, this);
189
+ this.broadcaster.broadcastAfterQueryEvent(broadcasterResult, query, parameters, false, undefined, undefined, err);
190
+ throw err;
186
191
  }
187
192
  finally {
188
193
  // Never forget to drop the statement we reserved
189
194
  if (statement === null || statement === void 0 ? void 0 : statement.drop) {
190
195
  await new Promise((ok) => statement.drop(() => ok()));
191
196
  }
197
+ await broadcasterResult.wait();
192
198
  // Always release the lock.
193
199
  release();
194
200
  }
@@ -1980,7 +1986,7 @@ class SapQueryRunner extends BaseQueryRunner_1.BaseQueryRunner {
1980
1986
  */
1981
1987
  escapePath(target) {
1982
1988
  const { schema, tableName } = this.driver.parseTableName(target);
1983
- if (schema) {
1989
+ if (schema && schema !== this.driver.schema) {
1984
1990
  return `"${schema}"."${tableName}"`;
1985
1991
  }
1986
1992
  return `"${tableName}"`;