typeorm 0.3.12-dev.ef64bfc → 0.3.13-dev.0619aca

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 (296) hide show
  1. package/browser/cli-ts-node-commonjs.js +0 -0
  2. package/browser/cli-ts-node-esm.js +0 -0
  3. package/browser/common/DeepPartial.d.ts +1 -1
  4. package/browser/common/EntityTarget.d.ts +1 -1
  5. package/browser/common/MixedList.d.ts +1 -1
  6. package/browser/common/NonNever.d.ts +1 -1
  7. package/browser/common/ObjectType.d.ts +1 -1
  8. package/browser/common/PickKeysByType.d.ts +6 -0
  9. package/browser/common/PickKeysByType.js +3 -0
  10. package/browser/common/PickKeysByType.js.map +1 -0
  11. package/browser/common/RelationType.d.ts +1 -1
  12. package/browser/connection/BaseConnectionOptions.d.ts +1 -1
  13. package/browser/connection/ConnectionOptions.d.ts +1 -1
  14. package/browser/container.d.ts +1 -1
  15. package/browser/data-source/DataSourceOptions.d.ts +1 -1
  16. package/browser/decorator/columns/PrimaryColumn.d.ts +1 -1
  17. package/browser/driver/Driver.d.ts +1 -1
  18. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +6 -0
  19. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  20. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +3 -1
  21. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  22. package/browser/driver/mongodb/MongoDriver.d.ts +1 -1
  23. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  24. package/browser/driver/mongodb/typings.d.ts +6 -6
  25. package/browser/driver/oracle/OracleDriver.d.ts +1 -1
  26. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  27. package/browser/driver/postgres/PostgresQueryRunner.js +1 -1
  28. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  29. package/browser/driver/react-native/ReactNativeDriver.d.ts +219 -6
  30. package/browser/driver/react-native/ReactNativeDriver.js +662 -10
  31. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  32. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  33. package/browser/driver/sap/SapDriver.d.ts +1 -1
  34. package/browser/driver/sap/SapDriver.js.map +1 -1
  35. package/browser/driver/spanner/SpannerDriver.d.ts +1 -1
  36. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  37. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +1 -1
  38. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +12 -0
  39. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  40. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +1 -1
  41. package/browser/driver/sqlserver/SqlServerDriver.d.ts +1 -1
  42. package/browser/driver/sqlserver/SqlServerDriver.js +7 -2
  43. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  44. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +2 -1
  45. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -9
  46. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  47. package/browser/driver/types/ColumnTypes.d.ts +7 -7
  48. package/browser/driver/types/DatabaseType.d.ts +1 -1
  49. package/browser/driver/types/GeoJsonTypes.d.ts +12 -12
  50. package/browser/driver/types/IsolationLevel.d.ts +1 -1
  51. package/browser/driver/types/ReplicationMode.d.ts +1 -1
  52. package/browser/driver/types/UpsertType.d.ts +1 -1
  53. package/browser/entity-manager/EntityManager.d.ts +18 -0
  54. package/browser/entity-manager/EntityManager.js +32 -0
  55. package/browser/entity-manager/EntityManager.js.map +1 -1
  56. package/browser/entity-manager/MongoEntityManager.js +4 -4
  57. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  58. package/browser/find-options/FindOperator.d.ts +1 -1
  59. package/browser/find-options/FindOperatorType.d.ts +1 -1
  60. package/browser/find-options/FindOperatorType.js.map +1 -1
  61. package/browser/find-options/FindOptionsOrder.d.ts +3 -3
  62. package/browser/find-options/FindOptionsOrder.js.map +1 -1
  63. package/browser/find-options/FindOptionsRelations.d.ts +3 -3
  64. package/browser/find-options/FindOptionsSelect.d.ts +3 -3
  65. package/browser/find-options/FindOptionsWhere.d.ts +6 -2
  66. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  67. package/browser/find-options/OrderByCondition.d.ts +1 -1
  68. package/browser/find-options/mongodb/MongoFindOneOptions.d.ts +1 -1
  69. package/browser/find-options/operator/JsonContains.d.ts +6 -0
  70. package/browser/find-options/operator/JsonContains.js +10 -0
  71. package/browser/find-options/operator/JsonContains.js.map +1 -0
  72. package/browser/index.d.ts +3 -0
  73. package/browser/index.js +3 -0
  74. package/browser/index.js.map +1 -1
  75. package/browser/logger/AbstractLogger.d.ts +49 -0
  76. package/browser/logger/AbstractLogger.js +230 -0
  77. package/browser/logger/AbstractLogger.js.map +1 -0
  78. package/browser/logger/AdvancedConsoleLogger.d.ts +5 -33
  79. package/browser/logger/AdvancedConsoleLogger.js +41 -106
  80. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  81. package/browser/logger/DebugLogger.d.ts +9 -29
  82. package/browser/logger/DebugLogger.js +56 -74
  83. package/browser/logger/DebugLogger.js.map +1 -1
  84. package/browser/logger/FileLogger.d.ts +6 -32
  85. package/browser/logger/FileLogger.js +50 -97
  86. package/browser/logger/FileLogger.js.map +1 -1
  87. package/browser/logger/Logger.d.ts +31 -0
  88. package/browser/logger/Logger.js.map +1 -1
  89. package/browser/logger/LoggerOptions.d.ts +3 -2
  90. package/browser/logger/LoggerOptions.js.map +1 -1
  91. package/browser/logger/SimpleConsoleLogger.d.ts +5 -33
  92. package/browser/logger/SimpleConsoleLogger.js +43 -106
  93. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  94. package/browser/metadata/types/DeferrableType.d.ts +1 -1
  95. package/browser/metadata/types/EventListenerTypes.d.ts +1 -1
  96. package/browser/metadata/types/OnDeleteType.d.ts +1 -1
  97. package/browser/metadata/types/OnUpdateType.d.ts +1 -1
  98. package/browser/metadata/types/PropertyTypeInFunction.d.ts +1 -1
  99. package/browser/metadata/types/RelationTypeInFunction.d.ts +1 -1
  100. package/browser/metadata/types/RelationTypes.d.ts +1 -1
  101. package/browser/metadata/types/TableTypes.d.ts +1 -1
  102. package/browser/metadata/types/TreeTypes.d.ts +1 -1
  103. package/browser/metadata-args/types/ColumnMode.d.ts +1 -1
  104. package/browser/metadata-builder/RelationJoinColumnBuilder.js +2 -1
  105. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  106. package/browser/migration/MigrationExecutor.js +1 -1
  107. package/browser/migration/MigrationExecutor.js.map +1 -1
  108. package/browser/naming-strategy/LegacyOracleNamingStrategy.d.ts +21 -0
  109. package/browser/naming-strategy/LegacyOracleNamingStrategy.js +46 -0
  110. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -0
  111. package/browser/persistence/SubjectExecutor.js +6 -6
  112. package/browser/persistence/SubjectExecutor.js.map +1 -1
  113. package/browser/persistence/SubjectTopoligicalSorter.js +2 -6
  114. package/browser/persistence/SubjectTopoligicalSorter.js.map +1 -1
  115. package/browser/platform/BrowserPlatformTools.js +2 -2
  116. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  117. package/browser/platform/PlatformTools.d.ts +3 -1
  118. package/browser/platform/PlatformTools.js +11 -2
  119. package/browser/platform/PlatformTools.js.map +1 -1
  120. package/browser/query-builder/InsertOrUpdateOptions.d.ts +1 -1
  121. package/browser/query-builder/QueryBuilder.js +2 -0
  122. package/browser/query-builder/QueryBuilder.js.map +1 -1
  123. package/browser/query-builder/QueryPartialEntity.d.ts +3 -3
  124. package/browser/query-builder/SelectQueryBuilder.d.ts +1 -1
  125. package/browser/query-builder/SelectQueryBuilder.js +8 -4
  126. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  127. package/browser/query-builder/SelectQueryBuilderOption.d.ts +1 -1
  128. package/browser/query-builder/WhereClause.d.ts +3 -3
  129. package/browser/query-builder/WhereClause.js.map +1 -1
  130. package/browser/query-runner/BaseQueryRunner.d.ts +2 -1
  131. package/browser/query-runner/BaseQueryRunner.js +5 -2
  132. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  133. package/browser/repository/BaseEntity.d.ts +25 -0
  134. package/browser/repository/BaseEntity.js +24 -0
  135. package/browser/repository/BaseEntity.js.map +1 -1
  136. package/browser/repository/EntityId.d.ts +1 -1
  137. package/browser/repository/Repository.d.ts +17 -0
  138. package/browser/repository/Repository.js +32 -8
  139. package/browser/repository/Repository.js.map +1 -1
  140. package/browser/subscriber/Broadcaster.d.ts +6 -6
  141. package/browser/subscriber/Broadcaster.js +12 -12
  142. package/browser/subscriber/Broadcaster.js.map +1 -1
  143. package/browser/util/DateUtils.d.ts +12 -0
  144. package/browser/util/DateUtils.js +20 -16
  145. package/browser/util/DateUtils.js.map +1 -1
  146. package/browser/util/VersionUtils.d.ts +1 -1
  147. package/cli-ts-node-commonjs.js +0 -0
  148. package/cli-ts-node-esm.js +0 -0
  149. package/cli.js +0 -0
  150. package/commands/CommandUtils.d.ts +1 -1
  151. package/commands/MigrationCreateCommand.d.ts +1 -1
  152. package/commands/MigrationGenerateCommand.d.ts +1 -1
  153. package/common/DeepPartial.d.ts +1 -1
  154. package/common/EntityTarget.d.ts +1 -1
  155. package/common/MixedList.d.ts +1 -1
  156. package/common/NonNever.d.ts +1 -1
  157. package/common/ObjectType.d.ts +1 -1
  158. package/common/PickKeysByType.d.ts +6 -0
  159. package/common/PickKeysByType.js +4 -0
  160. package/common/PickKeysByType.js.map +1 -0
  161. package/common/RelationType.d.ts +1 -1
  162. package/connection/BaseConnectionOptions.d.ts +1 -1
  163. package/connection/ConnectionOptions.d.ts +1 -1
  164. package/container.d.ts +1 -1
  165. package/data-source/DataSourceOptions.d.ts +1 -1
  166. package/decorator/columns/PrimaryColumn.d.ts +1 -1
  167. package/driver/Driver.d.ts +1 -1
  168. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +6 -0
  169. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  170. package/driver/better-sqlite3/BetterSqlite3Driver.js +3 -1
  171. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  172. package/driver/mongodb/MongoDriver.d.ts +1 -1
  173. package/driver/mongodb/MongoDriver.js.map +1 -1
  174. package/driver/mongodb/typings.d.ts +6 -6
  175. package/driver/oracle/OracleDriver.d.ts +1 -1
  176. package/driver/oracle/OracleDriver.js.map +1 -1
  177. package/driver/postgres/PostgresQueryRunner.js +1 -1
  178. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  179. package/driver/react-native/ReactNativeDriver.d.ts +219 -6
  180. package/driver/react-native/ReactNativeDriver.js +663 -11
  181. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  182. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  183. package/driver/sap/SapDriver.d.ts +1 -1
  184. package/driver/sap/SapDriver.js.map +1 -1
  185. package/driver/spanner/SpannerDriver.d.ts +1 -1
  186. package/driver/spanner/SpannerDriver.js.map +1 -1
  187. package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +1 -1
  188. package/driver/sqlite-abstract/AbstractSqliteDriver.js +12 -0
  189. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  190. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +1 -1
  191. package/driver/sqlserver/SqlServerDriver.d.ts +1 -1
  192. package/driver/sqlserver/SqlServerDriver.js +7 -2
  193. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  194. package/driver/sqlserver/SqlServerQueryRunner.d.ts +2 -1
  195. package/driver/sqlserver/SqlServerQueryRunner.js +31 -9
  196. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  197. package/driver/types/ColumnTypes.d.ts +7 -7
  198. package/driver/types/DatabaseType.d.ts +1 -1
  199. package/driver/types/GeoJsonTypes.d.ts +12 -12
  200. package/driver/types/IsolationLevel.d.ts +1 -1
  201. package/driver/types/ReplicationMode.d.ts +1 -1
  202. package/driver/types/UpsertType.d.ts +1 -1
  203. package/entity-manager/EntityManager.d.ts +18 -0
  204. package/entity-manager/EntityManager.js +32 -0
  205. package/entity-manager/EntityManager.js.map +1 -1
  206. package/entity-manager/MongoEntityManager.js +4 -4
  207. package/entity-manager/MongoEntityManager.js.map +1 -1
  208. package/find-options/FindOperator.d.ts +1 -1
  209. package/find-options/FindOperatorType.d.ts +1 -1
  210. package/find-options/FindOperatorType.js.map +1 -1
  211. package/find-options/FindOptionsOrder.d.ts +3 -3
  212. package/find-options/FindOptionsOrder.js.map +1 -1
  213. package/find-options/FindOptionsRelations.d.ts +3 -3
  214. package/find-options/FindOptionsSelect.d.ts +3 -3
  215. package/find-options/FindOptionsWhere.d.ts +6 -2
  216. package/find-options/FindOptionsWhere.js.map +1 -1
  217. package/find-options/OrderByCondition.d.ts +1 -1
  218. package/find-options/mongodb/MongoFindOneOptions.d.ts +1 -1
  219. package/find-options/operator/JsonContains.d.ts +6 -0
  220. package/find-options/operator/JsonContains.js +14 -0
  221. package/find-options/operator/JsonContains.js.map +1 -0
  222. package/index.d.ts +3 -0
  223. package/index.js +5 -1
  224. package/index.js.map +1 -1
  225. package/index.mjs +6 -0
  226. package/logger/AbstractLogger.d.ts +49 -0
  227. package/logger/AbstractLogger.js +234 -0
  228. package/logger/AbstractLogger.js.map +1 -0
  229. package/logger/AdvancedConsoleLogger.d.ts +5 -33
  230. package/logger/AdvancedConsoleLogger.js +41 -106
  231. package/logger/AdvancedConsoleLogger.js.map +1 -1
  232. package/logger/DebugLogger.d.ts +9 -29
  233. package/logger/DebugLogger.js +56 -75
  234. package/logger/DebugLogger.js.map +1 -1
  235. package/logger/FileLogger.d.ts +6 -32
  236. package/logger/FileLogger.js +50 -97
  237. package/logger/FileLogger.js.map +1 -1
  238. package/logger/Logger.d.ts +31 -0
  239. package/logger/Logger.js.map +1 -1
  240. package/logger/LoggerOptions.d.ts +3 -2
  241. package/logger/LoggerOptions.js.map +1 -1
  242. package/logger/SimpleConsoleLogger.d.ts +5 -33
  243. package/logger/SimpleConsoleLogger.js +43 -106
  244. package/logger/SimpleConsoleLogger.js.map +1 -1
  245. package/metadata/types/DeferrableType.d.ts +1 -1
  246. package/metadata/types/EventListenerTypes.d.ts +1 -1
  247. package/metadata/types/OnDeleteType.d.ts +1 -1
  248. package/metadata/types/OnUpdateType.d.ts +1 -1
  249. package/metadata/types/PropertyTypeInFunction.d.ts +1 -1
  250. package/metadata/types/RelationTypeInFunction.d.ts +1 -1
  251. package/metadata/types/RelationTypes.d.ts +1 -1
  252. package/metadata/types/TableTypes.d.ts +1 -1
  253. package/metadata/types/TreeTypes.d.ts +1 -1
  254. package/metadata-args/types/ColumnMode.d.ts +1 -1
  255. package/metadata-builder/RelationJoinColumnBuilder.js +2 -1
  256. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  257. package/migration/MigrationExecutor.js +1 -1
  258. package/migration/MigrationExecutor.js.map +1 -1
  259. package/naming-strategy/LegacyOracleNamingStrategy.d.ts +21 -0
  260. package/naming-strategy/LegacyOracleNamingStrategy.js +50 -0
  261. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -0
  262. package/package.json +1 -1
  263. package/persistence/SubjectExecutor.js +6 -6
  264. package/persistence/SubjectExecutor.js.map +1 -1
  265. package/persistence/SubjectTopoligicalSorter.js +2 -6
  266. package/persistence/SubjectTopoligicalSorter.js.map +1 -1
  267. package/platform/PlatformTools.d.ts +3 -1
  268. package/platform/PlatformTools.js +11 -2
  269. package/platform/PlatformTools.js.map +1 -1
  270. package/query-builder/InsertOrUpdateOptions.d.ts +1 -1
  271. package/query-builder/QueryBuilder.js +2 -0
  272. package/query-builder/QueryBuilder.js.map +1 -1
  273. package/query-builder/QueryPartialEntity.d.ts +3 -3
  274. package/query-builder/SelectQueryBuilder.d.ts +1 -1
  275. package/query-builder/SelectQueryBuilder.js +8 -4
  276. package/query-builder/SelectQueryBuilder.js.map +1 -1
  277. package/query-builder/SelectQueryBuilderOption.d.ts +1 -1
  278. package/query-builder/WhereClause.d.ts +3 -3
  279. package/query-builder/WhereClause.js.map +1 -1
  280. package/query-runner/BaseQueryRunner.d.ts +2 -1
  281. package/query-runner/BaseQueryRunner.js +5 -2
  282. package/query-runner/BaseQueryRunner.js.map +1 -1
  283. package/repository/BaseEntity.d.ts +25 -0
  284. package/repository/BaseEntity.js +24 -0
  285. package/repository/BaseEntity.js.map +1 -1
  286. package/repository/EntityId.d.ts +1 -1
  287. package/repository/Repository.d.ts +17 -0
  288. package/repository/Repository.js +32 -8
  289. package/repository/Repository.js.map +1 -1
  290. package/subscriber/Broadcaster.d.ts +6 -6
  291. package/subscriber/Broadcaster.js +12 -12
  292. package/subscriber/Broadcaster.js.map +1 -1
  293. package/util/DateUtils.d.ts +12 -0
  294. package/util/DateUtils.js +20 -16
  295. package/util/DateUtils.js.map +1 -1
  296. package/util/VersionUtils.d.ts +1 -1
@@ -1,22 +1,193 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ReactNativeDriver = void 0;
4
- const AbstractSqliteDriver_1 = require("../sqlite-abstract/AbstractSqliteDriver");
4
+ const DateUtils_1 = require("../../util/DateUtils");
5
+ const RdbmsSchemaBuilder_1 = require("../../schema-builder/RdbmsSchemaBuilder");
6
+ const OrmUtils_1 = require("../../util/OrmUtils");
7
+ const ApplyValueTransformers_1 = require("../../util/ApplyValueTransformers");
8
+ const error_1 = require("../../error");
9
+ const InstanceChecker_1 = require("../../util/InstanceChecker");
5
10
  const ReactNativeQueryRunner_1 = require("./ReactNativeQueryRunner");
6
- const DriverPackageNotInstalledError_1 = require("../../error/DriverPackageNotInstalledError");
7
- class ReactNativeDriver extends AbstractSqliteDriver_1.AbstractSqliteDriver {
11
+ /**
12
+ * Organizes communication with sqlite DBMS.
13
+ */
14
+ class ReactNativeDriver {
8
15
  // -------------------------------------------------------------------------
9
16
  // Constructor
10
17
  // -------------------------------------------------------------------------
11
18
  constructor(connection) {
12
- super(connection);
19
+ /**
20
+ * Indicates if replication is enabled.
21
+ */
22
+ this.isReplicated = false;
23
+ /**
24
+ * Indicates if tree tables are supported by this driver.
25
+ */
26
+ this.treeSupport = true;
27
+ /**
28
+ * Represent transaction support by this driver
29
+ */
30
+ this.transactionSupport = "nested";
31
+ /**
32
+ * Gets list of supported column data types by a driver.
33
+ *
34
+ * @see https://www.tutorialspoint.com/sqlite/sqlite_data_types.htm
35
+ * @see https://sqlite.org/datatype3.html
36
+ */
37
+ this.supportedDataTypes = [
38
+ "int",
39
+ "integer",
40
+ "tinyint",
41
+ "smallint",
42
+ "mediumint",
43
+ "bigint",
44
+ "unsigned big int",
45
+ "int2",
46
+ "int8",
47
+ "integer",
48
+ "character",
49
+ "varchar",
50
+ "varying character",
51
+ "nchar",
52
+ "native character",
53
+ "nvarchar",
54
+ "text",
55
+ "clob",
56
+ "text",
57
+ "blob",
58
+ "real",
59
+ "double",
60
+ "double precision",
61
+ "float",
62
+ "real",
63
+ "numeric",
64
+ "decimal",
65
+ "boolean",
66
+ "date",
67
+ "time",
68
+ "datetime",
69
+ ];
70
+ /**
71
+ * Returns type of upsert supported by driver if any
72
+ */
73
+ this.supportedUpsertTypes = ["on-conflict-do-update"];
74
+ /**
75
+ * Gets list of column data types that support length by a driver.
76
+ */
77
+ this.withLengthColumnTypes = [
78
+ "character",
79
+ "varchar",
80
+ "varying character",
81
+ "nchar",
82
+ "native character",
83
+ "nvarchar",
84
+ "text",
85
+ "blob",
86
+ "clob",
87
+ ];
88
+ /**
89
+ * Gets list of spatial column data types.
90
+ */
91
+ this.spatialTypes = [];
92
+ /**
93
+ * Gets list of column data types that support precision by a driver.
94
+ */
95
+ this.withPrecisionColumnTypes = [
96
+ "real",
97
+ "double",
98
+ "double precision",
99
+ "float",
100
+ "real",
101
+ "numeric",
102
+ "decimal",
103
+ "date",
104
+ "time",
105
+ "datetime",
106
+ ];
107
+ /**
108
+ * Gets list of column data types that support scale by a driver.
109
+ */
110
+ this.withScaleColumnTypes = [
111
+ "real",
112
+ "double",
113
+ "double precision",
114
+ "float",
115
+ "real",
116
+ "numeric",
117
+ "decimal",
118
+ ];
119
+ /**
120
+ * Orm has special columns and we need to know what database column types should be for those types.
121
+ * Column types are driver dependant.
122
+ */
123
+ this.mappedDataTypes = {
124
+ createDate: "datetime",
125
+ createDateDefault: "datetime('now')",
126
+ updateDate: "datetime",
127
+ updateDateDefault: "datetime('now')",
128
+ deleteDate: "datetime",
129
+ deleteDateNullable: true,
130
+ version: "integer",
131
+ treeLevel: "integer",
132
+ migrationId: "integer",
133
+ migrationName: "varchar",
134
+ migrationTimestamp: "bigint",
135
+ cacheId: "int",
136
+ cacheIdentifier: "varchar",
137
+ cacheTime: "bigint",
138
+ cacheDuration: "int",
139
+ cacheQuery: "text",
140
+ cacheResult: "text",
141
+ metadataType: "varchar",
142
+ metadataDatabase: "varchar",
143
+ metadataSchema: "varchar",
144
+ metadataTable: "varchar",
145
+ metadataName: "varchar",
146
+ metadataValue: "text",
147
+ };
148
+ this.cteCapabilities = {
149
+ enabled: true,
150
+ requiresRecursiveHint: true,
151
+ };
152
+ // -------------------------------------------------------------------------
153
+ // Protected Properties
154
+ // -------------------------------------------------------------------------
155
+ /**
156
+ * Any attached databases (excepting default 'main')
157
+ */
158
+ this.attachedDatabases = {};
159
+ this.connection = connection;
160
+ this.options = connection.options;
161
+ // this.database = DriverUtils.buildDriverOptions(this.options).database
13
162
  this.database = this.options.database;
14
- // load sqlite package
15
163
  this.loadDependencies();
16
164
  }
17
165
  // -------------------------------------------------------------------------
166
+ // Public Abstract
167
+ // -------------------------------------------------------------------------
168
+ /**
169
+ * Creates a query runner used to execute database queries.
170
+ */
171
+ createQueryRunner(mode) {
172
+ if (!this.queryRunner)
173
+ this.queryRunner = new ReactNativeQueryRunner_1.ReactNativeQueryRunner(this);
174
+ return this.queryRunner;
175
+ }
176
+ // -------------------------------------------------------------------------
18
177
  // Public Methods
19
178
  // -------------------------------------------------------------------------
179
+ /**
180
+ * Performs connection to the database.
181
+ */
182
+ async connect() {
183
+ this.databaseConnection = await this.createDatabaseConnection();
184
+ }
185
+ /**
186
+ * Makes any action after connection (e.g. create extensions in Postgres driver).
187
+ */
188
+ afterConnect() {
189
+ return Promise.resolve();
190
+ }
20
191
  /**
21
192
  * Closes connection with database.
22
193
  */
@@ -26,13 +197,494 @@ class ReactNativeDriver extends AbstractSqliteDriver_1.AbstractSqliteDriver {
26
197
  this.databaseConnection.close(ok, fail);
27
198
  });
28
199
  }
200
+ hasAttachedDatabases() {
201
+ return !!Object.keys(this.attachedDatabases).length;
202
+ }
203
+ getAttachedDatabaseHandleByRelativePath(path) {
204
+ var _a, _b;
205
+ return (_b = (_a = this.attachedDatabases) === null || _a === void 0 ? void 0 : _a[path]) === null || _b === void 0 ? void 0 : _b.attachHandle;
206
+ }
207
+ getAttachedDatabasePathRelativeByHandle(handle) {
208
+ var _a;
209
+ return (_a = Object.values(this.attachedDatabases).find(({ attachHandle }) => handle === attachHandle)) === null || _a === void 0 ? void 0 : _a.attachFilepathRelative;
210
+ }
29
211
  /**
30
- * Creates a query runner used to execute database queries.
212
+ * Creates a schema builder used to build and sync a schema.
31
213
  */
32
- createQueryRunner(mode) {
33
- if (!this.queryRunner)
34
- this.queryRunner = new ReactNativeQueryRunner_1.ReactNativeQueryRunner(this);
35
- return this.queryRunner;
214
+ createSchemaBuilder() {
215
+ return new RdbmsSchemaBuilder_1.RdbmsSchemaBuilder(this.connection);
216
+ }
217
+ /**
218
+ * Prepares given value to a value to be persisted, based on its column type and metadata.
219
+ */
220
+ preparePersistentValue(value, columnMetadata) {
221
+ if (columnMetadata.transformer)
222
+ value = ApplyValueTransformers_1.ApplyValueTransformers.transformTo(columnMetadata.transformer, value);
223
+ if (value === null || value === undefined)
224
+ return value;
225
+ if (columnMetadata.type === Boolean ||
226
+ columnMetadata.type === "boolean") {
227
+ return value === true ? 1 : 0;
228
+ }
229
+ else if (columnMetadata.type === "date") {
230
+ return DateUtils_1.DateUtils.mixedDateToDateString(value);
231
+ }
232
+ else if (columnMetadata.type === "time") {
233
+ return DateUtils_1.DateUtils.mixedDateToTimeString(value);
234
+ }
235
+ else if (columnMetadata.type === "datetime" ||
236
+ columnMetadata.type === Date) {
237
+ // to string conversation needs because SQLite stores date as integer number, when date came as Object
238
+ // TODO: think about `toUTC` conversion
239
+ return DateUtils_1.DateUtils.mixedDateToUtcDatetimeString(value);
240
+ }
241
+ else if (columnMetadata.type === "simple-array") {
242
+ return DateUtils_1.DateUtils.simpleArrayToString(value);
243
+ }
244
+ else if (columnMetadata.type === "simple-json") {
245
+ return DateUtils_1.DateUtils.simpleJsonToString(value);
246
+ }
247
+ else if (columnMetadata.type === "simple-enum") {
248
+ return DateUtils_1.DateUtils.simpleEnumToString(value);
249
+ }
250
+ return value;
251
+ }
252
+ /**
253
+ * Prepares given value to a value to be hydrated, based on its column type or metadata.
254
+ */
255
+ prepareHydratedValue(value, columnMetadata) {
256
+ if (value === null || value === undefined)
257
+ return columnMetadata.transformer
258
+ ? ApplyValueTransformers_1.ApplyValueTransformers.transformFrom(columnMetadata.transformer, value)
259
+ : value;
260
+ if (columnMetadata.type === Boolean ||
261
+ columnMetadata.type === "boolean") {
262
+ value = value ? true : false;
263
+ }
264
+ else if (columnMetadata.type === "datetime" ||
265
+ columnMetadata.type === Date) {
266
+ /**
267
+ * Fix date conversion issue
268
+ *
269
+ * If the format of the date string is "2018-03-14 02:33:33.906", Safari (and iOS WKWebView) will convert it to an invalid date object.
270
+ * We need to modify the date string to "2018-03-14T02:33:33.906Z" and Safari will convert it correctly.
271
+ *
272
+ * ISO 8601
273
+ * https://www.w3.org/TR/NOTE-datetime
274
+ */
275
+ if (value && typeof value === "string") {
276
+ // There are various valid time string formats a sqlite time string might have:
277
+ // https://www.sqlite.org/lang_datefunc.html
278
+ // There are two separate fixes we may need to do:
279
+ // 1) Add 'T' separator if space is used instead
280
+ // 2) Add 'Z' UTC suffix if no timezone or offset specified
281
+ if (/^\d\d\d\d-\d\d-\d\d \d\d:\d\d/.test(value)) {
282
+ value = value.replace(" ", "T");
283
+ }
284
+ if (/^\d\d\d\d-\d\d-\d\dT\d\d:\d\d(:\d\d(\.\d\d\d)?)?$/.test(value)) {
285
+ value += "Z";
286
+ }
287
+ }
288
+ value = DateUtils_1.DateUtils.normalizeHydratedDate(value);
289
+ }
290
+ else if (columnMetadata.type === "date") {
291
+ value = DateUtils_1.DateUtils.mixedDateToDateString(value);
292
+ }
293
+ else if (columnMetadata.type === "time") {
294
+ value = DateUtils_1.DateUtils.mixedTimeToString(value);
295
+ }
296
+ else if (columnMetadata.type === "simple-array") {
297
+ value = DateUtils_1.DateUtils.stringToSimpleArray(value);
298
+ }
299
+ else if (columnMetadata.type === "simple-json") {
300
+ value = DateUtils_1.DateUtils.stringToSimpleJson(value);
301
+ }
302
+ else if (columnMetadata.type === "simple-enum") {
303
+ value = DateUtils_1.DateUtils.stringToSimpleEnum(value, columnMetadata);
304
+ }
305
+ else if (columnMetadata.type === Number) {
306
+ // convert to number if number
307
+ value = !isNaN(+value) ? parseInt(value) : value;
308
+ }
309
+ if (columnMetadata.transformer)
310
+ value = ApplyValueTransformers_1.ApplyValueTransformers.transformFrom(columnMetadata.transformer, value);
311
+ return value;
312
+ }
313
+ /**
314
+ * Replaces parameters in the given sql with special escaping character
315
+ * and an array of parameter names to be passed to a query.
316
+ */
317
+ escapeQueryWithParameters(sql, parameters, nativeParameters) {
318
+ const escapedParameters = Object.keys(nativeParameters).map((key) => {
319
+ // Mapping boolean values to their numeric representation
320
+ if (typeof nativeParameters[key] === "boolean") {
321
+ return nativeParameters[key] === true ? 1 : 0;
322
+ }
323
+ if (nativeParameters[key] instanceof Date) {
324
+ return DateUtils_1.DateUtils.mixedDateToUtcDatetimeString(nativeParameters[key]);
325
+ }
326
+ return nativeParameters[key];
327
+ });
328
+ if (!parameters || !Object.keys(parameters).length)
329
+ return [sql, escapedParameters];
330
+ sql = sql.replace(/:(\.\.\.)?([A-Za-z0-9_.]+)/g, (full, isArray, key) => {
331
+ if (!parameters.hasOwnProperty(key)) {
332
+ return full;
333
+ }
334
+ let value = parameters[key];
335
+ if (isArray) {
336
+ return value
337
+ .map((v) => {
338
+ escapedParameters.push(v);
339
+ return this.createParameter(key, escapedParameters.length - 1);
340
+ })
341
+ .join(", ");
342
+ }
343
+ if (typeof value === "function") {
344
+ return value();
345
+ }
346
+ else if (typeof value === "number") {
347
+ return String(value);
348
+ }
349
+ // Sqlite does not have a boolean data type so we have to transform
350
+ // it to 1 or 0
351
+ if (typeof value === "boolean") {
352
+ escapedParameters.push(+value);
353
+ return this.createParameter(key, escapedParameters.length - 1);
354
+ }
355
+ if (value instanceof Date) {
356
+ escapedParameters.push(DateUtils_1.DateUtils.mixedDateToUtcDatetimeString(value));
357
+ return this.createParameter(key, escapedParameters.length - 1);
358
+ }
359
+ escapedParameters.push(value);
360
+ return this.createParameter(key, escapedParameters.length - 1);
361
+ }); // todo: make replace only in value statements, otherwise problems
362
+ return [sql, escapedParameters];
363
+ }
364
+ /**
365
+ * Escapes a column name.
366
+ */
367
+ escape(columnName) {
368
+ return '"' + columnName + '"';
369
+ }
370
+ /**
371
+ * Build full table name with database name, schema name and table name.
372
+ * E.g. myDB.mySchema.myTable
373
+ *
374
+ * Returns only simple table name because all inherited drivers does not supports schema and database.
375
+ */
376
+ buildTableName(tableName, schema, database) {
377
+ return tableName;
378
+ }
379
+ /**
380
+ * Parse a target table name or other types and return a normalized table definition.
381
+ */
382
+ parseTableName(target) {
383
+ var _a;
384
+ const driverDatabase = this.database;
385
+ const driverSchema = undefined;
386
+ if (InstanceChecker_1.InstanceChecker.isTable(target) || InstanceChecker_1.InstanceChecker.isView(target)) {
387
+ const parsed = this.parseTableName(target.schema
388
+ ? `"${target.schema}"."${target.name}"`
389
+ : target.name);
390
+ return {
391
+ database: target.database || parsed.database || driverDatabase,
392
+ schema: target.schema || parsed.schema || driverSchema,
393
+ tableName: parsed.tableName,
394
+ };
395
+ }
396
+ if (InstanceChecker_1.InstanceChecker.isTableForeignKey(target)) {
397
+ const parsed = this.parseTableName(target.referencedTableName);
398
+ return {
399
+ database: target.referencedDatabase ||
400
+ parsed.database ||
401
+ driverDatabase,
402
+ schema: target.referencedSchema || parsed.schema || driverSchema,
403
+ tableName: parsed.tableName,
404
+ };
405
+ }
406
+ if (InstanceChecker_1.InstanceChecker.isEntityMetadata(target)) {
407
+ // EntityMetadata tableName is never a path
408
+ return {
409
+ database: target.database || driverDatabase,
410
+ schema: target.schema || driverSchema,
411
+ tableName: target.tableName,
412
+ };
413
+ }
414
+ const parts = target.split(".");
415
+ if (parts.length === 3) {
416
+ return {
417
+ database: parts[0] || driverDatabase,
418
+ schema: parts[1] || driverSchema,
419
+ tableName: parts[2],
420
+ };
421
+ }
422
+ else if (parts.length === 2) {
423
+ const database = (_a = this.getAttachedDatabasePathRelativeByHandle(parts[0])) !== null && _a !== void 0 ? _a : driverDatabase;
424
+ return {
425
+ database: database,
426
+ schema: parts[0],
427
+ tableName: parts[1],
428
+ };
429
+ }
430
+ else {
431
+ return {
432
+ database: driverDatabase,
433
+ schema: driverSchema,
434
+ tableName: target,
435
+ };
436
+ }
437
+ }
438
+ /**
439
+ * Creates a database type from a given column metadata.
440
+ */
441
+ normalizeType(column) {
442
+ if (column.type === Number || column.type === "int") {
443
+ return "integer";
444
+ }
445
+ else if (column.type === String) {
446
+ return "varchar";
447
+ }
448
+ else if (column.type === Date) {
449
+ return "datetime";
450
+ }
451
+ else if (column.type === Boolean) {
452
+ return "boolean";
453
+ }
454
+ else if (column.type === "uuid") {
455
+ return "varchar";
456
+ }
457
+ else if (column.type === "simple-array") {
458
+ return "text";
459
+ }
460
+ else if (column.type === "simple-json") {
461
+ return "text";
462
+ }
463
+ else if (column.type === "simple-enum") {
464
+ return "varchar";
465
+ }
466
+ else {
467
+ return column.type || "";
468
+ }
469
+ }
470
+ /**
471
+ * Normalizes "default" value of the column.
472
+ */
473
+ normalizeDefault(columnMetadata) {
474
+ const defaultValue = columnMetadata.default;
475
+ if (typeof defaultValue === "number") {
476
+ return "" + defaultValue;
477
+ }
478
+ if (typeof defaultValue === "boolean") {
479
+ return defaultValue ? "1" : "0";
480
+ }
481
+ if (typeof defaultValue === "function") {
482
+ return defaultValue();
483
+ }
484
+ if (typeof defaultValue === "string") {
485
+ return `'${defaultValue}'`;
486
+ }
487
+ if (defaultValue === null || defaultValue === undefined) {
488
+ return undefined;
489
+ }
490
+ return `${defaultValue}`;
491
+ }
492
+ /**
493
+ * Normalizes "isUnique" value of the column.
494
+ */
495
+ normalizeIsUnique(column) {
496
+ return column.entityMetadata.uniques.some((uq) => uq.columns.length === 1 && uq.columns[0] === column);
497
+ }
498
+ /**
499
+ * Calculates column length taking into account the default length values.
500
+ */
501
+ getColumnLength(column) {
502
+ return column.length ? column.length.toString() : "";
503
+ }
504
+ /**
505
+ * Normalizes "default" value of the column.
506
+ */
507
+ createFullType(column) {
508
+ let type = column.type;
509
+ if (column.enum) {
510
+ return "varchar";
511
+ }
512
+ if (column.length) {
513
+ type += "(" + column.length + ")";
514
+ }
515
+ else if (column.precision !== null &&
516
+ column.precision !== undefined &&
517
+ column.scale !== null &&
518
+ column.scale !== undefined) {
519
+ type += "(" + column.precision + "," + column.scale + ")";
520
+ }
521
+ else if (column.precision !== null &&
522
+ column.precision !== undefined) {
523
+ type += "(" + column.precision + ")";
524
+ }
525
+ if (column.isArray)
526
+ type += " array";
527
+ return type;
528
+ }
529
+ /**
530
+ * Obtains a new database connection to a master server.
531
+ * Used for replication.
532
+ * If replication is not setup then returns default connection's database connection.
533
+ */
534
+ obtainMasterConnection() {
535
+ return Promise.resolve();
536
+ }
537
+ /**
538
+ * Obtains a new database connection to a slave server.
539
+ * Used for replication.
540
+ * If replication is not setup then returns master (default) connection's database connection.
541
+ */
542
+ obtainSlaveConnection() {
543
+ return Promise.resolve();
544
+ }
545
+ /**
546
+ * Creates generated map of values generated or returned by database after INSERT query.
547
+ */
548
+ createGeneratedMap(metadata, insertResult, entityIndex, entityNum) {
549
+ const generatedMap = metadata.generatedColumns.reduce((map, generatedColumn) => {
550
+ let value;
551
+ if (generatedColumn.generationStrategy === "increment" &&
552
+ insertResult) {
553
+ // NOTE: When INSERT statement is successfully completed, the last inserted row ID is returned.
554
+ // see also: SqliteQueryRunner.query()
555
+ value = insertResult - entityNum + entityIndex + 1;
556
+ // } else if (generatedColumn.generationStrategy === "uuid") {
557
+ // value = insertValue[generatedColumn.databaseName];
558
+ }
559
+ if (!value)
560
+ return map;
561
+ return OrmUtils_1.OrmUtils.mergeDeep(map, generatedColumn.createValueMap(value));
562
+ }, {});
563
+ return Object.keys(generatedMap).length > 0 ? generatedMap : undefined;
564
+ }
565
+ /**
566
+ * Differentiate columns of this table and columns from the given column metadatas columns
567
+ * and returns only changed.
568
+ */
569
+ findChangedColumns(tableColumns, columnMetadatas) {
570
+ return columnMetadatas.filter((columnMetadata) => {
571
+ const tableColumn = tableColumns.find((c) => c.name === columnMetadata.databaseName);
572
+ if (!tableColumn)
573
+ return false; // we don't need new columns, we only need exist and changed
574
+ const isColumnChanged = tableColumn.name !== columnMetadata.databaseName ||
575
+ tableColumn.type !== this.normalizeType(columnMetadata) ||
576
+ tableColumn.length !== columnMetadata.length ||
577
+ tableColumn.precision !== columnMetadata.precision ||
578
+ tableColumn.scale !== columnMetadata.scale ||
579
+ this.normalizeDefault(columnMetadata) !== tableColumn.default ||
580
+ tableColumn.isPrimary !== columnMetadata.isPrimary ||
581
+ tableColumn.isNullable !== columnMetadata.isNullable ||
582
+ tableColumn.generatedType !== columnMetadata.generatedType ||
583
+ tableColumn.asExpression !== columnMetadata.asExpression ||
584
+ tableColumn.isUnique !==
585
+ this.normalizeIsUnique(columnMetadata) ||
586
+ (tableColumn.enum &&
587
+ columnMetadata.enum &&
588
+ !OrmUtils_1.OrmUtils.isArraysEqual(tableColumn.enum, columnMetadata.enum.map((val) => val + ""))) ||
589
+ (columnMetadata.generationStrategy !== "uuid" &&
590
+ tableColumn.isGenerated !== columnMetadata.isGenerated);
591
+ // DEBUG SECTION
592
+ // if (isColumnChanged) {
593
+ // console.log("table:", columnMetadata.entityMetadata.tableName)
594
+ // console.log(
595
+ // "name:",
596
+ // tableColumn.name,
597
+ // columnMetadata.databaseName,
598
+ // )
599
+ // console.log(
600
+ // "type:",
601
+ // tableColumn.type,
602
+ // this.normalizeType(columnMetadata),
603
+ // )
604
+ // console.log(
605
+ // "length:",
606
+ // tableColumn.length,
607
+ // columnMetadata.length,
608
+ // )
609
+ // console.log(
610
+ // "precision:",
611
+ // tableColumn.precision,
612
+ // columnMetadata.precision,
613
+ // )
614
+ // console.log("scale:", tableColumn.scale, columnMetadata.scale)
615
+ // console.log(
616
+ // "default:",
617
+ // this.normalizeDefault(columnMetadata),
618
+ // columnMetadata.default,
619
+ // )
620
+ // console.log(
621
+ // "isPrimary:",
622
+ // tableColumn.isPrimary,
623
+ // columnMetadata.isPrimary,
624
+ // )
625
+ // console.log(
626
+ // "isNullable:",
627
+ // tableColumn.isNullable,
628
+ // columnMetadata.isNullable,
629
+ // )
630
+ // console.log(
631
+ // "generatedType:",
632
+ // tableColumn.generatedType,
633
+ // columnMetadata.generatedType,
634
+ // )
635
+ // console.log(
636
+ // "asExpression:",
637
+ // tableColumn.asExpression,
638
+ // columnMetadata.asExpression,
639
+ // )
640
+ // console.log(
641
+ // "isUnique:",
642
+ // tableColumn.isUnique,
643
+ // this.normalizeIsUnique(columnMetadata),
644
+ // )
645
+ // console.log(
646
+ // "enum:",
647
+ // tableColumn.enum &&
648
+ // columnMetadata.enum &&
649
+ // !OrmUtils.isArraysEqual(
650
+ // tableColumn.enum,
651
+ // columnMetadata.enum.map((val) => val + ""),
652
+ // ),
653
+ // )
654
+ // console.log(
655
+ // "isGenerated:",
656
+ // tableColumn.isGenerated,
657
+ // columnMetadata.isGenerated,
658
+ // )
659
+ // }
660
+ return isColumnChanged;
661
+ });
662
+ }
663
+ /**
664
+ * Returns true if driver supports RETURNING / OUTPUT statement.
665
+ */
666
+ isReturningSqlSupported() {
667
+ return false;
668
+ }
669
+ /**
670
+ * Returns true if driver supports uuid values generation on its own.
671
+ */
672
+ isUUIDGenerationSupported() {
673
+ return false;
674
+ }
675
+ /**
676
+ * Returns true if driver supports fulltext indices.
677
+ */
678
+ isFullTextColumnTypeSupported() {
679
+ return false;
680
+ }
681
+ /**
682
+ * Creates an escaped parameter.
683
+ */
684
+ createParameter(parameterName, index) {
685
+ // return "$" + (index + 1);
686
+ return "?";
687
+ // return "$" + parameterName;
36
688
  }
37
689
  // -------------------------------------------------------------------------
38
690
  // Protected Methods
@@ -69,7 +721,7 @@ class ReactNativeDriver extends AbstractSqliteDriver_1.AbstractSqliteDriver {
69
721
  this.sqlite = sqlite;
70
722
  }
71
723
  catch (e) {
72
- throw new DriverPackageNotInstalledError_1.DriverPackageNotInstalledError("React-Native", "react-native-sqlite-storage");
724
+ throw new error_1.DriverPackageNotInstalledError("React-Native", "react-native-sqlite-storage");
73
725
  }
74
726
  }
75
727
  }