typeorm 0.3.21 → 0.3.22-dev.04ca83a

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 (1026) 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 +2 -0
  158. package/browser/driver/sap/SapDriver.js.map +1 -1
  159. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  160. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  161. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  162. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  163. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  164. package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  165. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  166. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  167. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  168. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  169. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  170. package/browser/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  171. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  172. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  173. package/browser/driver/sqlserver/MssqlParameter.js.map +1 -1
  174. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  175. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  176. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  177. package/browser/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  178. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  179. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  180. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  181. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  182. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  183. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  184. package/browser/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  185. package/browser/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  186. package/browser/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  187. package/browser/driver/types/ColumnTypes.js.map +1 -1
  188. package/browser/driver/types/CteCapabilities.js.map +1 -1
  189. package/browser/driver/types/DataTypeDefaults.js.map +1 -1
  190. package/browser/driver/types/DatabaseType.js.map +1 -1
  191. package/browser/driver/types/GeoJsonTypes.js.map +1 -1
  192. package/browser/driver/types/IsolationLevel.js.map +1 -1
  193. package/browser/driver/types/MappedColumnTypes.js.map +1 -1
  194. package/browser/driver/types/MetadataTableType.js.map +1 -1
  195. package/browser/driver/types/ReplicationMode.js.map +1 -1
  196. package/browser/driver/types/UpsertType.js.map +1 -1
  197. package/browser/entity-manager/EntityManager.js.map +1 -1
  198. package/browser/entity-manager/EntityManagerFactory.js.map +1 -1
  199. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  200. package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
  201. package/browser/entity-schema/EntitySchema.js.map +1 -1
  202. package/browser/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  203. package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  204. package/browser/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  205. package/browser/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  206. package/browser/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  207. package/browser/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  208. package/browser/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  209. package/browser/entity-schema/EntitySchemaOptions.js.map +1 -1
  210. package/browser/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  211. package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  212. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  213. package/browser/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  214. package/browser/error/AlreadyHasActiveConnectionError.js.map +1 -1
  215. package/browser/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  216. package/browser/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  217. package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
  218. package/browser/error/CannotDetermineEntityError.js.map +1 -1
  219. package/browser/error/CannotExecuteNotConnectedError.js.map +1 -1
  220. package/browser/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  221. package/browser/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  222. package/browser/error/CircularRelationsError.js.map +1 -1
  223. package/browser/error/ColumnTypeUndefinedError.js.map +1 -1
  224. package/browser/error/ConnectionIsNotSetError.js.map +1 -1
  225. package/browser/error/ConnectionNotFoundError.js.map +1 -1
  226. package/browser/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  227. package/browser/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  228. package/browser/error/CustomRepositoryNotFoundError.js.map +1 -1
  229. package/browser/error/DataTypeNotSupportedError.js.map +1 -1
  230. package/browser/error/DriverOptionNotSetError.js.map +1 -1
  231. package/browser/error/DriverPackageNotInstalledError.js.map +1 -1
  232. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  233. package/browser/error/EntityNotFoundError.js.map +1 -1
  234. package/browser/error/EntityPropertyNotFoundError.js.map +1 -1
  235. package/browser/error/FindRelationsNotFoundError.js.map +1 -1
  236. package/browser/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  237. package/browser/error/InitializedRelationError.js.map +1 -1
  238. package/browser/error/InsertValuesMissingError.js.map +1 -1
  239. package/browser/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  240. package/browser/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  241. package/browser/error/MetadataAlreadyExistsError.js.map +1 -1
  242. package/browser/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  243. package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
  244. package/browser/error/MissingDriverError.js.map +1 -1
  245. package/browser/error/MissingJoinColumnError.js.map +1 -1
  246. package/browser/error/MissingJoinTableError.js.map +1 -1
  247. package/browser/error/MissingPrimaryColumnError.js.map +1 -1
  248. package/browser/error/MustBeEntityError.js.map +1 -1
  249. package/browser/error/NamingStrategyNotFoundError.js.map +1 -1
  250. package/browser/error/NestedSetMultipleRootError.js.map +1 -1
  251. package/browser/error/NoConnectionForRepositoryError.js.map +1 -1
  252. package/browser/error/NoConnectionOptionError.js.map +1 -1
  253. package/browser/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  254. package/browser/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  255. package/browser/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  256. package/browser/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  257. package/browser/error/OptimisticLockVersionMismatchError.js.map +1 -1
  258. package/browser/error/PersistedEntityNotFoundError.js.map +1 -1
  259. package/browser/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  260. package/browser/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  261. package/browser/error/QueryFailedError.js.map +1 -1
  262. package/browser/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  263. package/browser/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  264. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  265. package/browser/error/ReturningStatementNotSupportedError.js.map +1 -1
  266. package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  267. package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
  268. package/browser/error/TransactionAlreadyStartedError.js.map +1 -1
  269. package/browser/error/TransactionNotStartedError.js.map +1 -1
  270. package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
  271. package/browser/error/TypeORMError.js.map +1 -1
  272. package/browser/error/UpdateValuesMissingError.js.map +1 -1
  273. package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  274. package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  275. package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  276. package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  277. package/browser/error/index.js.map +1 -1
  278. package/browser/find-options/EqualOperator.js.map +1 -1
  279. package/browser/find-options/FindManyOptions.js.map +1 -1
  280. package/browser/find-options/FindOneOptions.js.map +1 -1
  281. package/browser/find-options/FindOperator.js.map +1 -1
  282. package/browser/find-options/FindOperatorType.js.map +1 -1
  283. package/browser/find-options/FindOptionsOrder.js.map +1 -1
  284. package/browser/find-options/FindOptionsRelations.js.map +1 -1
  285. package/browser/find-options/FindOptionsSelect.js.map +1 -1
  286. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  287. package/browser/find-options/FindOptionsWhere.js.map +1 -1
  288. package/browser/find-options/FindTreeOptions.js.map +1 -1
  289. package/browser/find-options/JoinOptions.js.map +1 -1
  290. package/browser/find-options/OrderByCondition.js.map +1 -1
  291. package/browser/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  292. package/browser/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  293. package/browser/find-options/operator/And.js.map +1 -1
  294. package/browser/find-options/operator/Any.js.map +1 -1
  295. package/browser/find-options/operator/ArrayContainedBy.js.map +1 -1
  296. package/browser/find-options/operator/ArrayContains.js.map +1 -1
  297. package/browser/find-options/operator/ArrayOverlap.js.map +1 -1
  298. package/browser/find-options/operator/Between.js.map +1 -1
  299. package/browser/find-options/operator/Equal.js.map +1 -1
  300. package/browser/find-options/operator/ILike.js.map +1 -1
  301. package/browser/find-options/operator/In.js.map +1 -1
  302. package/browser/find-options/operator/IsNull.js.map +1 -1
  303. package/browser/find-options/operator/JsonContains.js.map +1 -1
  304. package/browser/find-options/operator/LessThan.js.map +1 -1
  305. package/browser/find-options/operator/LessThanOrEqual.js.map +1 -1
  306. package/browser/find-options/operator/Like.js.map +1 -1
  307. package/browser/find-options/operator/MoreThan.js.map +1 -1
  308. package/browser/find-options/operator/MoreThanOrEqual.js.map +1 -1
  309. package/browser/find-options/operator/Not.js.map +1 -1
  310. package/browser/find-options/operator/Or.js.map +1 -1
  311. package/browser/find-options/operator/Raw.js.map +1 -1
  312. package/browser/globals.js.map +1 -1
  313. package/browser/index.js.map +1 -1
  314. package/browser/logger/AbstractLogger.js.map +1 -1
  315. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  316. package/browser/logger/DebugLogger.js.map +1 -1
  317. package/browser/logger/FileLogger.js.map +1 -1
  318. package/browser/logger/Logger.js.map +1 -1
  319. package/browser/logger/LoggerFactory.js.map +1 -1
  320. package/browser/logger/LoggerOptions.js.map +1 -1
  321. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  322. package/browser/metadata/CheckMetadata.js.map +1 -1
  323. package/browser/metadata/ColumnMetadata.js.map +1 -1
  324. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  325. package/browser/metadata/EntityListenerMetadata.js.map +1 -1
  326. package/browser/metadata/EntityMetadata.js.map +1 -1
  327. package/browser/metadata/ExclusionMetadata.js.map +1 -1
  328. package/browser/metadata/ForeignKeyMetadata.js.map +1 -1
  329. package/browser/metadata/IndexMetadata.js.map +1 -1
  330. package/browser/metadata/RelationCountMetadata.js.map +1 -1
  331. package/browser/metadata/RelationIdMetadata.js.map +1 -1
  332. package/browser/metadata/RelationMetadata.js.map +1 -1
  333. package/browser/metadata/UniqueMetadata.js.map +1 -1
  334. package/browser/metadata/types/ClosureTreeOptions.js.map +1 -1
  335. package/browser/metadata/types/DeferrableType.js.map +1 -1
  336. package/browser/metadata/types/EventListenerTypes.js.map +1 -1
  337. package/browser/metadata/types/OnDeleteType.js.map +1 -1
  338. package/browser/metadata/types/OnUpdateType.js.map +1 -1
  339. package/browser/metadata/types/PropertyTypeInFunction.js.map +1 -1
  340. package/browser/metadata/types/RelationTypeInFunction.js.map +1 -1
  341. package/browser/metadata/types/RelationTypes.js.map +1 -1
  342. package/browser/metadata/types/TableTypes.js.map +1 -1
  343. package/browser/metadata/types/TreeTypes.js.map +1 -1
  344. package/browser/metadata-args/CheckMetadataArgs.js.map +1 -1
  345. package/browser/metadata-args/ColumnMetadataArgs.js.map +1 -1
  346. package/browser/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  347. package/browser/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  348. package/browser/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  349. package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  350. package/browser/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  351. package/browser/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  352. package/browser/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  353. package/browser/metadata-args/IndexMetadataArgs.js.map +1 -1
  354. package/browser/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  355. package/browser/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  356. package/browser/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  357. package/browser/metadata-args/MetadataArgsStorage.js.map +1 -1
  358. package/browser/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  359. package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  360. package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  361. package/browser/metadata-args/RelationMetadataArgs.js.map +1 -1
  362. package/browser/metadata-args/TableMetadataArgs.js.map +1 -1
  363. package/browser/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  364. package/browser/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  365. package/browser/metadata-args/TreeMetadataArgs.js.map +1 -1
  366. package/browser/metadata-args/UniqueMetadataArgs.js.map +1 -1
  367. package/browser/metadata-args/types/ColumnMode.js.map +1 -1
  368. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  369. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  370. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  371. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  372. package/browser/metadata-builder/MetadataUtils.js.map +1 -1
  373. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  374. package/browser/migration/Migration.js.map +1 -1
  375. package/browser/migration/MigrationExecutor.js.map +1 -1
  376. package/browser/migration/MigrationInterface.js.map +1 -1
  377. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  378. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  379. package/browser/naming-strategy/NamingStrategyInterface.js.map +1 -1
  380. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  381. package/browser/persistence/Subject.js.map +1 -1
  382. package/browser/persistence/SubjectChangeMap.js.map +1 -1
  383. package/browser/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  384. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  385. package/browser/persistence/SubjectExecutor.js.map +1 -1
  386. package/browser/persistence/SubjectTopologicalSorter.js.map +1 -1
  387. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  388. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  389. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  390. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  391. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  392. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  393. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  394. package/browser/platform/BrowserConnectionOptionsReaderDummy.js.map +1 -1
  395. package/browser/platform/BrowserDirectoryExportedClassesLoader.js.map +1 -1
  396. package/browser/platform/BrowserDisabledDriversDummy.js.map +1 -1
  397. package/browser/platform/BrowserFileLoggerDummy.js.map +1 -1
  398. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  399. package/browser/platform/PlatformTools.js.map +1 -1
  400. package/browser/query-builder/Alias.js.map +1 -1
  401. package/browser/query-builder/Brackets.js.map +1 -1
  402. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  403. package/browser/query-builder/InsertOrUpdateOptions.js.map +1 -1
  404. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  405. package/browser/query-builder/JoinAttribute.js.map +1 -1
  406. package/browser/query-builder/JoinOptions.js.map +1 -1
  407. package/browser/query-builder/NotBrackets.js.map +1 -1
  408. package/browser/query-builder/QueryBuilder.js.map +1 -1
  409. package/browser/query-builder/QueryBuilderCte.js.map +1 -1
  410. package/browser/query-builder/QueryBuilderUtils.js.map +1 -1
  411. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  412. package/browser/query-builder/QueryPartialEntity.js.map +1 -1
  413. package/browser/query-builder/RelationIdLoader.js +3 -2
  414. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  415. package/browser/query-builder/RelationLoader.js.map +1 -1
  416. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  417. package/browser/query-builder/RelationRemover.js.map +1 -1
  418. package/browser/query-builder/RelationUpdater.js.map +1 -1
  419. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  420. package/browser/query-builder/SelectQuery.js.map +1 -1
  421. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  422. package/browser/query-builder/SelectQueryBuilderOption.js.map +1 -1
  423. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  424. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  425. package/browser/query-builder/WhereClause.js.map +1 -1
  426. package/browser/query-builder/WhereExpressionBuilder.js.map +1 -1
  427. package/browser/query-builder/index.js.map +1 -1
  428. package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  429. package/browser/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  430. package/browser/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  431. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  432. package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  433. package/browser/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  434. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  435. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  436. package/browser/query-builder/result/DeleteResult.js.map +1 -1
  437. package/browser/query-builder/result/InsertResult.js.map +1 -1
  438. package/browser/query-builder/result/UpdateResult.js.map +1 -1
  439. package/browser/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  440. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  441. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  442. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  443. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  444. package/browser/query-runner/QueryLock.js.map +1 -1
  445. package/browser/query-runner/QueryResult.js.map +1 -1
  446. package/browser/query-runner/QueryRunner.js.map +1 -1
  447. package/browser/repository/AbstractRepository.js.map +1 -1
  448. package/browser/repository/BaseEntity.js.map +1 -1
  449. package/browser/repository/EntityId.js.map +1 -1
  450. package/browser/repository/FindTreesOptions.js.map +1 -1
  451. package/browser/repository/MongoRepository.js.map +1 -1
  452. package/browser/repository/RemoveOptions.js.map +1 -1
  453. package/browser/repository/Repository.js.map +1 -1
  454. package/browser/repository/SaveOptions.js.map +1 -1
  455. package/browser/repository/TreeRepository.js.map +1 -1
  456. package/browser/repository/UpsertOptions.js.map +1 -1
  457. package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
  458. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  459. package/browser/schema-builder/SchemaBuilder.js.map +1 -1
  460. package/browser/schema-builder/options/TableCheckOptions.js.map +1 -1
  461. package/browser/schema-builder/options/TableColumnOptions.js.map +1 -1
  462. package/browser/schema-builder/options/TableExclusionOptions.js.map +1 -1
  463. package/browser/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  464. package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
  465. package/browser/schema-builder/options/TableOptions.js.map +1 -1
  466. package/browser/schema-builder/options/TableUniqueOptions.js.map +1 -1
  467. package/browser/schema-builder/options/ViewOptions.js.map +1 -1
  468. package/browser/schema-builder/table/Table.js.map +1 -1
  469. package/browser/schema-builder/table/TableCheck.js.map +1 -1
  470. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  471. package/browser/schema-builder/table/TableExclusion.js.map +1 -1
  472. package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
  473. package/browser/schema-builder/table/TableIndex.js.map +1 -1
  474. package/browser/schema-builder/table/TableUnique.js.map +1 -1
  475. package/browser/schema-builder/util/TableUtils.js.map +1 -1
  476. package/browser/schema-builder/util/ViewUtils.js.map +1 -1
  477. package/browser/schema-builder/view/View.js.map +1 -1
  478. package/browser/subscriber/Broadcaster.js.map +1 -1
  479. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  480. package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
  481. package/browser/subscriber/event/InsertEvent.js.map +1 -1
  482. package/browser/subscriber/event/LoadEvent.js.map +1 -1
  483. package/browser/subscriber/event/QueryEvent.js.map +1 -1
  484. package/browser/subscriber/event/RecoverEvent.js.map +1 -1
  485. package/browser/subscriber/event/RemoveEvent.js.map +1 -1
  486. package/browser/subscriber/event/SoftRemoveEvent.js.map +1 -1
  487. package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -1
  488. package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  489. package/browser/subscriber/event/TransactionStartEvent.js.map +1 -1
  490. package/browser/subscriber/event/UpdateEvent.js.map +1 -1
  491. package/browser/util/ApplyValueTransformers.js.map +1 -1
  492. package/browser/util/DateUtils.js.map +1 -1
  493. package/browser/util/DepGraph.js.map +1 -1
  494. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  495. package/browser/util/ImportUtils.js.map +1 -1
  496. package/browser/util/InstanceChecker.js.map +1 -1
  497. package/browser/util/ObjectUtils.js.map +1 -1
  498. package/browser/util/OrmUtils.js.map +1 -1
  499. package/browser/util/PathUtils.js.map +1 -1
  500. package/browser/util/RandomGenerator.js.map +1 -1
  501. package/browser/util/StringUtils.js.map +1 -1
  502. package/browser/util/TreeRepositoryUtils.js.map +1 -1
  503. package/browser/util/VersionUtils.js.map +1 -1
  504. package/browser/util/escapeRegExp.js.map +1 -1
  505. package/cache/DbQueryResultCache.js.map +1 -1
  506. package/cache/QueryResultCache.js.map +1 -1
  507. package/cache/QueryResultCacheFactory.js.map +1 -1
  508. package/cache/QueryResultCacheOptions.js.map +1 -1
  509. package/cache/RedisQueryResultCache.js.map +1 -1
  510. package/cli-ts-node-commonjs.js.map +1 -1
  511. package/cli-ts-node-esm.js.map +1 -1
  512. package/cli.js.map +1 -1
  513. package/commands/CacheClearCommand.js.map +1 -1
  514. package/commands/CommandUtils.js.map +1 -1
  515. package/commands/EntityCreateCommand.js +6 -6
  516. package/commands/EntityCreateCommand.js.map +1 -1
  517. package/commands/InitCommand.js +294 -302
  518. package/commands/InitCommand.js.map +1 -1
  519. package/commands/MigrationCreateCommand.js +22 -22
  520. package/commands/MigrationCreateCommand.js.map +1 -1
  521. package/commands/MigrationGenerateCommand.js +31 -31
  522. package/commands/MigrationGenerateCommand.js.map +1 -1
  523. package/commands/MigrationRevertCommand.js.map +1 -1
  524. package/commands/MigrationRunCommand.js.map +1 -1
  525. package/commands/MigrationShowCommand.js.map +1 -1
  526. package/commands/QueryCommand.js.map +1 -1
  527. package/commands/SchemaDropCommand.js.map +1 -1
  528. package/commands/SchemaLogCommand.js.map +1 -1
  529. package/commands/SchemaSyncCommand.js.map +1 -1
  530. package/commands/SubscriberCreateCommand.js +6 -6
  531. package/commands/SubscriberCreateCommand.js.map +1 -1
  532. package/commands/VersionCommand.js.map +1 -1
  533. package/common/DeepPartial.js.map +1 -1
  534. package/common/EntityTarget.js.map +1 -1
  535. package/common/MixedList.js.map +1 -1
  536. package/common/NonNever.js.map +1 -1
  537. package/common/ObjectLiteral.js.map +1 -1
  538. package/common/ObjectType.js.map +1 -1
  539. package/common/PickKeysByType.js.map +1 -1
  540. package/common/RelationType.js.map +1 -1
  541. package/connection/BaseConnectionOptions.js.map +1 -1
  542. package/connection/Connection.js.map +1 -1
  543. package/connection/ConnectionManager.js.map +1 -1
  544. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  545. package/connection/ConnectionOptions.js.map +1 -1
  546. package/connection/ConnectionOptionsReader.js.map +1 -1
  547. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  548. package/container.js.map +1 -1
  549. package/data-source/BaseDataSourceOptions.js.map +1 -1
  550. package/data-source/DataSource.js.map +1 -1
  551. package/data-source/DataSourceOptions.js.map +1 -1
  552. package/data-source/index.js.map +1 -1
  553. package/decorator/Check.js.map +1 -1
  554. package/decorator/EntityRepository.js.map +1 -1
  555. package/decorator/Exclusion.js.map +1 -1
  556. package/decorator/Generated.js.map +1 -1
  557. package/decorator/Index.js.map +1 -1
  558. package/decorator/Unique.js.map +1 -1
  559. package/decorator/columns/Column.js.map +1 -1
  560. package/decorator/columns/CreateDateColumn.js.map +1 -1
  561. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  562. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  563. package/decorator/columns/PrimaryColumn.js.map +1 -1
  564. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  565. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  566. package/decorator/columns/VersionColumn.js.map +1 -1
  567. package/decorator/columns/ViewColumn.js.map +1 -1
  568. package/decorator/columns/VirtualColumn.js.map +1 -1
  569. package/decorator/entity/ChildEntity.js.map +1 -1
  570. package/decorator/entity/Entity.js.map +1 -1
  571. package/decorator/entity/TableInheritance.js.map +1 -1
  572. package/decorator/entity-view/ViewEntity.js.map +1 -1
  573. package/decorator/listeners/AfterInsert.js.map +1 -1
  574. package/decorator/listeners/AfterLoad.js.map +1 -1
  575. package/decorator/listeners/AfterRecover.js.map +1 -1
  576. package/decorator/listeners/AfterRemove.js.map +1 -1
  577. package/decorator/listeners/AfterSoftRemove.js.map +1 -1
  578. package/decorator/listeners/AfterUpdate.js.map +1 -1
  579. package/decorator/listeners/BeforeInsert.js.map +1 -1
  580. package/decorator/listeners/BeforeRecover.js.map +1 -1
  581. package/decorator/listeners/BeforeRemove.js.map +1 -1
  582. package/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  583. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  584. package/decorator/listeners/EventSubscriber.js.map +1 -1
  585. package/decorator/options/ColumnCommonOptions.js.map +1 -1
  586. package/decorator/options/ColumnEmbeddedOptions.js.map +1 -1
  587. package/decorator/options/ColumnEnumOptions.js.map +1 -1
  588. package/decorator/options/ColumnHstoreOptions.js.map +1 -1
  589. package/decorator/options/ColumnNumericOptions.js.map +1 -1
  590. package/decorator/options/ColumnOptions.js.map +1 -1
  591. package/decorator/options/ColumnWithLengthOptions.js.map +1 -1
  592. package/decorator/options/ColumnWithWidthOptions.js.map +1 -1
  593. package/decorator/options/EntityOptions.js.map +1 -1
  594. package/decorator/options/IndexOptions.js.map +1 -1
  595. package/decorator/options/JoinColumnOptions.js.map +1 -1
  596. package/decorator/options/JoinTableMultipleColumnsOptions.js.map +1 -1
  597. package/decorator/options/JoinTableOptions.js.map +1 -1
  598. package/decorator/options/PrimaryGeneratedColumnIdentityOptions.js.map +1 -1
  599. package/decorator/options/PrimaryGeneratedColumnNumericOptions.js.map +1 -1
  600. package/decorator/options/PrimaryGeneratedColumnUUIDOptions.js.map +1 -1
  601. package/decorator/options/RelationOptions.js.map +1 -1
  602. package/decorator/options/SpatialColumnOptions.js.map +1 -1
  603. package/decorator/options/TransactionOptions.js.map +1 -1
  604. package/decorator/options/UniqueOptions.js.map +1 -1
  605. package/decorator/options/ValueTransformer.js.map +1 -1
  606. package/decorator/options/ViewColumnOptions.js.map +1 -1
  607. package/decorator/options/ViewEntityOptions.js.map +1 -1
  608. package/decorator/options/VirtualColumnOptions.js.map +1 -1
  609. package/decorator/relations/JoinColumn.js.map +1 -1
  610. package/decorator/relations/JoinTable.js.map +1 -1
  611. package/decorator/relations/ManyToMany.js.map +1 -1
  612. package/decorator/relations/ManyToOne.js.map +1 -1
  613. package/decorator/relations/OneToMany.js.map +1 -1
  614. package/decorator/relations/OneToOne.js.map +1 -1
  615. package/decorator/relations/RelationCount.js.map +1 -1
  616. package/decorator/relations/RelationId.js.map +1 -1
  617. package/decorator/tree/Tree.js.map +1 -1
  618. package/decorator/tree/TreeChildren.js.map +1 -1
  619. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  620. package/decorator/tree/TreeParent.js.map +1 -1
  621. package/driver/Driver.js.map +1 -1
  622. package/driver/DriverFactory.js.map +1 -1
  623. package/driver/DriverUtils.js.map +1 -1
  624. package/driver/Query.js.map +1 -1
  625. package/driver/SqlInMemory.js.map +1 -1
  626. package/driver/aurora-mysql/AuroraMysqlConnection.js.map +1 -1
  627. package/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  628. package/driver/aurora-mysql/AuroraMysqlConnectionOptions.js.map +1 -1
  629. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  630. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +6 -9
  631. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  632. package/driver/aurora-postgres/AuroraPostgresConnectionOptions.js.map +1 -1
  633. package/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  634. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js +6 -9
  635. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  636. package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -1
  637. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  638. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  639. package/driver/capacitor/CapacitorConnectionOptions.js.map +1 -1
  640. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  641. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  642. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  643. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  644. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  645. package/driver/cockroachdb/CockroachQueryRunner.js +7 -11
  646. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  647. package/driver/cordova/CordovaConnectionOptions.js.map +1 -1
  648. package/driver/cordova/CordovaDriver.js.map +1 -1
  649. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  650. package/driver/expo/ExpoConnectionOptions.js.map +1 -1
  651. package/driver/expo/ExpoDriver.js.map +1 -1
  652. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  653. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  654. package/driver/mongodb/MongoDriver.js.map +1 -1
  655. package/driver/mongodb/MongoQueryRunner.js.map +1 -1
  656. package/driver/mongodb/bson.typings.js.map +1 -1
  657. package/driver/mongodb/typings.js.map +1 -1
  658. package/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  659. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  660. package/driver/mysql/MysqlDriver.js.map +1 -1
  661. package/driver/mysql/MysqlQueryRunner.js +77 -80
  662. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  663. package/driver/nativescript/NativescriptConnectionOptions.js.map +1 -1
  664. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  665. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  666. package/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  667. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  668. package/driver/oracle/OracleDriver.js.map +1 -1
  669. package/driver/oracle/OracleQueryRunner.js +4 -6
  670. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  671. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  672. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  673. package/driver/postgres/PostgresDriver.js.map +1 -1
  674. package/driver/postgres/PostgresQueryRunner.js +6 -9
  675. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  676. package/driver/react-native/ReactNativeConnectionOptions.js.map +1 -1
  677. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  678. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  679. package/driver/sap/SapConnectionCredentialsOptions.js.map +1 -1
  680. package/driver/sap/SapConnectionOptions.js.map +1 -1
  681. package/driver/sap/SapDriver.js +2 -0
  682. package/driver/sap/SapDriver.js.map +1 -1
  683. package/driver/sap/SapQueryRunner.js.map +1 -1
  684. package/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  685. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  686. package/driver/spanner/SpannerDriver.js.map +1 -1
  687. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  688. package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
  689. package/driver/sqlite/SqliteDriver.js.map +1 -1
  690. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  691. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  692. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +6 -9
  693. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  694. package/driver/sqljs/SqljsConnectionOptions.js.map +1 -1
  695. package/driver/sqljs/SqljsDriver.js.map +1 -1
  696. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  697. package/driver/sqlserver/MssqlParameter.js.map +1 -1
  698. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  699. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  700. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  701. package/driver/sqlserver/SqlServerQueryRunner.js +31 -32
  702. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  703. package/driver/sqlserver/authentication/AzureActiveDirectoryAccessTokenAuthentication.js.map +1 -1
  704. package/driver/sqlserver/authentication/AzureActiveDirectoryDefaultAuthentication.js.map +1 -1
  705. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiAppServiceAuthentication.js.map +1 -1
  706. package/driver/sqlserver/authentication/AzureActiveDirectoryMsiVmAuthentication.js.map +1 -1
  707. package/driver/sqlserver/authentication/AzureActiveDirectoryPasswordAuthentication.js.map +1 -1
  708. package/driver/sqlserver/authentication/AzureActiveDirectoryServicePrincipalSecret.js.map +1 -1
  709. package/driver/sqlserver/authentication/DefaultAuthentication.js.map +1 -1
  710. package/driver/sqlserver/authentication/NtlmAuthentication.js.map +1 -1
  711. package/driver/types/ColumnTypes.js.map +1 -1
  712. package/driver/types/CteCapabilities.js.map +1 -1
  713. package/driver/types/DataTypeDefaults.js.map +1 -1
  714. package/driver/types/DatabaseType.js.map +1 -1
  715. package/driver/types/GeoJsonTypes.js.map +1 -1
  716. package/driver/types/IsolationLevel.js.map +1 -1
  717. package/driver/types/MappedColumnTypes.js.map +1 -1
  718. package/driver/types/MetadataTableType.js.map +1 -1
  719. package/driver/types/ReplicationMode.js.map +1 -1
  720. package/driver/types/UpsertType.js.map +1 -1
  721. package/entity-manager/EntityManager.js.map +1 -1
  722. package/entity-manager/EntityManagerFactory.js.map +1 -1
  723. package/entity-manager/MongoEntityManager.js.map +1 -1
  724. package/entity-manager/SqljsEntityManager.js.map +1 -1
  725. package/entity-schema/EntitySchema.js.map +1 -1
  726. package/entity-schema/EntitySchemaCheckOptions.js.map +1 -1
  727. package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
  728. package/entity-schema/EntitySchemaEmbeddedColumnOptions.js.map +1 -1
  729. package/entity-schema/EntitySchemaEmbeddedError.js.map +1 -1
  730. package/entity-schema/EntitySchemaExclusionOptions.js.map +1 -1
  731. package/entity-schema/EntitySchemaIndexOptions.js.map +1 -1
  732. package/entity-schema/EntitySchemaInheritanceOptions.js.map +1 -1
  733. package/entity-schema/EntitySchemaOptions.js.map +1 -1
  734. package/entity-schema/EntitySchemaRelationIdOptions.js.map +1 -1
  735. package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
  736. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  737. package/entity-schema/EntitySchemaUniqueOptions.js.map +1 -1
  738. package/error/AlreadyHasActiveConnectionError.js.map +1 -1
  739. package/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
  740. package/error/CannotConnectAlreadyConnectedError.js.map +1 -1
  741. package/error/CannotCreateEntityIdMapError.js.map +1 -1
  742. package/error/CannotDetermineEntityError.js.map +1 -1
  743. package/error/CannotExecuteNotConnectedError.js.map +1 -1
  744. package/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
  745. package/error/CannotReflectMethodParameterTypeError.js.map +1 -1
  746. package/error/CircularRelationsError.js.map +1 -1
  747. package/error/ColumnTypeUndefinedError.js.map +1 -1
  748. package/error/ConnectionIsNotSetError.js.map +1 -1
  749. package/error/ConnectionNotFoundError.js.map +1 -1
  750. package/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
  751. package/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
  752. package/error/CustomRepositoryNotFoundError.js.map +1 -1
  753. package/error/DataTypeNotSupportedError.js.map +1 -1
  754. package/error/DriverOptionNotSetError.js.map +1 -1
  755. package/error/DriverPackageNotInstalledError.js.map +1 -1
  756. package/error/EntityMetadataNotFoundError.js.map +1 -1
  757. package/error/EntityNotFoundError.js.map +1 -1
  758. package/error/EntityPropertyNotFoundError.js.map +1 -1
  759. package/error/FindRelationsNotFoundError.js.map +1 -1
  760. package/error/ForbiddenTransactionModeOverrideError.js.map +1 -1
  761. package/error/InitializedRelationError.js.map +1 -1
  762. package/error/InsertValuesMissingError.js.map +1 -1
  763. package/error/LimitOnUpdateNotSupportedError.js.map +1 -1
  764. package/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
  765. package/error/MetadataAlreadyExistsError.js.map +1 -1
  766. package/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
  767. package/error/MissingDeleteDateColumnError.js.map +1 -1
  768. package/error/MissingDriverError.js.map +1 -1
  769. package/error/MissingJoinColumnError.js.map +1 -1
  770. package/error/MissingJoinTableError.js.map +1 -1
  771. package/error/MissingPrimaryColumnError.js.map +1 -1
  772. package/error/MustBeEntityError.js.map +1 -1
  773. package/error/NamingStrategyNotFoundError.js.map +1 -1
  774. package/error/NestedSetMultipleRootError.js.map +1 -1
  775. package/error/NoConnectionForRepositoryError.js.map +1 -1
  776. package/error/NoConnectionOptionError.js.map +1 -1
  777. package/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
  778. package/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
  779. package/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
  780. package/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
  781. package/error/OptimisticLockVersionMismatchError.js.map +1 -1
  782. package/error/PersistedEntityNotFoundError.js.map +1 -1
  783. package/error/PessimisticLockTransactionRequiredError.js.map +1 -1
  784. package/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
  785. package/error/QueryFailedError.js.map +1 -1
  786. package/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
  787. package/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
  788. package/error/RepositoryNotTreeError.js.map +1 -1
  789. package/error/ReturningStatementNotSupportedError.js.map +1 -1
  790. package/error/SubjectRemovedAndUpdatedError.js.map +1 -1
  791. package/error/SubjectWithoutIdentifierError.js.map +1 -1
  792. package/error/TransactionAlreadyStartedError.js.map +1 -1
  793. package/error/TransactionNotStartedError.js.map +1 -1
  794. package/error/TreeRepositoryNotSupportedError.js.map +1 -1
  795. package/error/TypeORMError.js.map +1 -1
  796. package/error/UpdateValuesMissingError.js.map +1 -1
  797. package/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
  798. package/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
  799. package/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
  800. package/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
  801. package/error/index.js.map +1 -1
  802. package/find-options/EqualOperator.js.map +1 -1
  803. package/find-options/FindManyOptions.js.map +1 -1
  804. package/find-options/FindOneOptions.js.map +1 -1
  805. package/find-options/FindOperator.js.map +1 -1
  806. package/find-options/FindOperatorType.js.map +1 -1
  807. package/find-options/FindOptionsOrder.js.map +1 -1
  808. package/find-options/FindOptionsRelations.js.map +1 -1
  809. package/find-options/FindOptionsSelect.js.map +1 -1
  810. package/find-options/FindOptionsUtils.js.map +1 -1
  811. package/find-options/FindOptionsWhere.js.map +1 -1
  812. package/find-options/FindTreeOptions.js.map +1 -1
  813. package/find-options/JoinOptions.js.map +1 -1
  814. package/find-options/OrderByCondition.js.map +1 -1
  815. package/find-options/mongodb/MongoFindManyOptions.js.map +1 -1
  816. package/find-options/mongodb/MongoFindOneOptions.js.map +1 -1
  817. package/find-options/operator/And.js.map +1 -1
  818. package/find-options/operator/Any.js.map +1 -1
  819. package/find-options/operator/ArrayContainedBy.js.map +1 -1
  820. package/find-options/operator/ArrayContains.js.map +1 -1
  821. package/find-options/operator/ArrayOverlap.js.map +1 -1
  822. package/find-options/operator/Between.js.map +1 -1
  823. package/find-options/operator/Equal.js.map +1 -1
  824. package/find-options/operator/ILike.js.map +1 -1
  825. package/find-options/operator/In.js.map +1 -1
  826. package/find-options/operator/IsNull.js.map +1 -1
  827. package/find-options/operator/JsonContains.js.map +1 -1
  828. package/find-options/operator/LessThan.js.map +1 -1
  829. package/find-options/operator/LessThanOrEqual.js.map +1 -1
  830. package/find-options/operator/Like.js.map +1 -1
  831. package/find-options/operator/MoreThan.js.map +1 -1
  832. package/find-options/operator/MoreThanOrEqual.js.map +1 -1
  833. package/find-options/operator/Not.js.map +1 -1
  834. package/find-options/operator/Or.js.map +1 -1
  835. package/find-options/operator/Raw.js.map +1 -1
  836. package/globals.js.map +1 -1
  837. package/index.js.map +1 -1
  838. package/logger/AbstractLogger.js.map +1 -1
  839. package/logger/AdvancedConsoleLogger.js.map +1 -1
  840. package/logger/DebugLogger.js.map +1 -1
  841. package/logger/FileLogger.js.map +1 -1
  842. package/logger/Logger.js.map +1 -1
  843. package/logger/LoggerFactory.js.map +1 -1
  844. package/logger/LoggerOptions.js.map +1 -1
  845. package/logger/SimpleConsoleLogger.js.map +1 -1
  846. package/metadata/CheckMetadata.js.map +1 -1
  847. package/metadata/ColumnMetadata.js.map +1 -1
  848. package/metadata/EmbeddedMetadata.js.map +1 -1
  849. package/metadata/EntityListenerMetadata.js.map +1 -1
  850. package/metadata/EntityMetadata.js.map +1 -1
  851. package/metadata/ExclusionMetadata.js.map +1 -1
  852. package/metadata/ForeignKeyMetadata.js.map +1 -1
  853. package/metadata/IndexMetadata.js.map +1 -1
  854. package/metadata/RelationCountMetadata.js.map +1 -1
  855. package/metadata/RelationIdMetadata.js.map +1 -1
  856. package/metadata/RelationMetadata.js.map +1 -1
  857. package/metadata/UniqueMetadata.js.map +1 -1
  858. package/metadata/types/ClosureTreeOptions.js.map +1 -1
  859. package/metadata/types/DeferrableType.js.map +1 -1
  860. package/metadata/types/EventListenerTypes.js.map +1 -1
  861. package/metadata/types/OnDeleteType.js.map +1 -1
  862. package/metadata/types/OnUpdateType.js.map +1 -1
  863. package/metadata/types/PropertyTypeInFunction.js.map +1 -1
  864. package/metadata/types/RelationTypeInFunction.js.map +1 -1
  865. package/metadata/types/RelationTypes.js.map +1 -1
  866. package/metadata/types/TableTypes.js.map +1 -1
  867. package/metadata/types/TreeTypes.js.map +1 -1
  868. package/metadata-args/CheckMetadataArgs.js.map +1 -1
  869. package/metadata-args/ColumnMetadataArgs.js.map +1 -1
  870. package/metadata-args/DiscriminatorValueMetadataArgs.js.map +1 -1
  871. package/metadata-args/EmbeddedMetadataArgs.js.map +1 -1
  872. package/metadata-args/EntityListenerMetadataArgs.js.map +1 -1
  873. package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
  874. package/metadata-args/EntitySubscriberMetadataArgs.js.map +1 -1
  875. package/metadata-args/ExclusionMetadataArgs.js.map +1 -1
  876. package/metadata-args/GeneratedMetadataArgs.js.map +1 -1
  877. package/metadata-args/IndexMetadataArgs.js.map +1 -1
  878. package/metadata-args/InheritanceMetadataArgs.js.map +1 -1
  879. package/metadata-args/JoinColumnMetadataArgs.js.map +1 -1
  880. package/metadata-args/JoinTableMetadataArgs.js.map +1 -1
  881. package/metadata-args/MetadataArgsStorage.js.map +1 -1
  882. package/metadata-args/NamingStrategyMetadataArgs.js.map +1 -1
  883. package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
  884. package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
  885. package/metadata-args/RelationMetadataArgs.js.map +1 -1
  886. package/metadata-args/TableMetadataArgs.js.map +1 -1
  887. package/metadata-args/TransactionEntityMetadataArgs.js.map +1 -1
  888. package/metadata-args/TransactionRepositoryMetadataArgs.js.map +1 -1
  889. package/metadata-args/TreeMetadataArgs.js.map +1 -1
  890. package/metadata-args/UniqueMetadataArgs.js.map +1 -1
  891. package/metadata-args/types/ColumnMode.js.map +1 -1
  892. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  893. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  894. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  895. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  896. package/metadata-builder/MetadataUtils.js.map +1 -1
  897. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  898. package/migration/Migration.js.map +1 -1
  899. package/migration/MigrationExecutor.js.map +1 -1
  900. package/migration/MigrationInterface.js.map +1 -1
  901. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  902. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  903. package/naming-strategy/NamingStrategyInterface.js.map +1 -1
  904. package/package.json +1 -260
  905. package/persistence/EntityPersistExecutor.js.map +1 -1
  906. package/persistence/Subject.js.map +1 -1
  907. package/persistence/SubjectChangeMap.js.map +1 -1
  908. package/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  909. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  910. package/persistence/SubjectExecutor.js.map +1 -1
  911. package/persistence/SubjectTopologicalSorter.js.map +1 -1
  912. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  913. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  914. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  915. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  916. package/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  917. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  918. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  919. package/platform/PlatformTools.js.map +1 -1
  920. package/query-builder/Alias.js.map +1 -1
  921. package/query-builder/Brackets.js.map +1 -1
  922. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  923. package/query-builder/InsertOrUpdateOptions.js.map +1 -1
  924. package/query-builder/InsertQueryBuilder.js.map +1 -1
  925. package/query-builder/JoinAttribute.js.map +1 -1
  926. package/query-builder/JoinOptions.js.map +1 -1
  927. package/query-builder/NotBrackets.js.map +1 -1
  928. package/query-builder/QueryBuilder.js.map +1 -1
  929. package/query-builder/QueryBuilderCte.js.map +1 -1
  930. package/query-builder/QueryBuilderUtils.js.map +1 -1
  931. package/query-builder/QueryExpressionMap.js.map +1 -1
  932. package/query-builder/QueryPartialEntity.js.map +1 -1
  933. package/query-builder/RelationIdLoader.js +3 -2
  934. package/query-builder/RelationIdLoader.js.map +1 -1
  935. package/query-builder/RelationLoader.js.map +1 -1
  936. package/query-builder/RelationQueryBuilder.js.map +1 -1
  937. package/query-builder/RelationRemover.js.map +1 -1
  938. package/query-builder/RelationUpdater.js.map +1 -1
  939. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  940. package/query-builder/SelectQuery.js.map +1 -1
  941. package/query-builder/SelectQueryBuilder.js.map +1 -1
  942. package/query-builder/SelectQueryBuilderOption.js.map +1 -1
  943. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  944. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  945. package/query-builder/WhereClause.js.map +1 -1
  946. package/query-builder/WhereExpressionBuilder.js.map +1 -1
  947. package/query-builder/index.js.map +1 -1
  948. package/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
  949. package/query-builder/relation-count/RelationCountLoadResult.js.map +1 -1
  950. package/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  951. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  952. package/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
  953. package/query-builder/relation-id/RelationIdLoadResult.js.map +1 -1
  954. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  955. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  956. package/query-builder/result/DeleteResult.js.map +1 -1
  957. package/query-builder/result/InsertResult.js.map +1 -1
  958. package/query-builder/result/UpdateResult.js.map +1 -1
  959. package/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  960. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  961. package/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  962. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  963. package/query-runner/BaseQueryRunner.js.map +1 -1
  964. package/query-runner/QueryLock.js.map +1 -1
  965. package/query-runner/QueryResult.js.map +1 -1
  966. package/query-runner/QueryRunner.js.map +1 -1
  967. package/repository/AbstractRepository.js.map +1 -1
  968. package/repository/BaseEntity.js.map +1 -1
  969. package/repository/EntityId.js.map +1 -1
  970. package/repository/FindTreesOptions.js.map +1 -1
  971. package/repository/MongoRepository.js.map +1 -1
  972. package/repository/RemoveOptions.js.map +1 -1
  973. package/repository/Repository.js.map +1 -1
  974. package/repository/SaveOptions.js.map +1 -1
  975. package/repository/TreeRepository.js.map +1 -1
  976. package/repository/UpsertOptions.js.map +1 -1
  977. package/schema-builder/MongoSchemaBuilder.js.map +1 -1
  978. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  979. package/schema-builder/SchemaBuilder.js.map +1 -1
  980. package/schema-builder/options/TableCheckOptions.js.map +1 -1
  981. package/schema-builder/options/TableColumnOptions.js.map +1 -1
  982. package/schema-builder/options/TableExclusionOptions.js.map +1 -1
  983. package/schema-builder/options/TableForeignKeyOptions.js.map +1 -1
  984. package/schema-builder/options/TableIndexOptions.js.map +1 -1
  985. package/schema-builder/options/TableOptions.js.map +1 -1
  986. package/schema-builder/options/TableUniqueOptions.js.map +1 -1
  987. package/schema-builder/options/ViewOptions.js.map +1 -1
  988. package/schema-builder/table/Table.js.map +1 -1
  989. package/schema-builder/table/TableCheck.js.map +1 -1
  990. package/schema-builder/table/TableColumn.js.map +1 -1
  991. package/schema-builder/table/TableExclusion.js.map +1 -1
  992. package/schema-builder/table/TableForeignKey.js.map +1 -1
  993. package/schema-builder/table/TableIndex.js.map +1 -1
  994. package/schema-builder/table/TableUnique.js.map +1 -1
  995. package/schema-builder/util/TableUtils.js.map +1 -1
  996. package/schema-builder/util/ViewUtils.js.map +1 -1
  997. package/schema-builder/view/View.js.map +1 -1
  998. package/subscriber/Broadcaster.js.map +1 -1
  999. package/subscriber/BroadcasterResult.js.map +1 -1
  1000. package/subscriber/EntitySubscriberInterface.js.map +1 -1
  1001. package/subscriber/event/InsertEvent.js.map +1 -1
  1002. package/subscriber/event/LoadEvent.js.map +1 -1
  1003. package/subscriber/event/QueryEvent.js.map +1 -1
  1004. package/subscriber/event/RecoverEvent.js.map +1 -1
  1005. package/subscriber/event/RemoveEvent.js.map +1 -1
  1006. package/subscriber/event/SoftRemoveEvent.js.map +1 -1
  1007. package/subscriber/event/TransactionCommitEvent.js.map +1 -1
  1008. package/subscriber/event/TransactionRollbackEvent.js.map +1 -1
  1009. package/subscriber/event/TransactionStartEvent.js.map +1 -1
  1010. package/subscriber/event/UpdateEvent.js.map +1 -1
  1011. package/typeorm-class-transformer-shim.js +271 -271
  1012. package/typeorm-model-shim.js +295 -295
  1013. package/util/ApplyValueTransformers.js.map +1 -1
  1014. package/util/DateUtils.js.map +1 -1
  1015. package/util/DepGraph.js.map +1 -1
  1016. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  1017. package/util/ImportUtils.js.map +1 -1
  1018. package/util/InstanceChecker.js.map +1 -1
  1019. package/util/ObjectUtils.js.map +1 -1
  1020. package/util/OrmUtils.js.map +1 -1
  1021. package/util/PathUtils.js.map +1 -1
  1022. package/util/RandomGenerator.js.map +1 -1
  1023. package/util/StringUtils.js.map +1 -1
  1024. package/util/TreeRepositoryUtils.js.map +1 -1
  1025. package/util/VersionUtils.js.map +1 -1
  1026. package/util/escapeRegExp.js.map +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.ts"],"names":[],"mappings":";;;AAEA,qEAAiE;AAEjE,MAAa,2CAA2C;IACpD,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAsB,aAAiC;QAAjC,kBAAa,GAAb,aAAa,CAAoB;IAAG,CAAC;IAE3D,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,SAAS;QACL,cAAc;QACd,2BAA2B;QAC3B,wDAAwD;QACxD,8BAA8B;QAC9B,yDAAyD;QACzD,iCAAiC;QACjC,oFAAoF;QAEpF,0HAA0H;QAC1H,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CACxD,CAAC,aAAa,EAAE,EAAE;gBACd,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,aAAa,CAAC,SAAU,CAAC,IAAI,EAClC,aAAa,CAChB,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC9D,CAAC,CACJ,CAAA;QACL,CAAC;QAED,yHAAyH;QACzH,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,8FAA8F;YAC9F,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU;gBAAE,OAAM;YAEtD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,EAAE;gBACnD,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,KAAK,CAAC,IAAI,EACf,aAAa,CAChB,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC9D,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4EAA4E;IAC5E,kBAAkB;IAClB,4EAA4E;IAEpE,mBAAmB,CACvB,eAAuB,EACvB,aAAoC;QAEpC,OAAO,IAAI,+CAAsB,CAAC,IAAI,CAAC,aAAa,EAAE;YAClD,YAAY,EACR,eAAe,GAAG,GAAG,GAAG,aAAa,CAAC,QAAQ,CAAC,YAAY,EAAE,kBAAkB;YACnF,aAAa,EAAE,eAAe,GAAG,GAAG,GAAG,aAAa,CAAC,YAAY,EAAE,oBAAoB;YACvF,KAAK,EAAE,aAAa,CAAC,KAAK;YAC1B,mBAAmB,EAAE,aAAa,CAAC,mBAAmB;SACzD,CAAC,CAAA;IACN,CAAC;CACJ;AAhED,kGAgEC","file":"RelationCountMetadataToAttributeTransformer.js","sourcesContent":["import { QueryExpressionMap } from \"../QueryExpressionMap\"\r\nimport { RelationCountMetadata } from \"../../metadata/RelationCountMetadata\"\r\nimport { RelationCountAttribute } from \"./RelationCountAttribute\"\r\n\r\nexport class RelationCountMetadataToAttributeTransformer {\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(protected expressionMap: QueryExpressionMap) {}\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n transform() {\r\n // by example:\r\n // post has relation count:\r\n // @RelationCount(post => post.categories) categoryCount\r\n // category has relation count\r\n // @RelationCount(category => category.images) imageCount\r\n // we load post and join category\r\n // we expect post.categoryCount and post.category.imageCount to have relation counts\r\n\r\n // first create relation count attributes for all relation count metadatas of the main selected object (post from example)\r\n if (this.expressionMap.mainAlias) {\r\n this.expressionMap.mainAlias.metadata.relationCounts.forEach(\r\n (relationCount) => {\r\n const attribute = this.metadataToAttribute(\r\n this.expressionMap.mainAlias!.name,\r\n relationCount,\r\n )\r\n this.expressionMap.relationCountAttributes.push(attribute)\r\n },\r\n )\r\n }\r\n\r\n // second create relation count attributes for all relation count metadatas of all joined objects (category from example)\r\n this.expressionMap.joinAttributes.forEach((join) => {\r\n // ensure this join has a metadata, because relation count can only work for real orm entities\r\n if (!join.metadata || join.metadata.isJunction) return\r\n\r\n join.metadata.relationCounts.forEach((relationCount) => {\r\n const attribute = this.metadataToAttribute(\r\n join.alias.name,\r\n relationCount,\r\n )\r\n this.expressionMap.relationCountAttributes.push(attribute)\r\n })\r\n })\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Private Methods\r\n // -------------------------------------------------------------------------\r\n\r\n private metadataToAttribute(\r\n parentAliasName: string,\r\n relationCount: RelationCountMetadata,\r\n ): RelationCountAttribute {\r\n return new RelationCountAttribute(this.expressionMap, {\r\n relationName:\r\n parentAliasName + \".\" + relationCount.relation.propertyName, // category.images\r\n mapToProperty: parentAliasName + \".\" + relationCount.propertyName, // category.imageIds\r\n alias: relationCount.alias,\r\n queryBuilderFactory: relationCount.queryBuilderFactory,\r\n })\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.ts"],"names":[],"mappings":";;;AAEA,qEAAiE;AAEjE,MAAa,2CAA2C;IACpD,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAsB,aAAiC;QAAjC,kBAAa,GAAb,aAAa,CAAoB;IAAG,CAAC;IAE3D,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,SAAS;QACL,cAAc;QACd,2BAA2B;QAC3B,wDAAwD;QACxD,8BAA8B;QAC9B,yDAAyD;QACzD,iCAAiC;QACjC,oFAAoF;QAEpF,0HAA0H;QAC1H,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CACxD,CAAC,aAAa,EAAE,EAAE;gBACd,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,aAAa,CAAC,SAAU,CAAC,IAAI,EAClC,aAAa,CAChB,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC9D,CAAC,CACJ,CAAA;QACL,CAAC;QAED,yHAAyH;QACzH,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,8FAA8F;YAC9F,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU;gBAAE,OAAM;YAEtD,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,aAAa,EAAE,EAAE;gBACnD,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,KAAK,CAAC,IAAI,EACf,aAAa,CAChB,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC9D,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4EAA4E;IAC5E,kBAAkB;IAClB,4EAA4E;IAEpE,mBAAmB,CACvB,eAAuB,EACvB,aAAoC;QAEpC,OAAO,IAAI,+CAAsB,CAAC,IAAI,CAAC,aAAa,EAAE;YAClD,YAAY,EACR,eAAe,GAAG,GAAG,GAAG,aAAa,CAAC,QAAQ,CAAC,YAAY,EAAE,kBAAkB;YACnF,aAAa,EAAE,eAAe,GAAG,GAAG,GAAG,aAAa,CAAC,YAAY,EAAE,oBAAoB;YACvF,KAAK,EAAE,aAAa,CAAC,KAAK;YAC1B,mBAAmB,EAAE,aAAa,CAAC,mBAAmB;SACzD,CAAC,CAAA;IACN,CAAC;CACJ;AAhED,kGAgEC","file":"RelationCountMetadataToAttributeTransformer.js","sourcesContent":["import { QueryExpressionMap } from \"../QueryExpressionMap\"\nimport { RelationCountMetadata } from \"../../metadata/RelationCountMetadata\"\nimport { RelationCountAttribute } from \"./RelationCountAttribute\"\n\nexport class RelationCountMetadataToAttributeTransformer {\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(protected expressionMap: QueryExpressionMap) {}\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n transform() {\n // by example:\n // post has relation count:\n // @RelationCount(post => post.categories) categoryCount\n // category has relation count\n // @RelationCount(category => category.images) imageCount\n // we load post and join category\n // we expect post.categoryCount and post.category.imageCount to have relation counts\n\n // first create relation count attributes for all relation count metadatas of the main selected object (post from example)\n if (this.expressionMap.mainAlias) {\n this.expressionMap.mainAlias.metadata.relationCounts.forEach(\n (relationCount) => {\n const attribute = this.metadataToAttribute(\n this.expressionMap.mainAlias!.name,\n relationCount,\n )\n this.expressionMap.relationCountAttributes.push(attribute)\n },\n )\n }\n\n // second create relation count attributes for all relation count metadatas of all joined objects (category from example)\n this.expressionMap.joinAttributes.forEach((join) => {\n // ensure this join has a metadata, because relation count can only work for real orm entities\n if (!join.metadata || join.metadata.isJunction) return\n\n join.metadata.relationCounts.forEach((relationCount) => {\n const attribute = this.metadataToAttribute(\n join.alias.name,\n relationCount,\n )\n this.expressionMap.relationCountAttributes.push(attribute)\n })\n })\n }\n\n // -------------------------------------------------------------------------\n // Private Methods\n // -------------------------------------------------------------------------\n\n private metadataToAttribute(\n parentAliasName: string,\n relationCount: RelationCountMetadata,\n ): RelationCountAttribute {\n return new RelationCountAttribute(this.expressionMap, {\n relationName:\n parentAliasName + \".\" + relationCount.relation.propertyName, // category.images\n mapToProperty: parentAliasName + \".\" + relationCount.propertyName, // category.imageIds\n alias: relationCount.alias,\n queryBuilderFactory: relationCount.queryBuilderFactory,\n })\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdAttribute.ts"],"names":[],"mappings":";;;AACA,4DAAwD;AAIxD,wDAAoD;AACpD,2DAAuD;AAEvD;;GAEG;AACH,MAAa,mBAAmB;IAgC5B,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YACY,kBAAsC,EAC9C,mBAAkD;QAD1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QAVlD;;WAEG;QACH,oBAAe,GAAG,KAAK,CAAA;QAUnB,yBAAW,CAAC,MAAM,CAAC,IAAI,EAAE,mBAAmB,IAAI,EAAE,CAAC,CAAA;IACvD,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,IAAI,uBAAuB;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAA;IAC9C,CAAC;IAED;;;;;OAKG;IACH,IAAI,WAAW;QACX,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;IACtE,CAAC;IAED;;;;;;OAMG;IACH,IAAI,oBAAoB;QACpB,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;IACvE,CAAC;IAED;;;;OAIG;IACH,IAAI,QAAQ;QACR,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,MAAM,sBAAsB,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAClE,IAAI,CAAC,WAAY,CACpB,CAAA;QACD,MAAM,QAAQ,GACV,sBAAsB,CAAC,QAAQ,CAAC,4BAA4B,CACxD,IAAI,CAAC,oBAAqB,CAC7B,CAAA;QACL,IAAI,CAAC,QAAQ;YACT,MAAM,IAAI,2BAAY,CAClB,+BAA+B,IAAI,CAAC,oBAAoB,2BAA2B,CACtF,CAAA;QACL,OAAO,QAAQ,CAAA;IACnB,CAAC;IAED;;OAEG;IACH,IAAI,aAAa;QACb,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACpE,OAAO,WAAW,GAAG,GAAG,GAAG,gBAAgB,GAAG,MAAM,CAAA;IACxD,CAAC;IAED;;;OAGG;IACH,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,sBAAuB,CAAA;IAChD,CAAC;IAED,IAAI,wBAAwB;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;IACxE,CAAC;IAED,IAAI,yBAAyB;QACzB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;IACzE,CAAC;CACJ;AAlID,kDAkIC","file":"RelationIdAttribute.js","sourcesContent":["import { RelationMetadata } from \"../../metadata/RelationMetadata\"\r\nimport { QueryBuilderUtils } from \"../QueryBuilderUtils\"\r\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { QueryExpressionMap } from \"../QueryExpressionMap\"\r\nimport { SelectQueryBuilder } from \"../SelectQueryBuilder\"\r\nimport { ObjectUtils } from \"../../util/ObjectUtils\"\r\nimport { TypeORMError } from \"../../error/TypeORMError\"\r\n\r\n/**\r\n * Stores all join relation id attributes which will be used to build a JOIN query.\r\n */\r\nexport class RelationIdAttribute {\r\n // -------------------------------------------------------------------------\r\n // Public Properties\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Alias of the joined (destination) table.\r\n */\r\n alias?: string\r\n\r\n /**\r\n * Name of relation.\r\n */\r\n relationName: string\r\n\r\n /**\r\n * Property + alias of the object where to joined data should be mapped.\r\n */\r\n mapToProperty: string\r\n\r\n /**\r\n * Extra condition applied to \"ON\" section of join.\r\n */\r\n queryBuilderFactory?: (\r\n qb: SelectQueryBuilder<any>,\r\n ) => SelectQueryBuilder<any>\r\n\r\n /**\r\n * Indicates if relation id should NOT be loaded as id map.\r\n */\r\n disableMixedMap = false\r\n\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(\r\n private queryExpressionMap: QueryExpressionMap,\r\n relationIdAttribute?: Partial<RelationIdAttribute>,\r\n ) {\r\n ObjectUtils.assign(this, relationIdAttribute || {})\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n get joinInverseSideMetadata(): EntityMetadata {\r\n return this.relation.inverseEntityMetadata\r\n }\r\n\r\n /**\r\n * Alias of the parent of this join.\r\n * For example, if we join (\"post.category\", \"categoryAlias\") then \"post\" is a parent alias.\r\n * This value is extracted from entityOrProperty value.\r\n * This is available when join was made using \"post.category\" syntax.\r\n */\r\n get parentAlias(): string {\r\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\r\n throw new TypeORMError(\r\n `Given value must be a string representation of alias property`,\r\n )\r\n\r\n return this.relationName.substr(0, this.relationName.indexOf(\".\"))\r\n }\r\n\r\n /**\r\n * Relation property name of the parent.\r\n * This is used to understand what is joined.\r\n * For example, if we join (\"post.category\", \"categoryAlias\") then \"category\" is a relation property.\r\n * This value is extracted from entityOrProperty value.\r\n * This is available when join was made using \"post.category\" syntax.\r\n */\r\n get relationPropertyPath(): string {\r\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\r\n throw new TypeORMError(\r\n `Given value must be a string representation of alias property`,\r\n )\r\n\r\n return this.relationName.substr(this.relationName.indexOf(\".\") + 1)\r\n }\r\n\r\n /**\r\n * Relation of the parent.\r\n * This is used to understand what is joined.\r\n * This is available when join was made using \"post.category\" syntax.\r\n */\r\n get relation(): RelationMetadata {\r\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\r\n throw new TypeORMError(\r\n `Given value must be a string representation of alias property`,\r\n )\r\n\r\n const relationOwnerSelection = this.queryExpressionMap.findAliasByName(\r\n this.parentAlias!,\r\n )\r\n const relation =\r\n relationOwnerSelection.metadata.findRelationWithPropertyPath(\r\n this.relationPropertyPath!,\r\n )\r\n if (!relation)\r\n throw new TypeORMError(\r\n `Relation with property path ${this.relationPropertyPath} in entity was not found.`,\r\n )\r\n return relation\r\n }\r\n\r\n /**\r\n * Generates alias of junction table, whose ids we get.\r\n */\r\n get junctionAlias(): string {\r\n const [parentAlias, relationProperty] = this.relationName.split(\".\")\r\n return parentAlias + \"_\" + relationProperty + \"_rid\"\r\n }\r\n\r\n /**\r\n * Metadata of the joined entity.\r\n * If extra condition without entity was joined, then it will return undefined.\r\n */\r\n get junctionMetadata(): EntityMetadata {\r\n return this.relation.junctionEntityMetadata!\r\n }\r\n\r\n get mapToPropertyParentAlias(): string {\r\n return this.mapToProperty.substr(0, this.mapToProperty.indexOf(\".\"))\r\n }\r\n\r\n get mapToPropertyPropertyPath(): string {\r\n return this.mapToProperty.substr(this.mapToProperty.indexOf(\".\") + 1)\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdAttribute.ts"],"names":[],"mappings":";;;AACA,4DAAwD;AAIxD,wDAAoD;AACpD,2DAAuD;AAEvD;;GAEG;AACH,MAAa,mBAAmB;IAgC5B,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YACY,kBAAsC,EAC9C,mBAAkD;QAD1C,uBAAkB,GAAlB,kBAAkB,CAAoB;QAVlD;;WAEG;QACH,oBAAe,GAAG,KAAK,CAAA;QAUnB,yBAAW,CAAC,MAAM,CAAC,IAAI,EAAE,mBAAmB,IAAI,EAAE,CAAC,CAAA;IACvD,CAAC;IAED,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,IAAI,uBAAuB;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAA;IAC9C,CAAC;IAED;;;;;OAKG;IACH,IAAI,WAAW;QACX,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;IACtE,CAAC;IAED;;;;;;OAMG;IACH,IAAI,oBAAoB;QACpB,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;IACvE,CAAC;IAED;;;;OAIG;IACH,IAAI,QAAQ;QACR,IAAI,CAAC,qCAAiB,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC;YACrD,MAAM,IAAI,2BAAY,CAClB,+DAA+D,CAClE,CAAA;QAEL,MAAM,sBAAsB,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAClE,IAAI,CAAC,WAAY,CACpB,CAAA;QACD,MAAM,QAAQ,GACV,sBAAsB,CAAC,QAAQ,CAAC,4BAA4B,CACxD,IAAI,CAAC,oBAAqB,CAC7B,CAAA;QACL,IAAI,CAAC,QAAQ;YACT,MAAM,IAAI,2BAAY,CAClB,+BAA+B,IAAI,CAAC,oBAAoB,2BAA2B,CACtF,CAAA;QACL,OAAO,QAAQ,CAAA;IACnB,CAAC;IAED;;OAEG;IACH,IAAI,aAAa;QACb,MAAM,CAAC,WAAW,EAAE,gBAAgB,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACpE,OAAO,WAAW,GAAG,GAAG,GAAG,gBAAgB,GAAG,MAAM,CAAA;IACxD,CAAC;IAED;;;OAGG;IACH,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,QAAQ,CAAC,sBAAuB,CAAA;IAChD,CAAC;IAED,IAAI,wBAAwB;QACxB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;IACxE,CAAC;IAED,IAAI,yBAAyB;QACzB,OAAO,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;IACzE,CAAC;CACJ;AAlID,kDAkIC","file":"RelationIdAttribute.js","sourcesContent":["import { RelationMetadata } from \"../../metadata/RelationMetadata\"\nimport { QueryBuilderUtils } from \"../QueryBuilderUtils\"\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { QueryExpressionMap } from \"../QueryExpressionMap\"\nimport { SelectQueryBuilder } from \"../SelectQueryBuilder\"\nimport { ObjectUtils } from \"../../util/ObjectUtils\"\nimport { TypeORMError } from \"../../error/TypeORMError\"\n\n/**\n * Stores all join relation id attributes which will be used to build a JOIN query.\n */\nexport class RelationIdAttribute {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Alias of the joined (destination) table.\n */\n alias?: string\n\n /**\n * Name of relation.\n */\n relationName: string\n\n /**\n * Property + alias of the object where to joined data should be mapped.\n */\n mapToProperty: string\n\n /**\n * Extra condition applied to \"ON\" section of join.\n */\n queryBuilderFactory?: (\n qb: SelectQueryBuilder<any>,\n ) => SelectQueryBuilder<any>\n\n /**\n * Indicates if relation id should NOT be loaded as id map.\n */\n disableMixedMap = false\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(\n private queryExpressionMap: QueryExpressionMap,\n relationIdAttribute?: Partial<RelationIdAttribute>,\n ) {\n ObjectUtils.assign(this, relationIdAttribute || {})\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n get joinInverseSideMetadata(): EntityMetadata {\n return this.relation.inverseEntityMetadata\n }\n\n /**\n * Alias of the parent of this join.\n * For example, if we join (\"post.category\", \"categoryAlias\") then \"post\" is a parent alias.\n * This value is extracted from entityOrProperty value.\n * This is available when join was made using \"post.category\" syntax.\n */\n get parentAlias(): string {\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\n throw new TypeORMError(\n `Given value must be a string representation of alias property`,\n )\n\n return this.relationName.substr(0, this.relationName.indexOf(\".\"))\n }\n\n /**\n * Relation property name of the parent.\n * This is used to understand what is joined.\n * For example, if we join (\"post.category\", \"categoryAlias\") then \"category\" is a relation property.\n * This value is extracted from entityOrProperty value.\n * This is available when join was made using \"post.category\" syntax.\n */\n get relationPropertyPath(): string {\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\n throw new TypeORMError(\n `Given value must be a string representation of alias property`,\n )\n\n return this.relationName.substr(this.relationName.indexOf(\".\") + 1)\n }\n\n /**\n * Relation of the parent.\n * This is used to understand what is joined.\n * This is available when join was made using \"post.category\" syntax.\n */\n get relation(): RelationMetadata {\n if (!QueryBuilderUtils.isAliasProperty(this.relationName))\n throw new TypeORMError(\n `Given value must be a string representation of alias property`,\n )\n\n const relationOwnerSelection = this.queryExpressionMap.findAliasByName(\n this.parentAlias!,\n )\n const relation =\n relationOwnerSelection.metadata.findRelationWithPropertyPath(\n this.relationPropertyPath!,\n )\n if (!relation)\n throw new TypeORMError(\n `Relation with property path ${this.relationPropertyPath} in entity was not found.`,\n )\n return relation\n }\n\n /**\n * Generates alias of junction table, whose ids we get.\n */\n get junctionAlias(): string {\n const [parentAlias, relationProperty] = this.relationName.split(\".\")\n return parentAlias + \"_\" + relationProperty + \"_rid\"\n }\n\n /**\n * Metadata of the joined entity.\n * If extra condition without entity was joined, then it will return undefined.\n */\n get junctionMetadata(): EntityMetadata {\n return this.relation.junctionEntityMetadata!\n }\n\n get mapToPropertyParentAlias(): string {\n return this.mapToProperty.substr(0, this.mapToProperty.indexOf(\".\"))\n }\n\n get mapToPropertyPropertyPath(): string {\n return this.mapToProperty.substr(this.mapToProperty.indexOf(\".\") + 1)\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdLoadResult.ts"],"names":[],"mappings":"","file":"RelationIdLoadResult.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\r\n\r\nexport interface RelationIdLoadResult {\r\n relationIdAttribute: RelationIdAttribute\r\n results: any[]\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdLoadResult.ts"],"names":[],"mappings":"","file":"RelationIdLoadResult.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\n\nexport interface RelationIdLoadResult {\n relationIdAttribute: RelationIdAttribute\n results: any[]\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdLoader.ts"],"names":[],"mappings":"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","file":"RelationIdLoader.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\r\nimport { DataSource } from \"../../data-source/DataSource\"\r\nimport { RelationIdLoadResult } from \"./RelationIdLoadResult\"\r\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\r\nimport { DriverUtils } from \"../../driver/DriverUtils\"\r\nimport { TypeORMError } from \"../../error/TypeORMError\"\r\nimport { OrmUtils } from \"../../util/OrmUtils\"\r\n\r\nexport class RelationIdLoader {\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(\r\n protected connection: DataSource,\r\n protected queryRunner: QueryRunner | undefined,\r\n protected relationIdAttributes: RelationIdAttribute[],\r\n ) {}\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n async load(rawEntities: any[]): Promise<RelationIdLoadResult[]> {\r\n const promises = this.relationIdAttributes.map(\r\n async (relationIdAttr) => {\r\n if (\r\n relationIdAttr.relation.isManyToOne ||\r\n relationIdAttr.relation.isOneToOneOwner\r\n ) {\r\n // example: Post and Tag\r\n // loadRelationIdAndMap(\"post.tagId\", \"post.tag\")\r\n // we expect it to load id of tag\r\n\r\n if (relationIdAttr.queryBuilderFactory)\r\n throw new TypeORMError(\r\n \"Additional condition can not be used with ManyToOne or OneToOne owner relations.\",\r\n )\r\n\r\n const duplicates: { [duplicateKey: string]: boolean } = {}\r\n const results = rawEntities\r\n .map((rawEntity) => {\r\n const result: ObjectLiteral = {}\r\n const duplicateParts: Array<string> = []\r\n relationIdAttr.relation.joinColumns.forEach(\r\n (joinColumn) => {\r\n result[joinColumn.databaseName] =\r\n this.connection.driver.prepareHydratedValue(\r\n rawEntity[\r\n DriverUtils.buildAlias(\r\n this.connection.driver,\r\n undefined,\r\n relationIdAttr.parentAlias,\r\n joinColumn.databaseName,\r\n )\r\n ],\r\n joinColumn.referencedColumn!,\r\n )\r\n const duplicatePart = `${\r\n joinColumn.databaseName\r\n }:${result[joinColumn.databaseName]}`\r\n if (\r\n duplicateParts.indexOf(\r\n duplicatePart,\r\n ) === -1\r\n ) {\r\n duplicateParts.push(duplicatePart)\r\n }\r\n },\r\n )\r\n\r\n relationIdAttr.relation.entityMetadata.primaryColumns.forEach(\r\n (primaryColumn) => {\r\n result[primaryColumn.databaseName] =\r\n this.connection.driver.prepareHydratedValue(\r\n rawEntity[\r\n DriverUtils.buildAlias(\r\n this.connection.driver,\r\n undefined,\r\n relationIdAttr.parentAlias,\r\n primaryColumn.databaseName,\r\n )\r\n ],\r\n primaryColumn,\r\n )\r\n const duplicatePart = `${\r\n primaryColumn.databaseName\r\n }:${result[primaryColumn.databaseName]}`\r\n if (\r\n duplicateParts.indexOf(\r\n duplicatePart,\r\n ) === -1\r\n ) {\r\n duplicateParts.push(duplicatePart)\r\n }\r\n },\r\n )\r\n\r\n duplicateParts.sort()\r\n const duplicate = duplicateParts.join(\"::\")\r\n if (duplicates[duplicate]) {\r\n return null\r\n }\r\n duplicates[duplicate] = true\r\n return result\r\n })\r\n .filter((v) => v)\r\n\r\n return {\r\n relationIdAttribute: relationIdAttr,\r\n results: results,\r\n }\r\n } else if (\r\n relationIdAttr.relation.isOneToMany ||\r\n relationIdAttr.relation.isOneToOneNotOwner\r\n ) {\r\n // example: Post and Category\r\n // loadRelationIdAndMap(\"post.categoryIds\", \"post.categories\")\r\n // we expect it to load array of category ids\r\n\r\n const relation = relationIdAttr.relation // \"post.categories\"\r\n const joinColumns = relation.isOwning\r\n ? relation.joinColumns\r\n : relation.inverseRelation!.joinColumns\r\n const table = relation.inverseEntityMetadata.target // category\r\n const tableName = relation.inverseEntityMetadata.tableName // category\r\n const tableAlias = relationIdAttr.alias || tableName // if condition (custom query builder factory) is set then relationIdAttr.alias defined\r\n\r\n const duplicates: { [duplicateKey: string]: boolean } = {}\r\n const parameters: ObjectLiteral = {}\r\n const condition = rawEntities\r\n .map((rawEntity, index) => {\r\n const duplicateParts: Array<string> = []\r\n const parameterParts: ObjectLiteral = {}\r\n const queryPart = joinColumns\r\n .map((joinColumn) => {\r\n const parameterName =\r\n joinColumn.databaseName + index\r\n const parameterValue =\r\n rawEntity[\r\n DriverUtils.buildAlias(\r\n this.connection.driver,\r\n undefined,\r\n relationIdAttr.parentAlias,\r\n joinColumn.referencedColumn!\r\n .databaseName,\r\n )\r\n ]\r\n const duplicatePart = `${tableAlias}:${joinColumn.propertyPath}:${parameterValue}`\r\n if (\r\n duplicateParts.indexOf(\r\n duplicatePart,\r\n ) !== -1\r\n ) {\r\n return \"\"\r\n }\r\n duplicateParts.push(duplicatePart)\r\n parameterParts[parameterName] =\r\n parameterValue\r\n return (\r\n tableAlias +\r\n \".\" +\r\n joinColumn.propertyPath +\r\n \" = :\" +\r\n parameterName\r\n )\r\n })\r\n .filter((v) => v)\r\n .join(\" AND \")\r\n duplicateParts.sort()\r\n const duplicate = duplicateParts.join(\"::\")\r\n if (duplicates[duplicate]) {\r\n return \"\"\r\n }\r\n duplicates[duplicate] = true\r\n Object.assign(parameters, parameterParts)\r\n return queryPart\r\n })\r\n .filter((v) => v)\r\n .map((condition) => \"(\" + condition + \")\")\r\n .join(\" OR \")\r\n\r\n // ensure we won't perform redundant queries for joined data which was not found in selection\r\n // example: if post.category was not found in db then no need to execute query for category.imageIds\r\n if (!condition)\r\n return {\r\n relationIdAttribute: relationIdAttr,\r\n results: [],\r\n }\r\n\r\n // generate query:\r\n // SELECT category.id, category.postId FROM category category ON category.postId = :postId\r\n const qb = this.connection.createQueryBuilder(\r\n this.queryRunner,\r\n )\r\n\r\n const columns = OrmUtils.uniq(\r\n [\r\n ...joinColumns,\r\n ...relation.inverseRelation!.entityMetadata\r\n .primaryColumns,\r\n ],\r\n (column) => column.propertyPath,\r\n )\r\n\r\n columns.forEach((joinColumn) => {\r\n qb.addSelect(\r\n tableAlias + \".\" + joinColumn.propertyPath,\r\n joinColumn.databaseName,\r\n )\r\n })\r\n\r\n qb.from(table, tableAlias)\r\n .where(\"(\" + condition + \")\") // need brackets because if we have additional condition and no brackets, it looks like (a = 1) OR (a = 2) AND b = 1, that is incorrect\r\n .setParameters(parameters)\r\n\r\n // apply condition (custom query builder factory)\r\n if (relationIdAttr.queryBuilderFactory)\r\n relationIdAttr.queryBuilderFactory(qb)\r\n\r\n const results = await qb.getRawMany()\r\n results.forEach((result) => {\r\n joinColumns.forEach((column) => {\r\n result[column.databaseName] =\r\n this.connection.driver.prepareHydratedValue(\r\n result[column.databaseName],\r\n column.referencedColumn!,\r\n )\r\n })\r\n relation.inverseRelation!.entityMetadata.primaryColumns.forEach(\r\n (column) => {\r\n result[column.databaseName] =\r\n this.connection.driver.prepareHydratedValue(\r\n result[column.databaseName],\r\n column,\r\n )\r\n },\r\n )\r\n })\r\n\r\n return {\r\n relationIdAttribute: relationIdAttr,\r\n results,\r\n }\r\n } else {\r\n // many-to-many\r\n // example: Post and Category\r\n // owner side: loadRelationIdAndMap(\"post.categoryIds\", \"post.categories\")\r\n // inverse side: loadRelationIdAndMap(\"category.postIds\", \"category.posts\")\r\n // we expect it to load array of post ids\r\n\r\n const relation = relationIdAttr.relation\r\n const joinColumns = relation.isOwning\r\n ? relation.joinColumns\r\n : relation.inverseRelation!.inverseJoinColumns\r\n const inverseJoinColumns = relation.isOwning\r\n ? relation.inverseJoinColumns\r\n : relation.inverseRelation!.joinColumns\r\n const junctionAlias = relationIdAttr.junctionAlias\r\n const inverseSideTableName =\r\n relationIdAttr.joinInverseSideMetadata.tableName\r\n const inverseSideTableAlias =\r\n relationIdAttr.alias || inverseSideTableName\r\n const junctionTableName = relation.isOwning\r\n ? relation.junctionEntityMetadata!.tableName\r\n : relation.inverseRelation!.junctionEntityMetadata!\r\n .tableName\r\n\r\n const mappedColumns = rawEntities.map((rawEntity) => {\r\n return joinColumns.reduce((map, joinColumn) => {\r\n map[joinColumn.propertyPath] =\r\n rawEntity[\r\n DriverUtils.buildAlias(\r\n this.connection.driver,\r\n undefined,\r\n relationIdAttr.parentAlias,\r\n joinColumn.referencedColumn!\r\n .databaseName,\r\n )\r\n ]\r\n return map\r\n }, {} as ObjectLiteral)\r\n })\r\n\r\n // ensure we won't perform redundant queries for joined data which was not found in selection\r\n // example: if post.category was not found in db then no need to execute query for category.imageIds\r\n if (mappedColumns.length === 0)\r\n return {\r\n relationIdAttribute: relationIdAttr,\r\n results: [],\r\n }\r\n\r\n const parameters: ObjectLiteral = {}\r\n const duplicates: { [duplicateKey: string]: boolean } = {}\r\n const joinColumnConditions = mappedColumns\r\n .map((mappedColumn, index) => {\r\n const duplicateParts: Array<string> = []\r\n const parameterParts: ObjectLiteral = {}\r\n const queryPart = Object.keys(mappedColumn)\r\n .map((key) => {\r\n const parameterName = key + index\r\n const parameterValue = mappedColumn[key]\r\n const duplicatePart = `${junctionAlias}:${key}:${parameterValue}`\r\n if (\r\n duplicateParts.indexOf(\r\n duplicatePart,\r\n ) !== -1\r\n ) {\r\n return \"\"\r\n }\r\n duplicateParts.push(duplicatePart)\r\n parameterParts[parameterName] =\r\n parameterValue\r\n return (\r\n junctionAlias +\r\n \".\" +\r\n key +\r\n \" = :\" +\r\n parameterName\r\n )\r\n })\r\n .filter((s) => s)\r\n .join(\" AND \")\r\n duplicateParts.sort()\r\n const duplicate = duplicateParts.join(\"::\")\r\n if (duplicates[duplicate]) {\r\n return \"\"\r\n }\r\n duplicates[duplicate] = true\r\n Object.assign(parameters, parameterParts)\r\n return queryPart\r\n })\r\n .filter((s) => s)\r\n\r\n const inverseJoinColumnCondition = inverseJoinColumns\r\n .map((joinColumn) => {\r\n return (\r\n junctionAlias +\r\n \".\" +\r\n joinColumn.propertyPath +\r\n \" = \" +\r\n inverseSideTableAlias +\r\n \".\" +\r\n joinColumn.referencedColumn!.propertyPath\r\n )\r\n })\r\n .join(\" AND \")\r\n\r\n const condition = joinColumnConditions\r\n .map((condition) => {\r\n return (\r\n \"(\" +\r\n condition +\r\n \" AND \" +\r\n inverseJoinColumnCondition +\r\n \")\"\r\n )\r\n })\r\n .join(\" OR \")\r\n\r\n const qb = this.connection.createQueryBuilder(\r\n this.queryRunner,\r\n )\r\n\r\n inverseJoinColumns.forEach((joinColumn) => {\r\n qb.addSelect(\r\n junctionAlias + \".\" + joinColumn.propertyPath,\r\n joinColumn.databaseName,\r\n ).addOrderBy(\r\n junctionAlias + \".\" + joinColumn.propertyPath,\r\n )\r\n })\r\n\r\n joinColumns.forEach((joinColumn) => {\r\n qb.addSelect(\r\n junctionAlias + \".\" + joinColumn.propertyPath,\r\n joinColumn.databaseName,\r\n ).addOrderBy(\r\n junctionAlias + \".\" + joinColumn.propertyPath,\r\n )\r\n })\r\n\r\n qb.from(inverseSideTableName, inverseSideTableAlias)\r\n .innerJoin(junctionTableName, junctionAlias, condition)\r\n .setParameters(parameters)\r\n\r\n // apply condition (custom query builder factory)\r\n if (relationIdAttr.queryBuilderFactory)\r\n relationIdAttr.queryBuilderFactory(qb)\r\n\r\n const results = await qb.getRawMany()\r\n results.forEach((result) => {\r\n ;[...joinColumns, ...inverseJoinColumns].forEach(\r\n (column) => {\r\n result[column.databaseName] =\r\n this.connection.driver.prepareHydratedValue(\r\n result[column.databaseName],\r\n column.referencedColumn!,\r\n )\r\n },\r\n )\r\n })\r\n\r\n return {\r\n relationIdAttribute: relationIdAttr,\r\n results,\r\n }\r\n }\r\n },\r\n )\r\n\r\n return Promise.all(promises)\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdLoader.ts"],"names":[],"mappings":"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","file":"RelationIdLoader.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\nimport { DataSource } from \"../../data-source/DataSource\"\nimport { RelationIdLoadResult } from \"./RelationIdLoadResult\"\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryRunner } from \"../../query-runner/QueryRunner\"\nimport { DriverUtils } from \"../../driver/DriverUtils\"\nimport { TypeORMError } from \"../../error/TypeORMError\"\nimport { OrmUtils } from \"../../util/OrmUtils\"\n\nexport class RelationIdLoader {\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(\n protected connection: DataSource,\n protected queryRunner: QueryRunner | undefined,\n protected relationIdAttributes: RelationIdAttribute[],\n ) {}\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n async load(rawEntities: any[]): Promise<RelationIdLoadResult[]> {\n const promises = this.relationIdAttributes.map(\n async (relationIdAttr) => {\n if (\n relationIdAttr.relation.isManyToOne ||\n relationIdAttr.relation.isOneToOneOwner\n ) {\n // example: Post and Tag\n // loadRelationIdAndMap(\"post.tagId\", \"post.tag\")\n // we expect it to load id of tag\n\n if (relationIdAttr.queryBuilderFactory)\n throw new TypeORMError(\n \"Additional condition can not be used with ManyToOne or OneToOne owner relations.\",\n )\n\n const duplicates: { [duplicateKey: string]: boolean } = {}\n const results = rawEntities\n .map((rawEntity) => {\n const result: ObjectLiteral = {}\n const duplicateParts: Array<string> = []\n relationIdAttr.relation.joinColumns.forEach(\n (joinColumn) => {\n result[joinColumn.databaseName] =\n this.connection.driver.prepareHydratedValue(\n rawEntity[\n DriverUtils.buildAlias(\n this.connection.driver,\n undefined,\n relationIdAttr.parentAlias,\n joinColumn.databaseName,\n )\n ],\n joinColumn.referencedColumn!,\n )\n const duplicatePart = `${\n joinColumn.databaseName\n }:${result[joinColumn.databaseName]}`\n if (\n duplicateParts.indexOf(\n duplicatePart,\n ) === -1\n ) {\n duplicateParts.push(duplicatePart)\n }\n },\n )\n\n relationIdAttr.relation.entityMetadata.primaryColumns.forEach(\n (primaryColumn) => {\n result[primaryColumn.databaseName] =\n this.connection.driver.prepareHydratedValue(\n rawEntity[\n DriverUtils.buildAlias(\n this.connection.driver,\n undefined,\n relationIdAttr.parentAlias,\n primaryColumn.databaseName,\n )\n ],\n primaryColumn,\n )\n const duplicatePart = `${\n primaryColumn.databaseName\n }:${result[primaryColumn.databaseName]}`\n if (\n duplicateParts.indexOf(\n duplicatePart,\n ) === -1\n ) {\n duplicateParts.push(duplicatePart)\n }\n },\n )\n\n duplicateParts.sort()\n const duplicate = duplicateParts.join(\"::\")\n if (duplicates[duplicate]) {\n return null\n }\n duplicates[duplicate] = true\n return result\n })\n .filter((v) => v)\n\n return {\n relationIdAttribute: relationIdAttr,\n results: results,\n }\n } else if (\n relationIdAttr.relation.isOneToMany ||\n relationIdAttr.relation.isOneToOneNotOwner\n ) {\n // example: Post and Category\n // loadRelationIdAndMap(\"post.categoryIds\", \"post.categories\")\n // we expect it to load array of category ids\n\n const relation = relationIdAttr.relation // \"post.categories\"\n const joinColumns = relation.isOwning\n ? relation.joinColumns\n : relation.inverseRelation!.joinColumns\n const table = relation.inverseEntityMetadata.target // category\n const tableName = relation.inverseEntityMetadata.tableName // category\n const tableAlias = relationIdAttr.alias || tableName // if condition (custom query builder factory) is set then relationIdAttr.alias defined\n\n const duplicates: { [duplicateKey: string]: boolean } = {}\n const parameters: ObjectLiteral = {}\n const condition = rawEntities\n .map((rawEntity, index) => {\n const duplicateParts: Array<string> = []\n const parameterParts: ObjectLiteral = {}\n const queryPart = joinColumns\n .map((joinColumn) => {\n const parameterName =\n joinColumn.databaseName + index\n const parameterValue =\n rawEntity[\n DriverUtils.buildAlias(\n this.connection.driver,\n undefined,\n relationIdAttr.parentAlias,\n joinColumn.referencedColumn!\n .databaseName,\n )\n ]\n const duplicatePart = `${tableAlias}:${joinColumn.propertyPath}:${parameterValue}`\n if (\n duplicateParts.indexOf(\n duplicatePart,\n ) !== -1\n ) {\n return \"\"\n }\n duplicateParts.push(duplicatePart)\n parameterParts[parameterName] =\n parameterValue\n return (\n tableAlias +\n \".\" +\n joinColumn.propertyPath +\n \" = :\" +\n parameterName\n )\n })\n .filter((v) => v)\n .join(\" AND \")\n duplicateParts.sort()\n const duplicate = duplicateParts.join(\"::\")\n if (duplicates[duplicate]) {\n return \"\"\n }\n duplicates[duplicate] = true\n Object.assign(parameters, parameterParts)\n return queryPart\n })\n .filter((v) => v)\n .map((condition) => \"(\" + condition + \")\")\n .join(\" OR \")\n\n // ensure we won't perform redundant queries for joined data which was not found in selection\n // example: if post.category was not found in db then no need to execute query for category.imageIds\n if (!condition)\n return {\n relationIdAttribute: relationIdAttr,\n results: [],\n }\n\n // generate query:\n // SELECT category.id, category.postId FROM category category ON category.postId = :postId\n const qb = this.connection.createQueryBuilder(\n this.queryRunner,\n )\n\n const columns = OrmUtils.uniq(\n [\n ...joinColumns,\n ...relation.inverseRelation!.entityMetadata\n .primaryColumns,\n ],\n (column) => column.propertyPath,\n )\n\n columns.forEach((joinColumn) => {\n qb.addSelect(\n tableAlias + \".\" + joinColumn.propertyPath,\n joinColumn.databaseName,\n )\n })\n\n qb.from(table, tableAlias)\n .where(\"(\" + condition + \")\") // need brackets because if we have additional condition and no brackets, it looks like (a = 1) OR (a = 2) AND b = 1, that is incorrect\n .setParameters(parameters)\n\n // apply condition (custom query builder factory)\n if (relationIdAttr.queryBuilderFactory)\n relationIdAttr.queryBuilderFactory(qb)\n\n const results = await qb.getRawMany()\n results.forEach((result) => {\n joinColumns.forEach((column) => {\n result[column.databaseName] =\n this.connection.driver.prepareHydratedValue(\n result[column.databaseName],\n column.referencedColumn!,\n )\n })\n relation.inverseRelation!.entityMetadata.primaryColumns.forEach(\n (column) => {\n result[column.databaseName] =\n this.connection.driver.prepareHydratedValue(\n result[column.databaseName],\n column,\n )\n },\n )\n })\n\n return {\n relationIdAttribute: relationIdAttr,\n results,\n }\n } else {\n // many-to-many\n // example: Post and Category\n // owner side: loadRelationIdAndMap(\"post.categoryIds\", \"post.categories\")\n // inverse side: loadRelationIdAndMap(\"category.postIds\", \"category.posts\")\n // we expect it to load array of post ids\n\n const relation = relationIdAttr.relation\n const joinColumns = relation.isOwning\n ? relation.joinColumns\n : relation.inverseRelation!.inverseJoinColumns\n const inverseJoinColumns = relation.isOwning\n ? relation.inverseJoinColumns\n : relation.inverseRelation!.joinColumns\n const junctionAlias = relationIdAttr.junctionAlias\n const inverseSideTableName =\n relationIdAttr.joinInverseSideMetadata.tableName\n const inverseSideTableAlias =\n relationIdAttr.alias || inverseSideTableName\n const junctionTableName = relation.isOwning\n ? relation.junctionEntityMetadata!.tableName\n : relation.inverseRelation!.junctionEntityMetadata!\n .tableName\n\n const mappedColumns = rawEntities.map((rawEntity) => {\n return joinColumns.reduce((map, joinColumn) => {\n map[joinColumn.propertyPath] =\n rawEntity[\n DriverUtils.buildAlias(\n this.connection.driver,\n undefined,\n relationIdAttr.parentAlias,\n joinColumn.referencedColumn!\n .databaseName,\n )\n ]\n return map\n }, {} as ObjectLiteral)\n })\n\n // ensure we won't perform redundant queries for joined data which was not found in selection\n // example: if post.category was not found in db then no need to execute query for category.imageIds\n if (mappedColumns.length === 0)\n return {\n relationIdAttribute: relationIdAttr,\n results: [],\n }\n\n const parameters: ObjectLiteral = {}\n const duplicates: { [duplicateKey: string]: boolean } = {}\n const joinColumnConditions = mappedColumns\n .map((mappedColumn, index) => {\n const duplicateParts: Array<string> = []\n const parameterParts: ObjectLiteral = {}\n const queryPart = Object.keys(mappedColumn)\n .map((key) => {\n const parameterName = key + index\n const parameterValue = mappedColumn[key]\n const duplicatePart = `${junctionAlias}:${key}:${parameterValue}`\n if (\n duplicateParts.indexOf(\n duplicatePart,\n ) !== -1\n ) {\n return \"\"\n }\n duplicateParts.push(duplicatePart)\n parameterParts[parameterName] =\n parameterValue\n return (\n junctionAlias +\n \".\" +\n key +\n \" = :\" +\n parameterName\n )\n })\n .filter((s) => s)\n .join(\" AND \")\n duplicateParts.sort()\n const duplicate = duplicateParts.join(\"::\")\n if (duplicates[duplicate]) {\n return \"\"\n }\n duplicates[duplicate] = true\n Object.assign(parameters, parameterParts)\n return queryPart\n })\n .filter((s) => s)\n\n const inverseJoinColumnCondition = inverseJoinColumns\n .map((joinColumn) => {\n return (\n junctionAlias +\n \".\" +\n joinColumn.propertyPath +\n \" = \" +\n inverseSideTableAlias +\n \".\" +\n joinColumn.referencedColumn!.propertyPath\n )\n })\n .join(\" AND \")\n\n const condition = joinColumnConditions\n .map((condition) => {\n return (\n \"(\" +\n condition +\n \" AND \" +\n inverseJoinColumnCondition +\n \")\"\n )\n })\n .join(\" OR \")\n\n const qb = this.connection.createQueryBuilder(\n this.queryRunner,\n )\n\n inverseJoinColumns.forEach((joinColumn) => {\n qb.addSelect(\n junctionAlias + \".\" + joinColumn.propertyPath,\n joinColumn.databaseName,\n ).addOrderBy(\n junctionAlias + \".\" + joinColumn.propertyPath,\n )\n })\n\n joinColumns.forEach((joinColumn) => {\n qb.addSelect(\n junctionAlias + \".\" + joinColumn.propertyPath,\n joinColumn.databaseName,\n ).addOrderBy(\n junctionAlias + \".\" + joinColumn.propertyPath,\n )\n })\n\n qb.from(inverseSideTableName, inverseSideTableAlias)\n .innerJoin(junctionTableName, junctionAlias, condition)\n .setParameters(parameters)\n\n // apply condition (custom query builder factory)\n if (relationIdAttr.queryBuilderFactory)\n relationIdAttr.queryBuilderFactory(qb)\n\n const results = await qb.getRawMany()\n results.forEach((result) => {\n ;[...joinColumns, ...inverseJoinColumns].forEach(\n (column) => {\n result[column.databaseName] =\n this.connection.driver.prepareHydratedValue(\n result[column.databaseName],\n column.referencedColumn!,\n )\n },\n )\n })\n\n return {\n relationIdAttribute: relationIdAttr,\n results,\n }\n }\n },\n )\n\n return Promise.all(promises)\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.ts"],"names":[],"mappings":";;;AAAA,+DAA2D;AAI3D,MAAa,wCAAwC;IACjD,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAsB,aAAiC;QAAjC,kBAAa,GAAb,aAAa,CAAoB;IAAG,CAAC;IAE3D,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,SAAS;QACL,cAAc;QACd,wBAAwB;QACxB,mDAAmD;QACnD,2BAA2B;QAC3B,oDAAoD;QACpD,iCAAiC;QACjC,6EAA6E;QAE7E,oHAAoH;QACpH,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CACrD,CAAC,UAAU,EAAE,EAAE;gBACX,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,aAAa,CAAC,SAAU,CAAC,IAAI,EAClC,UAAU,CACb,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC3D,CAAC,CACJ,CAAA;QACL,CAAC;QAED,mHAAmH;QACnH,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,2FAA2F;YAC3F,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU;gBAAE,OAAM;YAEtD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;gBAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,KAAK,CAAC,IAAI,EACf,UAAU,CACb,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC3D,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4EAA4E;IAC5E,kBAAkB;IAClB,4EAA4E;IAEpE,mBAAmB,CACvB,eAAuB,EACvB,UAA8B;QAE9B,OAAO,IAAI,yCAAmB,CAAC,IAAI,CAAC,aAAa,EAAE;YAC/C,YAAY,EACR,eAAe,GAAG,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,EAAE,kBAAkB;YAChF,aAAa,EAAE,eAAe,GAAG,GAAG,GAAG,UAAU,CAAC,YAAY,EAAE,oBAAoB;YACpF,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;SACtD,CAAC,CAAA;IACN,CAAC;CACJ;AAhED,4FAgEC","file":"RelationIdMetadataToAttributeTransformer.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\r\nimport { QueryExpressionMap } from \"../QueryExpressionMap\"\r\nimport { RelationIdMetadata } from \"../../metadata/RelationIdMetadata\"\r\n\r\nexport class RelationIdMetadataToAttributeTransformer {\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(protected expressionMap: QueryExpressionMap) {}\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n transform() {\r\n // by example:\r\n // post has relation id:\r\n // @RelationId(post => post.categories) categoryIds\r\n // category has relation id\r\n // @RelationId(category => category.images) imageIds\r\n // we load post and join category\r\n // we expect post.categoryIds and post.category.imageIds to have relation ids\r\n\r\n // first create relation id attributes for all relation id metadatas of the main selected object (post from example)\r\n if (this.expressionMap.mainAlias) {\r\n this.expressionMap.mainAlias.metadata.relationIds.forEach(\r\n (relationId) => {\r\n const attribute = this.metadataToAttribute(\r\n this.expressionMap.mainAlias!.name,\r\n relationId,\r\n )\r\n this.expressionMap.relationIdAttributes.push(attribute)\r\n },\r\n )\r\n }\r\n\r\n // second create relation id attributes for all relation id metadatas of all joined objects (category from example)\r\n this.expressionMap.joinAttributes.forEach((join) => {\r\n // ensure this join has a metadata, because relation id can only work for real orm entities\r\n if (!join.metadata || join.metadata.isJunction) return\r\n\r\n join.metadata.relationIds.forEach((relationId) => {\r\n const attribute = this.metadataToAttribute(\r\n join.alias.name,\r\n relationId,\r\n )\r\n this.expressionMap.relationIdAttributes.push(attribute)\r\n })\r\n })\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Private Methods\r\n // -------------------------------------------------------------------------\r\n\r\n private metadataToAttribute(\r\n parentAliasName: string,\r\n relationId: RelationIdMetadata,\r\n ): RelationIdAttribute {\r\n return new RelationIdAttribute(this.expressionMap, {\r\n relationName:\r\n parentAliasName + \".\" + relationId.relation.propertyName, // category.images\r\n mapToProperty: parentAliasName + \".\" + relationId.propertyName, // category.imageIds\r\n alias: relationId.alias,\r\n queryBuilderFactory: relationId.queryBuilderFactory,\r\n })\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.ts"],"names":[],"mappings":";;;AAAA,+DAA2D;AAI3D,MAAa,wCAAwC;IACjD,4EAA4E;IAC5E,cAAc;IACd,4EAA4E;IAE5E,YAAsB,aAAiC;QAAjC,kBAAa,GAAb,aAAa,CAAoB;IAAG,CAAC;IAE3D,4EAA4E;IAC5E,iBAAiB;IACjB,4EAA4E;IAE5E,SAAS;QACL,cAAc;QACd,wBAAwB;QACxB,mDAAmD;QACnD,2BAA2B;QAC3B,oDAAoD;QACpD,iCAAiC;QACjC,6EAA6E;QAE7E,oHAAoH;QACpH,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CACrD,CAAC,UAAU,EAAE,EAAE;gBACX,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,aAAa,CAAC,SAAU,CAAC,IAAI,EAClC,UAAU,CACb,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC3D,CAAC,CACJ,CAAA;QACL,CAAC;QAED,mHAAmH;QACnH,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,2FAA2F;YAC3F,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,UAAU;gBAAE,OAAM;YAEtD,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;gBAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,mBAAmB,CACtC,IAAI,CAAC,KAAK,CAAC,IAAI,EACf,UAAU,CACb,CAAA;gBACD,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YAC3D,CAAC,CAAC,CAAA;QACN,CAAC,CAAC,CAAA;IACN,CAAC;IAED,4EAA4E;IAC5E,kBAAkB;IAClB,4EAA4E;IAEpE,mBAAmB,CACvB,eAAuB,EACvB,UAA8B;QAE9B,OAAO,IAAI,yCAAmB,CAAC,IAAI,CAAC,aAAa,EAAE;YAC/C,YAAY,EACR,eAAe,GAAG,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,EAAE,kBAAkB;YAChF,aAAa,EAAE,eAAe,GAAG,GAAG,GAAG,UAAU,CAAC,YAAY,EAAE,oBAAoB;YACpF,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;SACtD,CAAC,CAAA;IACN,CAAC;CACJ;AAhED,4FAgEC","file":"RelationIdMetadataToAttributeTransformer.js","sourcesContent":["import { RelationIdAttribute } from \"./RelationIdAttribute\"\nimport { QueryExpressionMap } from \"../QueryExpressionMap\"\nimport { RelationIdMetadata } from \"../../metadata/RelationIdMetadata\"\n\nexport class RelationIdMetadataToAttributeTransformer {\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(protected expressionMap: QueryExpressionMap) {}\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n transform() {\n // by example:\n // post has relation id:\n // @RelationId(post => post.categories) categoryIds\n // category has relation id\n // @RelationId(category => category.images) imageIds\n // we load post and join category\n // we expect post.categoryIds and post.category.imageIds to have relation ids\n\n // first create relation id attributes for all relation id metadatas of the main selected object (post from example)\n if (this.expressionMap.mainAlias) {\n this.expressionMap.mainAlias.metadata.relationIds.forEach(\n (relationId) => {\n const attribute = this.metadataToAttribute(\n this.expressionMap.mainAlias!.name,\n relationId,\n )\n this.expressionMap.relationIdAttributes.push(attribute)\n },\n )\n }\n\n // second create relation id attributes for all relation id metadatas of all joined objects (category from example)\n this.expressionMap.joinAttributes.forEach((join) => {\n // ensure this join has a metadata, because relation id can only work for real orm entities\n if (!join.metadata || join.metadata.isJunction) return\n\n join.metadata.relationIds.forEach((relationId) => {\n const attribute = this.metadataToAttribute(\n join.alias.name,\n relationId,\n )\n this.expressionMap.relationIdAttributes.push(attribute)\n })\n })\n }\n\n // -------------------------------------------------------------------------\n // Private Methods\n // -------------------------------------------------------------------------\n\n private metadataToAttribute(\n parentAliasName: string,\n relationId: RelationIdMetadata,\n ): RelationIdAttribute {\n return new RelationIdAttribute(this.expressionMap, {\n relationName:\n parentAliasName + \".\" + relationId.relation.propertyName, // category.images\n mapToProperty: parentAliasName + \".\" + relationId.propertyName, // category.imageIds\n alias: relationId.alias,\n queryBuilderFactory: relationId.queryBuilderFactory,\n })\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/result/DeleteResult.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,MAAa,YAAY;IACrB,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QAEzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,OAAO,CAAA;QAChC,MAAM,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;QAEtC,OAAO,MAAM,CAAA;IACjB,CAAC;CAYJ;AApBD,oCAoBC","file":"DeleteResult.js","sourcesContent":["import { QueryResult } from \"../../query-runner/QueryResult\"\r\n\r\n/**\r\n * Result object returned by DeleteQueryBuilder execution.\r\n */\r\nexport class DeleteResult {\r\n static from(queryResult: QueryResult) {\r\n const result = new this()\r\n\r\n result.raw = queryResult.records\r\n result.affected = queryResult.affected\r\n\r\n return result\r\n }\r\n\r\n /**\r\n * Raw SQL result returned by executed query.\r\n */\r\n raw: any\r\n\r\n /**\r\n * Number of affected rows/documents\r\n * Not all drivers support this\r\n */\r\n affected?: number | null\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/result/DeleteResult.ts"],"names":[],"mappings":";;;AAEA;;GAEG;AACH,MAAa,YAAY;IACrB,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QAEzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,OAAO,CAAA;QAChC,MAAM,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;QAEtC,OAAO,MAAM,CAAA;IACjB,CAAC;CAYJ;AApBD,oCAoBC","file":"DeleteResult.js","sourcesContent":["import { QueryResult } from \"../../query-runner/QueryResult\"\n\n/**\n * Result object returned by DeleteQueryBuilder execution.\n */\nexport class DeleteResult {\n static from(queryResult: QueryResult) {\n const result = new this()\n\n result.raw = queryResult.records\n result.affected = queryResult.affected\n\n return result\n }\n\n /**\n * Raw SQL result returned by executed query.\n */\n raw: any\n\n /**\n * Number of affected rows/documents\n * Not all drivers support this\n */\n affected?: number | null\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/result/InsertResult.ts"],"names":[],"mappings":";;;AAGA;;GAEG;AACH,MAAa,YAAY;IAAzB;QAOI;;;WAGG;QACH,gBAAW,GAAoB,EAAE,CAAA;QAEjC;;;WAGG;QACH,kBAAa,GAAoB,EAAE,CAAA;IAMvC,CAAC;IAtBG,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QACzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAA;QAC5B,OAAO,MAAM,CAAA;IACjB,CAAC;CAkBJ;AAvBD,oCAuBC","file":"InsertResult.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { QueryResult } from \"../../query-runner/QueryResult\"\r\n\r\n/**\r\n * Result object returned by InsertQueryBuilder execution.\r\n */\r\nexport class InsertResult {\r\n static from(queryResult: QueryResult) {\r\n const result = new this()\r\n result.raw = queryResult.raw\r\n return result\r\n }\r\n\r\n /**\r\n * Contains inserted entity id.\r\n * Has entity-like structure (not just column database name and values).\r\n */\r\n identifiers: ObjectLiteral[] = []\r\n\r\n /**\r\n * Generated values returned by a database.\r\n * Has entity-like structure (not just column database name and values).\r\n */\r\n generatedMaps: ObjectLiteral[] = []\r\n\r\n /**\r\n * Raw SQL result returned by executed query.\r\n */\r\n raw: any\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/result/InsertResult.ts"],"names":[],"mappings":";;;AAGA;;GAEG;AACH,MAAa,YAAY;IAAzB;QAOI;;;WAGG;QACH,gBAAW,GAAoB,EAAE,CAAA;QAEjC;;;WAGG;QACH,kBAAa,GAAoB,EAAE,CAAA;IAMvC,CAAC;IAtBG,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QACzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAA;QAC5B,OAAO,MAAM,CAAA;IACjB,CAAC;CAkBJ;AAvBD,oCAuBC","file":"InsertResult.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\n\n/**\n * Result object returned by InsertQueryBuilder execution.\n */\nexport class InsertResult {\n static from(queryResult: QueryResult) {\n const result = new this()\n result.raw = queryResult.raw\n return result\n }\n\n /**\n * Contains inserted entity id.\n * Has entity-like structure (not just column database name and values).\n */\n identifiers: ObjectLiteral[] = []\n\n /**\n * Generated values returned by a database.\n * Has entity-like structure (not just column database name and values).\n */\n generatedMaps: ObjectLiteral[] = []\n\n /**\n * Raw SQL result returned by executed query.\n */\n raw: any\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/result/UpdateResult.ts"],"names":[],"mappings":";;;AAGA;;GAEG;AACH,MAAa,YAAY;IAAzB;QAmBI;;;WAGG;QACH,oCAAoC;QAEpC;;;WAGG;QACH,kBAAa,GAAoB,EAAE,CAAA;IACvC,CAAC;IA7BG,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QACzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,OAAO,CAAA;QAChC,MAAM,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;QACtC,OAAO,MAAM,CAAA;IACjB,CAAC;CAwBJ;AA9BD,oCA8BC","file":"UpdateResult.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { QueryResult } from \"../../query-runner/QueryResult\"\r\n\r\n/**\r\n * Result object returned by UpdateQueryBuilder execution.\r\n */\r\nexport class UpdateResult {\r\n static from(queryResult: QueryResult) {\r\n const result = new this()\r\n result.raw = queryResult.records\r\n result.affected = queryResult.affected\r\n return result\r\n }\r\n\r\n /**\r\n * Raw SQL result returned by executed query.\r\n */\r\n raw: any\r\n\r\n /**\r\n * Number of affected rows/documents\r\n * Not all drivers support this\r\n */\r\n affected?: number\r\n\r\n /**\r\n * Contains inserted entity id.\r\n * Has entity-like structure (not just column database name and values).\r\n */\r\n // identifier: ObjectLiteral[] = [];\r\n\r\n /**\r\n * Generated values returned by a database.\r\n * Has entity-like structure (not just column database name and values).\r\n */\r\n generatedMaps: ObjectLiteral[] = []\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/result/UpdateResult.ts"],"names":[],"mappings":";;;AAGA;;GAEG;AACH,MAAa,YAAY;IAAzB;QAmBI;;;WAGG;QACH,oCAAoC;QAEpC;;;WAGG;QACH,kBAAa,GAAoB,EAAE,CAAA;IACvC,CAAC;IA7BG,MAAM,CAAC,IAAI,CAAC,WAAwB;QAChC,MAAM,MAAM,GAAG,IAAI,IAAI,EAAE,CAAA;QACzB,MAAM,CAAC,GAAG,GAAG,WAAW,CAAC,OAAO,CAAA;QAChC,MAAM,CAAC,QAAQ,GAAG,WAAW,CAAC,QAAQ,CAAA;QACtC,OAAO,MAAM,CAAA;IACjB,CAAC;CAwBJ;AA9BD,oCA8BC","file":"UpdateResult.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { QueryResult } from \"../../query-runner/QueryResult\"\n\n/**\n * Result object returned by UpdateQueryBuilder execution.\n */\nexport class UpdateResult {\n static from(queryResult: QueryResult) {\n const result = new this()\n result.raw = queryResult.records\n result.affected = queryResult.affected\n return result\n }\n\n /**\n * Raw SQL result returned by executed query.\n */\n raw: any\n\n /**\n * Number of affected rows/documents\n * Not all drivers support this\n */\n affected?: number\n\n /**\n * Contains inserted entity id.\n * Has entity-like structure (not just column database name and values).\n */\n // identifier: ObjectLiteral[] = [];\n\n /**\n * Generated values returned by a database.\n * Has entity-like structure (not just column database name and values).\n */\n generatedMaps: ObjectLiteral[] = []\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/transformer/DocumentToEntityTransformer.ts"],"names":[],"mappings":"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","file":"DocumentToEntityTransformer.js","sourcesContent":["import { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { EmbeddedMetadata } from \"../../metadata/EmbeddedMetadata\"\r\n\r\n/**\r\n * Transforms raw document into entity object.\r\n * Entity is constructed based on its entity metadata.\r\n */\r\nexport class DocumentToEntityTransformer {\r\n // -------------------------------------------------------------------------\r\n // Constructor\r\n // -------------------------------------------------------------------------\r\n\r\n constructor(\r\n // private selectionMap: AliasMap,\r\n // private joinMappings: JoinMapping[],\r\n // private relationCountMetas: RelationCountAttribute[],\r\n private enableRelationIdValues: boolean = false,\r\n ) {}\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n transformAll(documents: ObjectLiteral[], metadata: EntityMetadata) {\r\n return documents.map((document) => this.transform(document, metadata))\r\n }\r\n\r\n transform(document: any, metadata: EntityMetadata) {\r\n const entity: any = metadata.create(undefined, {\r\n fromDeserializer: true,\r\n })\r\n let hasData = false\r\n\r\n // handle _id property the special way\r\n if (metadata.objectIdColumn) {\r\n // todo: we can't use driver in this class\r\n // do we really need prepare hydrated value here? If no then no problem. If yes then think maybe prepareHydratedValue process should be extracted out of driver class?\r\n // entity[metadata.ObjectIdColumn.propertyName] = this.driver.prepareHydratedValue(document[metadata.ObjectIdColumn.name\"], metadata.ObjectIdColumn);\r\n const { databaseNameWithoutPrefixes, propertyName } =\r\n metadata.objectIdColumn\r\n\r\n const documentIdWithoutPrefixes =\r\n document[databaseNameWithoutPrefixes]\r\n const documentIdWithPropertyName = document[propertyName]\r\n\r\n if (documentIdWithoutPrefixes) {\r\n entity[propertyName] = documentIdWithoutPrefixes\r\n hasData = true\r\n } else if (documentIdWithPropertyName) {\r\n entity[propertyName] = documentIdWithPropertyName\r\n hasData = true\r\n }\r\n }\r\n\r\n // add special columns that contains relation ids\r\n if (this.enableRelationIdValues) {\r\n metadata.columns\r\n .filter((column) => !!column.relationMetadata)\r\n .forEach((column) => {\r\n const valueInObject =\r\n document[column.databaseNameWithoutPrefixes]\r\n if (\r\n valueInObject !== undefined &&\r\n valueInObject !== null &&\r\n column.propertyName\r\n ) {\r\n // todo: we can't use driver in this class\r\n // const value = this.driver.prepareHydratedValue(valueInObject, column);\r\n entity[column.propertyName] = valueInObject\r\n hasData = true\r\n }\r\n })\r\n }\r\n\r\n /*this.joinMappings\r\n .filter(joinMapping => joinMapping.parentName === alias.name && !joinMapping.alias.relationOwnerSelection && joinMapping.alias.target)\r\n .map(joinMapping => {\r\n const relatedEntities = this.transformRawResultsGroup(rawSqlResults, joinMapping.alias);\r\n const isResultArray = joinMapping.isMany;\r\n const result = !isResultArray ? relatedEntities[0] : relatedEntities;\r\n\r\n if (result && (!isResultArray || result.length > 0)) {\r\n entity[joinMapping.propertyName] = result;\r\n hasData = true;\r\n }\r\n });*/\r\n\r\n // get value from columns selections and put them into object\r\n metadata.ownColumns.forEach((column) => {\r\n const valueInObject = document[column.databaseNameWithoutPrefixes]\r\n if (\r\n valueInObject !== undefined &&\r\n column.propertyName &&\r\n !column.isVirtual\r\n ) {\r\n // const value = this.driver.prepareHydratedValue(valueInObject, column);\r\n\r\n entity[column.propertyName] = valueInObject\r\n hasData = true\r\n }\r\n })\r\n\r\n const addEmbeddedValuesRecursively = (\r\n entity: any,\r\n document: any,\r\n embeddeds: EmbeddedMetadata[],\r\n ) => {\r\n embeddeds.forEach((embedded) => {\r\n if (!document[embedded.prefix]) return\r\n\r\n if (embedded.isArray) {\r\n entity[embedded.propertyName] = (\r\n document[embedded.prefix] as any[]\r\n ).map((subValue: any, index: number) => {\r\n const newItem = embedded.create({\r\n fromDeserializer: true,\r\n })\r\n embedded.columns.forEach((column) => {\r\n newItem[column.propertyName] =\r\n subValue[column.databaseNameWithoutPrefixes]\r\n })\r\n addEmbeddedValuesRecursively(\r\n newItem,\r\n document[embedded.prefix][index],\r\n embedded.embeddeds,\r\n )\r\n return newItem\r\n })\r\n } else {\r\n if (\r\n embedded.embeddeds.length &&\r\n !entity[embedded.propertyName]\r\n )\r\n entity[embedded.propertyName] = embedded.create({\r\n fromDeserializer: true,\r\n })\r\n\r\n embedded.columns.forEach((column) => {\r\n const value =\r\n document[embedded.prefix][\r\n column.databaseNameWithoutPrefixes\r\n ]\r\n if (value === undefined) return\r\n\r\n if (!entity[embedded.propertyName])\r\n entity[embedded.propertyName] = embedded.create({\r\n fromDeserializer: true,\r\n })\r\n\r\n entity[embedded.propertyName][column.propertyName] =\r\n value\r\n })\r\n\r\n addEmbeddedValuesRecursively(\r\n entity[embedded.propertyName],\r\n document[embedded.prefix],\r\n embedded.embeddeds,\r\n )\r\n }\r\n })\r\n }\r\n\r\n addEmbeddedValuesRecursively(entity, document, metadata.embeddeds)\r\n\r\n // if relation is loaded then go into it recursively and transform its values too\r\n /*metadata.relations.forEach(relation => {\r\n const relationAlias = this.selectionMap.findSelectionByParent(alias.name, relation.propertyName);\r\n if (relationAlias) {\r\n const joinMapping = this.joinMappings.find(joinMapping => joinMapping.type === \"join\" && joinMapping.alias === relationAlias);\r\n const relatedEntities = this.transformRawResultsGroup(rawSqlResults, relationAlias);\r\n const isResultArray = relation.isManyToMany || relation.isOneToMany;\r\n const result = !isResultArray ? relatedEntities[0] : relatedEntities;\r\n\r\n if (result) {\r\n let propertyName = relation.propertyName;\r\n if (joinMapping) {\r\n propertyName = joinMapping.propertyName;\r\n }\r\n\r\n if (relation.isLazy) {\r\n entity[\"__\" + propertyName + \"__\"] = result;\r\n } else {\r\n entity[propertyName] = result;\r\n }\r\n\r\n if (!isResultArray || result.length > 0)\r\n hasData = true;\r\n }\r\n }\r\n\r\n // if relation has id field then relation id/ids to that field.\r\n if (relation.isManyToMany) {\r\n if (relationAlias) {\r\n const ids: any[] = [];\r\n const joinMapping = this.joinMappings.find(joinMapping => joinMapping.type === \"relationId\" && joinMapping.alias === relationAlias);\r\n\r\n if (relation.idField || joinMapping) {\r\n const propertyName = joinMapping ? joinMapping.propertyName : relation.idField as string;\r\n const junctionMetadata = relation.junctionEntityMetadata;\r\n const columnName = relation.isOwning ? junctionMetadata.columns[1].name : junctionMetadata.columns[0].name;\r\n\r\n rawSqlResults.forEach(results => {\r\n if (relationAlias) {\r\n const resultsKey = relationAlias.name + \"_\" + columnName;\r\n const value = this.driver.prepareHydratedValue(results[resultsKey], relation.referencedColumn);\r\n if (value !== undefined && value !== null)\r\n ids.push(value);\r\n }\r\n });\r\n\r\n if (ids && ids.length)\r\n entity[propertyName] = ids;\r\n }\r\n }\r\n } else if (relation.idField) {\r\n const relationName = relation.name;\r\n entity[relation.idField] = this.driver.prepareHydratedValue(rawSqlResults[0][alias.name + \"_\" + relationName], relation.referencedColumn);\r\n }\r\n\r\n // if relation counter\r\n this.relationCountMetas.forEach(joinMeta => {\r\n if (joinMeta.alias === relationAlias) {\r\n // console.log(\"relation count was found for relation: \", relation);\r\n // joinMeta.entity = entity;\r\n joinMeta.entities.push({ entity: entity, metadata: metadata });\r\n // console.log(joinMeta);\r\n // console.log(\"---------------------\");\r\n }\r\n });\r\n });*/\r\n\r\n return hasData ? entity : null\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/transformer/DocumentToEntityTransformer.ts"],"names":[],"mappings":"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","file":"DocumentToEntityTransformer.js","sourcesContent":["import { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { EmbeddedMetadata } from \"../../metadata/EmbeddedMetadata\"\n\n/**\n * Transforms raw document into entity object.\n * Entity is constructed based on its entity metadata.\n */\nexport class DocumentToEntityTransformer {\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(\n // private selectionMap: AliasMap,\n // private joinMappings: JoinMapping[],\n // private relationCountMetas: RelationCountAttribute[],\n private enableRelationIdValues: boolean = false,\n ) {}\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n transformAll(documents: ObjectLiteral[], metadata: EntityMetadata) {\n return documents.map((document) => this.transform(document, metadata))\n }\n\n transform(document: any, metadata: EntityMetadata) {\n const entity: any = metadata.create(undefined, {\n fromDeserializer: true,\n })\n let hasData = false\n\n // handle _id property the special way\n if (metadata.objectIdColumn) {\n // todo: we can't use driver in this class\n // do we really need prepare hydrated value here? If no then no problem. If yes then think maybe prepareHydratedValue process should be extracted out of driver class?\n // entity[metadata.ObjectIdColumn.propertyName] = this.driver.prepareHydratedValue(document[metadata.ObjectIdColumn.name\"], metadata.ObjectIdColumn);\n const { databaseNameWithoutPrefixes, propertyName } =\n metadata.objectIdColumn\n\n const documentIdWithoutPrefixes =\n document[databaseNameWithoutPrefixes]\n const documentIdWithPropertyName = document[propertyName]\n\n if (documentIdWithoutPrefixes) {\n entity[propertyName] = documentIdWithoutPrefixes\n hasData = true\n } else if (documentIdWithPropertyName) {\n entity[propertyName] = documentIdWithPropertyName\n hasData = true\n }\n }\n\n // add special columns that contains relation ids\n if (this.enableRelationIdValues) {\n metadata.columns\n .filter((column) => !!column.relationMetadata)\n .forEach((column) => {\n const valueInObject =\n document[column.databaseNameWithoutPrefixes]\n if (\n valueInObject !== undefined &&\n valueInObject !== null &&\n column.propertyName\n ) {\n // todo: we can't use driver in this class\n // const value = this.driver.prepareHydratedValue(valueInObject, column);\n entity[column.propertyName] = valueInObject\n hasData = true\n }\n })\n }\n\n /*this.joinMappings\n .filter(joinMapping => joinMapping.parentName === alias.name && !joinMapping.alias.relationOwnerSelection && joinMapping.alias.target)\n .map(joinMapping => {\n const relatedEntities = this.transformRawResultsGroup(rawSqlResults, joinMapping.alias);\n const isResultArray = joinMapping.isMany;\n const result = !isResultArray ? relatedEntities[0] : relatedEntities;\n\n if (result && (!isResultArray || result.length > 0)) {\n entity[joinMapping.propertyName] = result;\n hasData = true;\n }\n });*/\n\n // get value from columns selections and put them into object\n metadata.ownColumns.forEach((column) => {\n const valueInObject = document[column.databaseNameWithoutPrefixes]\n if (\n valueInObject !== undefined &&\n column.propertyName &&\n !column.isVirtual\n ) {\n // const value = this.driver.prepareHydratedValue(valueInObject, column);\n\n entity[column.propertyName] = valueInObject\n hasData = true\n }\n })\n\n const addEmbeddedValuesRecursively = (\n entity: any,\n document: any,\n embeddeds: EmbeddedMetadata[],\n ) => {\n embeddeds.forEach((embedded) => {\n if (!document[embedded.prefix]) return\n\n if (embedded.isArray) {\n entity[embedded.propertyName] = (\n document[embedded.prefix] as any[]\n ).map((subValue: any, index: number) => {\n const newItem = embedded.create({\n fromDeserializer: true,\n })\n embedded.columns.forEach((column) => {\n newItem[column.propertyName] =\n subValue[column.databaseNameWithoutPrefixes]\n })\n addEmbeddedValuesRecursively(\n newItem,\n document[embedded.prefix][index],\n embedded.embeddeds,\n )\n return newItem\n })\n } else {\n if (\n embedded.embeddeds.length &&\n !entity[embedded.propertyName]\n )\n entity[embedded.propertyName] = embedded.create({\n fromDeserializer: true,\n })\n\n embedded.columns.forEach((column) => {\n const value =\n document[embedded.prefix][\n column.databaseNameWithoutPrefixes\n ]\n if (value === undefined) return\n\n if (!entity[embedded.propertyName])\n entity[embedded.propertyName] = embedded.create({\n fromDeserializer: true,\n })\n\n entity[embedded.propertyName][column.propertyName] =\n value\n })\n\n addEmbeddedValuesRecursively(\n entity[embedded.propertyName],\n document[embedded.prefix],\n embedded.embeddeds,\n )\n }\n })\n }\n\n addEmbeddedValuesRecursively(entity, document, metadata.embeddeds)\n\n // if relation is loaded then go into it recursively and transform its values too\n /*metadata.relations.forEach(relation => {\n const relationAlias = this.selectionMap.findSelectionByParent(alias.name, relation.propertyName);\n if (relationAlias) {\n const joinMapping = this.joinMappings.find(joinMapping => joinMapping.type === \"join\" && joinMapping.alias === relationAlias);\n const relatedEntities = this.transformRawResultsGroup(rawSqlResults, relationAlias);\n const isResultArray = relation.isManyToMany || relation.isOneToMany;\n const result = !isResultArray ? relatedEntities[0] : relatedEntities;\n\n if (result) {\n let propertyName = relation.propertyName;\n if (joinMapping) {\n propertyName = joinMapping.propertyName;\n }\n\n if (relation.isLazy) {\n entity[\"__\" + propertyName + \"__\"] = result;\n } else {\n entity[propertyName] = result;\n }\n\n if (!isResultArray || result.length > 0)\n hasData = true;\n }\n }\n\n // if relation has id field then relation id/ids to that field.\n if (relation.isManyToMany) {\n if (relationAlias) {\n const ids: any[] = [];\n const joinMapping = this.joinMappings.find(joinMapping => joinMapping.type === \"relationId\" && joinMapping.alias === relationAlias);\n\n if (relation.idField || joinMapping) {\n const propertyName = joinMapping ? joinMapping.propertyName : relation.idField as string;\n const junctionMetadata = relation.junctionEntityMetadata;\n const columnName = relation.isOwning ? junctionMetadata.columns[1].name : junctionMetadata.columns[0].name;\n\n rawSqlResults.forEach(results => {\n if (relationAlias) {\n const resultsKey = relationAlias.name + \"_\" + columnName;\n const value = this.driver.prepareHydratedValue(results[resultsKey], relation.referencedColumn);\n if (value !== undefined && value !== null)\n ids.push(value);\n }\n });\n\n if (ids && ids.length)\n entity[propertyName] = ids;\n }\n }\n } else if (relation.idField) {\n const relationName = relation.name;\n entity[relation.idField] = this.driver.prepareHydratedValue(rawSqlResults[0][alias.name + \"_\" + relationName], relation.referencedColumn);\n }\n\n // if relation counter\n this.relationCountMetas.forEach(joinMeta => {\n if (joinMeta.alias === relationAlias) {\n // console.log(\"relation count was found for relation: \", relation);\n // joinMeta.entity = entity;\n joinMeta.entities.push({ entity: entity, metadata: metadata });\n // console.log(joinMeta);\n // console.log(\"---------------------\");\n }\n });\n });*/\n\n return hasData ? entity : null\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.ts"],"names":[],"mappings":"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","file":"PlainObjectToDatabaseEntityTransformer.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { EntityManager } from \"../../entity-manager/EntityManager\"\r\nimport { RelationMetadata } from \"../../metadata/RelationMetadata\"\r\n\r\n/**\r\n */\r\nclass LoadMapItem {\r\n entity?: ObjectLiteral\r\n plainEntity: ObjectLiteral\r\n metadata: EntityMetadata\r\n parentLoadMapItem?: LoadMapItem\r\n relation?: RelationMetadata\r\n\r\n constructor(\r\n plainEntity: ObjectLiteral,\r\n metadata: EntityMetadata,\r\n parentLoadMapItem?: LoadMapItem,\r\n relation?: RelationMetadata,\r\n ) {\r\n this.plainEntity = plainEntity\r\n this.metadata = metadata\r\n this.parentLoadMapItem = parentLoadMapItem\r\n this.relation = relation\r\n }\r\n\r\n get target(): Function | string {\r\n return this.metadata.target\r\n }\r\n\r\n get id(): any {\r\n return this.metadata.getEntityIdMixedMap(this.plainEntity)\r\n }\r\n}\r\n\r\nclass LoadMap {\r\n loadMapItems: LoadMapItem[] = []\r\n\r\n get mainLoadMapItem(): LoadMapItem | undefined {\r\n return this.loadMapItems.find(\r\n (item) => !item.relation && !item.parentLoadMapItem,\r\n )\r\n }\r\n\r\n addLoadMap(newLoadMap: LoadMapItem) {\r\n const item = this.loadMapItems.find(\r\n (item) =>\r\n item.target === newLoadMap.target && item.id === newLoadMap.id,\r\n )\r\n if (!item) this.loadMapItems.push(newLoadMap)\r\n }\r\n\r\n fillEntities(target: Function | string, entities: any[]) {\r\n entities.forEach((entity) => {\r\n const item = this.loadMapItems.find((loadMapItem) => {\r\n return (\r\n loadMapItem.target === target &&\r\n loadMapItem.metadata.compareEntities(\r\n entity,\r\n loadMapItem.plainEntity,\r\n )\r\n )\r\n })\r\n if (item) item.entity = entity\r\n })\r\n }\r\n\r\n groupByTargetIds(): { target: Function | string; ids: any[] }[] {\r\n const groups: { target: Function | string; ids: any[] }[] = []\r\n this.loadMapItems.forEach((loadMapItem) => {\r\n let group = groups.find(\r\n (group) => group.target === loadMapItem.target,\r\n )\r\n if (!group) {\r\n group = { target: loadMapItem.target, ids: [] }\r\n groups.push(group)\r\n }\r\n\r\n group.ids.push(loadMapItem.id)\r\n })\r\n return groups\r\n }\r\n}\r\n\r\n/**\r\n * Transforms plain old javascript object\r\n * Entity is constructed based on its entity metadata.\r\n */\r\nexport class PlainObjectToDatabaseEntityTransformer {\r\n constructor(private manager: EntityManager) {}\r\n\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n async transform(\r\n plainObject: ObjectLiteral,\r\n metadata: EntityMetadata,\r\n ): Promise<ObjectLiteral | undefined> {\r\n // if plain object does not have id then nothing to load really\r\n if (!metadata.hasAllPrimaryKeys(plainObject))\r\n return Promise.reject(\r\n \"Given object does not have a primary column, cannot transform it to database entity.\",\r\n )\r\n\r\n // create a special load map that will hold all metadata that will be used to operate with entities easily\r\n const loadMap = new LoadMap()\r\n const fillLoadMap = (\r\n entity: ObjectLiteral,\r\n entityMetadata: EntityMetadata,\r\n parentLoadMapItem?: LoadMapItem,\r\n relation?: RelationMetadata,\r\n ) => {\r\n const item = new LoadMapItem(\r\n entity,\r\n entityMetadata,\r\n parentLoadMapItem,\r\n relation,\r\n )\r\n loadMap.addLoadMap(item)\r\n\r\n entityMetadata\r\n .extractRelationValuesFromEntity(entity, metadata.relations)\r\n .filter((value) => value !== null && value !== undefined)\r\n .forEach(([relation, value, inverseEntityMetadata]) =>\r\n fillLoadMap(value, inverseEntityMetadata, item, relation),\r\n )\r\n }\r\n fillLoadMap(plainObject, metadata)\r\n // load all entities and store them in the load map\r\n await Promise.all(\r\n loadMap.groupByTargetIds().map((targetWithIds) => {\r\n // todo: fix type hinting\r\n return this.manager\r\n .findByIds<ObjectLiteral>(\r\n targetWithIds.target as any,\r\n targetWithIds.ids,\r\n )\r\n .then((entities) =>\r\n loadMap.fillEntities(targetWithIds.target, entities),\r\n )\r\n }),\r\n )\r\n\r\n // go through each item in the load map and set their entity relationship using metadata stored in load map\r\n loadMap.loadMapItems.forEach((loadMapItem) => {\r\n if (\r\n !loadMapItem.relation ||\r\n !loadMapItem.entity ||\r\n !loadMapItem.parentLoadMapItem ||\r\n !loadMapItem.parentLoadMapItem.entity\r\n )\r\n return\r\n\r\n if (\r\n loadMapItem.relation.isManyToMany ||\r\n loadMapItem.relation.isOneToMany\r\n ) {\r\n if (\r\n !loadMapItem.parentLoadMapItem.entity[\r\n loadMapItem.relation.propertyName\r\n ]\r\n )\r\n loadMapItem.parentLoadMapItem.entity[\r\n loadMapItem.relation.propertyName\r\n ] = []\r\n loadMapItem.parentLoadMapItem.entity[\r\n loadMapItem.relation.propertyName\r\n ].push(loadMapItem.entity)\r\n } else {\r\n loadMapItem.parentLoadMapItem.entity[\r\n loadMapItem.relation.propertyName\r\n ] = loadMapItem.entity\r\n }\r\n })\r\n\r\n return loadMap.mainLoadMapItem\r\n ? loadMap.mainLoadMapItem.entity\r\n : undefined\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.ts"],"names":[],"mappings":"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","file":"PlainObjectToDatabaseEntityTransformer.js","sourcesContent":["import { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { EntityManager } from \"../../entity-manager/EntityManager\"\nimport { RelationMetadata } from \"../../metadata/RelationMetadata\"\n\n/**\n */\nclass LoadMapItem {\n entity?: ObjectLiteral\n plainEntity: ObjectLiteral\n metadata: EntityMetadata\n parentLoadMapItem?: LoadMapItem\n relation?: RelationMetadata\n\n constructor(\n plainEntity: ObjectLiteral,\n metadata: EntityMetadata,\n parentLoadMapItem?: LoadMapItem,\n relation?: RelationMetadata,\n ) {\n this.plainEntity = plainEntity\n this.metadata = metadata\n this.parentLoadMapItem = parentLoadMapItem\n this.relation = relation\n }\n\n get target(): Function | string {\n return this.metadata.target\n }\n\n get id(): any {\n return this.metadata.getEntityIdMixedMap(this.plainEntity)\n }\n}\n\nclass LoadMap {\n loadMapItems: LoadMapItem[] = []\n\n get mainLoadMapItem(): LoadMapItem | undefined {\n return this.loadMapItems.find(\n (item) => !item.relation && !item.parentLoadMapItem,\n )\n }\n\n addLoadMap(newLoadMap: LoadMapItem) {\n const item = this.loadMapItems.find(\n (item) =>\n item.target === newLoadMap.target && item.id === newLoadMap.id,\n )\n if (!item) this.loadMapItems.push(newLoadMap)\n }\n\n fillEntities(target: Function | string, entities: any[]) {\n entities.forEach((entity) => {\n const item = this.loadMapItems.find((loadMapItem) => {\n return (\n loadMapItem.target === target &&\n loadMapItem.metadata.compareEntities(\n entity,\n loadMapItem.plainEntity,\n )\n )\n })\n if (item) item.entity = entity\n })\n }\n\n groupByTargetIds(): { target: Function | string; ids: any[] }[] {\n const groups: { target: Function | string; ids: any[] }[] = []\n this.loadMapItems.forEach((loadMapItem) => {\n let group = groups.find(\n (group) => group.target === loadMapItem.target,\n )\n if (!group) {\n group = { target: loadMapItem.target, ids: [] }\n groups.push(group)\n }\n\n group.ids.push(loadMapItem.id)\n })\n return groups\n }\n}\n\n/**\n * Transforms plain old javascript object\n * Entity is constructed based on its entity metadata.\n */\nexport class PlainObjectToDatabaseEntityTransformer {\n constructor(private manager: EntityManager) {}\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n async transform(\n plainObject: ObjectLiteral,\n metadata: EntityMetadata,\n ): Promise<ObjectLiteral | undefined> {\n // if plain object does not have id then nothing to load really\n if (!metadata.hasAllPrimaryKeys(plainObject))\n return Promise.reject(\n \"Given object does not have a primary column, cannot transform it to database entity.\",\n )\n\n // create a special load map that will hold all metadata that will be used to operate with entities easily\n const loadMap = new LoadMap()\n const fillLoadMap = (\n entity: ObjectLiteral,\n entityMetadata: EntityMetadata,\n parentLoadMapItem?: LoadMapItem,\n relation?: RelationMetadata,\n ) => {\n const item = new LoadMapItem(\n entity,\n entityMetadata,\n parentLoadMapItem,\n relation,\n )\n loadMap.addLoadMap(item)\n\n entityMetadata\n .extractRelationValuesFromEntity(entity, metadata.relations)\n .filter((value) => value !== null && value !== undefined)\n .forEach(([relation, value, inverseEntityMetadata]) =>\n fillLoadMap(value, inverseEntityMetadata, item, relation),\n )\n }\n fillLoadMap(plainObject, metadata)\n // load all entities and store them in the load map\n await Promise.all(\n loadMap.groupByTargetIds().map((targetWithIds) => {\n // todo: fix type hinting\n return this.manager\n .findByIds<ObjectLiteral>(\n targetWithIds.target as any,\n targetWithIds.ids,\n )\n .then((entities) =>\n loadMap.fillEntities(targetWithIds.target, entities),\n )\n }),\n )\n\n // go through each item in the load map and set their entity relationship using metadata stored in load map\n loadMap.loadMapItems.forEach((loadMapItem) => {\n if (\n !loadMapItem.relation ||\n !loadMapItem.entity ||\n !loadMapItem.parentLoadMapItem ||\n !loadMapItem.parentLoadMapItem.entity\n )\n return\n\n if (\n loadMapItem.relation.isManyToMany ||\n loadMapItem.relation.isOneToMany\n ) {\n if (\n !loadMapItem.parentLoadMapItem.entity[\n loadMapItem.relation.propertyName\n ]\n )\n loadMapItem.parentLoadMapItem.entity[\n loadMapItem.relation.propertyName\n ] = []\n loadMapItem.parentLoadMapItem.entity[\n loadMapItem.relation.propertyName\n ].push(loadMapItem.entity)\n } else {\n loadMapItem.parentLoadMapItem.entity[\n loadMapItem.relation.propertyName\n ] = loadMapItem.entity\n }\n })\n\n return loadMap.mainLoadMapItem\n ? loadMap.mainLoadMapItem.entity\n : undefined\n }\n}\n"],"sourceRoot":"../.."}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/query-builder/transformer/PlainObjectToNewEntityTransformer.ts"],"names":[],"mappings":"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","file":"PlainObjectToNewEntityTransformer.js","sourcesContent":["import { EntityMetadata } from \"../../metadata/EntityMetadata\"\r\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\r\nimport { ObjectUtils } from \"../../util/ObjectUtils\"\r\n\r\n/**\r\n * Transforms plain old javascript object\r\n * Entity is constructed based on its entity metadata.\r\n */\r\nexport class PlainObjectToNewEntityTransformer {\r\n // -------------------------------------------------------------------------\r\n // Public Methods\r\n // -------------------------------------------------------------------------\r\n\r\n transform<T extends ObjectLiteral>(\r\n newEntity: T,\r\n object: ObjectLiteral,\r\n metadata: EntityMetadata,\r\n getLazyRelationsPromiseValue: boolean = false,\r\n ): T {\r\n // console.log(\"groupAndTransform entity:\", newEntity);\r\n // console.log(\"groupAndTransform object:\", object);\r\n this.groupAndTransform(\r\n newEntity,\r\n object,\r\n metadata,\r\n getLazyRelationsPromiseValue,\r\n )\r\n // console.log(\"result:\", newEntity);\r\n return newEntity\r\n }\r\n\r\n // -------------------------------------------------------------------------\r\n // Private Methods\r\n // -------------------------------------------------------------------------\r\n\r\n /**\r\n * Since db returns a duplicated rows of the data where accuracies of the same object can be duplicated\r\n * we need to group our result and we must have some unique id (primary key in our case)\r\n */\r\n private groupAndTransform(\r\n entity: ObjectLiteral,\r\n object: ObjectLiteral,\r\n metadata: EntityMetadata,\r\n getLazyRelationsPromiseValue: boolean = false,\r\n ): void {\r\n // console.log(\"groupAndTransform entity:\", entity);\r\n // console.log(\"groupAndTransform object:\", object);\r\n\r\n // copy regular column properties from the given object\r\n metadata.nonVirtualColumns.forEach((column) => {\r\n const objectColumnValue = column.getEntityValue(object)\r\n if (objectColumnValue !== undefined)\r\n column.setEntityValue(entity, objectColumnValue)\r\n })\r\n\r\n // // copy relation properties from the given object\r\n if (metadata.relations.length) {\r\n metadata.relations.forEach((relation) => {\r\n let entityRelatedValue = relation.getEntityValue(entity)\r\n const objectRelatedValue = relation.getEntityValue(\r\n object,\r\n getLazyRelationsPromiseValue,\r\n )\r\n if (objectRelatedValue === undefined) return\r\n\r\n if (relation.isOneToMany || relation.isManyToMany) {\r\n if (!Array.isArray(objectRelatedValue)) return\r\n\r\n if (!entityRelatedValue) {\r\n entityRelatedValue = []\r\n relation.setEntityValue(entity, entityRelatedValue)\r\n }\r\n\r\n objectRelatedValue.forEach((objectRelatedValueItem) => {\r\n // check if we have this item from the merging object in the original entity we merge into\r\n let objectRelatedValueEntity = (\r\n entityRelatedValue as any[]\r\n ).find((entityRelatedValueItem) => {\r\n return relation.inverseEntityMetadata.compareEntities(\r\n objectRelatedValueItem,\r\n entityRelatedValueItem,\r\n )\r\n })\r\n\r\n const inverseEntityMetadata =\r\n relation.inverseEntityMetadata.findInheritanceMetadata(\r\n objectRelatedValueItem,\r\n )\r\n\r\n // if such item already exist then merge new data into it, if its not we create a new entity and merge it into the array\r\n if (!objectRelatedValueEntity) {\r\n objectRelatedValueEntity =\r\n inverseEntityMetadata.create(undefined, {\r\n fromDeserializer: true,\r\n })\r\n entityRelatedValue.push(objectRelatedValueEntity)\r\n }\r\n\r\n this.groupAndTransform(\r\n objectRelatedValueEntity,\r\n objectRelatedValueItem,\r\n inverseEntityMetadata,\r\n getLazyRelationsPromiseValue,\r\n )\r\n })\r\n } else {\r\n // if related object isn't an object (direct relation id for example)\r\n // we just set it to the entity relation, we don't need anything more from it\r\n // however we do it only if original entity does not have this relation set to object\r\n // to prevent full overriding of objects\r\n if (!ObjectUtils.isObject(objectRelatedValue)) {\r\n if (!ObjectUtils.isObject(entityRelatedValue))\r\n relation.setEntityValue(entity, objectRelatedValue)\r\n return\r\n }\r\n\r\n const inverseEntityMetadata =\r\n relation.inverseEntityMetadata.findInheritanceMetadata(\r\n objectRelatedValue,\r\n )\r\n\r\n if (!entityRelatedValue) {\r\n entityRelatedValue = inverseEntityMetadata.create(\r\n undefined,\r\n {\r\n fromDeserializer: true,\r\n },\r\n )\r\n relation.setEntityValue(entity, entityRelatedValue)\r\n }\r\n\r\n this.groupAndTransform(\r\n entityRelatedValue,\r\n objectRelatedValue,\r\n inverseEntityMetadata,\r\n getLazyRelationsPromiseValue,\r\n )\r\n }\r\n })\r\n }\r\n }\r\n}\r\n"],"sourceRoot":"../.."}
1
+ {"version":3,"sources":["../../src/query-builder/transformer/PlainObjectToNewEntityTransformer.ts"],"names":[],"mappings":"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","file":"PlainObjectToNewEntityTransformer.js","sourcesContent":["import { EntityMetadata } from \"../../metadata/EntityMetadata\"\nimport { ObjectLiteral } from \"../../common/ObjectLiteral\"\nimport { ObjectUtils } from \"../../util/ObjectUtils\"\n\n/**\n * Transforms plain old javascript object\n * Entity is constructed based on its entity metadata.\n */\nexport class PlainObjectToNewEntityTransformer {\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n transform<T extends ObjectLiteral>(\n newEntity: T,\n object: ObjectLiteral,\n metadata: EntityMetadata,\n getLazyRelationsPromiseValue: boolean = false,\n ): T {\n // console.log(\"groupAndTransform entity:\", newEntity);\n // console.log(\"groupAndTransform object:\", object);\n this.groupAndTransform(\n newEntity,\n object,\n metadata,\n getLazyRelationsPromiseValue,\n )\n // console.log(\"result:\", newEntity);\n return newEntity\n }\n\n // -------------------------------------------------------------------------\n // Private Methods\n // -------------------------------------------------------------------------\n\n /**\n * Since db returns a duplicated rows of the data where accuracies of the same object can be duplicated\n * we need to group our result and we must have some unique id (primary key in our case)\n */\n private groupAndTransform(\n entity: ObjectLiteral,\n object: ObjectLiteral,\n metadata: EntityMetadata,\n getLazyRelationsPromiseValue: boolean = false,\n ): void {\n // console.log(\"groupAndTransform entity:\", entity);\n // console.log(\"groupAndTransform object:\", object);\n\n // copy regular column properties from the given object\n metadata.nonVirtualColumns.forEach((column) => {\n const objectColumnValue = column.getEntityValue(object)\n if (objectColumnValue !== undefined)\n column.setEntityValue(entity, objectColumnValue)\n })\n\n // // copy relation properties from the given object\n if (metadata.relations.length) {\n metadata.relations.forEach((relation) => {\n let entityRelatedValue = relation.getEntityValue(entity)\n const objectRelatedValue = relation.getEntityValue(\n object,\n getLazyRelationsPromiseValue,\n )\n if (objectRelatedValue === undefined) return\n\n if (relation.isOneToMany || relation.isManyToMany) {\n if (!Array.isArray(objectRelatedValue)) return\n\n if (!entityRelatedValue) {\n entityRelatedValue = []\n relation.setEntityValue(entity, entityRelatedValue)\n }\n\n objectRelatedValue.forEach((objectRelatedValueItem) => {\n // check if we have this item from the merging object in the original entity we merge into\n let objectRelatedValueEntity = (\n entityRelatedValue as any[]\n ).find((entityRelatedValueItem) => {\n return relation.inverseEntityMetadata.compareEntities(\n objectRelatedValueItem,\n entityRelatedValueItem,\n )\n })\n\n const inverseEntityMetadata =\n relation.inverseEntityMetadata.findInheritanceMetadata(\n objectRelatedValueItem,\n )\n\n // if such item already exist then merge new data into it, if its not we create a new entity and merge it into the array\n if (!objectRelatedValueEntity) {\n objectRelatedValueEntity =\n inverseEntityMetadata.create(undefined, {\n fromDeserializer: true,\n })\n entityRelatedValue.push(objectRelatedValueEntity)\n }\n\n this.groupAndTransform(\n objectRelatedValueEntity,\n objectRelatedValueItem,\n inverseEntityMetadata,\n getLazyRelationsPromiseValue,\n )\n })\n } else {\n // if related object isn't an object (direct relation id for example)\n // we just set it to the entity relation, we don't need anything more from it\n // however we do it only if original entity does not have this relation set to object\n // to prevent full overriding of objects\n if (!ObjectUtils.isObject(objectRelatedValue)) {\n if (!ObjectUtils.isObject(entityRelatedValue))\n relation.setEntityValue(entity, objectRelatedValue)\n return\n }\n\n const inverseEntityMetadata =\n relation.inverseEntityMetadata.findInheritanceMetadata(\n objectRelatedValue,\n )\n\n if (!entityRelatedValue) {\n entityRelatedValue = inverseEntityMetadata.create(\n undefined,\n {\n fromDeserializer: true,\n },\n )\n relation.setEntityValue(entity, entityRelatedValue)\n }\n\n this.groupAndTransform(\n entityRelatedValue,\n objectRelatedValue,\n inverseEntityMetadata,\n getLazyRelationsPromiseValue,\n )\n }\n })\n }\n }\n}\n"],"sourceRoot":"../.."}