typeorm 0.3.12-dev.ef64bfc → 0.3.13-dev.099fcd9

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