typeorm 0.3.21 → 0.3.22-dev.40cc688

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 (1024) hide show
  1. package/README.md +1315 -1315
  2. package/browser/cache/DbQueryResultCache.js.map +1 -1
  3. package/browser/cache/QueryResultCache.js.map +1 -1
  4. package/browser/cache/QueryResultCacheFactory.js.map +1 -1
  5. package/browser/cache/QueryResultCacheOptions.js.map +1 -1
  6. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  7. package/browser/cli-ts-node-commonjs.js.map +1 -1
  8. package/browser/cli-ts-node-esm.js.map +1 -1
  9. package/browser/common/DeepPartial.js.map +1 -1
  10. package/browser/common/EntityTarget.js.map +1 -1
  11. package/browser/common/MixedList.js.map +1 -1
  12. package/browser/common/NonNever.js.map +1 -1
  13. package/browser/common/ObjectLiteral.js.map +1 -1
  14. package/browser/common/ObjectType.js.map +1 -1
  15. package/browser/common/PickKeysByType.js.map +1 -1
  16. package/browser/common/RelationType.js.map +1 -1
  17. package/browser/connection/BaseConnectionOptions.js.map +1 -1
  18. package/browser/connection/Connection.js.map +1 -1
  19. package/browser/connection/ConnectionManager.js.map +1 -1
  20. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  21. package/browser/connection/ConnectionOptions.js.map +1 -1
  22. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  23. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  24. package/browser/container.js.map +1 -1
  25. package/browser/data-source/BaseDataSourceOptions.js.map +1 -1
  26. package/browser/data-source/DataSource.js.map +1 -1
  27. package/browser/data-source/DataSourceOptions.js.map +1 -1
  28. package/browser/data-source/index.js.map +1 -1
  29. package/browser/decorator/Check.js.map +1 -1
  30. package/browser/decorator/EntityRepository.js.map +1 -1
  31. package/browser/decorator/Exclusion.js.map +1 -1
  32. package/browser/decorator/Generated.js.map +1 -1
  33. package/browser/decorator/Index.js.map +1 -1
  34. package/browser/decorator/Unique.js.map +1 -1
  35. package/browser/decorator/columns/Column.js.map +1 -1
  36. package/browser/decorator/columns/CreateDateColumn.js.map +1 -1
  37. package/browser/decorator/columns/DeleteDateColumn.js.map +1 -1
  38. package/browser/decorator/columns/ObjectIdColumn.js.map +1 -1
  39. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  40. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  41. package/browser/decorator/columns/UpdateDateColumn.js.map +1 -1
  42. package/browser/decorator/columns/VersionColumn.js.map +1 -1
  43. package/browser/decorator/columns/ViewColumn.js.map +1 -1
  44. package/browser/decorator/columns/VirtualColumn.js.map +1 -1
  45. package/browser/decorator/entity/ChildEntity.js.map +1 -1
  46. package/browser/decorator/entity/Entity.js.map +1 -1
  47. package/browser/decorator/entity/TableInheritance.js.map +1 -1
  48. package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
  49. package/browser/decorator/listeners/AfterInsert.js.map +1 -1
  50. package/browser/decorator/listeners/AfterLoad.js.map +1 -1
  51. package/browser/decorator/listeners/AfterRecover.js.map +1 -1
  52. package/browser/decorator/listeners/AfterRemove.js.map +1 -1
  53. package/browser/decorator/listeners/AfterSoftRemove.js.map +1 -1
  54. package/browser/decorator/listeners/AfterUpdate.js.map +1 -1
  55. package/browser/decorator/listeners/BeforeInsert.js.map +1 -1
  56. package/browser/decorator/listeners/BeforeRecover.js.map +1 -1
  57. package/browser/decorator/listeners/BeforeRemove.js.map +1 -1
  58. package/browser/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  59. package/browser/decorator/listeners/BeforeUpdate.js.map +1 -1
  60. package/browser/decorator/listeners/EventSubscriber.js.map +1 -1
  61. package/browser/decorator/options/ColumnCommonOptions.js.map +1 -1
  62. package/browser/decorator/options/ColumnEmbeddedOptions.js.map +1 -1
  63. package/browser/decorator/options/ColumnEnumOptions.js.map +1 -1
  64. package/browser/decorator/options/ColumnHstoreOptions.js.map +1 -1
  65. package/browser/decorator/options/ColumnNumericOptions.js.map +1 -1
  66. package/browser/decorator/options/ColumnOptions.js.map +1 -1
  67. package/browser/decorator/options/ColumnWithLengthOptions.js.map +1 -1
  68. package/browser/decorator/options/ColumnWithWidthOptions.js.map +1 -1
  69. package/browser/decorator/options/EntityOptions.js.map +1 -1
  70. package/browser/decorator/options/IndexOptions.js.map +1 -1
  71. package/browser/decorator/options/JoinColumnOptions.js.map +1 -1
  72. package/browser/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  73. package/browser/decorator/options/JoinTableOptions.js.map +1 -1
  74. package/browser/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  75. package/browser/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  76. package/browser/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  77. package/browser/decorator/options/RelationOptions.js.map +1 -1
  78. package/browser/decorator/options/SpatialColumnOptions.js.map +1 -1
  79. package/browser/decorator/options/TransactionOptions.js.map +1 -1
  80. package/browser/decorator/options/UniqueOptions.js.map +1 -1
  81. package/browser/decorator/options/ValueTransformer.js.map +1 -1
  82. package/browser/decorator/options/ViewColumnOptions.js.map +1 -1
  83. package/browser/decorator/options/ViewEntityOptions.js.map +1 -1
  84. package/browser/decorator/options/VirtualColumnOptions.js.map +1 -1
  85. package/browser/decorator/relations/JoinColumn.js.map +1 -1
  86. package/browser/decorator/relations/JoinTable.js.map +1 -1
  87. package/browser/decorator/relations/ManyToMany.js.map +1 -1
  88. package/browser/decorator/relations/ManyToOne.js.map +1 -1
  89. package/browser/decorator/relations/OneToMany.js.map +1 -1
  90. package/browser/decorator/relations/OneToOne.js.map +1 -1
  91. package/browser/decorator/relations/RelationCount.js.map +1 -1
  92. package/browser/decorator/relations/RelationId.js.map +1 -1
  93. package/browser/decorator/tree/Tree.js.map +1 -1
  94. package/browser/decorator/tree/TreeChildren.js.map +1 -1
  95. package/browser/decorator/tree/TreeLevelColumn.js.map +1 -1
  96. package/browser/decorator/tree/TreeParent.js.map +1 -1
  97. package/browser/driver/Driver.js.map +1 -1
  98. package/browser/driver/DriverFactory.js.map +1 -1
  99. package/browser/driver/DriverUtils.js.map +1 -1
  100. package/browser/driver/Query.js.map +1 -1
  101. package/browser/driver/SqlInMemory.js.map +1 -1
  102. package/browser/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  103. package/browser/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  104. package/browser/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  105. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  106. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +6 -9
  107. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  108. package/browser/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  109. package/browser/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  110. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js +6 -9
  111. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  112. package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  113. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  114. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  115. package/browser/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  116. package/browser/driver/capacitor/CapacitorDriver.js.map +1 -1
  117. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  118. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  119. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  120. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  121. package/browser/driver/cockroachdb/CockroachQueryRunner.js +7 -11
  122. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  123. package/browser/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  124. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  125. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  126. package/browser/driver/expo/ExpoConnectionOptions.js.map +1 -1
  127. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  128. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  129. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  130. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  131. package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
  132. package/browser/driver/mongodb/bson.typings.js.map +1 -1
  133. package/browser/driver/mongodb/typings.js.map +1 -1
  134. package/browser/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  135. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  136. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  137. package/browser/driver/mysql/MysqlQueryRunner.js +77 -80
  138. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  139. package/browser/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  140. package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
  141. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  142. package/browser/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  143. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  144. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  145. package/browser/driver/oracle/OracleQueryRunner.js +4 -6
  146. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  147. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  148. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  149. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  150. package/browser/driver/postgres/PostgresQueryRunner.js +6 -9
  151. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  152. package/browser/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  153. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  154. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  155. package/browser/driver/sap/SapConnectionCredentialsOptions.js.map +1 -1
  156. package/browser/driver/sap/SapConnectionOptions.js.map +1 -1
  157. package/browser/driver/sap/SapDriver.js.map +1 -1
  158. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  159. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  160. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  161. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  162. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  163. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  164. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  165. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  166. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  167. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  168. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  169. package/browser/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  170. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  171. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  172. package/browser/driver/sqlserver/MssqlParameter.js.map +1 -1
  173. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  174. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  175. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  176. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  177. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  178. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  179. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  180. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  181. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  182. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  183. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  184. package/browser/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  185. package/browser/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  186. package/browser/driver/types/ColumnTypes.js.map +1 -1
  187. package/browser/driver/types/CteCapabilities.js.map +1 -1
  188. package/browser/driver/types/DataTypeDefaults.js.map +1 -1
  189. package/browser/driver/types/DatabaseType.js.map +1 -1
  190. package/browser/driver/types/GeoJsonTypes.js.map +1 -1
  191. package/browser/driver/types/IsolationLevel.js.map +1 -1
  192. package/browser/driver/types/MappedColumnTypes.js.map +1 -1
  193. package/browser/driver/types/MetadataTableType.js.map +1 -1
  194. package/browser/driver/types/ReplicationMode.js.map +1 -1
  195. package/browser/driver/types/UpsertType.js.map +1 -1
  196. package/browser/entity-manager/EntityManager.js.map +1 -1
  197. package/browser/entity-manager/EntityManagerFactory.js.map +1 -1
  198. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  199. package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
  200. package/browser/entity-schema/EntitySchema.js.map +1 -1
  201. package/browser/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  202. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  203. package/browser/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  204. package/browser/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  205. package/browser/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  206. package/browser/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  207. package/browser/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  208. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  209. package/browser/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  210. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  211. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  212. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  213. package/browser/error/AlreadyHasActiveConnectionError.js.map +1 -1
  214. package/browser/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  215. package/browser/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  216. package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
  217. package/browser/error/CannotDetermineEntityError.js.map +1 -1
  218. package/browser/error/CannotExecuteNotConnectedError.js.map +1 -1
  219. package/browser/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  220. package/browser/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  221. package/browser/error/CircularRelationsError.js.map +1 -1
  222. package/browser/error/ColumnTypeUndefinedError.js.map +1 -1
  223. package/browser/error/ConnectionIsNotSetError.js.map +1 -1
  224. package/browser/error/ConnectionNotFoundError.js.map +1 -1
  225. package/browser/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  226. package/browser/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  227. package/browser/error/CustomRepositoryNotFoundError.js.map +1 -1
  228. package/browser/error/DataTypeNotSupportedError.js.map +1 -1
  229. package/browser/error/DriverOptionNotSetError.js.map +1 -1
  230. package/browser/error/DriverPackageNotInstalledError.js.map +1 -1
  231. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  232. package/browser/error/EntityNotFoundError.js.map +1 -1
  233. package/browser/error/EntityPropertyNotFoundError.js.map +1 -1
  234. package/browser/error/FindRelationsNotFoundError.js.map +1 -1
  235. package/browser/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  236. package/browser/error/InitializedRelationError.js.map +1 -1
  237. package/browser/error/InsertValuesMissingError.js.map +1 -1
  238. package/browser/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  239. package/browser/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  240. package/browser/error/MetadataAlreadyExistsError.js.map +1 -1
  241. package/browser/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  242. package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
  243. package/browser/error/MissingDriverError.js.map +1 -1
  244. package/browser/error/MissingJoinColumnError.js.map +1 -1
  245. package/browser/error/MissingJoinTableError.js.map +1 -1
  246. package/browser/error/MissingPrimaryColumnError.js.map +1 -1
  247. package/browser/error/MustBeEntityError.js.map +1 -1
  248. package/browser/error/NamingStrategyNotFoundError.js.map +1 -1
  249. package/browser/error/NestedSetMultipleRootError.js.map +1 -1
  250. package/browser/error/NoConnectionForRepositoryError.js.map +1 -1
  251. package/browser/error/NoConnectionOptionError.js.map +1 -1
  252. package/browser/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  253. package/browser/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  254. package/browser/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  255. package/browser/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  256. package/browser/error/OptimisticLockVersionMismatchError.js.map +1 -1
  257. package/browser/error/PersistedEntityNotFoundError.js.map +1 -1
  258. package/browser/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  259. package/browser/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  260. package/browser/error/QueryFailedError.js.map +1 -1
  261. package/browser/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  262. package/browser/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  263. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  264. package/browser/error/ReturningStatementNotSupportedError.js.map +1 -1
  265. package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  266. package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
  267. package/browser/error/TransactionAlreadyStartedError.js.map +1 -1
  268. package/browser/error/TransactionNotStartedError.js.map +1 -1
  269. package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
  270. package/browser/error/TypeORMError.js.map +1 -1
  271. package/browser/error/UpdateValuesMissingError.js.map +1 -1
  272. package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  273. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  274. package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  275. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  276. package/browser/error/index.js.map +1 -1
  277. package/browser/find-options/EqualOperator.js.map +1 -1
  278. package/browser/find-options/FindManyOptions.js.map +1 -1
  279. package/browser/find-options/FindOneOptions.js.map +1 -1
  280. package/browser/find-options/FindOperator.js.map +1 -1
  281. package/browser/find-options/FindOperatorType.js.map +1 -1
  282. package/browser/find-options/FindOptionsOrder.js.map +1 -1
  283. package/browser/find-options/FindOptionsRelations.js.map +1 -1
  284. package/browser/find-options/FindOptionsSelect.js.map +1 -1
  285. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  286. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  287. package/browser/find-options/FindTreeOptions.js.map +1 -1
  288. package/browser/find-options/JoinOptions.js.map +1 -1
  289. package/browser/find-options/OrderByCondition.js.map +1 -1
  290. package/browser/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  291. package/browser/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  292. package/browser/find-options/operator/And.js.map +1 -1
  293. package/browser/find-options/operator/Any.js.map +1 -1
  294. package/browser/find-options/operator/ArrayContainedBy.js.map +1 -1
  295. package/browser/find-options/operator/ArrayContains.js.map +1 -1
  296. package/browser/find-options/operator/ArrayOverlap.js.map +1 -1
  297. package/browser/find-options/operator/Between.js.map +1 -1
  298. package/browser/find-options/operator/Equal.js.map +1 -1
  299. package/browser/find-options/operator/ILike.js.map +1 -1
  300. package/browser/find-options/operator/In.js.map +1 -1
  301. package/browser/find-options/operator/IsNull.js.map +1 -1
  302. package/browser/find-options/operator/JsonContains.js.map +1 -1
  303. package/browser/find-options/operator/LessThan.js.map +1 -1
  304. package/browser/find-options/operator/LessThanOrEqual.js.map +1 -1
  305. package/browser/find-options/operator/Like.js.map +1 -1
  306. package/browser/find-options/operator/MoreThan.js.map +1 -1
  307. package/browser/find-options/operator/MoreThanOrEqual.js.map +1 -1
  308. package/browser/find-options/operator/Not.js.map +1 -1
  309. package/browser/find-options/operator/Or.js.map +1 -1
  310. package/browser/find-options/operator/Raw.js.map +1 -1
  311. package/browser/globals.js.map +1 -1
  312. package/browser/index.js.map +1 -1
  313. package/browser/logger/AbstractLogger.js.map +1 -1
  314. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  315. package/browser/logger/DebugLogger.js.map +1 -1
  316. package/browser/logger/FileLogger.js.map +1 -1
  317. package/browser/logger/Logger.js.map +1 -1
  318. package/browser/logger/LoggerFactory.js.map +1 -1
  319. package/browser/logger/LoggerOptions.js.map +1 -1
  320. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  321. package/browser/metadata/CheckMetadata.js.map +1 -1
  322. package/browser/metadata/ColumnMetadata.js.map +1 -1
  323. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  324. package/browser/metadata/EntityListenerMetadata.js.map +1 -1
  325. package/browser/metadata/EntityMetadata.js.map +1 -1
  326. package/browser/metadata/ExclusionMetadata.js.map +1 -1
  327. package/browser/metadata/ForeignKeyMetadata.js.map +1 -1
  328. package/browser/metadata/IndexMetadata.js.map +1 -1
  329. package/browser/metadata/RelationCountMetadata.js.map +1 -1
  330. package/browser/metadata/RelationIdMetadata.js.map +1 -1
  331. package/browser/metadata/RelationMetadata.js.map +1 -1
  332. package/browser/metadata/UniqueMetadata.js.map +1 -1
  333. package/browser/metadata/types/ClosureTreeOptions.js.map +1 -1
  334. package/browser/metadata/types/DeferrableType.js.map +1 -1
  335. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  336. package/browser/metadata/types/OnDeleteType.js.map +1 -1
  337. package/browser/metadata/types/OnUpdateType.js.map +1 -1
  338. package/browser/metadata/types/PropertyTypeInFunction.js.map +1 -1
  339. package/browser/metadata/types/RelationTypeInFunction.js.map +1 -1
  340. package/browser/metadata/types/RelationTypes.js.map +1 -1
  341. package/browser/metadata/types/TableTypes.js.map +1 -1
  342. package/browser/metadata/types/TreeTypes.js.map +1 -1
  343. package/browser/metadata-args/CheckMetadataArgs.js.map +1 -1
  344. package/browser/metadata-args/ColumnMetadataArgs.js.map +1 -1
  345. package/browser/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  346. package/browser/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  347. package/browser/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  348. package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  349. package/browser/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  350. package/browser/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  351. package/browser/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  352. package/browser/metadata-args/IndexMetadataArgs.js.map +1 -1
  353. package/browser/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  354. package/browser/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  355. package/browser/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  356. package/browser/metadata-args/MetadataArgsStorage.js.map +1 -1
  357. package/browser/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  358. package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  359. package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  360. package/browser/metadata-args/RelationMetadataArgs.js.map +1 -1
  361. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  362. package/browser/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  363. package/browser/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  364. package/browser/metadata-args/TreeMetadataArgs.js.map +1 -1
  365. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  366. package/browser/metadata-args/types/ColumnMode.js.map +1 -1
  367. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  368. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  369. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  370. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  371. package/browser/metadata-builder/MetadataUtils.js.map +1 -1
  372. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  373. package/browser/migration/Migration.js.map +1 -1
  374. package/browser/migration/MigrationExecutor.js.map +1 -1
  375. package/browser/migration/MigrationInterface.js.map +1 -1
  376. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  377. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  378. package/browser/naming-strategy/NamingStrategyInterface.js.map +1 -1
  379. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  380. package/browser/persistence/Subject.js.map +1 -1
  381. package/browser/persistence/SubjectChangeMap.js.map +1 -1
  382. package/browser/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  383. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  384. package/browser/persistence/SubjectExecutor.js.map +1 -1
  385. package/browser/persistence/SubjectTopologicalSorter.js.map +1 -1
  386. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  387. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  388. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  389. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  390. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  391. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  392. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  393. package/browser/platform/BrowserConnectionOptionsReaderDummy.js.map +1 -1
  394. package/browser/platform/BrowserDirectoryExportedClassesLoader.js.map +1 -1
  395. package/browser/platform/BrowserDisabledDriversDummy.js.map +1 -1
  396. package/browser/platform/BrowserFileLoggerDummy.js.map +1 -1
  397. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  398. package/browser/platform/PlatformTools.js.map +1 -1
  399. package/browser/query-builder/Alias.js.map +1 -1
  400. package/browser/query-builder/Brackets.js.map +1 -1
  401. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  402. package/browser/query-builder/InsertOrUpdateOptions.js.map +1 -1
  403. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  404. package/browser/query-builder/JoinAttribute.js.map +1 -1
  405. package/browser/query-builder/JoinOptions.js.map +1 -1
  406. package/browser/query-builder/NotBrackets.js.map +1 -1
  407. package/browser/query-builder/QueryBuilder.js.map +1 -1
  408. package/browser/query-builder/QueryBuilderCte.js.map +1 -1
  409. package/browser/query-builder/QueryBuilderUtils.js.map +1 -1
  410. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  411. package/browser/query-builder/QueryPartialEntity.js.map +1 -1
  412. package/browser/query-builder/RelationIdLoader.js +3 -2
  413. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  414. package/browser/query-builder/RelationLoader.js.map +1 -1
  415. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  416. package/browser/query-builder/RelationRemover.js.map +1 -1
  417. package/browser/query-builder/RelationUpdater.js.map +1 -1
  418. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  419. package/browser/query-builder/SelectQuery.js.map +1 -1
  420. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  421. package/browser/query-builder/SelectQueryBuilderOption.js.map +1 -1
  422. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  423. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  424. package/browser/query-builder/WhereClause.js.map +1 -1
  425. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  426. package/browser/query-builder/index.js.map +1 -1
  427. package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  428. package/browser/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  429. package/browser/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  430. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  431. package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  432. package/browser/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  433. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  434. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  435. package/browser/query-builder/result/DeleteResult.js.map +1 -1
  436. package/browser/query-builder/result/InsertResult.js.map +1 -1
  437. package/browser/query-builder/result/UpdateResult.js.map +1 -1
  438. package/browser/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  439. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  440. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  441. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  442. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  443. package/browser/query-runner/QueryLock.js.map +1 -1
  444. package/browser/query-runner/QueryResult.js.map +1 -1
  445. package/browser/query-runner/QueryRunner.js.map +1 -1
  446. package/browser/repository/AbstractRepository.js.map +1 -1
  447. package/browser/repository/BaseEntity.js.map +1 -1
  448. package/browser/repository/EntityId.js.map +1 -1
  449. package/browser/repository/FindTreesOptions.js.map +1 -1
  450. package/browser/repository/MongoRepository.js.map +1 -1
  451. package/browser/repository/RemoveOptions.js.map +1 -1
  452. package/browser/repository/Repository.js.map +1 -1
  453. package/browser/repository/SaveOptions.js.map +1 -1
  454. package/browser/repository/TreeRepository.js.map +1 -1
  455. package/browser/repository/UpsertOptions.js.map +1 -1
  456. package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
  457. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  458. package/browser/schema-builder/SchemaBuilder.js.map +1 -1
  459. package/browser/schema-builder/options/TableCheckOptions.js.map +1 -1
  460. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  461. package/browser/schema-builder/options/TableExclusionOptions.js.map +1 -1
  462. package/browser/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  463. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  464. package/browser/schema-builder/options/TableOptions.js.map +1 -1
  465. package/browser/schema-builder/options/TableUniqueOptions.js.map +1 -1
  466. package/browser/schema-builder/options/ViewOptions.js.map +1 -1
  467. package/browser/schema-builder/table/Table.js.map +1 -1
  468. package/browser/schema-builder/table/TableCheck.js.map +1 -1
  469. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  470. package/browser/schema-builder/table/TableExclusion.js.map +1 -1
  471. package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
  472. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  473. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  474. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  475. package/browser/schema-builder/util/ViewUtils.js.map +1 -1
  476. package/browser/schema-builder/view/View.js.map +1 -1
  477. package/browser/subscriber/Broadcaster.js.map +1 -1
  478. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  479. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  480. package/browser/subscriber/event/InsertEvent.js.map +1 -1
  481. package/browser/subscriber/event/LoadEvent.js.map +1 -1
  482. package/browser/subscriber/event/QueryEvent.js.map +1 -1
  483. package/browser/subscriber/event/RecoverEvent.js.map +1 -1
  484. package/browser/subscriber/event/RemoveEvent.js.map +1 -1
  485. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -1
  486. package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -1
  487. package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  488. package/browser/subscriber/event/TransactionStartEvent.js.map +1 -1
  489. package/browser/subscriber/event/UpdateEvent.js.map +1 -1
  490. package/browser/util/ApplyValueTransformers.js.map +1 -1
  491. package/browser/util/DateUtils.js.map +1 -1
  492. package/browser/util/DepGraph.js.map +1 -1
  493. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  494. package/browser/util/ImportUtils.js.map +1 -1
  495. package/browser/util/InstanceChecker.js.map +1 -1
  496. package/browser/util/ObjectUtils.js.map +1 -1
  497. package/browser/util/OrmUtils.js.map +1 -1
  498. package/browser/util/PathUtils.js.map +1 -1
  499. package/browser/util/RandomGenerator.js.map +1 -1
  500. package/browser/util/StringUtils.js.map +1 -1
  501. package/browser/util/TreeRepositoryUtils.js.map +1 -1
  502. package/browser/util/VersionUtils.js.map +1 -1
  503. package/browser/util/escapeRegExp.js.map +1 -1
  504. package/cache/DbQueryResultCache.js.map +1 -1
  505. package/cache/QueryResultCache.js.map +1 -1
  506. package/cache/QueryResultCacheFactory.js.map +1 -1
  507. package/cache/QueryResultCacheOptions.js.map +1 -1
  508. package/cache/RedisQueryResultCache.js.map +1 -1
  509. package/cli-ts-node-commonjs.js.map +1 -1
  510. package/cli-ts-node-esm.js.map +1 -1
  511. package/cli.js.map +1 -1
  512. package/commands/CacheClearCommand.js.map +1 -1
  513. package/commands/CommandUtils.js.map +1 -1
  514. package/commands/EntityCreateCommand.js +6 -6
  515. package/commands/EntityCreateCommand.js.map +1 -1
  516. package/commands/InitCommand.js +294 -302
  517. package/commands/InitCommand.js.map +1 -1
  518. package/commands/MigrationCreateCommand.js +22 -22
  519. package/commands/MigrationCreateCommand.js.map +1 -1
  520. package/commands/MigrationGenerateCommand.js +31 -31
  521. package/commands/MigrationGenerateCommand.js.map +1 -1
  522. package/commands/MigrationRevertCommand.js.map +1 -1
  523. package/commands/MigrationRunCommand.js.map +1 -1
  524. package/commands/MigrationShowCommand.js.map +1 -1
  525. package/commands/QueryCommand.js.map +1 -1
  526. package/commands/SchemaDropCommand.js.map +1 -1
  527. package/commands/SchemaLogCommand.js.map +1 -1
  528. package/commands/SchemaSyncCommand.js.map +1 -1
  529. package/commands/SubscriberCreateCommand.js +6 -6
  530. package/commands/SubscriberCreateCommand.js.map +1 -1
  531. package/commands/VersionCommand.js.map +1 -1
  532. package/common/DeepPartial.js.map +1 -1
  533. package/common/EntityTarget.js.map +1 -1
  534. package/common/MixedList.js.map +1 -1
  535. package/common/NonNever.js.map +1 -1
  536. package/common/ObjectLiteral.js.map +1 -1
  537. package/common/ObjectType.js.map +1 -1
  538. package/common/PickKeysByType.js.map +1 -1
  539. package/common/RelationType.js.map +1 -1
  540. package/connection/BaseConnectionOptions.js.map +1 -1
  541. package/connection/Connection.js.map +1 -1
  542. package/connection/ConnectionManager.js.map +1 -1
  543. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  544. package/connection/ConnectionOptions.js.map +1 -1
  545. package/connection/ConnectionOptionsReader.js.map +1 -1
  546. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  547. package/container.js.map +1 -1
  548. package/data-source/BaseDataSourceOptions.js.map +1 -1
  549. package/data-source/DataSource.js.map +1 -1
  550. package/data-source/DataSourceOptions.js.map +1 -1
  551. package/data-source/index.js.map +1 -1
  552. package/decorator/Check.js.map +1 -1
  553. package/decorator/EntityRepository.js.map +1 -1
  554. package/decorator/Exclusion.js.map +1 -1
  555. package/decorator/Generated.js.map +1 -1
  556. package/decorator/Index.js.map +1 -1
  557. package/decorator/Unique.js.map +1 -1
  558. package/decorator/columns/Column.js.map +1 -1
  559. package/decorator/columns/CreateDateColumn.js.map +1 -1
  560. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  561. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  562. package/decorator/columns/PrimaryColumn.js.map +1 -1
  563. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  564. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  565. package/decorator/columns/VersionColumn.js.map +1 -1
  566. package/decorator/columns/ViewColumn.js.map +1 -1
  567. package/decorator/columns/VirtualColumn.js.map +1 -1
  568. package/decorator/entity/ChildEntity.js.map +1 -1
  569. package/decorator/entity/Entity.js.map +1 -1
  570. package/decorator/entity/TableInheritance.js.map +1 -1
  571. package/decorator/entity-view/ViewEntity.js.map +1 -1
  572. package/decorator/listeners/AfterInsert.js.map +1 -1
  573. package/decorator/listeners/AfterLoad.js.map +1 -1
  574. package/decorator/listeners/AfterRecover.js.map +1 -1
  575. package/decorator/listeners/AfterRemove.js.map +1 -1
  576. package/decorator/listeners/AfterSoftRemove.js.map +1 -1
  577. package/decorator/listeners/AfterUpdate.js.map +1 -1
  578. package/decorator/listeners/BeforeInsert.js.map +1 -1
  579. package/decorator/listeners/BeforeRecover.js.map +1 -1
  580. package/decorator/listeners/BeforeRemove.js.map +1 -1
  581. package/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  582. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  583. package/decorator/listeners/EventSubscriber.js.map +1 -1
  584. package/decorator/options/ColumnCommonOptions.js.map +1 -1
  585. package/decorator/options/ColumnEmbeddedOptions.js.map +1 -1
  586. package/decorator/options/ColumnEnumOptions.js.map +1 -1
  587. package/decorator/options/ColumnHstoreOptions.js.map +1 -1
  588. package/decorator/options/ColumnNumericOptions.js.map +1 -1
  589. package/decorator/options/ColumnOptions.js.map +1 -1
  590. package/decorator/options/ColumnWithLengthOptions.js.map +1 -1
  591. package/decorator/options/ColumnWithWidthOptions.js.map +1 -1
  592. package/decorator/options/EntityOptions.js.map +1 -1
  593. package/decorator/options/IndexOptions.js.map +1 -1
  594. package/decorator/options/JoinColumnOptions.js.map +1 -1
  595. package/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  596. package/decorator/options/JoinTableOptions.js.map +1 -1
  597. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  598. package/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  599. package/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  600. package/decorator/options/RelationOptions.js.map +1 -1
  601. package/decorator/options/SpatialColumnOptions.js.map +1 -1
  602. package/decorator/options/TransactionOptions.js.map +1 -1
  603. package/decorator/options/UniqueOptions.js.map +1 -1
  604. package/decorator/options/ValueTransformer.js.map +1 -1
  605. package/decorator/options/ViewColumnOptions.js.map +1 -1
  606. package/decorator/options/ViewEntityOptions.js.map +1 -1
  607. package/decorator/options/VirtualColumnOptions.js.map +1 -1
  608. package/decorator/relations/JoinColumn.js.map +1 -1
  609. package/decorator/relations/JoinTable.js.map +1 -1
  610. package/decorator/relations/ManyToMany.js.map +1 -1
  611. package/decorator/relations/ManyToOne.js.map +1 -1
  612. package/decorator/relations/OneToMany.js.map +1 -1
  613. package/decorator/relations/OneToOne.js.map +1 -1
  614. package/decorator/relations/RelationCount.js.map +1 -1
  615. package/decorator/relations/RelationId.js.map +1 -1
  616. package/decorator/tree/Tree.js.map +1 -1
  617. package/decorator/tree/TreeChildren.js.map +1 -1
  618. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  619. package/decorator/tree/TreeParent.js.map +1 -1
  620. package/driver/Driver.js.map +1 -1
  621. package/driver/DriverFactory.js.map +1 -1
  622. package/driver/DriverUtils.js.map +1 -1
  623. package/driver/Query.js.map +1 -1
  624. package/driver/SqlInMemory.js.map +1 -1
  625. package/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  626. package/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  627. package/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  628. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  629. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +6 -9
  630. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  631. package/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  632. package/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  633. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js +6 -9
  634. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  635. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  636. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  637. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  638. package/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  639. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  640. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  641. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  642. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  643. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  644. package/driver/cockroachdb/CockroachQueryRunner.js +7 -11
  645. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  646. package/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  647. package/driver/cordova/CordovaDriver.js.map +1 -1
  648. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  649. package/driver/expo/ExpoConnectionOptions.js.map +1 -1
  650. package/driver/expo/ExpoDriver.js.map +1 -1
  651. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  652. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  653. package/driver/mongodb/MongoDriver.js.map +1 -1
  654. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  655. package/driver/mongodb/bson.typings.js.map +1 -1
  656. package/driver/mongodb/typings.js.map +1 -1
  657. package/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  658. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  659. package/driver/mysql/MysqlDriver.js.map +1 -1
  660. package/driver/mysql/MysqlQueryRunner.js +77 -80
  661. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  662. package/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  663. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  664. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  665. package/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  666. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  667. package/driver/oracle/OracleDriver.js.map +1 -1
  668. package/driver/oracle/OracleQueryRunner.js +4 -6
  669. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  670. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  671. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  672. package/driver/postgres/PostgresDriver.js.map +1 -1
  673. package/driver/postgres/PostgresQueryRunner.js +6 -9
  674. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  675. package/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  676. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  677. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  678. package/driver/sap/SapConnectionCredentialsOptions.js.map +1 -1
  679. package/driver/sap/SapConnectionOptions.js.map +1 -1
  680. package/driver/sap/SapDriver.js.map +1 -1
  681. package/driver/sap/SapQueryRunner.js.map +1 -1
  682. package/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  683. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  684. package/driver/spanner/SpannerDriver.js.map +1 -1
  685. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  686. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  687. package/driver/sqlite/SqliteDriver.js.map +1 -1
  688. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  689. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  690. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  691. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  692. package/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  693. package/driver/sqljs/SqljsDriver.js.map +1 -1
  694. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  695. package/driver/sqlserver/MssqlParameter.js.map +1 -1
  696. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  697. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  698. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  699. package/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  700. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  701. package/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  702. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  703. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  704. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  705. package/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  706. package/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  707. package/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  708. package/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  709. package/driver/types/ColumnTypes.js.map +1 -1
  710. package/driver/types/CteCapabilities.js.map +1 -1
  711. package/driver/types/DataTypeDefaults.js.map +1 -1
  712. package/driver/types/DatabaseType.js.map +1 -1
  713. package/driver/types/GeoJsonTypes.js.map +1 -1
  714. package/driver/types/IsolationLevel.js.map +1 -1
  715. package/driver/types/MappedColumnTypes.js.map +1 -1
  716. package/driver/types/MetadataTableType.js.map +1 -1
  717. package/driver/types/ReplicationMode.js.map +1 -1
  718. package/driver/types/UpsertType.js.map +1 -1
  719. package/entity-manager/EntityManager.js.map +1 -1
  720. package/entity-manager/EntityManagerFactory.js.map +1 -1
  721. package/entity-manager/MongoEntityManager.js.map +1 -1
  722. package/entity-manager/SqljsEntityManager.js.map +1 -1
  723. package/entity-schema/EntitySchema.js.map +1 -1
  724. package/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  725. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  726. package/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  727. package/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  728. package/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  729. package/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  730. package/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  731. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  732. package/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  733. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  734. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  735. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  736. package/error/AlreadyHasActiveConnectionError.js.map +1 -1
  737. package/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  738. package/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  739. package/error/CannotCreateEntityIdMapError.js.map +1 -1
  740. package/error/CannotDetermineEntityError.js.map +1 -1
  741. package/error/CannotExecuteNotConnectedError.js.map +1 -1
  742. package/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  743. package/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  744. package/error/CircularRelationsError.js.map +1 -1
  745. package/error/ColumnTypeUndefinedError.js.map +1 -1
  746. package/error/ConnectionIsNotSetError.js.map +1 -1
  747. package/error/ConnectionNotFoundError.js.map +1 -1
  748. package/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  749. package/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  750. package/error/CustomRepositoryNotFoundError.js.map +1 -1
  751. package/error/DataTypeNotSupportedError.js.map +1 -1
  752. package/error/DriverOptionNotSetError.js.map +1 -1
  753. package/error/DriverPackageNotInstalledError.js.map +1 -1
  754. package/error/EntityMetadataNotFoundError.js.map +1 -1
  755. package/error/EntityNotFoundError.js.map +1 -1
  756. package/error/EntityPropertyNotFoundError.js.map +1 -1
  757. package/error/FindRelationsNotFoundError.js.map +1 -1
  758. package/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  759. package/error/InitializedRelationError.js.map +1 -1
  760. package/error/InsertValuesMissingError.js.map +1 -1
  761. package/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  762. package/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  763. package/error/MetadataAlreadyExistsError.js.map +1 -1
  764. package/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  765. package/error/MissingDeleteDateColumnError.js.map +1 -1
  766. package/error/MissingDriverError.js.map +1 -1
  767. package/error/MissingJoinColumnError.js.map +1 -1
  768. package/error/MissingJoinTableError.js.map +1 -1
  769. package/error/MissingPrimaryColumnError.js.map +1 -1
  770. package/error/MustBeEntityError.js.map +1 -1
  771. package/error/NamingStrategyNotFoundError.js.map +1 -1
  772. package/error/NestedSetMultipleRootError.js.map +1 -1
  773. package/error/NoConnectionForRepositoryError.js.map +1 -1
  774. package/error/NoConnectionOptionError.js.map +1 -1
  775. package/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  776. package/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  777. package/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  778. package/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  779. package/error/OptimisticLockVersionMismatchError.js.map +1 -1
  780. package/error/PersistedEntityNotFoundError.js.map +1 -1
  781. package/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  782. package/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  783. package/error/QueryFailedError.js.map +1 -1
  784. package/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  785. package/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  786. package/error/RepositoryNotTreeError.js.map +1 -1
  787. package/error/ReturningStatementNotSupportedError.js.map +1 -1
  788. package/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  789. package/error/SubjectWithoutIdentifierError.js.map +1 -1
  790. package/error/TransactionAlreadyStartedError.js.map +1 -1
  791. package/error/TransactionNotStartedError.js.map +1 -1
  792. package/error/TreeRepositoryNotSupportedError.js.map +1 -1
  793. package/error/TypeORMError.js.map +1 -1
  794. package/error/UpdateValuesMissingError.js.map +1 -1
  795. package/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  796. package/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  797. package/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  798. package/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  799. package/error/index.js.map +1 -1
  800. package/find-options/EqualOperator.js.map +1 -1
  801. package/find-options/FindManyOptions.js.map +1 -1
  802. package/find-options/FindOneOptions.js.map +1 -1
  803. package/find-options/FindOperator.js.map +1 -1
  804. package/find-options/FindOperatorType.js.map +1 -1
  805. package/find-options/FindOptionsOrder.js.map +1 -1
  806. package/find-options/FindOptionsRelations.js.map +1 -1
  807. package/find-options/FindOptionsSelect.js.map +1 -1
  808. package/find-options/FindOptionsUtils.js.map +1 -1
  809. package/find-options/FindOptionsWhere.js.map +1 -1
  810. package/find-options/FindTreeOptions.js.map +1 -1
  811. package/find-options/JoinOptions.js.map +1 -1
  812. package/find-options/OrderByCondition.js.map +1 -1
  813. package/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  814. package/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  815. package/find-options/operator/And.js.map +1 -1
  816. package/find-options/operator/Any.js.map +1 -1
  817. package/find-options/operator/ArrayContainedBy.js.map +1 -1
  818. package/find-options/operator/ArrayContains.js.map +1 -1
  819. package/find-options/operator/ArrayOverlap.js.map +1 -1
  820. package/find-options/operator/Between.js.map +1 -1
  821. package/find-options/operator/Equal.js.map +1 -1
  822. package/find-options/operator/ILike.js.map +1 -1
  823. package/find-options/operator/In.js.map +1 -1
  824. package/find-options/operator/IsNull.js.map +1 -1
  825. package/find-options/operator/JsonContains.js.map +1 -1
  826. package/find-options/operator/LessThan.js.map +1 -1
  827. package/find-options/operator/LessThanOrEqual.js.map +1 -1
  828. package/find-options/operator/Like.js.map +1 -1
  829. package/find-options/operator/MoreThan.js.map +1 -1
  830. package/find-options/operator/MoreThanOrEqual.js.map +1 -1
  831. package/find-options/operator/Not.js.map +1 -1
  832. package/find-options/operator/Or.js.map +1 -1
  833. package/find-options/operator/Raw.js.map +1 -1
  834. package/globals.js.map +1 -1
  835. package/index.js.map +1 -1
  836. package/logger/AbstractLogger.js.map +1 -1
  837. package/logger/AdvancedConsoleLogger.js.map +1 -1
  838. package/logger/DebugLogger.js.map +1 -1
  839. package/logger/FileLogger.js.map +1 -1
  840. package/logger/Logger.js.map +1 -1
  841. package/logger/LoggerFactory.js.map +1 -1
  842. package/logger/LoggerOptions.js.map +1 -1
  843. package/logger/SimpleConsoleLogger.js.map +1 -1
  844. package/metadata/CheckMetadata.js.map +1 -1
  845. package/metadata/ColumnMetadata.js.map +1 -1
  846. package/metadata/EmbeddedMetadata.js.map +1 -1
  847. package/metadata/EntityListenerMetadata.js.map +1 -1
  848. package/metadata/EntityMetadata.js.map +1 -1
  849. package/metadata/ExclusionMetadata.js.map +1 -1
  850. package/metadata/ForeignKeyMetadata.js.map +1 -1
  851. package/metadata/IndexMetadata.js.map +1 -1
  852. package/metadata/RelationCountMetadata.js.map +1 -1
  853. package/metadata/RelationIdMetadata.js.map +1 -1
  854. package/metadata/RelationMetadata.js.map +1 -1
  855. package/metadata/UniqueMetadata.js.map +1 -1
  856. package/metadata/types/ClosureTreeOptions.js.map +1 -1
  857. package/metadata/types/DeferrableType.js.map +1 -1
  858. package/metadata/types/EventListenerTypes.js.map +1 -1
  859. package/metadata/types/OnDeleteType.js.map +1 -1
  860. package/metadata/types/OnUpdateType.js.map +1 -1
  861. package/metadata/types/PropertyTypeInFunction.js.map +1 -1
  862. package/metadata/types/RelationTypeInFunction.js.map +1 -1
  863. package/metadata/types/RelationTypes.js.map +1 -1
  864. package/metadata/types/TableTypes.js.map +1 -1
  865. package/metadata/types/TreeTypes.js.map +1 -1
  866. package/metadata-args/CheckMetadataArgs.js.map +1 -1
  867. package/metadata-args/ColumnMetadataArgs.js.map +1 -1
  868. package/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  869. package/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  870. package/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  871. package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  872. package/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  873. package/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  874. package/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  875. package/metadata-args/IndexMetadataArgs.js.map +1 -1
  876. package/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  877. package/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  878. package/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  879. package/metadata-args/MetadataArgsStorage.js.map +1 -1
  880. package/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  881. package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  882. package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  883. package/metadata-args/RelationMetadataArgs.js.map +1 -1
  884. package/metadata-args/TableMetadataArgs.js.map +1 -1
  885. package/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  886. package/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  887. package/metadata-args/TreeMetadataArgs.js.map +1 -1
  888. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  889. package/metadata-args/types/ColumnMode.js.map +1 -1
  890. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  891. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  892. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  893. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  894. package/metadata-builder/MetadataUtils.js.map +1 -1
  895. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  896. package/migration/Migration.js.map +1 -1
  897. package/migration/MigrationExecutor.js.map +1 -1
  898. package/migration/MigrationInterface.js.map +1 -1
  899. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  900. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  901. package/naming-strategy/NamingStrategyInterface.js.map +1 -1
  902. package/package.json +1 -260
  903. package/persistence/EntityPersistExecutor.js.map +1 -1
  904. package/persistence/Subject.js.map +1 -1
  905. package/persistence/SubjectChangeMap.js.map +1 -1
  906. package/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  907. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  908. package/persistence/SubjectExecutor.js.map +1 -1
  909. package/persistence/SubjectTopologicalSorter.js.map +1 -1
  910. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  911. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  912. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  913. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  914. package/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  915. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  916. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  917. package/platform/PlatformTools.js.map +1 -1
  918. package/query-builder/Alias.js.map +1 -1
  919. package/query-builder/Brackets.js.map +1 -1
  920. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  921. package/query-builder/InsertOrUpdateOptions.js.map +1 -1
  922. package/query-builder/InsertQueryBuilder.js.map +1 -1
  923. package/query-builder/JoinAttribute.js.map +1 -1
  924. package/query-builder/JoinOptions.js.map +1 -1
  925. package/query-builder/NotBrackets.js.map +1 -1
  926. package/query-builder/QueryBuilder.js.map +1 -1
  927. package/query-builder/QueryBuilderCte.js.map +1 -1
  928. package/query-builder/QueryBuilderUtils.js.map +1 -1
  929. package/query-builder/QueryExpressionMap.js.map +1 -1
  930. package/query-builder/QueryPartialEntity.js.map +1 -1
  931. package/query-builder/RelationIdLoader.js +3 -2
  932. package/query-builder/RelationIdLoader.js.map +1 -1
  933. package/query-builder/RelationLoader.js.map +1 -1
  934. package/query-builder/RelationQueryBuilder.js.map +1 -1
  935. package/query-builder/RelationRemover.js.map +1 -1
  936. package/query-builder/RelationUpdater.js.map +1 -1
  937. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  938. package/query-builder/SelectQuery.js.map +1 -1
  939. package/query-builder/SelectQueryBuilder.js.map +1 -1
  940. package/query-builder/SelectQueryBuilderOption.js.map +1 -1
  941. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  942. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  943. package/query-builder/WhereClause.js.map +1 -1
  944. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  945. package/query-builder/index.js.map +1 -1
  946. package/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  947. package/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  948. package/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  949. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  950. package/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  951. package/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  952. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  953. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  954. package/query-builder/result/DeleteResult.js.map +1 -1
  955. package/query-builder/result/InsertResult.js.map +1 -1
  956. package/query-builder/result/UpdateResult.js.map +1 -1
  957. package/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  958. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  959. package/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  960. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  961. package/query-runner/BaseQueryRunner.js.map +1 -1
  962. package/query-runner/QueryLock.js.map +1 -1
  963. package/query-runner/QueryResult.js.map +1 -1
  964. package/query-runner/QueryRunner.js.map +1 -1
  965. package/repository/AbstractRepository.js.map +1 -1
  966. package/repository/BaseEntity.js.map +1 -1
  967. package/repository/EntityId.js.map +1 -1
  968. package/repository/FindTreesOptions.js.map +1 -1
  969. package/repository/MongoRepository.js.map +1 -1
  970. package/repository/RemoveOptions.js.map +1 -1
  971. package/repository/Repository.js.map +1 -1
  972. package/repository/SaveOptions.js.map +1 -1
  973. package/repository/TreeRepository.js.map +1 -1
  974. package/repository/UpsertOptions.js.map +1 -1
  975. package/schema-builder/MongoSchemaBuilder.js.map +1 -1
  976. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  977. package/schema-builder/SchemaBuilder.js.map +1 -1
  978. package/schema-builder/options/TableCheckOptions.js.map +1 -1
  979. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  980. package/schema-builder/options/TableExclusionOptions.js.map +1 -1
  981. package/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  982. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  983. package/schema-builder/options/TableOptions.js.map +1 -1
  984. package/schema-builder/options/TableUniqueOptions.js.map +1 -1
  985. package/schema-builder/options/ViewOptions.js.map +1 -1
  986. package/schema-builder/table/Table.js.map +1 -1
  987. package/schema-builder/table/TableCheck.js.map +1 -1
  988. package/schema-builder/table/TableColumn.js.map +1 -1
  989. package/schema-builder/table/TableExclusion.js.map +1 -1
  990. package/schema-builder/table/TableForeignKey.js.map +1 -1
  991. package/schema-builder/table/TableIndex.js.map +1 -1
  992. package/schema-builder/table/TableUnique.js.map +1 -1
  993. package/schema-builder/util/TableUtils.js.map +1 -1
  994. package/schema-builder/util/ViewUtils.js.map +1 -1
  995. package/schema-builder/view/View.js.map +1 -1
  996. package/subscriber/Broadcaster.js.map +1 -1
  997. package/subscriber/BroadcasterResult.js.map +1 -1
  998. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  999. package/subscriber/event/InsertEvent.js.map +1 -1
  1000. package/subscriber/event/LoadEvent.js.map +1 -1
  1001. package/subscriber/event/QueryEvent.js.map +1 -1
  1002. package/subscriber/event/RecoverEvent.js.map +1 -1
  1003. package/subscriber/event/RemoveEvent.js.map +1 -1
  1004. package/subscriber/event/SoftRemoveEvent.js.map +1 -1
  1005. package/subscriber/event/TransactionCommitEvent.js.map +1 -1
  1006. package/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  1007. package/subscriber/event/TransactionStartEvent.js.map +1 -1
  1008. package/subscriber/event/UpdateEvent.js.map +1 -1
  1009. package/typeorm-class-transformer-shim.js +271 -271
  1010. package/typeorm-model-shim.js +295 -295
  1011. package/util/ApplyValueTransformers.js.map +1 -1
  1012. package/util/DateUtils.js.map +1 -1
  1013. package/util/DepGraph.js.map +1 -1
  1014. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  1015. package/util/ImportUtils.js.map +1 -1
  1016. package/util/InstanceChecker.js.map +1 -1
  1017. package/util/ObjectUtils.js.map +1 -1
  1018. package/util/OrmUtils.js.map +1 -1
  1019. package/util/PathUtils.js.map +1 -1
  1020. package/util/RandomGenerator.js.map +1 -1
  1021. package/util/StringUtils.js.map +1 -1
  1022. package/util/TreeRepositoryUtils.js.map +1 -1
  1023. package/util/VersionUtils.js.map +1 -1
  1024. package/util/escapeRegExp.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/mysql/MysqlConnectionCredentialsOptions.ts"],"names":[],"mappings":"","file":"MysqlConnectionCredentialsOptions.js","sourcesContent":["/**\r\n * MySQL specific connection credential options.\r\n *\r\n * @see https://github.com/mysqljs/mysql#connection-options\r\n */\r\nexport interface MysqlConnectionCredentialsOptions {\r\n /**\r\n * Connection url where the connection is performed.\r\n */\r\n readonly url?: string\r\n\r\n /**\r\n * Database host.\r\n */\r\n readonly host?: string\r\n\r\n /**\r\n * Database host port.\r\n */\r\n readonly port?: number\r\n\r\n /**\r\n * Database username.\r\n */\r\n readonly username?: string\r\n\r\n /**\r\n * Database password.\r\n */\r\n readonly password?: string\r\n\r\n /**\r\n * Database name to connect to.\r\n */\r\n readonly database?: string\r\n\r\n /**\r\n * Object with ssl parameters or a string containing name of ssl profile.\r\n */\r\n readonly ssl?: any\r\n\r\n /**\r\n * Database socket path\r\n */\r\n readonly socketPath?: string\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/mysql/MysqlConnectionCredentialsOptions.ts"],"names":[],"mappings":"","file":"MysqlConnectionCredentialsOptions.js","sourcesContent":["/**\n * MySQL specific connection credential options.\n *\n * @see https://github.com/mysqljs/mysql#connection-options\n */\nexport interface MysqlConnectionCredentialsOptions {\n /**\n * Connection url where the connection is performed.\n */\n readonly url?: string\n\n /**\n * Database host.\n */\n readonly host?: string\n\n /**\n * Database host port.\n */\n readonly port?: number\n\n /**\n * Database username.\n */\n readonly username?: string\n\n /**\n * Database password.\n */\n readonly password?: string\n\n /**\n * Database name to connect to.\n */\n readonly database?: string\n\n /**\n * Object with ssl parameters or a string containing name of ssl profile.\n */\n readonly ssl?: any\n\n /**\n * Database socket path\n */\n readonly socketPath?: string\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/mysql/MysqlConnectionOptions.ts"],"names":[],"mappings":"","file":"MysqlConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\r\nimport { ReplicationMode } from \"../types/ReplicationMode\"\r\nimport { MysqlConnectionCredentialsOptions } from \"./MysqlConnectionCredentialsOptions\"\r\n\r\n/**\r\n * MySQL specific connection options.\r\n *\r\n * @see https://github.com/mysqljs/mysql#connection-options\r\n */\r\nexport interface MysqlConnectionOptions\r\n extends BaseDataSourceOptions,\r\n MysqlConnectionCredentialsOptions {\r\n /**\r\n * Database type.\r\n */\r\n readonly type: \"mysql\" | \"mariadb\"\r\n\r\n /**\r\n * The driver object\r\n * This defaults to require(\"mysql\").\r\n * Falls back to require(\"mysql2\")\r\n */\r\n readonly driver?: any\r\n\r\n /**\r\n * The charset for the connection. This is called \"collation\" in the SQL-level of MySQL (like utf8_general_ci).\r\n * If a SQL-level charset is specified (like utf8mb4) then the default collation for that charset is used.\r\n * Default: 'UTF8_GENERAL_CI'\r\n */\r\n readonly charset?: string\r\n\r\n /**\r\n * The timezone configured on the MySQL server.\r\n * This is used to type cast server date/time values to JavaScript Date object and vice versa.\r\n * This can be 'local', 'Z', or an offset in the form +HH:MM or -HH:MM. (Default: 'local')\r\n */\r\n readonly timezone?: string\r\n\r\n /**\r\n * The milliseconds before a timeout occurs during the initial connection to the MySQL server. (Default: 10000)\r\n */\r\n readonly connectTimeout?: number\r\n\r\n /**\r\n * The milliseconds before a timeout occurs during the initial connection to the MySQL server. (Default: 10000)\r\n * This difference between connectTimeout and acquireTimeout is subtle and is described in the mysqljs/mysql docs\r\n * https://github.com/mysqljs/mysql/tree/master#pool-options\r\n */\r\n readonly acquireTimeout?: number\r\n\r\n /**\r\n * Allow connecting to MySQL instances that ask for the old (insecure) authentication method. (Default: false)\r\n */\r\n readonly insecureAuth?: boolean\r\n\r\n /**\r\n * When dealing with big numbers (BIGINT and DECIMAL columns) in the database, you should enable this option (Default: false)\r\n */\r\n readonly supportBigNumbers?: boolean\r\n\r\n /**\r\n * Enabling both supportBigNumbers and bigNumberStrings forces big numbers (BIGINT and DECIMAL columns) to be always\r\n * returned as JavaScript String objects (Default: false). Enabling supportBigNumbers but leaving bigNumberStrings\r\n * disabled will return big numbers as String objects only when they cannot be accurately represented with\r\n * [JavaScript Number objects](http://ecma262-5.com/ELS5_HTML.htm#Section_8.5) (which happens when they exceed the [-2^53, +2^53] range),\r\n * otherwise they will be returned as Number objects. This option is ignored if supportBigNumbers is disabled.\r\n */\r\n readonly bigNumberStrings?: boolean\r\n\r\n /**\r\n * Force date types (TIMESTAMP, DATETIME, DATE) to be returned as strings rather then inflated into JavaScript Date objects.\r\n * Can be true/false or an array of type names to keep as strings.\r\n */\r\n readonly dateStrings?: boolean | string[]\r\n\r\n /**\r\n * Prints protocol details to stdout. Can be true/false or an array of packet type names that should be printed.\r\n * (Default: false)\r\n */\r\n readonly debug?: boolean | string[]\r\n\r\n /**\r\n * Generates stack traces on Error to include call site of library entrance (\"long stack traces\").\r\n * Slight performance penalty for most calls. (Default: true)\r\n */\r\n readonly trace?: boolean\r\n\r\n /**\r\n * Allow multiple mysql statements per query. Be careful with this, it could increase the scope of SQL injection attacks.\r\n * (Default: false)\r\n */\r\n readonly multipleStatements?: boolean\r\n\r\n /**\r\n * Use spatial functions like GeomFromText and AsText which are removed in MySQL 8.\r\n * (Default: true)\r\n */\r\n readonly legacySpatialSupport?: boolean\r\n\r\n /**\r\n * List of connection flags to use other than the default ones. It is also possible to blacklist default ones.\r\n * For more information, check https://github.com/mysqljs/mysql#connection-flags.\r\n */\r\n readonly flags?: string[]\r\n\r\n /**\r\n * TypeORM will automatically use package found in your node_modules, prioritizing mysql over mysql2,\r\n * but you can specify it manually\r\n */\r\n readonly connectorPackage?: \"mysql\" | \"mysql2\"\r\n\r\n /**\r\n * Replication setup.\r\n */\r\n readonly replication?: {\r\n /**\r\n * Master server used by orm to perform writes.\r\n */\r\n readonly master: MysqlConnectionCredentialsOptions\r\n\r\n /**\r\n * List of read-from servers (slaves).\r\n */\r\n readonly slaves: MysqlConnectionCredentialsOptions[]\r\n\r\n /**\r\n * If true, PoolCluster will attempt to reconnect when connection fails. (Default: true)\r\n */\r\n readonly canRetry?: boolean\r\n\r\n /**\r\n * If connection fails, node's errorCount increases.\r\n * When errorCount is greater than removeNodeErrorCount, remove a node in the PoolCluster. (Default: 5)\r\n */\r\n readonly removeNodeErrorCount?: number\r\n\r\n /**\r\n * If connection fails, specifies the number of milliseconds before another connection attempt will be made.\r\n * If set to 0, then node will be removed instead and never re-used. (Default: 0)\r\n */\r\n readonly restoreNodeTimeout?: number\r\n\r\n /**\r\n * Determines how slaves are selected:\r\n * RR: Select one alternately (Round-Robin).\r\n * RANDOM: Select the node by random function.\r\n * ORDER: Select the first node available unconditionally.\r\n */\r\n readonly selector?: \"RR\" | \"RANDOM\" | \"ORDER\"\r\n\r\n /**\r\n * Default connection pool to use for SELECT queries\r\n * @default \"slave\"\r\n */\r\n readonly defaultMode?: ReplicationMode\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/mysql/MysqlConnectionOptions.ts"],"names":[],"mappings":"","file":"MysqlConnectionOptions.js","sourcesContent":["import { BaseDataSourceOptions } from \"../../data-source/BaseDataSourceOptions\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { MysqlConnectionCredentialsOptions } from \"./MysqlConnectionCredentialsOptions\"\n\n/**\n * MySQL specific connection options.\n *\n * @see https://github.com/mysqljs/mysql#connection-options\n */\nexport interface MysqlConnectionOptions\n extends BaseDataSourceOptions,\n MysqlConnectionCredentialsOptions {\n /**\n * Database type.\n */\n readonly type: \"mysql\" | \"mariadb\"\n\n /**\n * The driver object\n * This defaults to require(\"mysql\").\n * Falls back to require(\"mysql2\")\n */\n readonly driver?: any\n\n /**\n * The charset for the connection. This is called \"collation\" in the SQL-level of MySQL (like utf8_general_ci).\n * If a SQL-level charset is specified (like utf8mb4) then the default collation for that charset is used.\n * Default: 'UTF8_GENERAL_CI'\n */\n readonly charset?: string\n\n /**\n * The timezone configured on the MySQL server.\n * This is used to type cast server date/time values to JavaScript Date object and vice versa.\n * This can be 'local', 'Z', or an offset in the form +HH:MM or -HH:MM. (Default: 'local')\n */\n readonly timezone?: string\n\n /**\n * The milliseconds before a timeout occurs during the initial connection to the MySQL server. (Default: 10000)\n */\n readonly connectTimeout?: number\n\n /**\n * The milliseconds before a timeout occurs during the initial connection to the MySQL server. (Default: 10000)\n * This difference between connectTimeout and acquireTimeout is subtle and is described in the mysqljs/mysql docs\n * https://github.com/mysqljs/mysql/tree/master#pool-options\n */\n readonly acquireTimeout?: number\n\n /**\n * Allow connecting to MySQL instances that ask for the old (insecure) authentication method. (Default: false)\n */\n readonly insecureAuth?: boolean\n\n /**\n * When dealing with big numbers (BIGINT and DECIMAL columns) in the database, you should enable this option (Default: false)\n */\n readonly supportBigNumbers?: boolean\n\n /**\n * Enabling both supportBigNumbers and bigNumberStrings forces big numbers (BIGINT and DECIMAL columns) to be always\n * returned as JavaScript String objects (Default: false). Enabling supportBigNumbers but leaving bigNumberStrings\n * disabled will return big numbers as String objects only when they cannot be accurately represented with\n * [JavaScript Number objects](http://ecma262-5.com/ELS5_HTML.htm#Section_8.5) (which happens when they exceed the [-2^53, +2^53] range),\n * otherwise they will be returned as Number objects. This option is ignored if supportBigNumbers is disabled.\n */\n readonly bigNumberStrings?: boolean\n\n /**\n * Force date types (TIMESTAMP, DATETIME, DATE) to be returned as strings rather then inflated into JavaScript Date objects.\n * Can be true/false or an array of type names to keep as strings.\n */\n readonly dateStrings?: boolean | string[]\n\n /**\n * Prints protocol details to stdout. Can be true/false or an array of packet type names that should be printed.\n * (Default: false)\n */\n readonly debug?: boolean | string[]\n\n /**\n * Generates stack traces on Error to include call site of library entrance (\"long stack traces\").\n * Slight performance penalty for most calls. (Default: true)\n */\n readonly trace?: boolean\n\n /**\n * Allow multiple mysql statements per query. Be careful with this, it could increase the scope of SQL injection attacks.\n * (Default: false)\n */\n readonly multipleStatements?: boolean\n\n /**\n * Use spatial functions like GeomFromText and AsText which are removed in MySQL 8.\n * (Default: true)\n */\n readonly legacySpatialSupport?: boolean\n\n /**\n * List of connection flags to use other than the default ones. It is also possible to blacklist default ones.\n * For more information, check https://github.com/mysqljs/mysql#connection-flags.\n */\n readonly flags?: string[]\n\n /**\n * TypeORM will automatically use package found in your node_modules, prioritizing mysql over mysql2,\n * but you can specify it manually\n */\n readonly connectorPackage?: \"mysql\" | \"mysql2\"\n\n /**\n * Replication setup.\n */\n readonly replication?: {\n /**\n * Master server used by orm to perform writes.\n */\n readonly master: MysqlConnectionCredentialsOptions\n\n /**\n * List of read-from servers (slaves).\n */\n readonly slaves: MysqlConnectionCredentialsOptions[]\n\n /**\n * If true, PoolCluster will attempt to reconnect when connection fails. (Default: true)\n */\n readonly canRetry?: boolean\n\n /**\n * If connection fails, node's errorCount increases.\n * When errorCount is greater than removeNodeErrorCount, remove a node in the PoolCluster. (Default: 5)\n */\n readonly removeNodeErrorCount?: number\n\n /**\n * If connection fails, specifies the number of milliseconds before another connection attempt will be made.\n * If set to 0, then node will be removed instead and never re-used. (Default: 0)\n */\n readonly restoreNodeTimeout?: number\n\n /**\n * Determines how slaves are selected:\n * RR: Select one alternately (Round-Robin).\n * RANDOM: Select the node by random function.\n * ORDER: Select the first node available unconditionally.\n */\n readonly selector?: \"RR\" | \"RANDOM\" | \"ORDER\"\n\n /**\n * Default connection pool to use for SELECT queries\n * @default \"slave\"\n */\n readonly defaultMode?: ReplicationMode\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/driver/mysql/MysqlDriver.ts"],"names":[],"mappings":";;;AACA,iFAA6E;AAC7E,+FAA2F;AAC3F,gDAA4C;AAE5C,yDAAqD;AAGrD,oDAAgD;AAChD,gEAA4D;AAE5D,gFAA4E;AAQ5E,kDAA8C;AAC9C,8EAA0E;AAE1E,uCAA0C;AAI1C,0DAAsD;AACtD,gEAA4D;AAG5D;;GAEG;AACH,MAAa,WAAW;IAmTpB,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAY,UAAsB;QA1QlC;;WAEG;QACH,iBAAY,GAAY,KAAK,CAAA;QAE7B;;WAEG;QACH,gBAAW,GAAG,IAAI,CAAA;QAElB;;WAEG;QACH,uBAAkB,GAAG,QAAiB,CAAA;QAEtC;;;;;WAKG;QACH,uBAAkB,GAAiB;YAC/B,gBAAgB;YAChB,KAAK;YACL,KAAK;YACL,SAAS,EAAE,kBAAkB;YAC7B,SAAS;YACT,UAAU;YACV,WAAW;YACX,QAAQ;YACR,OAAO;YACP,QAAQ;YACR,kBAAkB,EAAE,qBAAqB;YACzC,MAAM,EAAE,qBAAqB;YAC7B,SAAS;YACT,KAAK,EAAE,sBAAsB;YAC7B,SAAS,EAAE,sBAAsB;YACjC,OAAO,EAAE,sBAAsB;YAC/B,MAAM,EAAE,sBAAsB;YAC9B,SAAS,EAAE,sBAAsB;YACjC,sBAAsB;YACtB,MAAM;YACN,UAAU;YACV,WAAW;YACX,MAAM;YACN,MAAM;YACN,eAAe;YACf,MAAM;YACN,OAAO,EAAE,4BAA4B;YACrC,eAAe;YACf,SAAS;YACT,UAAU,EAAE,+BAA+B;YAC3C,kBAAkB;YAClB,MAAM;YACN,MAAM;YACN,UAAU;YACV,UAAU;YACV,YAAY;YACZ,YAAY;YACZ,UAAU;YACV,UAAU;YACV,MAAM;YACN,KAAK;YACL,QAAQ;YACR,WAAW;YACX,iBAAiB;YACjB,MAAM;YACN,qBAAqB;YACrB,UAAU;YACV,OAAO;YACP,YAAY;YACZ,SAAS;YACT,YAAY;YACZ,iBAAiB;YACjB,cAAc;YACd,oBAAoB;YACpB,oCAAoC;YACpC,MAAM;YACN,OAAO;YACP,OAAO;SACV,CAAA;QAED;;WAEG;QACH,yBAAoB,GAAiB,CAAC,yBAAyB,CAAC,CAAA;QAEhE;;WAEG;QACH,iBAAY,GAAiB;YACzB,UAAU;YACV,OAAO;YACP,YAAY;YACZ,SAAS;YACT,YAAY;YACZ,iBAAiB;YACjB,cAAc;YACd,oBAAoB;SACvB,CAAA;QAED;;WAEG;QACH,0BAAqB,GAAiB;YAClC,MAAM;YACN,SAAS;YACT,UAAU;YACV,QAAQ;YACR,WAAW;SACd,CAAA;QAED;;WAEG;QACH,yBAAoB,GAAiB;YACjC,KAAK;YACL,SAAS;YACT,UAAU;YACV,WAAW;YACX,KAAK;YACL,SAAS;YACT,QAAQ;SACX,CAAA;QAED;;WAEG;QACH,6BAAwB,GAAiB;YACrC,SAAS;YACT,KAAK;YACL,SAAS;YACT,OAAO;YACP,OAAO;YACP,QAAQ;YACR,kBAAkB;YAClB,MAAM;YACN,MAAM;YACN,UAAU;YACV,WAAW;SACd,CAAA;QAED;;WAEG;QACH,yBAAoB,GAAiB;YACjC,SAAS;YACT,KAAK;YACL,SAAS;YACT,OAAO;YACP,OAAO;YACP,QAAQ;YACR,kBAAkB;YAClB,MAAM;SACT,CAAA;QAED;;WAEG;QACH,6BAAwB,GAAiB;YACrC,KAAK;YACL,SAAS;YACT,UAAU;YACV,SAAS;YACT,WAAW;YACX,QAAQ;YACR,SAAS;YACT,KAAK;YACL,SAAS;YACT,OAAO;YACP,OAAO;YACP,QAAQ;YACR,kBAAkB;YAClB,MAAM;SACT,CAAA;QAED;;;WAGG;QACH,oBAAe,GAAsB;YACjC,UAAU,EAAE,UAAU;YACtB,mBAAmB,EAAE,CAAC;YACtB,iBAAiB,EAAE,sBAAsB;YACzC,UAAU,EAAE,UAAU;YACtB,mBAAmB,EAAE,CAAC;YACtB,iBAAiB,EAAE,sBAAsB;YACzC,UAAU,EAAE,UAAU;YACtB,mBAAmB,EAAE,CAAC;YACtB,kBAAkB,EAAE,IAAI;YACxB,OAAO,EAAE,KAAK;YACd,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE,KAAK;YAClB,aAAa,EAAE,SAAS;YACxB,kBAAkB,EAAE,QAAQ;YAC5B,OAAO,EAAE,KAAK;YACd,eAAe,EAAE,SAAS;YAC1B,SAAS,EAAE,QAAQ;YACnB,aAAa,EAAE,KAAK;YACpB,UAAU,EAAE,MAAM;YAClB,WAAW,EAAE,MAAM;YACnB,YAAY,EAAE,SAAS;YACvB,gBAAgB,EAAE,SAAS;YAC3B,cAAc,EAAE,SAAS;YACzB,aAAa,EAAE,SAAS;YACxB,YAAY,EAAE,SAAS;YACvB,aAAa,EAAE,MAAM;SACxB,CAAA;QAED;;;WAGG;QACH,qBAAgB,GAAqB;YACjC,OAAO,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE;YACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE;YACzB,kBAAkB,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE;YACnC,IAAI,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;YACnB,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,EAAE;YACrB,SAAS,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE;YAC1B,OAAO,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACpC,GAAG,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YAChC,OAAO,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACpC,KAAK,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YAClC,KAAK,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YACxB,MAAM,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE;YACzB,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE;YACtB,QAAQ,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE;YAC1B,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE;YAC3B,GAAG,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACjB,GAAG,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;YAClB,OAAO,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;YACtB,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACrB,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACtB,SAAS,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE;YACvB,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;SACxB,CAAA;QAED;;;WAGG;QACH,mBAAc,GAAG,EAAE,CAAA;QAEnB,oBAAe,GAAoB;YAC/B,OAAO,EAAE,KAAK;YACd,qBAAqB,EAAE,IAAI;SAC9B,CAAA;QAED;;WAEG;QACc,6BAAwB,GACrC;YACI,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;SAChB,CAAA;QAEL,2DAA2D;QACnD,2BAAsB,GAAG,KAAK,CAAA;QAOlC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,OAAO,GAAG;YACX,oBAAoB,EAAE,IAAI;YAC1B,GAAG,UAAU,CAAC,OAAO;SACE,CAAA;QAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;QAE3D,qBAAqB;QACrB,IAAI,CAAC,gBAAgB,EAAE,CAAA;QAEvB,IAAI,CAAC,QAAQ,GAAG,yBAAW,CAAC,kBAAkB,CAC1C,IAAI,CAAC,OAAO,CAAC,WAAW;YACpB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM;YACjC,CAAC,CAAC,IAAI,CAAC,OAAO,CACrB,CAAC,QAAQ,CAAA;QAEV,kDAAkD;QAClD,oDAAoD;QACpD,iHAAiH;QACjH,gEAAgE;QAChE,8BAA8B;QAC9B,qDAAqD;QACrD,8BAA8B;QAC9B,qDAAqD;QACrD,gHAAgH;QAChH,2EAA2E;IAC/E,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E;;OAEG;IACH,KAAK,CAAC,OAAO;QACT,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAC3C,IAAI,CAAC,OAAO,CAAC,WAAW,CAC3B,CAAA;YACD,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;gBACrD,IAAI,CAAC,WAAW,CAAC,GAAG,CAChB,OAAO,GAAG,KAAK,EACf,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CACpD,CAAA;YACL,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,WAAW,CAAC,GAAG,CAChB,QAAQ,EACR,IAAI,CAAC,uBAAuB,CACxB,IAAI,CAAC,OAAO,EACZ,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAClC,CACJ,CAAA;QACL,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,IAAI,GAAG,MAAM,IAAI,CAAC,UAAU,CAC7B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,CAC3D,CAAA;QACL,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjB,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;YAE1D,IAAI,CAAC,QAAQ,GAAG,MAAM,WAAW,CAAC,kBAAkB,EAAE,CAAA;YAEtD,MAAM,WAAW,CAAC,OAAO,EAAE,CAAA;QAC/B,CAAC;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;QACpD,MAAM,MAAM,GAEN,MAAM,WAAW,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAA;QAChE,MAAM,SAAS,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAA;QACnC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAA;QACxB,MAAM,WAAW,CAAC,OAAO,EAAE,CAAA;QAE3B,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAClC,IAAI,2BAAY,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACrD,IAAI,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAA;YAC/C,CAAC;YACD,IAAI,2BAAY,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACrD,IAAI,CAAC,wBAAwB,CAAC,MAAM,GAAG,IAAI,CAAA;YAC/C,CAAC;YACD,IAAI,2BAAY,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACrD,IAAI,CAAC,eAAe,CAAC,OAAO,GAAG,IAAI,CAAA;YACvC,CAAC;YACD,IAAI,2BAAY,CAAC,gBAAgB,CAAC,SAAS,EAAE,QAAQ,CAAC,EAAE,CAAC;gBACrD,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAA;YACtC,CAAC;QACL,CAAC;aAAM,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YACvC,IAAI,2BAAY,CAAC,gBAAgB,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,CAAC;gBACpD,IAAI,CAAC,eAAe,CAAC,OAAO,GAAG,IAAI,CAAA;YACvC,CAAC;QACL,CAAC;IACL,CAAC;IAED;;OAEG;IACH,YAAY;QACR,OAAO,OAAO,CAAC,OAAO,EAAE,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU;QACZ,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,IAAI;YAC/B,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,iDAAuB,CAAC,OAAO,CAAC,CAAC,CAAA;QAE/D,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,OAAO,IAAI,OAAO,CAAO,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;gBAClC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;gBAC5D,IAAI,CAAC,WAAW,GAAG,SAAS,CAAA;YAChC,CAAC,CAAC,CAAA;QACN,CAAC;QACD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACZ,OAAO,IAAI,OAAO,CAAO,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;gBAClC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;oBACvB,IAAI,GAAG;wBAAE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAA;oBACzB,IAAI,CAAC,IAAI,GAAG,SAAS,CAAA;oBACrB,EAAE,EAAE,CAAA;gBACR,CAAC,CAAC,CAAA;YACN,CAAC,CAAC,CAAA;QACN,CAAC;IACL,CAAC;IAED;;OAEG;IACH,mBAAmB;QACf,OAAO,IAAI,uCAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;IAClD,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,IAAqB;QACnC,OAAO,IAAI,mCAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;IAC3C,CAAC;IAED;;;OAGG;IACH,yBAAyB,CACrB,GAAW,EACX,UAAyB,EACzB,gBAA+B;QAE/B,MAAM,iBAAiB,GAAU,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAC9D,CAAC,GAAG,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAG,CAAC,CACjC,CAAA;QACD,IAAI,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM;YAC9C,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAA;QAEnC,GAAG,GAAG,GAAG,CAAC,OAAO,CACb,6BAA6B,EAC7B,CAAC,IAAI,EAAE,OAAe,EAAE,GAAW,EAAU,EAAE;YAC3C,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC;gBAClC,OAAO,IAAI,CAAA;YACf,CAAC;YAED,IAAI,KAAK,GAAQ,UAAU,CAAC,GAAG,CAAC,CAAA;YAEhC,IAAI,OAAO,EAAE,CAAC;gBACV,OAAO,KAAK;qBACP,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;oBACZ,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBACzB,OAAO,IAAI,CAAC,eAAe,CACvB,GAAG,EACH,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAC/B,CAAA;gBACL,CAAC,CAAC;qBACD,IAAI,CAAC,IAAI,CAAC,CAAA;YACnB,CAAC;YAED,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;gBAC9B,OAAO,KAAK,EAAE,CAAA;YAClB,CAAC;YAED,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAC7B,OAAO,IAAI,CAAC,eAAe,CAAC,GAAG,EAAE,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAClE,CAAC,CACJ,CAAA,CAAC,kEAAkE;QACpE,OAAO,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAA;IACnC,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAkB;QACrB,OAAO,GAAG,GAAG,UAAU,GAAG,GAAG,CAAA;IACjC,CAAC;IAED;;;OAGG;IACH,cAAc,CACV,SAAiB,EACjB,MAAe,EACf,QAAiB;QAEjB,IAAI,SAAS,GAAG,CAAC,SAAS,CAAC,CAAA;QAE3B,IAAI,QAAQ,EAAE,CAAC;YACX,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;QAC/B,CAAC;QAED,OAAO,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAC9B,CAAC;IAED;;OAEG;IACH,cAAc,CACV,MAAgE;QAEhE,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAA;QACpC,MAAM,YAAY,GAAG,SAAS,CAAA;QAE9B,IAAI,iCAAe,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,iCAAe,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;YACpE,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YAE/C,OAAO;gBACH,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,IAAI,cAAc;gBAC9D,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,IAAI,YAAY;gBACtD,SAAS,EAAE,MAAM,CAAC,SAAS;aAC9B,CAAA;QACL,CAAC;QAED,IAAI,iCAAe,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC;YAC5C,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAA;YAE9D,OAAO;gBACH,QAAQ,EACJ,MAAM,CAAC,kBAAkB;oBACzB,MAAM,CAAC,QAAQ;oBACf,cAAc;gBAClB,MAAM,EACF,MAAM,CAAC,gBAAgB,IAAI,MAAM,CAAC,MAAM,IAAI,YAAY;gBAC5D,SAAS,EAAE,MAAM,CAAC,SAAS;aAC9B,CAAA;QACL,CAAC;QAED,IAAI,iCAAe,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3C,2CAA2C;YAE3C,OAAO;gBACH,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,cAAc;gBAC3C,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,YAAY;gBACrC,SAAS,EAAE,MAAM,CAAC,SAAS;aAC9B,CAAA;QACL,CAAC;QAED,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAE/B,OAAO;YACH,QAAQ,EACJ,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,cAAc;YAC/D,MAAM,EAAE,YAAY;YACpB,SAAS,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SACpD,CAAA;IACL,CAAC;IAED;;OAEG;IACH,sBAAsB,CAAC,KAAU,EAAE,cAA8B;QAC7D,IAAI,cAAc,CAAC,WAAW;YAC1B,KAAK,GAAG,+CAAsB,CAAC,WAAW,CACtC,cAAc,CAAC,WAAW,EAC1B,KAAK,CACR,CAAA;QAEL,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,KAAK,CAAA;QAEvD,IAAI,cAAc,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YAClC,OAAO,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACjC,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,OAAO,qBAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAA;QACjD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,OAAO,qBAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAA;QACjD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAChC,CAAC;aAAM,IACH,cAAc,CAAC,IAAI,KAAK,WAAW;YACnC,cAAc,CAAC,IAAI,KAAK,UAAU;YAClC,cAAc,CAAC,IAAI,KAAK,IAAI,EAC9B,CAAC;YACC,OAAO,qBAAS,CAAC,eAAe,CAAC,KAAK,CAAC,CAAA;QAC3C,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;YAChD,OAAO,qBAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA;QAC/C,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;YAC/C,OAAO,qBAAS,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QAC9C,CAAC;aAAM,IACH,cAAc,CAAC,IAAI,KAAK,MAAM;YAC9B,cAAc,CAAC,IAAI,KAAK,aAAa,EACvC,CAAC;YACC,OAAO,EAAE,GAAG,KAAK,CAAA;QACrB,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACvC,OAAO,qBAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA;QAC/C,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,8BAA8B;YAC9B,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;QACpD,CAAC;QAED,OAAO,KAAK,CAAA;IAChB,CAAC;IAED;;OAEG;IACH,oBAAoB,CAAC,KAAU,EAAE,cAA8B;QAC3D,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS;YACrC,OAAO,cAAc,CAAC,WAAW;gBAC7B,CAAC,CAAC,+CAAsB,CAAC,aAAa,CAChC,cAAc,CAAC,WAAW,EAC1B,KAAK,CACR;gBACH,CAAC,CAAC,KAAK,CAAA;QAEf,IACI,cAAc,CAAC,IAAI,KAAK,OAAO;YAC/B,cAAc,CAAC,IAAI,KAAK,MAAM;YAC9B,cAAc,CAAC,IAAI,KAAK,SAAS,EACnC,CAAC;YACC,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;QAChC,CAAC;aAAM,IACH,cAAc,CAAC,IAAI,KAAK,UAAU;YAClC,cAAc,CAAC,IAAI,KAAK,IAAI,EAC9B,CAAC;YACC,KAAK,GAAG,qBAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAA;QAClD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,KAAK,GAAG,qBAAS,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAA;QAClD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,KAAK,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;QACjE,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,KAAK,GAAG,qBAAS,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAA;QAC9C,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,cAAc,EAAE,CAAC;YAChD,KAAK,GAAG,qBAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA;QAChD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;YAC/C,KAAK,GAAG,qBAAS,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;QAC/C,CAAC;aAAM,IACH,CAAC,cAAc,CAAC,IAAI,KAAK,MAAM;YAC3B,cAAc,CAAC,IAAI,KAAK,aAAa,CAAC;YAC1C,cAAc,CAAC,IAAI;YACnB,CAAC,KAAK,CAAC,KAAK,CAAC;YACb,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EACnD,CAAC;YACC,4DAA4D;YAC5D,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;QAC3B,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACvC,KAAK,GAAG,qBAAS,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAA;QAChD,CAAC;aAAM,IAAI,cAAc,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxC,8BAA8B;YAC9B,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;QACpD,CAAC;QAED,IAAI,cAAc,CAAC,WAAW;YAC1B,KAAK,GAAG,+CAAsB,CAAC,aAAa,CACxC,cAAc,CAAC,WAAW,EAC1B,KAAK,CACR,CAAA;QAEL,OAAO,KAAK,CAAA;IAChB,CAAC;IAED;;OAEG;IACH,aAAa,CAAC,MAKb;QACG,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YACtD,OAAO,KAAK,CAAA;QAChB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YAChC,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;YAC9B,OAAO,UAAU,CAAA;QACrB,CAAC;aAAM,IAAK,MAAM,CAAC,IAAY,KAAK,MAAM,EAAE,CAAC;YACzC,OAAO,MAAM,CAAA;QACjB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;YACjC,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChE,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IACH,MAAM,CAAC,IAAI,KAAK,MAAM;YACtB,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS;YAC/B,CAAC,2BAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,IAAI,OAAO,EAAE,QAAQ,CAAC,EACnE,CAAC;YACC;;;;;;eAMG;YACH,OAAO,UAAU,CAAA;QACrB,CAAC;aAAM,IACH,MAAM,CAAC,IAAI,KAAK,cAAc;YAC9B,MAAM,CAAC,IAAI,KAAK,aAAa,EAC/B,CAAC;YACC,OAAO,MAAM,CAAA;QACjB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;YACvC,OAAO,MAAM,CAAA;QACjB,CAAC;aAAM,IACH,MAAM,CAAC,IAAI,KAAK,kBAAkB;YAClC,MAAM,CAAC,IAAI,KAAK,MAAM,EACxB,CAAC;YACC,OAAO,QAAQ,CAAA;QACnB,CAAC;aAAM,IACH,MAAM,CAAC,IAAI,KAAK,KAAK;YACrB,MAAM,CAAC,IAAI,KAAK,SAAS;YACzB,MAAM,CAAC,IAAI,KAAK,OAAO,EACzB,CAAC;YACC,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC7D,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IACH,MAAM,CAAC,IAAI,KAAK,UAAU;YAC1B,MAAM,CAAC,IAAI,KAAK,kBAAkB,EACpC,CAAC;YACC,OAAO,SAAS,CAAA;QACpB,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,MAAM,CAAC,IAAI,KAAK,eAAe,EAAE,CAAC;YACpE,OAAO,MAAM,CAAA;QACjB,CAAC;aAAM,CAAC;YACJ,OAAQ,MAAM,CAAC,IAAe,IAAI,EAAE,CAAA;QACxC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,cAA8B;QAC3C,MAAM,YAAY,GAAG,cAAc,CAAC,OAAO,CAAA;QAE3C,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;YACxB,OAAO,SAAS,CAAA;QACpB,CAAC;QAED,IACI,CAAC,cAAc,CAAC,IAAI,KAAK,MAAM;YAC3B,cAAc,CAAC,IAAI,KAAK,aAAa;YACrC,OAAO,YAAY,KAAK,QAAQ,CAAC;YACrC,YAAY,KAAK,SAAS,EAC5B,CAAC;YACC,OAAO,IAAI,YAAY,GAAG,CAAA;QAC9B,CAAC;QAED,IAAI,cAAc,CAAC,IAAI,KAAK,KAAK,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;YAC9D,OAAO,IAAI,qBAAS,CAAC,mBAAmB,CAAC,YAAY,CAAC,GAAG,CAAA;QAC7D,CAAC;QAED,IAAI,OAAO,YAAY,KAAK,QAAQ,EAAE,CAAC;YACnC,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,CAAA;QAC5D,CAAC;QAED,IAAI,OAAO,YAAY,KAAK,SAAS,EAAE,CAAC;YACpC,OAAO,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAA;QACnC,CAAC;QAED,IAAI,OAAO,YAAY,KAAK,UAAU,EAAE,CAAC;YACrC,MAAM,KAAK,GAAG,YAAY,EAAE,CAAA;YAC5B,OAAO,IAAI,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAA;QAChD,CAAC;QAED,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;YAC7B,OAAO,SAAS,CAAA;QACpB,CAAC;QAED,OAAO,GAAG,YAAY,EAAE,CAAA;IAC5B,CAAC;IAED;;OAEG;IACH,iBAAiB,CAAC,MAAsB;QACpC,OAAO,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CACrC,CAAC,GAAG,EAAE,EAAE,CACJ,GAAG,CAAC,QAAQ;YACZ,GAAG,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC;YACxB,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,MAAM,CAChC,CAAA;IACL,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,MAAoC;QAChD,IAAI,MAAM,CAAC,MAAM;YAAE,OAAO,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;QAElD;;;WAGG;QACH,IACI,MAAM,CAAC,kBAAkB,KAAK,MAAM;YACpC,CAAC,IAAI,CAAC,sBAAsB;YAE5B,OAAO,IAAI,CAAA;QAEf,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;YAClB,KAAK,MAAM,CAAC;YACZ,KAAK,SAAS,CAAC;YACf,KAAK,UAAU,CAAC;YAChB,KAAK,kBAAkB;gBACnB,OAAO,KAAK,CAAA;YAChB,KAAK,WAAW;gBACZ,OAAO,KAAK,CAAA;YAChB;gBACI,OAAO,EAAE,CAAA;QACjB,CAAC;IACL,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,MAAmB;QAC9B,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;QAEtB,6HAA6H;QAC7H,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE,CAAC;YAC/B,IAAI,IAAI,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,GAAG,CAAA;QAC/C,CAAC;aAAM,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;YACtB,IAAI,IAAI,IAAI,MAAM,CAAC,KAAK,GAAG,CAAA;QAC/B,CAAC;aAAM,IACH,MAAM,CAAC,SAAS,KAAK,IAAI;YACzB,MAAM,CAAC,SAAS,KAAK,SAAS;YAC9B,MAAM,CAAC,KAAK,KAAK,IAAI;YACrB,MAAM,CAAC,KAAK,KAAK,SAAS,EAC5B,CAAC;YACC,IAAI,IAAI,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,KAAK,GAAG,CAAA;QACnD,CAAC;aAAM,IACH,MAAM,CAAC,SAAS,KAAK,IAAI;YACzB,MAAM,CAAC,SAAS,KAAK,SAAS,EAChC,CAAC;YACC,IAAI,IAAI,IAAI,MAAM,CAAC,SAAS,GAAG,CAAA;QACnC,CAAC;QAED,IAAI,MAAM,CAAC,OAAO;YAAE,IAAI,IAAI,QAAQ,CAAA;QAEpC,OAAO,IAAI,CAAA;IACf,CAAC;IAED;;;;OAIG;IACH,sBAAsB;QAClB,OAAO,IAAI,OAAO,CAAM,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACjC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,IAAI,CAAC,WAAW,CAAC,aAAa,CAC1B,QAAQ,EACR,CAAC,GAAQ,EAAE,YAAiB,EAAE,EAAE;oBAC5B,GAAG;wBACC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;wBACX,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC,CAAA;gBACpD,CAAC,CACJ,CAAA;YACL,CAAC;iBAAM,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACnB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,GAAQ,EAAE,YAAiB,EAAE,EAAE;oBACpD,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC,CAAA;gBAChE,CAAC,CAAC,CAAA;YACN,CAAC;iBAAM,CAAC;gBACJ,IAAI,CACA,IAAI,oBAAY,CACZ,mDAAmD,CACtD,CACJ,CAAA;YACL,CAAC;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;;;OAIG;IACH,qBAAqB;QACjB,IAAI,CAAC,IAAI,CAAC,WAAW;YAAE,OAAO,IAAI,CAAC,sBAAsB,EAAE,CAAA;QAE3D,OAAO,IAAI,OAAO,CAAM,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACjC,IAAI,CAAC,WAAW,CAAC,aAAa,CAC1B,QAAQ,EACR,CAAC,GAAQ,EAAE,YAAiB,EAAE,EAAE;gBAC5B,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC,CAAA;YAChE,CAAC,CACJ,CAAA;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;OAEG;IACH,kBAAkB,CACd,QAAwB,EACxB,YAAiB,EACjB,WAAmB;QAEnB,IAAI,CAAC,YAAY,EAAE,CAAC;YAChB,OAAO,SAAS,CAAA;QACpB,CAAC;QAED,IAAI,YAAY,CAAC,QAAQ,KAAK,SAAS,EAAE,CAAC;YACtC,OAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;gBACjD,MAAM,MAAM,GAAG,QAAQ,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAA;gBACvD,IAAI,MAAM,EAAE,CAAC;oBACT,mBAAQ,CAAC,SAAS,CACd,GAAG,EACH,MAAM,CAAC,cAAc,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAC3C,CAAA;oBACD,8KAA8K;gBAClL,CAAC;gBACD,OAAO,GAAG,CAAA;YACd,CAAC,EAAE,EAAmB,CAAC,CAAA;QAC3B,CAAC;QAED,MAAM,YAAY,GAAG,QAAQ,CAAC,gBAAgB,CAAC,MAAM,CACjD,CAAC,GAAG,EAAE,eAAe,EAAE,EAAE;YACrB,IAAI,KAAU,CAAA;YACd,IACI,eAAe,CAAC,kBAAkB,KAAK,WAAW;gBAClD,YAAY,CAAC,QAAQ,EACvB,CAAC;gBACC,qEAAqE;gBACrE,qEAAqE;gBACrE,KAAK,GAAG,YAAY,CAAC,QAAQ,GAAG,WAAW,CAAA;gBAC3C,8DAA8D;gBAC9D,sEAAsE;gBACtE,uDAAuD;YAC3D,CAAC;YAED,OAAO,mBAAQ,CAAC,SAAS,CACrB,GAAG,EACH,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CACxC,CAAA;QACL,CAAC,EACD,EAAmB,CACtB,CAAA;QAED,OAAO,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAA;IAC1E,CAAC;IAED;;;OAGG;IACH,kBAAkB,CACd,YAA2B,EAC3B,eAAiC;QAEjC,OAAO,eAAe,CAAC,MAAM,CAAC,CAAC,cAAc,EAAE,EAAE;YAC7C,MAAM,WAAW,GAAG,YAAY,CAAC,IAAI,CACjC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,cAAc,CAAC,YAAY,CAChD,CAAA;YACD,IAAI,CAAC,WAAW;gBAAE,OAAO,KAAK,CAAA,CAAC,4DAA4D;YAE3F,MAAM,eAAe,GACjB,WAAW,CAAC,IAAI,KAAK,cAAc,CAAC,YAAY;gBAChD,IAAI,CAAC,uBAAuB,CAAC,WAAW,EAAE,cAAc,CAAC;gBACzD,WAAW,CAAC,MAAM,KAAK,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC;gBAC3D,WAAW,CAAC,KAAK,KAAK,cAAc,CAAC,KAAK;gBAC1C,CAAC,cAAc,CAAC,SAAS,KAAK,SAAS;oBACnC,WAAW,CAAC,SAAS,KAAK,cAAc,CAAC,SAAS,CAAC;gBACvD,CAAC,cAAc,CAAC,KAAK,KAAK,SAAS;oBAC/B,WAAW,CAAC,KAAK,KAAK,cAAc,CAAC,KAAK,CAAC;gBAC/C,WAAW,CAAC,QAAQ,KAAK,cAAc,CAAC,QAAQ;gBAChD,WAAW,CAAC,QAAQ,KAAK,cAAc,CAAC,QAAQ;gBAChD,WAAW,CAAC,YAAY,KAAK,cAAc,CAAC,YAAY;gBACxD,WAAW,CAAC,aAAa,KAAK,cAAc,CAAC,aAAa;gBAC1D,WAAW,CAAC,OAAO;oBACf,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC;gBAC9C,CAAC,IAAI,CAAC,oBAAoB,CACtB,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,EACrC,WAAW,CAAC,OAAO,CACtB;gBACD,CAAC,WAAW,CAAC,IAAI;oBACb,cAAc,CAAC,IAAI;oBACnB,CAAC,mBAAQ,CAAC,aAAa,CACnB,WAAW,CAAC,IAAI,EAChB,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,CAC7C,CAAC;gBACN,WAAW,CAAC,QAAQ;oBAChB,IAAI,CAAC,yBAAyB,CAAC,cAAc,CAAC,QAAQ,CAAC;gBAC3D,WAAW,CAAC,SAAS,KAAK,cAAc,CAAC,SAAS;gBAClD,CAAC,IAAI,CAAC,qBAAqB,CAAC,cAAc,EAAE,WAAW,CAAC;gBACxD,WAAW,CAAC,QAAQ;oBAChB,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC;gBAC1C,CAAC,cAAc,CAAC,kBAAkB,KAAK,MAAM;oBACzC,WAAW,CAAC,WAAW,KAAK,cAAc,CAAC,WAAW,CAAC,CAAA;YAE/D,gBAAgB;YAChB,yBAAyB;YACzB,qEAAqE;YACrE,mBAAmB;YACnB,mBAAmB;YACnB,4BAA4B;YAC5B,uCAAuC;YACvC,QAAQ;YACR,mBAAmB;YACnB,mBAAmB;YACnB,4BAA4B;YAC5B,8CAA8C;YAC9C,QAAQ;YACR,mBAAmB;YACnB,qBAAqB;YACrB,8BAA8B;YAC9B,iCAAiC;YACjC,QAAQ;YACR,qEAAqE;YACrE,mBAAmB;YACnB,wBAAwB;YACxB,iCAAiC;YACjC,oCAAoC;YACpC,QAAQ;YACR,qEAAqE;YACrE,mBAAmB;YACnB,uBAAuB;YACvB,gCAAgC;YAChC,mCAAmC;YACnC,QAAQ;YACR,mBAAmB;YACnB,uBAAuB;YACvB,gCAAgC;YAChC,mCAAmC;YACnC,QAAQ;YACR,mBAAmB;YACnB,2BAA2B;YAC3B,oCAAoC;YACpC,uCAAuC;YACvC,QAAQ;YACR,mBAAmB;YACnB,4BAA4B;YAC5B,qCAAqC;YACrC,wCAAwC;YACxC,QAAQ;YACR,mBAAmB;YACnB,sBAAsB;YACtB,+BAA+B;YAC/B,sDAAsD;YACtD,QAAQ;YACR,mBAAmB;YACnB,sBAAsB;YACtB,+BAA+B;YAC/B,iDAAiD;YACjD,QAAQ;YACR,kEAAkE;YAClE,mBAAmB;YACnB,8BAA8B;YAC9B,sCAAsC;YACtC,qDAAqD;YACrD,mCAAmC;YACnC,aAAa;YACb,QAAQ;YACR,mBAAmB;YACnB,wBAAwB;YACxB,iCAAiC;YACjC,oCAAoC;YACpC,QAAQ;YACR,mBAAmB;YACnB,iCAAiC;YACjC,oEAAoE;YACpE,QAAQ;YACR,mBAAmB;YACnB,uBAAuB;YACvB,gCAAgC;YAChC,kDAAkD;YAClD,QAAQ;YACR,mBAAmB;YACnB,0BAA0B;YAC1B,mCAAmC;YACnC,sCAAsC;YACtC,QAAQ;YACR,mBAAmB;YACnB,0DAA0D;YAC1D,sEAAsE;YACtE,QAAQ;YACR,gEAAgE;YAChE,IAAI;YAEJ,OAAO,eAAe,CAAA;QAC1B,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;OAEG;IACH,uBAAuB,CAAC,aAA4B;QAChD,OAAO,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAA;IACvD,CAAC;IAED;;OAEG;IACH,yBAAyB;QACrB,OAAO,KAAK,CAAA;IAChB,CAAC;IAED;;OAEG;IACH,6BAA6B;QACzB,OAAO,IAAI,CAAA;IACf,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,aAAqB,EAAE,KAAa;QAChD,OAAO,GAAG,CAAA;IACd,CAAC;IAED,4EAA4E;IAC5E,oBAAoB;IACpB,4EAA4E;IAE5E;;OAEG;IACO,gBAAgB;QACtB,MAAM,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,IAAI,OAAO,CAAA;QACjE,MAAM,wBAAwB,GAC1B,gBAAgB,KAAK,OAAO;YACxB,CAAC,CAAE,QAAkB;YACrB,CAAC,CAAE,OAAiB,CAAA;QAC5B,IAAI,CAAC;YACD,sCAAsC;YACtC,MAAM,KAAK,GACP,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,6BAAa,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YAC/D,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;YAClB;;;;;;eAMG;YACH,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvC,MAAM,IAAI,oBAAY,CAClB,IAAI,gBAAgB,iDAAiD,wBAAwB,IAAI,CACpG,CAAA;YACL,CAAC;QACL,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACT,IAAI,CAAC;gBACD,IAAI,CAAC,KAAK,GAAG,6BAAa,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAA,CAAC,uCAAuC;YACrG,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACT,MAAM,IAAI,+DAA8B,CACpC,OAAO,EACP,gBAAgB,CACnB,CAAA;YACL,CAAC;QACL,CAAC;IACL,CAAC;IAED;;OAEG;IACO,uBAAuB,CAC7B,OAA+B,EAC/B,WAA8C;QAE9C,WAAW,GAAG,MAAM,CAAC,MAAM,CACvB,EAAE,EACF,WAAW,EACX,yBAAW,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAC9C,CAAA,CAAC,yBAAyB;QAE3B,0CAA0C;QAC1C,OAAO,MAAM,CAAC,MAAM,CAChB,EAAE,EACF;YACI,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,cAAc,EAAE,OAAO,CAAC,cAAc;YACtC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,iBAAiB,EACb,OAAO,CAAC,iBAAiB,KAAK,SAAS;gBACnC,CAAC,CAAC,OAAO,CAAC,iBAAiB;gBAC3B,CAAC,CAAC,IAAI;YACd,gBAAgB,EACZ,OAAO,CAAC,gBAAgB,KAAK,SAAS;gBAClC,CAAC,CAAC,OAAO,CAAC,gBAAgB;gBAC1B,CAAC,CAAC,IAAI;YACd,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,KAAK,EAAE,OAAO,CAAC,KAAK;YACpB,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;YAC9C,KAAK,EAAE,OAAO,CAAC,KAAK;SACvB,EACD;YACI,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,IAAI,EAAE,WAAW,CAAC,QAAQ;YAC1B,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,QAAQ,EAAE,WAAW,CAAC,QAAQ;YAC9B,IAAI,EAAE,WAAW,CAAC,IAAI;YACtB,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,UAAU,EAAE,WAAW,CAAC,UAAU;SACrC,EACD,OAAO,CAAC,cAAc,KAAK,SAAS;YAChC,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,EAAE,cAAc,EAAE,OAAO,CAAC,cAAc,EAAE,EAChD,EAAE,eAAe,EAAE,OAAO,CAAC,QAAQ,EAAE,EACrC,OAAO,CAAC,KAAK,IAAI,EAAE,CACtB,CAAA;IACL,CAAC;IAED;;OAEG;IACO,UAAU,CAAC,iBAAsB;QACvC,2BAA2B;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAA;QAErD,uCAAuC;QACvC,OAAO,IAAI,OAAO,CAAO,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YAClC,qGAAqG;YACrG,iFAAiF;YACjF,IAAI,CAAC,aAAa,CAAC,CAAC,GAAQ,EAAE,UAAe,EAAE,EAAE;gBAC7C,IAAI,GAAG;oBAAE,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;gBAEzC,UAAU,CAAC,OAAO,EAAE,CAAA;gBACpB,EAAE,CAAC,IAAI,CAAC,CAAA;YACZ,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,UAAe;QACvC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAA;QAClC;;;WAGG;QACH,IAAI,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7C,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAU,EAAE,EAAE,CAClC,MAAM,CAAC,GAAG,CACN,MAAM,EACN,qCAAqC,KAAK,EAAE,CAC/C,CACJ,CAAA;QACL,CAAC;QACD,OAAO,UAAU,CAAA;IACrB,CAAC;IAED;;OAEG;IACO,oBAAoB,CAC1B,mBAAuC,EACvC,aAAiC;QAEjC,IACI,OAAO,mBAAmB,KAAK,QAAQ;YACvC,OAAO,aAAa,KAAK,QAAQ,EACnC,CAAC;YACC,qGAAqG;YACrG,0EAA0E;YAC1E,mBAAmB,GAAG,mBAAmB,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAA;YACjE,aAAa,GAAG,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAA;QACzD,CAAC;QAED,OAAO,mBAAmB,KAAK,aAAa,CAAA;IAChD,CAAC;IAED,qBAAqB,CACjB,cAA8B,EAC9B,WAAwB;QAExB,2EAA2E;QAC3E,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS,CAAA;QACjD,IAAI,SAAS,IAAI,cAAc,CAAC,aAAa,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAA;QACf,CAAC;QAED,OAAO,cAAc,CAAC,UAAU,KAAK,WAAW,CAAC,UAAU,CAAA;IAC/D,CAAC;IAED;;;OAGG;IACO,yBAAyB,CAAC,KAAc;QAC9C,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAA;QAExB,sCAAsC;QACtC,MAAM,kBAAkB,GACpB,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;YACvD,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAA;QAE7C,IAAI,kBAAkB,EAAE,CAAC;YACrB,gCAAgC;YAChC,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAA;YACxC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBAClC,OAAO,SAAS;oBACZ,CAAC,CAAC,oBAAoB,SAAS,CAAC,CAAC,CAAC,EAAE;oBACpC,CAAC,CAAC,qBAAqB,CAAA;YAC/B,CAAC;iBAAM,CAAC;gBACJ,OAAO,SAAS;oBACZ,CAAC,CAAC,oBAAoB,SAAS,CAAC,CAAC,CAAC,EAAE;oBACpC,CAAC,CAAC,mBAAmB,CAAA;YAC7B,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,OAAO,KAAK,CAAA;QAChB,CAAC;IACL,CAAC;IAED;;OAEG;IACO,aAAa,CAAC,OAAgB;QACpC,IAAI,CAAC,OAAO;YAAE,OAAO,OAAO,CAAA;QAE5B,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAA,CAAC,wCAAwC;QAEjF,OAAO,OAAO,CAAA;IAClB,CAAC;IAED;;;;OAIG;IACK,uBAAuB,CAC3B,WAAwB,EACxB,cAA8B;QAE9B,gFAAgF;QAChF,IACI,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,MAAM;YAC7C,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,UAAU;YAE7C,OAAO,KAAK,CAAA;QAChB,OAAO,WAAW,CAAC,IAAI,KAAK,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,CAAA;IAClE,CAAC;CACJ;AAz0CD,kCAy0CC","file":"MysqlDriver.js","sourcesContent":["import { Driver, ReturningType } from \"../Driver\"\r\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\r\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\r\nimport { DriverUtils } from \"../DriverUtils\"\r\nimport { CteCapabilities } from \"../types/CteCapabilities\"\r\nimport { MysqlQueryRunner } from \"./MysqlQueryRunner\"\r\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { ColumnMetadata } from \"../../metadata/ColumnMetadata\"\r\nimport { DateUtils } from \"../../util/DateUtils\"\r\nimport { PlatformTools } from \"../../platform/PlatformTools\"\r\nimport { DataSource } from \"../../data-source/DataSource\"\r\nimport { RdbmsSchemaBuilder } from \"../../schema-builder/RdbmsSchemaBuilder\"\r\nimport { MysqlConnectionOptions } from \"./MysqlConnectionOptions\"\r\nimport { MappedColumnTypes } from \"../types/MappedColumnTypes\"\r\nimport { ColumnType } from \"../types/ColumnTypes\"\r\nimport { DataTypeDefaults } from \"../types/DataTypeDefaults\"\r\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\r\nimport { MysqlConnectionCredentialsOptions } from \"./MysqlConnectionCredentialsOptions\"\r\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { OrmUtils } from \"../../util/OrmUtils\"\r\nimport { ApplyValueTransformers } from \"../../util/ApplyValueTransformers\"\r\nimport { ReplicationMode } from \"../types/ReplicationMode\"\r\nimport { TypeORMError } from \"../../error\"\r\nimport { Table } from \"../../schema-builder/table/Table\"\r\nimport { View } from \"../../schema-builder/view/View\"\r\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\r\nimport { VersionUtils } from \"../../util/VersionUtils\"\r\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\r\nimport { UpsertType } from \"../types/UpsertType\"\r\n\r\n/**\r\n * Organizes communication with MySQL DBMS.\r\n */\r\nexport class MysqlDriver implements Driver {\r\n // -------------------------------------------------------------------------\r\n // Public Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Connection used by driver.\r\n */\r\n connection: DataSource\r\n\r\n /**\r\n * Mysql underlying library.\r\n */\r\n mysql: any\r\n\r\n /**\r\n * Connection pool.\r\n * Used in non-replication mode.\r\n */\r\n pool: any\r\n\r\n /**\r\n * Pool cluster used in replication mode.\r\n */\r\n poolCluster: any\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Implemented Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Connection options.\r\n */\r\n options: MysqlConnectionOptions\r\n\r\n /**\r\n * Version of MySQL. Requires a SQL query to the DB, so it is not always set\r\n */\r\n version?: string\r\n\r\n /**\r\n * Master database used to perform all write queries.\r\n */\r\n database?: string\r\n\r\n /**\r\n * Indicates if replication is enabled.\r\n */\r\n isReplicated: boolean = false\r\n\r\n /**\r\n * Indicates if tree tables are supported by this driver.\r\n */\r\n treeSupport = true\r\n\r\n /**\r\n * Represent transaction support by this driver\r\n */\r\n transactionSupport = \"nested\" as const\r\n\r\n /**\r\n * Gets list of supported column data types by a driver.\r\n *\r\n * @see https://www.tutorialspoint.com/mysql/mysql-data-types.htm\r\n * @see https://dev.mysql.com/doc/refman/8.0/en/data-types.html\r\n */\r\n supportedDataTypes: ColumnType[] = [\r\n // numeric types\r\n \"bit\",\r\n \"int\",\r\n \"integer\", // synonym for int\r\n \"tinyint\",\r\n \"smallint\",\r\n \"mediumint\",\r\n \"bigint\",\r\n \"float\",\r\n \"double\",\r\n \"double precision\", // synonym for double\r\n \"real\", // synonym for double\r\n \"decimal\",\r\n \"dec\", // synonym for decimal\r\n \"numeric\", // synonym for decimal\r\n \"fixed\", // synonym for decimal\r\n \"bool\", // synonym for tinyint\r\n \"boolean\", // synonym for tinyint\r\n // date and time types\r\n \"date\",\r\n \"datetime\",\r\n \"timestamp\",\r\n \"time\",\r\n \"year\",\r\n // string types\r\n \"char\",\r\n \"nchar\", // synonym for national char\r\n \"national char\",\r\n \"varchar\",\r\n \"nvarchar\", // synonym for national varchar\r\n \"national varchar\",\r\n \"blob\",\r\n \"text\",\r\n \"tinyblob\",\r\n \"tinytext\",\r\n \"mediumblob\",\r\n \"mediumtext\",\r\n \"longblob\",\r\n \"longtext\",\r\n \"enum\",\r\n \"set\",\r\n \"binary\",\r\n \"varbinary\",\r\n // json data type\r\n \"json\",\r\n // spatial data types\r\n \"geometry\",\r\n \"point\",\r\n \"linestring\",\r\n \"polygon\",\r\n \"multipoint\",\r\n \"multilinestring\",\r\n \"multipolygon\",\r\n \"geometrycollection\",\r\n // additional data types for mariadb\r\n \"uuid\",\r\n \"inet4\",\r\n \"inet6\",\r\n ]\r\n\r\n /**\r\n * Returns type of upsert supported by driver if any\r\n */\r\n supportedUpsertTypes: UpsertType[] = [\"on-duplicate-key-update\"]\r\n\r\n /**\r\n * Gets list of spatial column data types.\r\n */\r\n spatialTypes: ColumnType[] = [\r\n \"geometry\",\r\n \"point\",\r\n \"linestring\",\r\n \"polygon\",\r\n \"multipoint\",\r\n \"multilinestring\",\r\n \"multipolygon\",\r\n \"geometrycollection\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that support length by a driver.\r\n */\r\n withLengthColumnTypes: ColumnType[] = [\r\n \"char\",\r\n \"varchar\",\r\n \"nvarchar\",\r\n \"binary\",\r\n \"varbinary\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that support length by a driver.\r\n */\r\n withWidthColumnTypes: ColumnType[] = [\r\n \"bit\",\r\n \"tinyint\",\r\n \"smallint\",\r\n \"mediumint\",\r\n \"int\",\r\n \"integer\",\r\n \"bigint\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that support precision by a driver.\r\n */\r\n withPrecisionColumnTypes: ColumnType[] = [\r\n \"decimal\",\r\n \"dec\",\r\n \"numeric\",\r\n \"fixed\",\r\n \"float\",\r\n \"double\",\r\n \"double precision\",\r\n \"real\",\r\n \"time\",\r\n \"datetime\",\r\n \"timestamp\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that supports scale by a driver.\r\n */\r\n withScaleColumnTypes: ColumnType[] = [\r\n \"decimal\",\r\n \"dec\",\r\n \"numeric\",\r\n \"fixed\",\r\n \"float\",\r\n \"double\",\r\n \"double precision\",\r\n \"real\",\r\n ]\r\n\r\n /**\r\n * Gets list of column data types that supports UNSIGNED and ZEROFILL attributes.\r\n */\r\n unsignedAndZerofillTypes: ColumnType[] = [\r\n \"int\",\r\n \"integer\",\r\n \"smallint\",\r\n \"tinyint\",\r\n \"mediumint\",\r\n \"bigint\",\r\n \"decimal\",\r\n \"dec\",\r\n \"numeric\",\r\n \"fixed\",\r\n \"float\",\r\n \"double\",\r\n \"double precision\",\r\n \"real\",\r\n ]\r\n\r\n /**\r\n * ORM has special columns and we need to know what database column types should be for those columns.\r\n * Column types are driver dependant.\r\n */\r\n mappedDataTypes: MappedColumnTypes = {\r\n createDate: \"datetime\",\r\n createDatePrecision: 6,\r\n createDateDefault: \"CURRENT_TIMESTAMP(6)\",\r\n updateDate: \"datetime\",\r\n updateDatePrecision: 6,\r\n updateDateDefault: \"CURRENT_TIMESTAMP(6)\",\r\n deleteDate: \"datetime\",\r\n deleteDatePrecision: 6,\r\n deleteDateNullable: true,\r\n version: \"int\",\r\n treeLevel: \"int\",\r\n migrationId: \"int\",\r\n migrationName: \"varchar\",\r\n migrationTimestamp: \"bigint\",\r\n cacheId: \"int\",\r\n cacheIdentifier: \"varchar\",\r\n cacheTime: \"bigint\",\r\n cacheDuration: \"int\",\r\n cacheQuery: \"text\",\r\n cacheResult: \"text\",\r\n metadataType: \"varchar\",\r\n metadataDatabase: \"varchar\",\r\n metadataSchema: \"varchar\",\r\n metadataTable: \"varchar\",\r\n metadataName: \"varchar\",\r\n metadataValue: \"text\",\r\n }\r\n\r\n /**\r\n * Default values of length, precision and scale depends on column data type.\r\n * Used in the cases when length/precision/scale is not specified by user.\r\n */\r\n dataTypeDefaults: DataTypeDefaults = {\r\n varchar: { length: 255 },\r\n nvarchar: { length: 255 },\r\n \"national varchar\": { length: 255 },\r\n char: { length: 1 },\r\n binary: { length: 1 },\r\n varbinary: { length: 255 },\r\n decimal: { precision: 10, scale: 0 },\r\n dec: { precision: 10, scale: 0 },\r\n numeric: { precision: 10, scale: 0 },\r\n fixed: { precision: 10, scale: 0 },\r\n float: { precision: 12 },\r\n double: { precision: 22 },\r\n time: { precision: 0 },\r\n datetime: { precision: 0 },\r\n timestamp: { precision: 0 },\r\n bit: { width: 1 },\r\n int: { width: 11 },\r\n integer: { width: 11 },\r\n tinyint: { width: 4 },\r\n smallint: { width: 6 },\r\n mediumint: { width: 9 },\r\n bigint: { width: 20 },\r\n }\r\n\r\n /**\r\n * Max length allowed by MySQL for aliases.\r\n * @see https://dev.mysql.com/doc/refman/5.5/en/identifiers.html\r\n */\r\n maxAliasLength = 63\r\n\r\n cteCapabilities: CteCapabilities = {\r\n enabled: false,\r\n requiresRecursiveHint: true,\r\n }\r\n\r\n /**\r\n * Supported returning types\r\n */\r\n private readonly _isReturningSqlSupported: Record<ReturningType, boolean> =\r\n {\r\n delete: false,\r\n insert: false,\r\n update: false,\r\n }\r\n\r\n /** MariaDB supports uuid type for version 10.7.0 and up */\r\n private uuidColumnTypeSuported = false\r\n\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(connection: DataSource) {\r\n this.connection = connection\r\n this.options = {\r\n legacySpatialSupport: true,\r\n ...connection.options,\r\n } as MysqlConnectionOptions\r\n this.isReplicated = this.options.replication ? true : false\r\n\r\n // load mysql package\r\n this.loadDependencies()\r\n\r\n this.database = DriverUtils.buildDriverOptions(\r\n this.options.replication\r\n ? this.options.replication.master\r\n : this.options,\r\n ).database\r\n\r\n // validate options to make sure everything is set\r\n // todo: revisit validation with replication in mind\r\n // if (!(this.options.host || (this.options.extra && this.options.extra.socketPath)) && !this.options.socketPath)\r\n // throw new DriverOptionNotSetError(\"socketPath and host\");\r\n // if (!this.options.username)\r\n // throw new DriverOptionNotSetError(\"username\");\r\n // if (!this.options.database)\r\n // throw new DriverOptionNotSetError(\"database\");\r\n // todo: check what is going on when connection is setup without database and how to connect to a database then?\r\n // todo: provide options to auto-create a database if it does not exist yet\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Performs connection to the database.\r\n */\r\n async connect(): Promise<void> {\r\n if (this.options.replication) {\r\n this.poolCluster = this.mysql.createPoolCluster(\r\n this.options.replication,\r\n )\r\n this.options.replication.slaves.forEach((slave, index) => {\r\n this.poolCluster.add(\r\n \"SLAVE\" + index,\r\n this.createConnectionOptions(this.options, slave),\r\n )\r\n })\r\n this.poolCluster.add(\r\n \"MASTER\",\r\n this.createConnectionOptions(\r\n this.options,\r\n this.options.replication.master,\r\n ),\r\n )\r\n } else {\r\n this.pool = await this.createPool(\r\n this.createConnectionOptions(this.options, this.options),\r\n )\r\n }\r\n\r\n if (!this.database) {\r\n const queryRunner = await this.createQueryRunner(\"master\")\r\n\r\n this.database = await queryRunner.getCurrentDatabase()\r\n\r\n await queryRunner.release()\r\n }\r\n\r\n const queryRunner = this.createQueryRunner(\"master\")\r\n const result: {\r\n version: string\r\n }[] = await queryRunner.query(`SELECT VERSION() AS \\`version\\``)\r\n const dbVersion = result[0].version\r\n this.version = dbVersion\r\n await queryRunner.release()\r\n\r\n if (this.options.type === \"mariadb\") {\r\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.0.5\")) {\r\n this._isReturningSqlSupported.delete = true\r\n }\r\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.5.0\")) {\r\n this._isReturningSqlSupported.insert = true\r\n }\r\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.2.0\")) {\r\n this.cteCapabilities.enabled = true\r\n }\r\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.7.0\")) {\r\n this.uuidColumnTypeSuported = true\r\n }\r\n } else if (this.options.type === \"mysql\") {\r\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"8.0.0\")) {\r\n this.cteCapabilities.enabled = true\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Makes any action after connection (e.g. create extensions in Postgres driver).\r\n */\r\n afterConnect(): Promise<void> {\r\n return Promise.resolve()\r\n }\r\n\r\n /**\r\n * Closes connection with the database.\r\n */\r\n async disconnect(): Promise<void> {\r\n if (!this.poolCluster && !this.pool)\r\n return Promise.reject(new ConnectionIsNotSetError(\"mysql\"))\r\n\r\n if (this.poolCluster) {\r\n return new Promise<void>((ok, fail) => {\r\n this.poolCluster.end((err: any) => (err ? fail(err) : ok()))\r\n this.poolCluster = undefined\r\n })\r\n }\r\n if (this.pool) {\r\n return new Promise<void>((ok, fail) => {\r\n this.pool.end((err: any) => {\r\n if (err) return fail(err)\r\n this.pool = undefined\r\n ok()\r\n })\r\n })\r\n }\r\n }\r\n\r\n /**\r\n * Creates a schema builder used to build and sync a schema.\r\n */\r\n createSchemaBuilder() {\r\n return new RdbmsSchemaBuilder(this.connection)\r\n }\r\n\r\n /**\r\n * Creates a query runner used to execute database queries.\r\n */\r\n createQueryRunner(mode: ReplicationMode) {\r\n return new MysqlQueryRunner(this, mode)\r\n }\r\n\r\n /**\r\n * Replaces parameters in the given sql with special escaping character\r\n * and an array of parameter names to be passed to a query.\r\n */\r\n escapeQueryWithParameters(\r\n sql: string,\r\n parameters: ObjectLiteral,\r\n nativeParameters: ObjectLiteral,\r\n ): [string, any[]] {\r\n const escapedParameters: any[] = Object.keys(nativeParameters).map(\r\n (key) => nativeParameters[key],\r\n )\r\n if (!parameters || !Object.keys(parameters).length)\r\n return [sql, escapedParameters]\r\n\r\n sql = sql.replace(\r\n /:(\\.\\.\\.)?([A-Za-z0-9_.]+)/g,\r\n (full, isArray: string, key: string): string => {\r\n if (!parameters.hasOwnProperty(key)) {\r\n return full\r\n }\r\n\r\n let value: any = parameters[key]\r\n\r\n if (isArray) {\r\n return value\r\n .map((v: any) => {\r\n escapedParameters.push(v)\r\n return this.createParameter(\r\n key,\r\n escapedParameters.length - 1,\r\n )\r\n })\r\n .join(\", \")\r\n }\r\n\r\n if (typeof value === \"function\") {\r\n return value()\r\n }\r\n\r\n escapedParameters.push(value)\r\n return this.createParameter(key, escapedParameters.length - 1)\r\n },\r\n ) // todo: make replace only in value statements, otherwise problems\r\n return [sql, escapedParameters]\r\n }\r\n\r\n /**\r\n * Escapes a column name.\r\n */\r\n escape(columnName: string): string {\r\n return \"`\" + columnName + \"`\"\r\n }\r\n\r\n /**\r\n * Build full table name with database name, schema name and table name.\r\n * E.g. myDB.mySchema.myTable\r\n */\r\n buildTableName(\r\n tableName: string,\r\n schema?: string,\r\n database?: string,\r\n ): string {\r\n let tablePath = [tableName]\r\n\r\n if (database) {\r\n tablePath.unshift(database)\r\n }\r\n\r\n return tablePath.join(\".\")\r\n }\r\n\r\n /**\r\n * Parse a target table name or other types and return a normalized table definition.\r\n */\r\n parseTableName(\r\n target: EntityMetadata | Table | View | TableForeignKey | string,\r\n ): { database?: string; schema?: string; tableName: string } {\r\n const driverDatabase = this.database\r\n const driverSchema = undefined\r\n\r\n if (InstanceChecker.isTable(target) || InstanceChecker.isView(target)) {\r\n const parsed = this.parseTableName(target.name)\r\n\r\n return {\r\n database: target.database || parsed.database || driverDatabase,\r\n schema: target.schema || parsed.schema || driverSchema,\r\n tableName: parsed.tableName,\r\n }\r\n }\r\n\r\n if (InstanceChecker.isTableForeignKey(target)) {\r\n const parsed = this.parseTableName(target.referencedTableName)\r\n\r\n return {\r\n database:\r\n target.referencedDatabase ||\r\n parsed.database ||\r\n driverDatabase,\r\n schema:\r\n target.referencedSchema || parsed.schema || driverSchema,\r\n tableName: parsed.tableName,\r\n }\r\n }\r\n\r\n if (InstanceChecker.isEntityMetadata(target)) {\r\n // EntityMetadata tableName is never a path\r\n\r\n return {\r\n database: target.database || driverDatabase,\r\n schema: target.schema || driverSchema,\r\n tableName: target.tableName,\r\n }\r\n }\r\n\r\n const parts = target.split(\".\")\r\n\r\n return {\r\n database:\r\n (parts.length > 1 ? parts[0] : undefined) || driverDatabase,\r\n schema: driverSchema,\r\n tableName: parts.length > 1 ? parts[1] : parts[0],\r\n }\r\n }\r\n\r\n /**\r\n * Prepares given value to a value to be persisted, based on its column type and metadata.\r\n */\r\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\r\n if (columnMetadata.transformer)\r\n value = ApplyValueTransformers.transformTo(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n\r\n if (value === null || value === undefined) return value\r\n\r\n if (columnMetadata.type === Boolean) {\r\n return value === true ? 1 : 0\r\n } else if (columnMetadata.type === \"date\") {\r\n return DateUtils.mixedDateToDateString(value)\r\n } else if (columnMetadata.type === \"time\") {\r\n return DateUtils.mixedDateToTimeString(value)\r\n } else if (columnMetadata.type === \"json\") {\r\n return JSON.stringify(value)\r\n } else if (\r\n columnMetadata.type === \"timestamp\" ||\r\n columnMetadata.type === \"datetime\" ||\r\n columnMetadata.type === Date\r\n ) {\r\n return DateUtils.mixedDateToDate(value)\r\n } else if (columnMetadata.type === \"simple-array\") {\r\n return DateUtils.simpleArrayToString(value)\r\n } else if (columnMetadata.type === \"simple-json\") {\r\n return DateUtils.simpleJsonToString(value)\r\n } else if (\r\n columnMetadata.type === \"enum\" ||\r\n columnMetadata.type === \"simple-enum\"\r\n ) {\r\n return \"\" + value\r\n } else if (columnMetadata.type === \"set\") {\r\n return DateUtils.simpleArrayToString(value)\r\n } else if (columnMetadata.type === Number) {\r\n // convert to number if number\r\n value = !isNaN(+value) ? parseInt(value) : value\r\n }\r\n\r\n return value\r\n }\r\n\r\n /**\r\n * Prepares given value to a value to be persisted, based on its column type or metadata.\r\n */\r\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\r\n if (value === null || value === undefined)\r\n return columnMetadata.transformer\r\n ? ApplyValueTransformers.transformFrom(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n : value\r\n\r\n if (\r\n columnMetadata.type === Boolean ||\r\n columnMetadata.type === \"bool\" ||\r\n columnMetadata.type === \"boolean\"\r\n ) {\r\n value = value ? true : false\r\n } else if (\r\n columnMetadata.type === \"datetime\" ||\r\n columnMetadata.type === Date\r\n ) {\r\n value = DateUtils.normalizeHydratedDate(value)\r\n } else if (columnMetadata.type === \"date\") {\r\n value = DateUtils.mixedDateToDateString(value)\r\n } else if (columnMetadata.type === \"json\") {\r\n value = typeof value === \"string\" ? JSON.parse(value) : value\r\n } else if (columnMetadata.type === \"time\") {\r\n value = DateUtils.mixedTimeToString(value)\r\n } else if (columnMetadata.type === \"simple-array\") {\r\n value = DateUtils.stringToSimpleArray(value)\r\n } else if (columnMetadata.type === \"simple-json\") {\r\n value = DateUtils.stringToSimpleJson(value)\r\n } else if (\r\n (columnMetadata.type === \"enum\" ||\r\n columnMetadata.type === \"simple-enum\") &&\r\n columnMetadata.enum &&\r\n !isNaN(value) &&\r\n columnMetadata.enum.indexOf(parseInt(value)) >= 0\r\n ) {\r\n // convert to number if that exists in possible enum options\r\n value = parseInt(value)\r\n } else if (columnMetadata.type === \"set\") {\r\n value = DateUtils.stringToSimpleArray(value)\r\n } else if (columnMetadata.type === Number) {\r\n // convert to number if number\r\n value = !isNaN(+value) ? parseInt(value) : value\r\n }\r\n\r\n if (columnMetadata.transformer)\r\n value = ApplyValueTransformers.transformFrom(\r\n columnMetadata.transformer,\r\n value,\r\n )\r\n\r\n return value\r\n }\r\n\r\n /**\r\n * Creates a database type from a given column metadata.\r\n */\r\n normalizeType(column: {\r\n type: ColumnType\r\n length?: number | string\r\n precision?: number | null\r\n scale?: number\r\n }): string {\r\n if (column.type === Number || column.type === \"integer\") {\r\n return \"int\"\r\n } else if (column.type === String) {\r\n return \"varchar\"\r\n } else if (column.type === Date) {\r\n return \"datetime\"\r\n } else if ((column.type as any) === Buffer) {\r\n return \"blob\"\r\n } else if (column.type === Boolean) {\r\n return \"tinyint\"\r\n } else if (column.type === \"uuid\" && !this.uuidColumnTypeSuported) {\r\n return \"varchar\"\r\n } else if (\r\n column.type === \"json\" &&\r\n this.options.type === \"mariadb\" &&\r\n !VersionUtils.isGreaterOrEqual(this.version ?? \"0.0.0\", \"10.4.3\")\r\n ) {\r\n /*\r\n * MariaDB implements this as a LONGTEXT rather, as the JSON data type contradicts the SQL standard,\r\n * and MariaDB's benchmarks indicate that performance is at least equivalent.\r\n *\r\n * @see https://mariadb.com/kb/en/json-data-type/\r\n * if Version is 10.4.3 or greater, JSON is an alias for longtext and an automatic check_json(column) constraint is added\r\n */\r\n return \"longtext\"\r\n } else if (\r\n column.type === \"simple-array\" ||\r\n column.type === \"simple-json\"\r\n ) {\r\n return \"text\"\r\n } else if (column.type === \"simple-enum\") {\r\n return \"enum\"\r\n } else if (\r\n column.type === \"double precision\" ||\r\n column.type === \"real\"\r\n ) {\r\n return \"double\"\r\n } else if (\r\n column.type === \"dec\" ||\r\n column.type === \"numeric\" ||\r\n column.type === \"fixed\"\r\n ) {\r\n return \"decimal\"\r\n } else if (column.type === \"bool\" || column.type === \"boolean\") {\r\n return \"tinyint\"\r\n } else if (\r\n column.type === \"nvarchar\" ||\r\n column.type === \"national varchar\"\r\n ) {\r\n return \"varchar\"\r\n } else if (column.type === \"nchar\" || column.type === \"national char\") {\r\n return \"char\"\r\n } else {\r\n return (column.type as string) || \"\"\r\n }\r\n }\r\n\r\n /**\r\n * Normalizes \"default\" value of the column.\r\n */\r\n normalizeDefault(columnMetadata: ColumnMetadata): string | undefined {\r\n const defaultValue = columnMetadata.default\r\n\r\n if (defaultValue === null) {\r\n return undefined\r\n }\r\n\r\n if (\r\n (columnMetadata.type === \"enum\" ||\r\n columnMetadata.type === \"simple-enum\" ||\r\n typeof defaultValue === \"string\") &&\r\n defaultValue !== undefined\r\n ) {\r\n return `'${defaultValue}'`\r\n }\r\n\r\n if (columnMetadata.type === \"set\" && defaultValue !== undefined) {\r\n return `'${DateUtils.simpleArrayToString(defaultValue)}'`\r\n }\r\n\r\n if (typeof defaultValue === \"number\") {\r\n return `'${defaultValue.toFixed(columnMetadata.scale)}'`\r\n }\r\n\r\n if (typeof defaultValue === \"boolean\") {\r\n return defaultValue ? \"1\" : \"0\"\r\n }\r\n\r\n if (typeof defaultValue === \"function\") {\r\n const value = defaultValue()\r\n return this.normalizeDatetimeFunction(value)\r\n }\r\n\r\n if (defaultValue === undefined) {\r\n return undefined\r\n }\r\n\r\n return `${defaultValue}`\r\n }\r\n\r\n /**\r\n * Normalizes \"isUnique\" value of the column.\r\n */\r\n normalizeIsUnique(column: ColumnMetadata): boolean {\r\n return column.entityMetadata.indices.some(\r\n (idx) =>\r\n idx.isUnique &&\r\n idx.columns.length === 1 &&\r\n idx.columns[0] === column,\r\n )\r\n }\r\n\r\n /**\r\n * Returns default column lengths, which is required on column creation.\r\n */\r\n getColumnLength(column: ColumnMetadata | TableColumn): string {\r\n if (column.length) return column.length.toString()\r\n\r\n /**\r\n * fix https://github.com/typeorm/typeorm/issues/1139\r\n * note that if the db did support uuid column type it wouldn't have been defaulted to varchar\r\n */\r\n if (\r\n column.generationStrategy === \"uuid\" &&\r\n !this.uuidColumnTypeSuported\r\n )\r\n return \"36\"\r\n\r\n switch (column.type) {\r\n case String:\r\n case \"varchar\":\r\n case \"nvarchar\":\r\n case \"national varchar\":\r\n return \"255\"\r\n case \"varbinary\":\r\n return \"255\"\r\n default:\r\n return \"\"\r\n }\r\n }\r\n\r\n /**\r\n * Creates column type definition including length, precision and scale\r\n */\r\n createFullType(column: TableColumn): string {\r\n let type = column.type\r\n\r\n // used 'getColumnLength()' method, because MySQL requires column length for `varchar`, `nvarchar` and `varbinary` data types\r\n if (this.getColumnLength(column)) {\r\n type += `(${this.getColumnLength(column)})`\r\n } else if (column.width) {\r\n type += `(${column.width})`\r\n } else if (\r\n column.precision !== null &&\r\n column.precision !== undefined &&\r\n column.scale !== null &&\r\n column.scale !== undefined\r\n ) {\r\n type += `(${column.precision},${column.scale})`\r\n } else if (\r\n column.precision !== null &&\r\n column.precision !== undefined\r\n ) {\r\n type += `(${column.precision})`\r\n }\r\n\r\n if (column.isArray) type += \" array\"\r\n\r\n return type\r\n }\r\n\r\n /**\r\n * Obtains a new database connection to a master server.\r\n * Used for replication.\r\n * If replication is not setup then returns default connection's database connection.\r\n */\r\n obtainMasterConnection(): Promise<any> {\r\n return new Promise<any>((ok, fail) => {\r\n if (this.poolCluster) {\r\n this.poolCluster.getConnection(\r\n \"MASTER\",\r\n (err: any, dbConnection: any) => {\r\n err\r\n ? fail(err)\r\n : ok(this.prepareDbConnection(dbConnection))\r\n },\r\n )\r\n } else if (this.pool) {\r\n this.pool.getConnection((err: any, dbConnection: any) => {\r\n err ? fail(err) : ok(this.prepareDbConnection(dbConnection))\r\n })\r\n } else {\r\n fail(\r\n new TypeORMError(\r\n `Connection is not established with mysql database`,\r\n ),\r\n )\r\n }\r\n })\r\n }\r\n\r\n /**\r\n * Obtains a new database connection to a slave server.\r\n * Used for replication.\r\n * If replication is not setup then returns master (default) connection's database connection.\r\n */\r\n obtainSlaveConnection(): Promise<any> {\r\n if (!this.poolCluster) return this.obtainMasterConnection()\r\n\r\n return new Promise<any>((ok, fail) => {\r\n this.poolCluster.getConnection(\r\n \"SLAVE*\",\r\n (err: any, dbConnection: any) => {\r\n err ? fail(err) : ok(this.prepareDbConnection(dbConnection))\r\n },\r\n )\r\n })\r\n }\r\n\r\n /**\r\n * Creates generated map of values generated or returned by database after INSERT query.\r\n */\r\n createGeneratedMap(\r\n metadata: EntityMetadata,\r\n insertResult: any,\r\n entityIndex: number,\r\n ) {\r\n if (!insertResult) {\r\n return undefined\r\n }\r\n\r\n if (insertResult.insertId === undefined) {\r\n return Object.keys(insertResult).reduce((map, key) => {\r\n const column = metadata.findColumnWithDatabaseName(key)\r\n if (column) {\r\n OrmUtils.mergeDeep(\r\n map,\r\n column.createValueMap(insertResult[key]),\r\n )\r\n // OrmUtils.mergeDeep(map, column.createValueMap(this.prepareHydratedValue(insertResult[key], column))); // TODO: probably should be like there, but fails on enums, fix later\r\n }\r\n return map\r\n }, {} as ObjectLiteral)\r\n }\r\n\r\n const generatedMap = metadata.generatedColumns.reduce(\r\n (map, generatedColumn) => {\r\n let value: any\r\n if (\r\n generatedColumn.generationStrategy === \"increment\" &&\r\n insertResult.insertId\r\n ) {\r\n // NOTE: When multiple rows is inserted by a single INSERT statement,\r\n // `insertId` is the value generated for the first inserted row only.\r\n value = insertResult.insertId + entityIndex\r\n // } else if (generatedColumn.generationStrategy === \"uuid\") {\r\n // console.log(\"getting db value:\", generatedColumn.databaseName);\r\n // value = generatedColumn.getEntityValue(uuidMap);\r\n }\r\n\r\n return OrmUtils.mergeDeep(\r\n map,\r\n generatedColumn.createValueMap(value),\r\n )\r\n },\r\n {} as ObjectLiteral,\r\n )\r\n\r\n return Object.keys(generatedMap).length > 0 ? generatedMap : undefined\r\n }\r\n\r\n /**\r\n * Differentiate columns of this table and columns from the given column metadatas columns\r\n * and returns only changed.\r\n */\r\n findChangedColumns(\r\n tableColumns: TableColumn[],\r\n columnMetadatas: ColumnMetadata[],\r\n ): ColumnMetadata[] {\r\n return columnMetadatas.filter((columnMetadata) => {\r\n const tableColumn = tableColumns.find(\r\n (c) => c.name === columnMetadata.databaseName,\r\n )\r\n if (!tableColumn) return false // we don't need new columns, we only need exist and changed\r\n\r\n const isColumnChanged =\r\n tableColumn.name !== columnMetadata.databaseName ||\r\n this.isColumnDataTypeChanged(tableColumn, columnMetadata) ||\r\n tableColumn.length !== this.getColumnLength(columnMetadata) ||\r\n tableColumn.width !== columnMetadata.width ||\r\n (columnMetadata.precision !== undefined &&\r\n tableColumn.precision !== columnMetadata.precision) ||\r\n (columnMetadata.scale !== undefined &&\r\n tableColumn.scale !== columnMetadata.scale) ||\r\n tableColumn.zerofill !== columnMetadata.zerofill ||\r\n tableColumn.unsigned !== columnMetadata.unsigned ||\r\n tableColumn.asExpression !== columnMetadata.asExpression ||\r\n tableColumn.generatedType !== columnMetadata.generatedType ||\r\n tableColumn.comment !==\r\n this.escapeComment(columnMetadata.comment) ||\r\n !this.compareDefaultValues(\r\n this.normalizeDefault(columnMetadata),\r\n tableColumn.default,\r\n ) ||\r\n (tableColumn.enum &&\r\n columnMetadata.enum &&\r\n !OrmUtils.isArraysEqual(\r\n tableColumn.enum,\r\n columnMetadata.enum.map((val) => val + \"\"),\r\n )) ||\r\n tableColumn.onUpdate !==\r\n this.normalizeDatetimeFunction(columnMetadata.onUpdate) ||\r\n tableColumn.isPrimary !== columnMetadata.isPrimary ||\r\n !this.compareNullableValues(columnMetadata, tableColumn) ||\r\n tableColumn.isUnique !==\r\n this.normalizeIsUnique(columnMetadata) ||\r\n (columnMetadata.generationStrategy !== \"uuid\" &&\r\n tableColumn.isGenerated !== columnMetadata.isGenerated)\r\n\r\n // DEBUG SECTION\r\n // if (isColumnChanged) {\r\n // console.log(\"table:\", columnMetadata.entityMetadata.tableName)\r\n // console.log(\r\n // \"name:\",\r\n // tableColumn.name,\r\n // columnMetadata.databaseName,\r\n // )\r\n // console.log(\r\n // \"type:\",\r\n // tableColumn.type,\r\n // this.normalizeType(columnMetadata),\r\n // )\r\n // console.log(\r\n // \"length:\",\r\n // tableColumn.length,\r\n // columnMetadata.length,\r\n // )\r\n // console.log(\"width:\", tableColumn.width, columnMetadata.width)\r\n // console.log(\r\n // \"precision:\",\r\n // tableColumn.precision,\r\n // columnMetadata.precision,\r\n // )\r\n // console.log(\"scale:\", tableColumn.scale, columnMetadata.scale)\r\n // console.log(\r\n // \"zerofill:\",\r\n // tableColumn.zerofill,\r\n // columnMetadata.zerofill,\r\n // )\r\n // console.log(\r\n // \"unsigned:\",\r\n // tableColumn.unsigned,\r\n // columnMetadata.unsigned,\r\n // )\r\n // console.log(\r\n // \"asExpression:\",\r\n // tableColumn.asExpression,\r\n // columnMetadata.asExpression,\r\n // )\r\n // console.log(\r\n // \"generatedType:\",\r\n // tableColumn.generatedType,\r\n // columnMetadata.generatedType,\r\n // )\r\n // console.log(\r\n // \"comment:\",\r\n // tableColumn.comment,\r\n // this.escapeComment(columnMetadata.comment),\r\n // )\r\n // console.log(\r\n // \"default:\",\r\n // tableColumn.default,\r\n // this.normalizeDefault(columnMetadata),\r\n // )\r\n // console.log(\"enum:\", tableColumn.enum, columnMetadata.enum)\r\n // console.log(\r\n // \"default changed:\",\r\n // !this.compareDefaultValues(\r\n // this.normalizeDefault(columnMetadata),\r\n // tableColumn.default,\r\n // ),\r\n // )\r\n // console.log(\r\n // \"isPrimary:\",\r\n // tableColumn.isPrimary,\r\n // columnMetadata.isPrimary,\r\n // )\r\n // console.log(\r\n // \"isNullable changed:\",\r\n // !this.compareNullableValues(columnMetadata, tableColumn),\r\n // )\r\n // console.log(\r\n // \"isUnique:\",\r\n // tableColumn.isUnique,\r\n // this.normalizeIsUnique(columnMetadata),\r\n // )\r\n // console.log(\r\n // \"isGenerated:\",\r\n // tableColumn.isGenerated,\r\n // columnMetadata.isGenerated,\r\n // )\r\n // console.log(\r\n // columnMetadata.generationStrategy !== \"uuid\" &&\r\n // tableColumn.isGenerated !== columnMetadata.isGenerated,\r\n // )\r\n // console.log(\"==========================================\")\r\n // }\r\n\r\n return isColumnChanged\r\n })\r\n }\r\n\r\n /**\r\n * Returns true if driver supports RETURNING / OUTPUT statement.\r\n */\r\n isReturningSqlSupported(returningType: ReturningType): boolean {\r\n return this._isReturningSqlSupported[returningType]\r\n }\r\n\r\n /**\r\n * Returns true if driver supports uuid values generation on its own.\r\n */\r\n isUUIDGenerationSupported(): boolean {\r\n return false\r\n }\r\n\r\n /**\r\n * Returns true if driver supports fulltext indices.\r\n */\r\n isFullTextColumnTypeSupported(): boolean {\r\n return true\r\n }\r\n\r\n /**\r\n * Creates an escaped parameter.\r\n */\r\n createParameter(parameterName: string, index: number): string {\r\n return \"?\"\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Protected Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Loads all driver dependencies.\r\n */\r\n protected loadDependencies(): void {\r\n const connectorPackage = this.options.connectorPackage ?? \"mysql\"\r\n const fallbackConnectorPackage =\r\n connectorPackage === \"mysql\"\r\n ? (\"mysql2\" as const)\r\n : (\"mysql\" as const)\r\n try {\r\n // try to load first supported package\r\n const mysql =\r\n this.options.driver || PlatformTools.load(connectorPackage)\r\n this.mysql = mysql\r\n /*\r\n * Some frameworks (such as Jest) may mess up Node's require cache and provide garbage for the 'mysql' module\r\n * if it was not installed. We check that the object we got actually contains something otherwise we treat\r\n * it as if the `require` call failed.\r\n *\r\n * @see https://github.com/typeorm/typeorm/issues/1373\r\n */\r\n if (Object.keys(this.mysql).length === 0) {\r\n throw new TypeORMError(\r\n `'${connectorPackage}' was found but it is empty. Falling back to '${fallbackConnectorPackage}'.`,\r\n )\r\n }\r\n } catch (e) {\r\n try {\r\n this.mysql = PlatformTools.load(fallbackConnectorPackage) // try to load second supported package\r\n } catch (e) {\r\n throw new DriverPackageNotInstalledError(\r\n \"Mysql\",\r\n connectorPackage,\r\n )\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Creates a new connection pool for a given database credentials.\r\n */\r\n protected createConnectionOptions(\r\n options: MysqlConnectionOptions,\r\n credentials: MysqlConnectionCredentialsOptions,\r\n ): Promise<any> {\r\n credentials = Object.assign(\r\n {},\r\n credentials,\r\n DriverUtils.buildDriverOptions(credentials),\r\n ) // todo: do it better way\r\n\r\n // build connection options for the driver\r\n return Object.assign(\r\n {},\r\n {\r\n charset: options.charset,\r\n timezone: options.timezone,\r\n connectTimeout: options.connectTimeout,\r\n insecureAuth: options.insecureAuth,\r\n supportBigNumbers:\r\n options.supportBigNumbers !== undefined\r\n ? options.supportBigNumbers\r\n : true,\r\n bigNumberStrings:\r\n options.bigNumberStrings !== undefined\r\n ? options.bigNumberStrings\r\n : true,\r\n dateStrings: options.dateStrings,\r\n debug: options.debug,\r\n trace: options.trace,\r\n multipleStatements: options.multipleStatements,\r\n flags: options.flags,\r\n },\r\n {\r\n host: credentials.host,\r\n user: credentials.username,\r\n password: credentials.password,\r\n database: credentials.database,\r\n port: credentials.port,\r\n ssl: options.ssl,\r\n socketPath: credentials.socketPath,\r\n },\r\n options.acquireTimeout === undefined\r\n ? {}\r\n : { acquireTimeout: options.acquireTimeout },\r\n { connectionLimit: options.poolSize },\r\n options.extra || {},\r\n )\r\n }\r\n\r\n /**\r\n * Creates a new connection pool for a given database credentials.\r\n */\r\n protected createPool(connectionOptions: any): Promise<any> {\r\n // create a connection pool\r\n const pool = this.mysql.createPool(connectionOptions)\r\n\r\n // make sure connection is working fine\r\n return new Promise<void>((ok, fail) => {\r\n // (issue #610) we make first connection to database to make sure if connection credentials are wrong\r\n // we give error before calling any other method that creates actual query runner\r\n pool.getConnection((err: any, connection: any) => {\r\n if (err) return pool.end(() => fail(err))\r\n\r\n connection.release()\r\n ok(pool)\r\n })\r\n })\r\n }\r\n\r\n /**\r\n * Attaches all required base handlers to a database connection, such as the unhandled error handler.\r\n */\r\n private prepareDbConnection(connection: any): any {\r\n const { logger } = this.connection\r\n /*\r\n * Attaching an error handler to connection errors is essential, as, otherwise, errors raised will go unhandled and\r\n * cause the hosting app to crash.\r\n */\r\n if (connection.listeners(\"error\").length === 0) {\r\n connection.on(\"error\", (error: any) =>\r\n logger.log(\r\n \"warn\",\r\n `MySQL connection raised an error. ${error}`,\r\n ),\r\n )\r\n }\r\n return connection\r\n }\r\n\r\n /**\r\n * Checks if \"DEFAULT\" values in the column metadata and in the database are equal.\r\n */\r\n protected compareDefaultValues(\r\n columnMetadataValue: string | undefined,\r\n databaseValue: string | undefined,\r\n ): boolean {\r\n if (\r\n typeof columnMetadataValue === \"string\" &&\r\n typeof databaseValue === \"string\"\r\n ) {\r\n // we need to cut out \"'\" because in mysql we can understand returned value is a string or a function\r\n // as result compare cannot understand if default is really changed or not\r\n columnMetadataValue = columnMetadataValue.replace(/^'+|'+$/g, \"\")\r\n databaseValue = databaseValue.replace(/^'+|'+$/g, \"\")\r\n }\r\n\r\n return columnMetadataValue === databaseValue\r\n }\r\n\r\n compareNullableValues(\r\n columnMetadata: ColumnMetadata,\r\n tableColumn: TableColumn,\r\n ): boolean {\r\n // MariaDB does not support NULL/NOT NULL expressions for generated columns\r\n const isMariaDb = this.options.type === \"mariadb\"\r\n if (isMariaDb && columnMetadata.generatedType) {\r\n return true\r\n }\r\n\r\n return columnMetadata.isNullable === tableColumn.isNullable\r\n }\r\n\r\n /**\r\n * If parameter is a datetime function, e.g. \"CURRENT_TIMESTAMP\", normalizes it.\r\n * Otherwise returns original input.\r\n */\r\n protected normalizeDatetimeFunction(value?: string) {\r\n if (!value) return value\r\n\r\n // check if input is datetime function\r\n const isDatetimeFunction =\r\n value.toUpperCase().indexOf(\"CURRENT_TIMESTAMP\") !== -1 ||\r\n value.toUpperCase().indexOf(\"NOW\") !== -1\r\n\r\n if (isDatetimeFunction) {\r\n // extract precision, e.g. \"(3)\"\r\n const precision = value.match(/\\(\\d+\\)/)\r\n if (this.options.type === \"mariadb\") {\r\n return precision\r\n ? `CURRENT_TIMESTAMP${precision[0]}`\r\n : \"CURRENT_TIMESTAMP()\"\r\n } else {\r\n return precision\r\n ? `CURRENT_TIMESTAMP${precision[0]}`\r\n : \"CURRENT_TIMESTAMP\"\r\n }\r\n } else {\r\n return value\r\n }\r\n }\r\n\r\n /**\r\n * Escapes a given comment.\r\n */\r\n protected escapeComment(comment?: string) {\r\n if (!comment) return comment\r\n\r\n comment = comment.replace(/\\u0000/g, \"\") // Null bytes aren't allowed in comments\r\n\r\n return comment\r\n }\r\n\r\n /**\r\n * A helper to check if column data types have changed\r\n * This can be used to manage checking any types the\r\n * database may alias\r\n */\r\n private isColumnDataTypeChanged(\r\n tableColumn: TableColumn,\r\n columnMetadata: ColumnMetadata,\r\n ) {\r\n // this is an exception for mariadb versions where json is an alias for longtext\r\n if (\r\n this.normalizeType(columnMetadata) === \"json\" &&\r\n tableColumn.type.toLowerCase() === \"longtext\"\r\n )\r\n return false\r\n return tableColumn.type !== this.normalizeType(columnMetadata)\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/driver/mysql/MysqlDriver.ts"],"names":[],"mappings":"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","file":"MysqlDriver.js","sourcesContent":["import { Driver, ReturningType } from \"../Driver\"\nimport { ConnectionIsNotSetError } from \"../../error/ConnectionIsNotSetError\"\nimport { DriverPackageNotInstalledError } from \"../../error/DriverPackageNotInstalledError\"\nimport { DriverUtils } from \"../DriverUtils\"\nimport { CteCapabilities } from \"../types/CteCapabilities\"\nimport { MysqlQueryRunner } from \"./MysqlQueryRunner\"\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { ColumnMetadata } from \"../../metadata/ColumnMetadata\"\nimport { DateUtils } from \"../../util/DateUtils\"\nimport { PlatformTools } from \"../../platform/PlatformTools\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { RdbmsSchemaBuilder } from \"../../schema-builder/RdbmsSchemaBuilder\"\nimport { MysqlConnectionOptions } from \"./MysqlConnectionOptions\"\nimport { MappedColumnTypes } from \"../types/MappedColumnTypes\"\nimport { ColumnType } from \"../types/ColumnTypes\"\nimport { DataTypeDefaults } from \"../types/DataTypeDefaults\"\nimport { TableColumn } from \"../../schema-builder/table/TableColumn\"\nimport { MysqlConnectionCredentialsOptions } from \"./MysqlConnectionCredentialsOptions\"\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { OrmUtils } from \"../../util/OrmUtils\"\nimport { ApplyValueTransformers } from \"../../util/ApplyValueTransformers\"\nimport { ReplicationMode } from \"../types/ReplicationMode\"\nimport { TypeORMError } from \"../../error\"\nimport { Table } from \"../../schema-builder/table/Table\"\nimport { View } from \"../../schema-builder/view/View\"\nimport { TableForeignKey } from \"../../schema-builder/table/TableForeignKey\"\nimport { VersionUtils } from \"../../util/VersionUtils\"\nimport { InstanceChecker } from \"../../util/InstanceChecker\"\nimport { UpsertType } from \"../types/UpsertType\"\n\n/**\n * Organizes communication with MySQL DBMS.\n */\nexport class MysqlDriver implements Driver {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection used by driver.\n */\n connection: DataSource\n\n /**\n * Mysql underlying library.\n */\n mysql: any\n\n /**\n * Connection pool.\n * Used in non-replication mode.\n */\n pool: any\n\n /**\n * Pool cluster used in replication mode.\n */\n poolCluster: any\n\n // -------------------------------------------------------------------------\n // Public Implemented Properties\n // -------------------------------------------------------------------------\n\n /**\n * Connection options.\n */\n options: MysqlConnectionOptions\n\n /**\n * Version of MySQL. Requires a SQL query to the DB, so it is not always set\n */\n version?: string\n\n /**\n * Master database used to perform all write queries.\n */\n database?: string\n\n /**\n * Indicates if replication is enabled.\n */\n isReplicated: boolean = false\n\n /**\n * Indicates if tree tables are supported by this driver.\n */\n treeSupport = true\n\n /**\n * Represent transaction support by this driver\n */\n transactionSupport = \"nested\" as const\n\n /**\n * Gets list of supported column data types by a driver.\n *\n * @see https://www.tutorialspoint.com/mysql/mysql-data-types.htm\n * @see https://dev.mysql.com/doc/refman/8.0/en/data-types.html\n */\n supportedDataTypes: ColumnType[] = [\n // numeric types\n \"bit\",\n \"int\",\n \"integer\", // synonym for int\n \"tinyint\",\n \"smallint\",\n \"mediumint\",\n \"bigint\",\n \"float\",\n \"double\",\n \"double precision\", // synonym for double\n \"real\", // synonym for double\n \"decimal\",\n \"dec\", // synonym for decimal\n \"numeric\", // synonym for decimal\n \"fixed\", // synonym for decimal\n \"bool\", // synonym for tinyint\n \"boolean\", // synonym for tinyint\n // date and time types\n \"date\",\n \"datetime\",\n \"timestamp\",\n \"time\",\n \"year\",\n // string types\n \"char\",\n \"nchar\", // synonym for national char\n \"national char\",\n \"varchar\",\n \"nvarchar\", // synonym for national varchar\n \"national varchar\",\n \"blob\",\n \"text\",\n \"tinyblob\",\n \"tinytext\",\n \"mediumblob\",\n \"mediumtext\",\n \"longblob\",\n \"longtext\",\n \"enum\",\n \"set\",\n \"binary\",\n \"varbinary\",\n // json data type\n \"json\",\n // spatial data types\n \"geometry\",\n \"point\",\n \"linestring\",\n \"polygon\",\n \"multipoint\",\n \"multilinestring\",\n \"multipolygon\",\n \"geometrycollection\",\n // additional data types for mariadb\n \"uuid\",\n \"inet4\",\n \"inet6\",\n ]\n\n /**\n * Returns type of upsert supported by driver if any\n */\n supportedUpsertTypes: UpsertType[] = [\"on-duplicate-key-update\"]\n\n /**\n * Gets list of spatial column data types.\n */\n spatialTypes: ColumnType[] = [\n \"geometry\",\n \"point\",\n \"linestring\",\n \"polygon\",\n \"multipoint\",\n \"multilinestring\",\n \"multipolygon\",\n \"geometrycollection\",\n ]\n\n /**\n * Gets list of column data types that support length by a driver.\n */\n withLengthColumnTypes: ColumnType[] = [\n \"char\",\n \"varchar\",\n \"nvarchar\",\n \"binary\",\n \"varbinary\",\n ]\n\n /**\n * Gets list of column data types that support length by a driver.\n */\n withWidthColumnTypes: ColumnType[] = [\n \"bit\",\n \"tinyint\",\n \"smallint\",\n \"mediumint\",\n \"int\",\n \"integer\",\n \"bigint\",\n ]\n\n /**\n * Gets list of column data types that support precision by a driver.\n */\n withPrecisionColumnTypes: ColumnType[] = [\n \"decimal\",\n \"dec\",\n \"numeric\",\n \"fixed\",\n \"float\",\n \"double\",\n \"double precision\",\n \"real\",\n \"time\",\n \"datetime\",\n \"timestamp\",\n ]\n\n /**\n * Gets list of column data types that supports scale by a driver.\n */\n withScaleColumnTypes: ColumnType[] = [\n \"decimal\",\n \"dec\",\n \"numeric\",\n \"fixed\",\n \"float\",\n \"double\",\n \"double precision\",\n \"real\",\n ]\n\n /**\n * Gets list of column data types that supports UNSIGNED and ZEROFILL attributes.\n */\n unsignedAndZerofillTypes: ColumnType[] = [\n \"int\",\n \"integer\",\n \"smallint\",\n \"tinyint\",\n \"mediumint\",\n \"bigint\",\n \"decimal\",\n \"dec\",\n \"numeric\",\n \"fixed\",\n \"float\",\n \"double\",\n \"double precision\",\n \"real\",\n ]\n\n /**\n * ORM has special columns and we need to know what database column types should be for those columns.\n * Column types are driver dependant.\n */\n mappedDataTypes: MappedColumnTypes = {\n createDate: \"datetime\",\n createDatePrecision: 6,\n createDateDefault: \"CURRENT_TIMESTAMP(6)\",\n updateDate: \"datetime\",\n updateDatePrecision: 6,\n updateDateDefault: \"CURRENT_TIMESTAMP(6)\",\n deleteDate: \"datetime\",\n deleteDatePrecision: 6,\n deleteDateNullable: true,\n version: \"int\",\n treeLevel: \"int\",\n migrationId: \"int\",\n migrationName: \"varchar\",\n migrationTimestamp: \"bigint\",\n cacheId: \"int\",\n cacheIdentifier: \"varchar\",\n cacheTime: \"bigint\",\n cacheDuration: \"int\",\n cacheQuery: \"text\",\n cacheResult: \"text\",\n metadataType: \"varchar\",\n metadataDatabase: \"varchar\",\n metadataSchema: \"varchar\",\n metadataTable: \"varchar\",\n metadataName: \"varchar\",\n metadataValue: \"text\",\n }\n\n /**\n * Default values of length, precision and scale depends on column data type.\n * Used in the cases when length/precision/scale is not specified by user.\n */\n dataTypeDefaults: DataTypeDefaults = {\n varchar: { length: 255 },\n nvarchar: { length: 255 },\n \"national varchar\": { length: 255 },\n char: { length: 1 },\n binary: { length: 1 },\n varbinary: { length: 255 },\n decimal: { precision: 10, scale: 0 },\n dec: { precision: 10, scale: 0 },\n numeric: { precision: 10, scale: 0 },\n fixed: { precision: 10, scale: 0 },\n float: { precision: 12 },\n double: { precision: 22 },\n time: { precision: 0 },\n datetime: { precision: 0 },\n timestamp: { precision: 0 },\n bit: { width: 1 },\n int: { width: 11 },\n integer: { width: 11 },\n tinyint: { width: 4 },\n smallint: { width: 6 },\n mediumint: { width: 9 },\n bigint: { width: 20 },\n }\n\n /**\n * Max length allowed by MySQL for aliases.\n * @see https://dev.mysql.com/doc/refman/5.5/en/identifiers.html\n */\n maxAliasLength = 63\n\n cteCapabilities: CteCapabilities = {\n enabled: false,\n requiresRecursiveHint: true,\n }\n\n /**\n * Supported returning types\n */\n private readonly _isReturningSqlSupported: Record<ReturningType, boolean> =\n {\n delete: false,\n insert: false,\n update: false,\n }\n\n /** MariaDB supports uuid type for version 10.7.0 and up */\n private uuidColumnTypeSuported = false\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(connection: DataSource) {\n this.connection = connection\n this.options = {\n legacySpatialSupport: true,\n ...connection.options,\n } as MysqlConnectionOptions\n this.isReplicated = this.options.replication ? true : false\n\n // load mysql package\n this.loadDependencies()\n\n this.database = DriverUtils.buildDriverOptions(\n this.options.replication\n ? this.options.replication.master\n : this.options,\n ).database\n\n // validate options to make sure everything is set\n // todo: revisit validation with replication in mind\n // if (!(this.options.host || (this.options.extra && this.options.extra.socketPath)) && !this.options.socketPath)\n // throw new DriverOptionNotSetError(\"socketPath and host\");\n // if (!this.options.username)\n // throw new DriverOptionNotSetError(\"username\");\n // if (!this.options.database)\n // throw new DriverOptionNotSetError(\"database\");\n // todo: check what is going on when connection is setup without database and how to connect to a database then?\n // todo: provide options to auto-create a database if it does not exist yet\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Performs connection to the database.\n */\n async connect(): Promise<void> {\n if (this.options.replication) {\n this.poolCluster = this.mysql.createPoolCluster(\n this.options.replication,\n )\n this.options.replication.slaves.forEach((slave, index) => {\n this.poolCluster.add(\n \"SLAVE\" + index,\n this.createConnectionOptions(this.options, slave),\n )\n })\n this.poolCluster.add(\n \"MASTER\",\n this.createConnectionOptions(\n this.options,\n this.options.replication.master,\n ),\n )\n } else {\n this.pool = await this.createPool(\n this.createConnectionOptions(this.options, this.options),\n )\n }\n\n if (!this.database) {\n const queryRunner = await this.createQueryRunner(\"master\")\n\n this.database = await queryRunner.getCurrentDatabase()\n\n await queryRunner.release()\n }\n\n const queryRunner = this.createQueryRunner(\"master\")\n const result: {\n version: string\n }[] = await queryRunner.query(`SELECT VERSION() AS \\`version\\``)\n const dbVersion = result[0].version\n this.version = dbVersion\n await queryRunner.release()\n\n if (this.options.type === \"mariadb\") {\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.0.5\")) {\n this._isReturningSqlSupported.delete = true\n }\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.5.0\")) {\n this._isReturningSqlSupported.insert = true\n }\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.2.0\")) {\n this.cteCapabilities.enabled = true\n }\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"10.7.0\")) {\n this.uuidColumnTypeSuported = true\n }\n } else if (this.options.type === \"mysql\") {\n if (VersionUtils.isGreaterOrEqual(dbVersion, \"8.0.0\")) {\n this.cteCapabilities.enabled = true\n }\n }\n }\n\n /**\n * Makes any action after connection (e.g. create extensions in Postgres driver).\n */\n afterConnect(): Promise<void> {\n return Promise.resolve()\n }\n\n /**\n * Closes connection with the database.\n */\n async disconnect(): Promise<void> {\n if (!this.poolCluster && !this.pool)\n return Promise.reject(new ConnectionIsNotSetError(\"mysql\"))\n\n if (this.poolCluster) {\n return new Promise<void>((ok, fail) => {\n this.poolCluster.end((err: any) => (err ? fail(err) : ok()))\n this.poolCluster = undefined\n })\n }\n if (this.pool) {\n return new Promise<void>((ok, fail) => {\n this.pool.end((err: any) => {\n if (err) return fail(err)\n this.pool = undefined\n ok()\n })\n })\n }\n }\n\n /**\n * Creates a schema builder used to build and sync a schema.\n */\n createSchemaBuilder() {\n return new RdbmsSchemaBuilder(this.connection)\n }\n\n /**\n * Creates a query runner used to execute database queries.\n */\n createQueryRunner(mode: ReplicationMode) {\n return new MysqlQueryRunner(this, mode)\n }\n\n /**\n * Replaces parameters in the given sql with special escaping character\n * and an array of parameter names to be passed to a query.\n */\n escapeQueryWithParameters(\n sql: string,\n parameters: ObjectLiteral,\n nativeParameters: ObjectLiteral,\n ): [string, any[]] {\n const escapedParameters: any[] = Object.keys(nativeParameters).map(\n (key) => nativeParameters[key],\n )\n if (!parameters || !Object.keys(parameters).length)\n return [sql, escapedParameters]\n\n sql = sql.replace(\n /:(\\.\\.\\.)?([A-Za-z0-9_.]+)/g,\n (full, isArray: string, key: string): string => {\n if (!parameters.hasOwnProperty(key)) {\n return full\n }\n\n let value: any = parameters[key]\n\n if (isArray) {\n return value\n .map((v: any) => {\n escapedParameters.push(v)\n return this.createParameter(\n key,\n escapedParameters.length - 1,\n )\n })\n .join(\", \")\n }\n\n if (typeof value === \"function\") {\n return value()\n }\n\n escapedParameters.push(value)\n return this.createParameter(key, escapedParameters.length - 1)\n },\n ) // todo: make replace only in value statements, otherwise problems\n return [sql, escapedParameters]\n }\n\n /**\n * Escapes a column name.\n */\n escape(columnName: string): string {\n return \"`\" + columnName + \"`\"\n }\n\n /**\n * Build full table name with database name, schema name and table name.\n * E.g. myDB.mySchema.myTable\n */\n buildTableName(\n tableName: string,\n schema?: string,\n database?: string,\n ): string {\n let tablePath = [tableName]\n\n if (database) {\n tablePath.unshift(database)\n }\n\n return tablePath.join(\".\")\n }\n\n /**\n * Parse a target table name or other types and return a normalized table definition.\n */\n parseTableName(\n target: EntityMetadata | Table | View | TableForeignKey | string,\n ): { database?: string; schema?: string; tableName: string } {\n const driverDatabase = this.database\n const driverSchema = undefined\n\n if (InstanceChecker.isTable(target) || InstanceChecker.isView(target)) {\n const parsed = this.parseTableName(target.name)\n\n return {\n database: target.database || parsed.database || driverDatabase,\n schema: target.schema || parsed.schema || driverSchema,\n tableName: parsed.tableName,\n }\n }\n\n if (InstanceChecker.isTableForeignKey(target)) {\n const parsed = this.parseTableName(target.referencedTableName)\n\n return {\n database:\n target.referencedDatabase ||\n parsed.database ||\n driverDatabase,\n schema:\n target.referencedSchema || parsed.schema || driverSchema,\n tableName: parsed.tableName,\n }\n }\n\n if (InstanceChecker.isEntityMetadata(target)) {\n // EntityMetadata tableName is never a path\n\n return {\n database: target.database || driverDatabase,\n schema: target.schema || driverSchema,\n tableName: target.tableName,\n }\n }\n\n const parts = target.split(\".\")\n\n return {\n database:\n (parts.length > 1 ? parts[0] : undefined) || driverDatabase,\n schema: driverSchema,\n tableName: parts.length > 1 ? parts[1] : parts[0],\n }\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type and metadata.\n */\n preparePersistentValue(value: any, columnMetadata: ColumnMetadata): any {\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformTo(\n columnMetadata.transformer,\n value,\n )\n\n if (value === null || value === undefined) return value\n\n if (columnMetadata.type === Boolean) {\n return value === true ? 1 : 0\n } else if (columnMetadata.type === \"date\") {\n return DateUtils.mixedDateToDateString(value)\n } else if (columnMetadata.type === \"time\") {\n return DateUtils.mixedDateToTimeString(value)\n } else if (columnMetadata.type === \"json\") {\n return JSON.stringify(value)\n } else if (\n columnMetadata.type === \"timestamp\" ||\n columnMetadata.type === \"datetime\" ||\n columnMetadata.type === Date\n ) {\n return DateUtils.mixedDateToDate(value)\n } else if (columnMetadata.type === \"simple-array\") {\n return DateUtils.simpleArrayToString(value)\n } else if (columnMetadata.type === \"simple-json\") {\n return DateUtils.simpleJsonToString(value)\n } else if (\n columnMetadata.type === \"enum\" ||\n columnMetadata.type === \"simple-enum\"\n ) {\n return \"\" + value\n } else if (columnMetadata.type === \"set\") {\n return DateUtils.simpleArrayToString(value)\n } else if (columnMetadata.type === Number) {\n // convert to number if number\n value = !isNaN(+value) ? parseInt(value) : value\n }\n\n return value\n }\n\n /**\n * Prepares given value to a value to be persisted, based on its column type or metadata.\n */\n prepareHydratedValue(value: any, columnMetadata: ColumnMetadata): any {\n if (value === null || value === undefined)\n return columnMetadata.transformer\n ? ApplyValueTransformers.transformFrom(\n columnMetadata.transformer,\n value,\n )\n : value\n\n if (\n columnMetadata.type === Boolean ||\n columnMetadata.type === \"bool\" ||\n columnMetadata.type === \"boolean\"\n ) {\n value = value ? true : false\n } else if (\n columnMetadata.type === \"datetime\" ||\n columnMetadata.type === Date\n ) {\n value = DateUtils.normalizeHydratedDate(value)\n } else if (columnMetadata.type === \"date\") {\n value = DateUtils.mixedDateToDateString(value)\n } else if (columnMetadata.type === \"json\") {\n value = typeof value === \"string\" ? JSON.parse(value) : value\n } else if (columnMetadata.type === \"time\") {\n value = DateUtils.mixedTimeToString(value)\n } else if (columnMetadata.type === \"simple-array\") {\n value = DateUtils.stringToSimpleArray(value)\n } else if (columnMetadata.type === \"simple-json\") {\n value = DateUtils.stringToSimpleJson(value)\n } else if (\n (columnMetadata.type === \"enum\" ||\n columnMetadata.type === \"simple-enum\") &&\n columnMetadata.enum &&\n !isNaN(value) &&\n columnMetadata.enum.indexOf(parseInt(value)) >= 0\n ) {\n // convert to number if that exists in possible enum options\n value = parseInt(value)\n } else if (columnMetadata.type === \"set\") {\n value = DateUtils.stringToSimpleArray(value)\n } else if (columnMetadata.type === Number) {\n // convert to number if number\n value = !isNaN(+value) ? parseInt(value) : value\n }\n\n if (columnMetadata.transformer)\n value = ApplyValueTransformers.transformFrom(\n columnMetadata.transformer,\n value,\n )\n\n return value\n }\n\n /**\n * Creates a database type from a given column metadata.\n */\n normalizeType(column: {\n type: ColumnType\n length?: number | string\n precision?: number | null\n scale?: number\n }): string {\n if (column.type === Number || column.type === \"integer\") {\n return \"int\"\n } else if (column.type === String) {\n return \"varchar\"\n } else if (column.type === Date) {\n return \"datetime\"\n } else if ((column.type as any) === Buffer) {\n return \"blob\"\n } else if (column.type === Boolean) {\n return \"tinyint\"\n } else if (column.type === \"uuid\" && !this.uuidColumnTypeSuported) {\n return \"varchar\"\n } else if (\n column.type === \"json\" &&\n this.options.type === \"mariadb\" &&\n !VersionUtils.isGreaterOrEqual(this.version ?? \"0.0.0\", \"10.4.3\")\n ) {\n /*\n * MariaDB implements this as a LONGTEXT rather, as the JSON data type contradicts the SQL standard,\n * and MariaDB's benchmarks indicate that performance is at least equivalent.\n *\n * @see https://mariadb.com/kb/en/json-data-type/\n * if Version is 10.4.3 or greater, JSON is an alias for longtext and an automatic check_json(column) constraint is added\n */\n return \"longtext\"\n } else if (\n column.type === \"simple-array\" ||\n column.type === \"simple-json\"\n ) {\n return \"text\"\n } else if (column.type === \"simple-enum\") {\n return \"enum\"\n } else if (\n column.type === \"double precision\" ||\n column.type === \"real\"\n ) {\n return \"double\"\n } else if (\n column.type === \"dec\" ||\n column.type === \"numeric\" ||\n column.type === \"fixed\"\n ) {\n return \"decimal\"\n } else if (column.type === \"bool\" || column.type === \"boolean\") {\n return \"tinyint\"\n } else if (\n column.type === \"nvarchar\" ||\n column.type === \"national varchar\"\n ) {\n return \"varchar\"\n } else if (column.type === \"nchar\" || column.type === \"national char\") {\n return \"char\"\n } else {\n return (column.type as string) || \"\"\n }\n }\n\n /**\n * Normalizes \"default\" value of the column.\n */\n normalizeDefault(columnMetadata: ColumnMetadata): string | undefined {\n const defaultValue = columnMetadata.default\n\n if (defaultValue === null) {\n return undefined\n }\n\n if (\n (columnMetadata.type === \"enum\" ||\n columnMetadata.type === \"simple-enum\" ||\n typeof defaultValue === \"string\") &&\n defaultValue !== undefined\n ) {\n return `'${defaultValue}'`\n }\n\n if (columnMetadata.type === \"set\" && defaultValue !== undefined) {\n return `'${DateUtils.simpleArrayToString(defaultValue)}'`\n }\n\n if (typeof defaultValue === \"number\") {\n return `'${defaultValue.toFixed(columnMetadata.scale)}'`\n }\n\n if (typeof defaultValue === \"boolean\") {\n return defaultValue ? \"1\" : \"0\"\n }\n\n if (typeof defaultValue === \"function\") {\n const value = defaultValue()\n return this.normalizeDatetimeFunction(value)\n }\n\n if (defaultValue === undefined) {\n return undefined\n }\n\n return `${defaultValue}`\n }\n\n /**\n * Normalizes \"isUnique\" value of the column.\n */\n normalizeIsUnique(column: ColumnMetadata): boolean {\n return column.entityMetadata.indices.some(\n (idx) =>\n idx.isUnique &&\n idx.columns.length === 1 &&\n idx.columns[0] === column,\n )\n }\n\n /**\n * Returns default column lengths, which is required on column creation.\n */\n getColumnLength(column: ColumnMetadata | TableColumn): string {\n if (column.length) return column.length.toString()\n\n /**\n * fix https://github.com/typeorm/typeorm/issues/1139\n * note that if the db did support uuid column type it wouldn't have been defaulted to varchar\n */\n if (\n column.generationStrategy === \"uuid\" &&\n !this.uuidColumnTypeSuported\n )\n return \"36\"\n\n switch (column.type) {\n case String:\n case \"varchar\":\n case \"nvarchar\":\n case \"national varchar\":\n return \"255\"\n case \"varbinary\":\n return \"255\"\n default:\n return \"\"\n }\n }\n\n /**\n * Creates column type definition including length, precision and scale\n */\n createFullType(column: TableColumn): string {\n let type = column.type\n\n // used 'getColumnLength()' method, because MySQL requires column length for `varchar`, `nvarchar` and `varbinary` data types\n if (this.getColumnLength(column)) {\n type += `(${this.getColumnLength(column)})`\n } else if (column.width) {\n type += `(${column.width})`\n } else if (\n column.precision !== null &&\n column.precision !== undefined &&\n column.scale !== null &&\n column.scale !== undefined\n ) {\n type += `(${column.precision},${column.scale})`\n } else if (\n column.precision !== null &&\n column.precision !== undefined\n ) {\n type += `(${column.precision})`\n }\n\n if (column.isArray) type += \" array\"\n\n return type\n }\n\n /**\n * Obtains a new database connection to a master server.\n * Used for replication.\n * If replication is not setup then returns default connection's database connection.\n */\n obtainMasterConnection(): Promise<any> {\n return new Promise<any>((ok, fail) => {\n if (this.poolCluster) {\n this.poolCluster.getConnection(\n \"MASTER\",\n (err: any, dbConnection: any) => {\n err\n ? fail(err)\n : ok(this.prepareDbConnection(dbConnection))\n },\n )\n } else if (this.pool) {\n this.pool.getConnection((err: any, dbConnection: any) => {\n err ? fail(err) : ok(this.prepareDbConnection(dbConnection))\n })\n } else {\n fail(\n new TypeORMError(\n `Connection is not established with mysql database`,\n ),\n )\n }\n })\n }\n\n /**\n * Obtains a new database connection to a slave server.\n * Used for replication.\n * If replication is not setup then returns master (default) connection's database connection.\n */\n obtainSlaveConnection(): Promise<any> {\n if (!this.poolCluster) return this.obtainMasterConnection()\n\n return new Promise<any>((ok, fail) => {\n this.poolCluster.getConnection(\n \"SLAVE*\",\n (err: any, dbConnection: any) => {\n err ? fail(err) : ok(this.prepareDbConnection(dbConnection))\n },\n )\n })\n }\n\n /**\n * Creates generated map of values generated or returned by database after INSERT query.\n */\n createGeneratedMap(\n metadata: EntityMetadata,\n insertResult: any,\n entityIndex: number,\n ) {\n if (!insertResult) {\n return undefined\n }\n\n if (insertResult.insertId === undefined) {\n return Object.keys(insertResult).reduce((map, key) => {\n const column = metadata.findColumnWithDatabaseName(key)\n if (column) {\n OrmUtils.mergeDeep(\n map,\n column.createValueMap(insertResult[key]),\n )\n // OrmUtils.mergeDeep(map, column.createValueMap(this.prepareHydratedValue(insertResult[key], column))); // TODO: probably should be like there, but fails on enums, fix later\n }\n return map\n }, {} as ObjectLiteral)\n }\n\n const generatedMap = metadata.generatedColumns.reduce(\n (map, generatedColumn) => {\n let value: any\n if (\n generatedColumn.generationStrategy === \"increment\" &&\n insertResult.insertId\n ) {\n // NOTE: When multiple rows is inserted by a single INSERT statement,\n // `insertId` is the value generated for the first inserted row only.\n value = insertResult.insertId + entityIndex\n // } else if (generatedColumn.generationStrategy === \"uuid\") {\n // console.log(\"getting db value:\", generatedColumn.databaseName);\n // value = generatedColumn.getEntityValue(uuidMap);\n }\n\n return OrmUtils.mergeDeep(\n map,\n generatedColumn.createValueMap(value),\n )\n },\n {} as ObjectLiteral,\n )\n\n return Object.keys(generatedMap).length > 0 ? generatedMap : undefined\n }\n\n /**\n * Differentiate columns of this table and columns from the given column metadatas columns\n * and returns only changed.\n */\n findChangedColumns(\n tableColumns: TableColumn[],\n columnMetadatas: ColumnMetadata[],\n ): ColumnMetadata[] {\n return columnMetadatas.filter((columnMetadata) => {\n const tableColumn = tableColumns.find(\n (c) => c.name === columnMetadata.databaseName,\n )\n if (!tableColumn) return false // we don't need new columns, we only need exist and changed\n\n const isColumnChanged =\n tableColumn.name !== columnMetadata.databaseName ||\n this.isColumnDataTypeChanged(tableColumn, columnMetadata) ||\n tableColumn.length !== this.getColumnLength(columnMetadata) ||\n tableColumn.width !== columnMetadata.width ||\n (columnMetadata.precision !== undefined &&\n tableColumn.precision !== columnMetadata.precision) ||\n (columnMetadata.scale !== undefined &&\n tableColumn.scale !== columnMetadata.scale) ||\n tableColumn.zerofill !== columnMetadata.zerofill ||\n tableColumn.unsigned !== columnMetadata.unsigned ||\n tableColumn.asExpression !== columnMetadata.asExpression ||\n tableColumn.generatedType !== columnMetadata.generatedType ||\n tableColumn.comment !==\n this.escapeComment(columnMetadata.comment) ||\n !this.compareDefaultValues(\n this.normalizeDefault(columnMetadata),\n tableColumn.default,\n ) ||\n (tableColumn.enum &&\n columnMetadata.enum &&\n !OrmUtils.isArraysEqual(\n tableColumn.enum,\n columnMetadata.enum.map((val) => val + \"\"),\n )) ||\n tableColumn.onUpdate !==\n this.normalizeDatetimeFunction(columnMetadata.onUpdate) ||\n tableColumn.isPrimary !== columnMetadata.isPrimary ||\n !this.compareNullableValues(columnMetadata, tableColumn) ||\n tableColumn.isUnique !==\n this.normalizeIsUnique(columnMetadata) ||\n (columnMetadata.generationStrategy !== \"uuid\" &&\n tableColumn.isGenerated !== columnMetadata.isGenerated)\n\n // DEBUG SECTION\n // if (isColumnChanged) {\n // console.log(\"table:\", columnMetadata.entityMetadata.tableName)\n // console.log(\n // \"name:\",\n // tableColumn.name,\n // columnMetadata.databaseName,\n // )\n // console.log(\n // \"type:\",\n // tableColumn.type,\n // this.normalizeType(columnMetadata),\n // )\n // console.log(\n // \"length:\",\n // tableColumn.length,\n // columnMetadata.length,\n // )\n // console.log(\"width:\", tableColumn.width, columnMetadata.width)\n // console.log(\n // \"precision:\",\n // tableColumn.precision,\n // columnMetadata.precision,\n // )\n // console.log(\"scale:\", tableColumn.scale, columnMetadata.scale)\n // console.log(\n // \"zerofill:\",\n // tableColumn.zerofill,\n // columnMetadata.zerofill,\n // )\n // console.log(\n // \"unsigned:\",\n // tableColumn.unsigned,\n // columnMetadata.unsigned,\n // )\n // console.log(\n // \"asExpression:\",\n // tableColumn.asExpression,\n // columnMetadata.asExpression,\n // )\n // console.log(\n // \"generatedType:\",\n // tableColumn.generatedType,\n // columnMetadata.generatedType,\n // )\n // console.log(\n // \"comment:\",\n // tableColumn.comment,\n // this.escapeComment(columnMetadata.comment),\n // )\n // console.log(\n // \"default:\",\n // tableColumn.default,\n // this.normalizeDefault(columnMetadata),\n // )\n // console.log(\"enum:\", tableColumn.enum, columnMetadata.enum)\n // console.log(\n // \"default changed:\",\n // !this.compareDefaultValues(\n // this.normalizeDefault(columnMetadata),\n // tableColumn.default,\n // ),\n // )\n // console.log(\n // \"isPrimary:\",\n // tableColumn.isPrimary,\n // columnMetadata.isPrimary,\n // )\n // console.log(\n // \"isNullable changed:\",\n // !this.compareNullableValues(columnMetadata, tableColumn),\n // )\n // console.log(\n // \"isUnique:\",\n // tableColumn.isUnique,\n // this.normalizeIsUnique(columnMetadata),\n // )\n // console.log(\n // \"isGenerated:\",\n // tableColumn.isGenerated,\n // columnMetadata.isGenerated,\n // )\n // console.log(\n // columnMetadata.generationStrategy !== \"uuid\" &&\n // tableColumn.isGenerated !== columnMetadata.isGenerated,\n // )\n // console.log(\"==========================================\")\n // }\n\n return isColumnChanged\n })\n }\n\n /**\n * Returns true if driver supports RETURNING / OUTPUT statement.\n */\n isReturningSqlSupported(returningType: ReturningType): boolean {\n return this._isReturningSqlSupported[returningType]\n }\n\n /**\n * Returns true if driver supports uuid values generation on its own.\n */\n isUUIDGenerationSupported(): boolean {\n return false\n }\n\n /**\n * Returns true if driver supports fulltext indices.\n */\n isFullTextColumnTypeSupported(): boolean {\n return true\n }\n\n /**\n * Creates an escaped parameter.\n */\n createParameter(parameterName: string, index: number): string {\n return \"?\"\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Loads all driver dependencies.\n */\n protected loadDependencies(): void {\n const connectorPackage = this.options.connectorPackage ?? \"mysql\"\n const fallbackConnectorPackage =\n connectorPackage === \"mysql\"\n ? (\"mysql2\" as const)\n : (\"mysql\" as const)\n try {\n // try to load first supported package\n const mysql =\n this.options.driver || PlatformTools.load(connectorPackage)\n this.mysql = mysql\n /*\n * Some frameworks (such as Jest) may mess up Node's require cache and provide garbage for the 'mysql' module\n * if it was not installed. We check that the object we got actually contains something otherwise we treat\n * it as if the `require` call failed.\n *\n * @see https://github.com/typeorm/typeorm/issues/1373\n */\n if (Object.keys(this.mysql).length === 0) {\n throw new TypeORMError(\n `'${connectorPackage}' was found but it is empty. Falling back to '${fallbackConnectorPackage}'.`,\n )\n }\n } catch (e) {\n try {\n this.mysql = PlatformTools.load(fallbackConnectorPackage) // try to load second supported package\n } catch (e) {\n throw new DriverPackageNotInstalledError(\n \"Mysql\",\n connectorPackage,\n )\n }\n }\n }\n\n /**\n * Creates a new connection pool for a given database credentials.\n */\n protected createConnectionOptions(\n options: MysqlConnectionOptions,\n credentials: MysqlConnectionCredentialsOptions,\n ): Promise<any> {\n credentials = Object.assign(\n {},\n credentials,\n DriverUtils.buildDriverOptions(credentials),\n ) // todo: do it better way\n\n // build connection options for the driver\n return Object.assign(\n {},\n {\n charset: options.charset,\n timezone: options.timezone,\n connectTimeout: options.connectTimeout,\n insecureAuth: options.insecureAuth,\n supportBigNumbers:\n options.supportBigNumbers !== undefined\n ? options.supportBigNumbers\n : true,\n bigNumberStrings:\n options.bigNumberStrings !== undefined\n ? options.bigNumberStrings\n : true,\n dateStrings: options.dateStrings,\n debug: options.debug,\n trace: options.trace,\n multipleStatements: options.multipleStatements,\n flags: options.flags,\n },\n {\n host: credentials.host,\n user: credentials.username,\n password: credentials.password,\n database: credentials.database,\n port: credentials.port,\n ssl: options.ssl,\n socketPath: credentials.socketPath,\n },\n options.acquireTimeout === undefined\n ? {}\n : { acquireTimeout: options.acquireTimeout },\n { connectionLimit: options.poolSize },\n options.extra || {},\n )\n }\n\n /**\n * Creates a new connection pool for a given database credentials.\n */\n protected createPool(connectionOptions: any): Promise<any> {\n // create a connection pool\n const pool = this.mysql.createPool(connectionOptions)\n\n // make sure connection is working fine\n return new Promise<void>((ok, fail) => {\n // (issue #610) we make first connection to database to make sure if connection credentials are wrong\n // we give error before calling any other method that creates actual query runner\n pool.getConnection((err: any, connection: any) => {\n if (err) return pool.end(() => fail(err))\n\n connection.release()\n ok(pool)\n })\n })\n }\n\n /**\n * Attaches all required base handlers to a database connection, such as the unhandled error handler.\n */\n private prepareDbConnection(connection: any): any {\n const { logger } = this.connection\n /*\n * Attaching an error handler to connection errors is essential, as, otherwise, errors raised will go unhandled and\n * cause the hosting app to crash.\n */\n if (connection.listeners(\"error\").length === 0) {\n connection.on(\"error\", (error: any) =>\n logger.log(\n \"warn\",\n `MySQL connection raised an error. ${error}`,\n ),\n )\n }\n return connection\n }\n\n /**\n * Checks if \"DEFAULT\" values in the column metadata and in the database are equal.\n */\n protected compareDefaultValues(\n columnMetadataValue: string | undefined,\n databaseValue: string | undefined,\n ): boolean {\n if (\n typeof columnMetadataValue === \"string\" &&\n typeof databaseValue === \"string\"\n ) {\n // we need to cut out \"'\" because in mysql we can understand returned value is a string or a function\n // as result compare cannot understand if default is really changed or not\n columnMetadataValue = columnMetadataValue.replace(/^'+|'+$/g, \"\")\n databaseValue = databaseValue.replace(/^'+|'+$/g, \"\")\n }\n\n return columnMetadataValue === databaseValue\n }\n\n compareNullableValues(\n columnMetadata: ColumnMetadata,\n tableColumn: TableColumn,\n ): boolean {\n // MariaDB does not support NULL/NOT NULL expressions for generated columns\n const isMariaDb = this.options.type === \"mariadb\"\n if (isMariaDb && columnMetadata.generatedType) {\n return true\n }\n\n return columnMetadata.isNullable === tableColumn.isNullable\n }\n\n /**\n * If parameter is a datetime function, e.g. \"CURRENT_TIMESTAMP\", normalizes it.\n * Otherwise returns original input.\n */\n protected normalizeDatetimeFunction(value?: string) {\n if (!value) return value\n\n // check if input is datetime function\n const isDatetimeFunction =\n value.toUpperCase().indexOf(\"CURRENT_TIMESTAMP\") !== -1 ||\n value.toUpperCase().indexOf(\"NOW\") !== -1\n\n if (isDatetimeFunction) {\n // extract precision, e.g. \"(3)\"\n const precision = value.match(/\\(\\d+\\)/)\n if (this.options.type === \"mariadb\") {\n return precision\n ? `CURRENT_TIMESTAMP${precision[0]}`\n : \"CURRENT_TIMESTAMP()\"\n } else {\n return precision\n ? `CURRENT_TIMESTAMP${precision[0]}`\n : \"CURRENT_TIMESTAMP\"\n }\n } else {\n return value\n }\n }\n\n /**\n * Escapes a given comment.\n */\n protected escapeComment(comment?: string) {\n if (!comment) return comment\n\n comment = comment.replace(/\\u0000/g, \"\") // Null bytes aren't allowed in comments\n\n return comment\n }\n\n /**\n * A helper to check if column data types have changed\n * This can be used to manage checking any types the\n * database may alias\n */\n private isColumnDataTypeChanged(\n tableColumn: TableColumn,\n columnMetadata: ColumnMetadata,\n ) {\n // this is an exception for mariadb versions where json is an alias for longtext\n if (\n this.normalizeType(columnMetadata) === \"json\" &&\n tableColumn.type.toLowerCase() === \"longtext\"\n )\n return false\n return tableColumn.type !== this.normalizeType(columnMetadata)\n }\n}\n"],"sourceRoot":"../.."}