typeorm 0.3.20-dev.fa86f6f → 0.3.21-dev.0d08246

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 (710) hide show
  1. package/README.md +11 -14
  2. package/browser/cache/DbQueryResultCache.js +1 -1
  3. package/browser/cache/DbQueryResultCache.js.map +1 -1
  4. package/browser/cache/QueryResultCache.d.ts +4 -2
  5. package/browser/cache/QueryResultCache.js.map +1 -1
  6. package/browser/cache/QueryResultCacheFactory.js.map +1 -1
  7. package/browser/cache/RedisQueryResultCache.js +1 -1
  8. package/browser/cache/RedisQueryResultCache.js.map +1 -1
  9. package/browser/cli-ts-node-esm.js.map +1 -1
  10. package/browser/connection/ConnectionManager.js.map +1 -1
  11. package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
  12. package/browser/connection/ConnectionOptionsReader.d.ts +4 -4
  13. package/browser/connection/ConnectionOptionsReader.js.map +1 -1
  14. package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  15. package/browser/container.js.map +1 -1
  16. package/browser/data-source/DataSource.d.ts +2 -0
  17. package/browser/data-source/DataSource.js +5 -1
  18. package/browser/data-source/DataSource.js.map +1 -1
  19. package/browser/decorator/Unique.js.map +1 -1
  20. package/browser/decorator/columns/Column.js.map +1 -1
  21. package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
  22. package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  23. package/browser/decorator/columns/VirtualColumn.js +1 -1
  24. package/browser/decorator/columns/VirtualColumn.js.map +1 -1
  25. package/browser/decorator/entity/ChildEntity.js.map +1 -1
  26. package/browser/decorator/relations/ManyToMany.js.map +1 -1
  27. package/browser/decorator/relations/ManyToOne.js.map +1 -1
  28. package/browser/decorator/relations/OneToMany.js.map +1 -1
  29. package/browser/decorator/relations/OneToOne.d.ts +4 -4
  30. package/browser/decorator/relations/OneToOne.js +2 -2
  31. package/browser/decorator/relations/OneToOne.js.map +1 -1
  32. package/browser/driver/DriverFactory.js.map +1 -1
  33. package/browser/driver/DriverUtils.js.map +1 -1
  34. package/browser/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.d.ts +1 -1
  35. package/browser/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  36. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js +10 -10
  37. package/browser/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  38. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +0 -1
  39. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js +2 -2
  40. package/browser/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  41. package/browser/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  42. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js +2 -2
  43. package/browser/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  44. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +2 -2
  45. package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  46. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js +4 -0
  47. package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  48. package/browser/driver/capacitor/CapacitorDriver.js.map +1 -1
  49. package/browser/driver/capacitor/CapacitorQueryRunner.js +2 -2
  50. package/browser/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  51. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.d.ts +1 -2
  52. package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  53. package/browser/driver/cockroachdb/CockroachConnectionOptions.d.ts +1 -1
  54. package/browser/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  55. package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
  56. package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +0 -1
  57. package/browser/driver/cockroachdb/CockroachQueryRunner.js +8 -6
  58. package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  59. package/browser/driver/cordova/CordovaDriver.js.map +1 -1
  60. package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
  61. package/browser/driver/expo/ExpoDriver.js.map +1 -1
  62. package/browser/driver/expo/ExpoQueryRunner.js +2 -2
  63. package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
  64. package/browser/driver/mongodb/MongoConnectionOptions.d.ts +1 -2
  65. package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  66. package/browser/driver/mongodb/MongoDriver.js.map +1 -1
  67. package/browser/driver/mongodb/MongoQueryRunner.d.ts +0 -1
  68. package/browser/driver/mongodb/typings.d.ts +0 -8
  69. package/browser/driver/mongodb/typings.js +0 -1
  70. package/browser/driver/mongodb/typings.js.map +1 -1
  71. package/browser/driver/mysql/MysqlConnectionCredentialsOptions.d.ts +1 -1
  72. package/browser/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  73. package/browser/driver/mysql/MysqlConnectionOptions.d.ts +1 -1
  74. package/browser/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  75. package/browser/driver/mysql/MysqlDriver.js +12 -14
  76. package/browser/driver/mysql/MysqlDriver.js.map +1 -1
  77. package/browser/driver/mysql/MysqlQueryRunner.d.ts +0 -1
  78. package/browser/driver/mysql/MysqlQueryRunner.js +1 -1
  79. package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
  80. package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
  81. package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  82. package/browser/driver/oracle/OracleConnectionCredentialsOptions.d.ts +1 -1
  83. package/browser/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  84. package/browser/driver/oracle/OracleConnectionOptions.d.ts +1 -1
  85. package/browser/driver/oracle/OracleConnectionOptions.js.map +1 -1
  86. package/browser/driver/oracle/OracleDriver.js +18 -10
  87. package/browser/driver/oracle/OracleDriver.js.map +1 -1
  88. package/browser/driver/oracle/OracleQueryRunner.d.ts +0 -1
  89. package/browser/driver/oracle/OracleQueryRunner.js +8 -10
  90. package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
  91. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +1 -2
  92. package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  93. package/browser/driver/postgres/PostgresConnectionOptions.d.ts +1 -1
  94. package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  95. package/browser/driver/postgres/PostgresDriver.js +11 -6
  96. package/browser/driver/postgres/PostgresDriver.js.map +1 -1
  97. package/browser/driver/postgres/PostgresQueryRunner.d.ts +1 -2
  98. package/browser/driver/postgres/PostgresQueryRunner.js +35 -12
  99. package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
  100. package/browser/driver/react-native/ReactNativeDriver.js +4 -6
  101. package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
  102. package/browser/driver/react-native/ReactNativeQueryRunner.js +2 -2
  103. package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  104. package/browser/driver/sap/SapDriver.js.map +1 -1
  105. package/browser/driver/sap/SapQueryRunner.d.ts +0 -1
  106. package/browser/driver/sap/SapQueryRunner.js +4 -4
  107. package/browser/driver/sap/SapQueryRunner.js.map +1 -1
  108. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.d.ts +1 -1
  109. package/browser/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  110. package/browser/driver/spanner/SpannerConnectionOptions.d.ts +1 -1
  111. package/browser/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  112. package/browser/driver/spanner/SpannerDriver.js.map +1 -1
  113. package/browser/driver/spanner/SpannerQueryRunner.d.ts +0 -1
  114. package/browser/driver/spanner/SpannerQueryRunner.js.map +1 -1
  115. package/browser/driver/sqlite/SqliteDriver.js +2 -2
  116. package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
  117. package/browser/driver/sqlite/SqliteQueryRunner.js +3 -2
  118. package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  119. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +4 -6
  120. package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  121. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +0 -1
  122. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +4 -4
  123. package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  124. package/browser/driver/sqljs/SqljsDriver.js +1 -2
  125. package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
  126. package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  127. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +1 -1
  128. package/browser/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  129. package/browser/driver/sqlserver/SqlServerConnectionOptions.d.ts +1 -1
  130. package/browser/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  131. package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
  132. package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +0 -1
  133. package/browser/driver/sqlserver/SqlServerQueryRunner.js +9 -7
  134. package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  135. package/browser/driver/types/ColumnTypes.d.ts +1 -1
  136. package/browser/driver/types/ColumnTypes.js.map +1 -1
  137. package/browser/entity-manager/EntityManager.d.ts +4 -2
  138. package/browser/entity-manager/EntityManager.js +4 -2
  139. package/browser/entity-manager/EntityManager.js.map +1 -1
  140. package/browser/entity-manager/MongoEntityManager.js +1 -1
  141. package/browser/entity-manager/MongoEntityManager.js.map +1 -1
  142. package/browser/entity-schema/EntitySchemaTransformer.js +2 -3
  143. package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
  144. package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
  145. package/browser/error/EntityNotFoundError.js.map +1 -1
  146. package/browser/error/FindRelationsNotFoundError.js.map +1 -1
  147. package/browser/error/MissingJoinColumnError.js.map +1 -1
  148. package/browser/error/MissingJoinTableError.js.map +1 -1
  149. package/browser/error/QueryFailedError.js.map +1 -1
  150. package/browser/error/RepositoryNotTreeError.js.map +1 -1
  151. package/browser/error/TypeORMError.js.map +1 -1
  152. package/browser/find-options/FindOperator.js.map +1 -1
  153. package/browser/find-options/FindOptionsOrder.d.ts +0 -1
  154. package/browser/find-options/FindOptionsRelations.d.ts +0 -1
  155. package/browser/find-options/FindOptionsSelect.d.ts +0 -1
  156. package/browser/find-options/FindOptionsUtils.js +1 -1
  157. package/browser/find-options/FindOptionsUtils.js.map +1 -1
  158. package/browser/find-options/FindOptionsWhere.d.ts +0 -1
  159. package/browser/find-options/operator/Raw.js.map +1 -1
  160. package/browser/globals.js.map +1 -1
  161. package/browser/logger/AbstractLogger.js.map +1 -1
  162. package/browser/logger/AdvancedConsoleLogger.js +1 -2
  163. package/browser/logger/AdvancedConsoleLogger.js.map +1 -1
  164. package/browser/logger/DebugLogger.js +1 -2
  165. package/browser/logger/DebugLogger.js.map +1 -1
  166. package/browser/logger/FileLogger.js +2 -3
  167. package/browser/logger/FileLogger.js.map +1 -1
  168. package/browser/logger/LoggerFactory.js.map +1 -1
  169. package/browser/logger/SimpleConsoleLogger.js +1 -2
  170. package/browser/logger/SimpleConsoleLogger.js.map +1 -1
  171. package/browser/metadata/CheckMetadata.js.map +1 -1
  172. package/browser/metadata/ColumnMetadata.js +19 -15
  173. package/browser/metadata/ColumnMetadata.js.map +1 -1
  174. package/browser/metadata/EmbeddedMetadata.js +1 -1
  175. package/browser/metadata/EmbeddedMetadata.js.map +1 -1
  176. package/browser/metadata/EntityListenerMetadata.js.map +1 -1
  177. package/browser/metadata/EntityMetadata.js +3 -7
  178. package/browser/metadata/EntityMetadata.js.map +1 -1
  179. package/browser/metadata/ExclusionMetadata.js.map +1 -1
  180. package/browser/metadata/IndexMetadata.js.map +1 -1
  181. package/browser/metadata/RelationIdMetadata.js.map +1 -1
  182. package/browser/metadata/RelationMetadata.js.map +1 -1
  183. package/browser/metadata/UniqueMetadata.js.map +1 -1
  184. package/browser/metadata-args/MetadataArgsStorage.js.map +1 -1
  185. package/browser/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  186. package/browser/metadata-builder/EntityMetadataBuilder.js +5 -8
  187. package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  188. package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
  189. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js +7 -8
  190. package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  191. package/browser/metadata-builder/MetadataUtils.js.map +1 -1
  192. package/browser/metadata-builder/RelationJoinColumnBuilder.js +2 -3
  193. package/browser/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  194. package/browser/migration/MigrationExecutor.js +2 -2
  195. package/browser/migration/MigrationExecutor.js.map +1 -1
  196. package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  197. package/browser/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  198. package/browser/persistence/EntityPersistExecutor.js.map +1 -1
  199. package/browser/persistence/Subject.js.map +1 -1
  200. package/browser/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  201. package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  202. package/browser/persistence/SubjectExecutor.js +3 -3
  203. package/browser/persistence/SubjectExecutor.js.map +1 -1
  204. package/browser/persistence/{SubjectTopoligicalSorter.d.ts → SubjectTopologicalSorter.d.ts} +1 -1
  205. package/browser/persistence/{SubjectTopoligicalSorter.js → SubjectTopologicalSorter.js} +2 -2
  206. package/browser/persistence/SubjectTopologicalSorter.js.map +1 -0
  207. package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  208. package/browser/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  209. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js +1 -2
  210. package/browser/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  211. package/browser/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  212. package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  213. package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  214. package/browser/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  215. package/browser/platform/BrowserPlatformTools.js.map +1 -1
  216. package/browser/platform/PlatformTools.d.ts +0 -1
  217. package/browser/platform/PlatformTools.js +3 -9
  218. package/browser/platform/PlatformTools.js.map +1 -1
  219. package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
  220. package/browser/query-builder/InsertQueryBuilder.js +15 -15
  221. package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
  222. package/browser/query-builder/JoinAttribute.js.map +1 -1
  223. package/browser/query-builder/QueryBuilder.d.ts +1 -1
  224. package/browser/query-builder/QueryBuilder.js +12 -14
  225. package/browser/query-builder/QueryBuilder.js.map +1 -1
  226. package/browser/query-builder/QueryExpressionMap.js +2 -2
  227. package/browser/query-builder/QueryExpressionMap.js.map +1 -1
  228. package/browser/query-builder/RelationIdLoader.js.map +1 -1
  229. package/browser/query-builder/RelationLoader.js.map +1 -1
  230. package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
  231. package/browser/query-builder/RelationRemover.js.map +1 -1
  232. package/browser/query-builder/RelationUpdater.js.map +1 -1
  233. package/browser/query-builder/ReturningResultsEntityUpdator.js +5 -2
  234. package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  235. package/browser/query-builder/SelectQueryBuilder.d.ts +4 -5
  236. package/browser/query-builder/SelectQueryBuilder.js +23 -22
  237. package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
  238. package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  239. package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
  240. package/browser/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  241. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js +2 -2
  242. package/browser/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  243. package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  244. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js +2 -2
  245. package/browser/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  246. package/browser/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  247. package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  248. package/browser/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  249. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -9
  250. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +94 -88
  251. package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  252. package/browser/query-runner/BaseQueryRunner.js.map +1 -1
  253. package/browser/query-runner/QueryLock.js.map +1 -1
  254. package/browser/query-runner/QueryRunner.d.ts +0 -1
  255. package/browser/repository/BaseEntity.js.map +1 -1
  256. package/browser/repository/Repository.d.ts +2 -0
  257. package/browser/repository/Repository.js +2 -0
  258. package/browser/repository/Repository.js.map +1 -1
  259. package/browser/repository/TreeRepository.js.map +1 -1
  260. package/browser/schema-builder/RdbmsSchemaBuilder.js +2 -1
  261. package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  262. package/browser/schema-builder/table/Table.js +2 -2
  263. package/browser/schema-builder/table/Table.js.map +1 -1
  264. package/browser/schema-builder/table/TableColumn.js.map +1 -1
  265. package/browser/schema-builder/util/ViewUtils.js.map +1 -1
  266. package/browser/schema-builder/view/View.js.map +1 -1
  267. package/browser/subscriber/Broadcaster.js +6 -6
  268. package/browser/subscriber/Broadcaster.js.map +1 -1
  269. package/browser/subscriber/BroadcasterResult.js.map +1 -1
  270. package/browser/util/ApplyValueTransformers.js.map +1 -1
  271. package/browser/util/DateUtils.js.map +1 -1
  272. package/browser/util/DepGraph.js +2 -2
  273. package/browser/util/DepGraph.js.map +1 -1
  274. package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
  275. package/browser/util/ImportUtils.js +23 -35
  276. package/browser/util/ImportUtils.js.map +1 -1
  277. package/browser/util/ObjectUtils.js.map +1 -1
  278. package/browser/util/OrmUtils.js.map +1 -1
  279. package/browser/util/PathUtils.js +1 -1
  280. package/browser/util/PathUtils.js.map +1 -1
  281. package/browser/util/RandomGenerator.js.map +1 -1
  282. package/browser/util/StringUtils.js.map +1 -1
  283. package/browser/util/TreeRepositoryUtils.js +3 -6
  284. package/browser/util/TreeRepositoryUtils.js.map +1 -1
  285. package/cache/DbQueryResultCache.js +1 -1
  286. package/cache/DbQueryResultCache.js.map +1 -1
  287. package/cache/QueryResultCache.d.ts +4 -2
  288. package/cache/QueryResultCache.js.map +1 -1
  289. package/cache/QueryResultCacheFactory.js.map +1 -1
  290. package/cache/RedisQueryResultCache.js +1 -1
  291. package/cache/RedisQueryResultCache.js.map +1 -1
  292. package/cli-ts-node-esm.js.map +1 -1
  293. package/commands/CacheClearCommand.js.map +1 -1
  294. package/commands/CommandUtils.d.ts +1 -1
  295. package/commands/CommandUtils.js +18 -16
  296. package/commands/CommandUtils.js.map +1 -1
  297. package/commands/EntityCreateCommand.js.map +1 -1
  298. package/commands/InitCommand.js +2 -2
  299. package/commands/InitCommand.js.map +1 -1
  300. package/commands/MigrationCreateCommand.js.map +1 -1
  301. package/commands/MigrationGenerateCommand.js.map +1 -1
  302. package/commands/MigrationRevertCommand.js +2 -2
  303. package/commands/MigrationRevertCommand.js.map +1 -1
  304. package/commands/MigrationRunCommand.js +2 -2
  305. package/commands/MigrationRunCommand.js.map +1 -1
  306. package/commands/MigrationShowCommand.js.map +1 -1
  307. package/commands/QueryCommand.js.map +1 -1
  308. package/commands/SchemaDropCommand.js.map +1 -1
  309. package/commands/SchemaLogCommand.js.map +1 -1
  310. package/commands/SchemaSyncCommand.js.map +1 -1
  311. package/commands/SubscriberCreateCommand.js.map +1 -1
  312. package/commands/VersionCommand.js.map +1 -1
  313. package/connection/ConnectionManager.js.map +1 -1
  314. package/connection/ConnectionMetadataBuilder.js.map +1 -1
  315. package/connection/ConnectionOptionsReader.d.ts +4 -4
  316. package/connection/ConnectionOptionsReader.js.map +1 -1
  317. package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
  318. package/container.js +2 -3
  319. package/container.js.map +1 -1
  320. package/data-source/DataSource.d.ts +2 -0
  321. package/data-source/DataSource.js +5 -1
  322. package/data-source/DataSource.js.map +1 -1
  323. package/decorator/Check.js +1 -2
  324. package/decorator/Check.js.map +1 -1
  325. package/decorator/EntityRepository.js +1 -2
  326. package/decorator/EntityRepository.js.map +1 -1
  327. package/decorator/Exclusion.js +1 -2
  328. package/decorator/Exclusion.js.map +1 -1
  329. package/decorator/Generated.js +1 -2
  330. package/decorator/Generated.js.map +1 -1
  331. package/decorator/Index.js +1 -2
  332. package/decorator/Index.js.map +1 -1
  333. package/decorator/Unique.js +1 -2
  334. package/decorator/Unique.js.map +1 -1
  335. package/decorator/columns/Column.js +1 -2
  336. package/decorator/columns/Column.js.map +1 -1
  337. package/decorator/columns/CreateDateColumn.js +1 -2
  338. package/decorator/columns/CreateDateColumn.js.map +1 -1
  339. package/decorator/columns/DeleteDateColumn.js +1 -2
  340. package/decorator/columns/DeleteDateColumn.js.map +1 -1
  341. package/decorator/columns/ObjectIdColumn.js +1 -2
  342. package/decorator/columns/ObjectIdColumn.js.map +1 -1
  343. package/decorator/columns/PrimaryColumn.js +1 -2
  344. package/decorator/columns/PrimaryColumn.js.map +1 -1
  345. package/decorator/columns/PrimaryGeneratedColumn.js +1 -2
  346. package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
  347. package/decorator/columns/UpdateDateColumn.js +1 -2
  348. package/decorator/columns/UpdateDateColumn.js.map +1 -1
  349. package/decorator/columns/VersionColumn.js +1 -2
  350. package/decorator/columns/VersionColumn.js.map +1 -1
  351. package/decorator/columns/ViewColumn.js +1 -2
  352. package/decorator/columns/ViewColumn.js.map +1 -1
  353. package/decorator/columns/VirtualColumn.js +2 -3
  354. package/decorator/columns/VirtualColumn.js.map +1 -1
  355. package/decorator/entity/ChildEntity.js +1 -2
  356. package/decorator/entity/ChildEntity.js.map +1 -1
  357. package/decorator/entity/Entity.js +1 -2
  358. package/decorator/entity/Entity.js.map +1 -1
  359. package/decorator/entity/TableInheritance.js +1 -2
  360. package/decorator/entity/TableInheritance.js.map +1 -1
  361. package/decorator/entity-view/ViewEntity.js +1 -2
  362. package/decorator/entity-view/ViewEntity.js.map +1 -1
  363. package/decorator/listeners/AfterInsert.js +1 -2
  364. package/decorator/listeners/AfterInsert.js.map +1 -1
  365. package/decorator/listeners/AfterLoad.js +1 -2
  366. package/decorator/listeners/AfterLoad.js.map +1 -1
  367. package/decorator/listeners/AfterRecover.js +1 -2
  368. package/decorator/listeners/AfterRecover.js.map +1 -1
  369. package/decorator/listeners/AfterRemove.js +1 -2
  370. package/decorator/listeners/AfterRemove.js.map +1 -1
  371. package/decorator/listeners/AfterSoftRemove.js +1 -2
  372. package/decorator/listeners/AfterSoftRemove.js.map +1 -1
  373. package/decorator/listeners/AfterUpdate.js +1 -2
  374. package/decorator/listeners/AfterUpdate.js.map +1 -1
  375. package/decorator/listeners/BeforeInsert.js +1 -2
  376. package/decorator/listeners/BeforeInsert.js.map +1 -1
  377. package/decorator/listeners/BeforeRecover.js +1 -2
  378. package/decorator/listeners/BeforeRecover.js.map +1 -1
  379. package/decorator/listeners/BeforeRemove.js +1 -2
  380. package/decorator/listeners/BeforeRemove.js.map +1 -1
  381. package/decorator/listeners/BeforeSoftRemove.js +1 -2
  382. package/decorator/listeners/BeforeSoftRemove.js.map +1 -1
  383. package/decorator/listeners/BeforeUpdate.js +1 -2
  384. package/decorator/listeners/BeforeUpdate.js.map +1 -1
  385. package/decorator/listeners/EventSubscriber.js +1 -2
  386. package/decorator/listeners/EventSubscriber.js.map +1 -1
  387. package/decorator/relations/JoinColumn.js +1 -2
  388. package/decorator/relations/JoinColumn.js.map +1 -1
  389. package/decorator/relations/JoinTable.js +1 -2
  390. package/decorator/relations/JoinTable.js.map +1 -1
  391. package/decorator/relations/ManyToMany.js +1 -2
  392. package/decorator/relations/ManyToMany.js.map +1 -1
  393. package/decorator/relations/ManyToOne.js +1 -2
  394. package/decorator/relations/ManyToOne.js.map +1 -1
  395. package/decorator/relations/OneToMany.js +1 -2
  396. package/decorator/relations/OneToMany.js.map +1 -1
  397. package/decorator/relations/OneToOne.d.ts +4 -4
  398. package/decorator/relations/OneToOne.js +3 -4
  399. package/decorator/relations/OneToOne.js.map +1 -1
  400. package/decorator/relations/RelationCount.js +1 -2
  401. package/decorator/relations/RelationCount.js.map +1 -1
  402. package/decorator/relations/RelationId.js +1 -2
  403. package/decorator/relations/RelationId.js.map +1 -1
  404. package/decorator/tree/Tree.js +1 -2
  405. package/decorator/tree/Tree.js.map +1 -1
  406. package/decorator/tree/TreeChildren.js +1 -2
  407. package/decorator/tree/TreeChildren.js.map +1 -1
  408. package/decorator/tree/TreeLevelColumn.js +1 -2
  409. package/decorator/tree/TreeLevelColumn.js.map +1 -1
  410. package/decorator/tree/TreeParent.js +1 -2
  411. package/decorator/tree/TreeParent.js.map +1 -1
  412. package/driver/DriverFactory.js.map +1 -1
  413. package/driver/DriverUtils.js.map +1 -1
  414. package/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.d.ts +1 -1
  415. package/driver/aurora-mysql/AuroraMysqlConnectionCredentialsOptions.js.map +1 -1
  416. package/driver/aurora-mysql/AuroraMysqlDriver.js +10 -10
  417. package/driver/aurora-mysql/AuroraMysqlDriver.js.map +1 -1
  418. package/driver/aurora-mysql/AuroraMysqlQueryRunner.d.ts +0 -1
  419. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js +2 -2
  420. package/driver/aurora-mysql/AuroraMysqlQueryRunner.js.map +1 -1
  421. package/driver/aurora-postgres/AuroraPostgresDriver.js.map +1 -1
  422. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js +2 -2
  423. package/driver/aurora-postgres/AuroraPostgresQueryRunner.js.map +1 -1
  424. package/driver/better-sqlite3/BetterSqlite3Driver.js +2 -2
  425. package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -1
  426. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js +4 -0
  427. package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -1
  428. package/driver/capacitor/CapacitorDriver.js.map +1 -1
  429. package/driver/capacitor/CapacitorQueryRunner.js +2 -2
  430. package/driver/capacitor/CapacitorQueryRunner.js.map +1 -1
  431. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.d.ts +1 -2
  432. package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
  433. package/driver/cockroachdb/CockroachConnectionOptions.d.ts +1 -1
  434. package/driver/cockroachdb/CockroachConnectionOptions.js.map +1 -1
  435. package/driver/cockroachdb/CockroachDriver.js.map +1 -1
  436. package/driver/cockroachdb/CockroachQueryRunner.d.ts +0 -1
  437. package/driver/cockroachdb/CockroachQueryRunner.js +8 -6
  438. package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
  439. package/driver/cordova/CordovaDriver.js.map +1 -1
  440. package/driver/cordova/CordovaQueryRunner.js.map +1 -1
  441. package/driver/expo/ExpoDriver.js.map +1 -1
  442. package/driver/expo/ExpoQueryRunner.js +2 -2
  443. package/driver/expo/ExpoQueryRunner.js.map +1 -1
  444. package/driver/mongodb/MongoConnectionOptions.d.ts +1 -2
  445. package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
  446. package/driver/mongodb/MongoDriver.js.map +1 -1
  447. package/driver/mongodb/MongoQueryRunner.d.ts +0 -1
  448. package/driver/mongodb/typings.d.ts +0 -8
  449. package/driver/mongodb/typings.js +0 -1
  450. package/driver/mongodb/typings.js.map +1 -1
  451. package/driver/mysql/MysqlConnectionCredentialsOptions.d.ts +1 -1
  452. package/driver/mysql/MysqlConnectionCredentialsOptions.js.map +1 -1
  453. package/driver/mysql/MysqlConnectionOptions.d.ts +1 -1
  454. package/driver/mysql/MysqlConnectionOptions.js.map +1 -1
  455. package/driver/mysql/MysqlDriver.js +12 -14
  456. package/driver/mysql/MysqlDriver.js.map +1 -1
  457. package/driver/mysql/MysqlQueryRunner.d.ts +0 -1
  458. package/driver/mysql/MysqlQueryRunner.js +1 -1
  459. package/driver/mysql/MysqlQueryRunner.js.map +1 -1
  460. package/driver/nativescript/NativescriptDriver.js.map +1 -1
  461. package/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
  462. package/driver/oracle/OracleConnectionCredentialsOptions.d.ts +1 -1
  463. package/driver/oracle/OracleConnectionCredentialsOptions.js.map +1 -1
  464. package/driver/oracle/OracleConnectionOptions.d.ts +1 -1
  465. package/driver/oracle/OracleConnectionOptions.js.map +1 -1
  466. package/driver/oracle/OracleDriver.js +18 -10
  467. package/driver/oracle/OracleDriver.js.map +1 -1
  468. package/driver/oracle/OracleQueryRunner.d.ts +0 -1
  469. package/driver/oracle/OracleQueryRunner.js +8 -10
  470. package/driver/oracle/OracleQueryRunner.js.map +1 -1
  471. package/driver/postgres/PostgresConnectionCredentialsOptions.d.ts +1 -2
  472. package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
  473. package/driver/postgres/PostgresConnectionOptions.d.ts +1 -1
  474. package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
  475. package/driver/postgres/PostgresDriver.js +11 -6
  476. package/driver/postgres/PostgresDriver.js.map +1 -1
  477. package/driver/postgres/PostgresQueryRunner.d.ts +1 -2
  478. package/driver/postgres/PostgresQueryRunner.js +35 -12
  479. package/driver/postgres/PostgresQueryRunner.js.map +1 -1
  480. package/driver/react-native/ReactNativeDriver.js +4 -6
  481. package/driver/react-native/ReactNativeDriver.js.map +1 -1
  482. package/driver/react-native/ReactNativeQueryRunner.js +2 -2
  483. package/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
  484. package/driver/sap/SapDriver.js.map +1 -1
  485. package/driver/sap/SapQueryRunner.d.ts +0 -1
  486. package/driver/sap/SapQueryRunner.js +4 -4
  487. package/driver/sap/SapQueryRunner.js.map +1 -1
  488. package/driver/spanner/SpannerConnectionCredentialsOptions.d.ts +1 -1
  489. package/driver/spanner/SpannerConnectionCredentialsOptions.js.map +1 -1
  490. package/driver/spanner/SpannerConnectionOptions.d.ts +1 -1
  491. package/driver/spanner/SpannerConnectionOptions.js.map +1 -1
  492. package/driver/spanner/SpannerDriver.js.map +1 -1
  493. package/driver/spanner/SpannerQueryRunner.d.ts +0 -1
  494. package/driver/spanner/SpannerQueryRunner.js.map +1 -1
  495. package/driver/sqlite/SqliteDriver.js +2 -2
  496. package/driver/sqlite/SqliteDriver.js.map +1 -1
  497. package/driver/sqlite/SqliteQueryRunner.js +3 -2
  498. package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
  499. package/driver/sqlite-abstract/AbstractSqliteDriver.js +4 -6
  500. package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
  501. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +0 -1
  502. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +4 -4
  503. package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
  504. package/driver/sqljs/SqljsDriver.js +1 -2
  505. package/driver/sqljs/SqljsDriver.js.map +1 -1
  506. package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
  507. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.d.ts +1 -1
  508. package/driver/sqlserver/SqlServerConnectionCredentialsOptions.js.map +1 -1
  509. package/driver/sqlserver/SqlServerConnectionOptions.d.ts +1 -1
  510. package/driver/sqlserver/SqlServerConnectionOptions.js.map +1 -1
  511. package/driver/sqlserver/SqlServerDriver.js.map +1 -1
  512. package/driver/sqlserver/SqlServerQueryRunner.d.ts +0 -1
  513. package/driver/sqlserver/SqlServerQueryRunner.js +9 -7
  514. package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
  515. package/driver/types/ColumnTypes.d.ts +1 -1
  516. package/driver/types/ColumnTypes.js.map +1 -1
  517. package/driver/types/MetadataTableType.js +1 -1
  518. package/driver/types/MetadataTableType.js.map +1 -1
  519. package/entity-manager/EntityManager.d.ts +4 -2
  520. package/entity-manager/EntityManager.js +4 -2
  521. package/entity-manager/EntityManager.js.map +1 -1
  522. package/entity-manager/MongoEntityManager.js +1 -1
  523. package/entity-manager/MongoEntityManager.js.map +1 -1
  524. package/entity-schema/EntitySchemaTransformer.js +2 -3
  525. package/entity-schema/EntitySchemaTransformer.js.map +1 -1
  526. package/error/EntityMetadataNotFoundError.js.map +1 -1
  527. package/error/EntityNotFoundError.js.map +1 -1
  528. package/error/FindRelationsNotFoundError.js.map +1 -1
  529. package/error/MissingJoinColumnError.js.map +1 -1
  530. package/error/MissingJoinTableError.js.map +1 -1
  531. package/error/QueryFailedError.js.map +1 -1
  532. package/error/RepositoryNotTreeError.js.map +1 -1
  533. package/error/TypeORMError.js.map +1 -1
  534. package/find-options/FindOperator.js.map +1 -1
  535. package/find-options/FindOptionsOrder.d.ts +0 -1
  536. package/find-options/FindOptionsRelations.d.ts +0 -1
  537. package/find-options/FindOptionsSelect.d.ts +0 -1
  538. package/find-options/FindOptionsUtils.js +1 -1
  539. package/find-options/FindOptionsUtils.js.map +1 -1
  540. package/find-options/FindOptionsWhere.d.ts +0 -1
  541. package/find-options/operator/And.js +1 -2
  542. package/find-options/operator/And.js.map +1 -1
  543. package/find-options/operator/Any.js +1 -2
  544. package/find-options/operator/Any.js.map +1 -1
  545. package/find-options/operator/ArrayContainedBy.js +1 -2
  546. package/find-options/operator/ArrayContainedBy.js.map +1 -1
  547. package/find-options/operator/ArrayContains.js +1 -2
  548. package/find-options/operator/ArrayContains.js.map +1 -1
  549. package/find-options/operator/ArrayOverlap.js +1 -2
  550. package/find-options/operator/ArrayOverlap.js.map +1 -1
  551. package/find-options/operator/Between.js +1 -2
  552. package/find-options/operator/Between.js.map +1 -1
  553. package/find-options/operator/Equal.js +1 -2
  554. package/find-options/operator/Equal.js.map +1 -1
  555. package/find-options/operator/ILike.js +1 -2
  556. package/find-options/operator/ILike.js.map +1 -1
  557. package/find-options/operator/In.js +1 -2
  558. package/find-options/operator/In.js.map +1 -1
  559. package/find-options/operator/IsNull.js +1 -2
  560. package/find-options/operator/IsNull.js.map +1 -1
  561. package/find-options/operator/JsonContains.js +1 -2
  562. package/find-options/operator/JsonContains.js.map +1 -1
  563. package/find-options/operator/LessThan.js +1 -2
  564. package/find-options/operator/LessThan.js.map +1 -1
  565. package/find-options/operator/LessThanOrEqual.js +1 -2
  566. package/find-options/operator/LessThanOrEqual.js.map +1 -1
  567. package/find-options/operator/Like.js +1 -2
  568. package/find-options/operator/Like.js.map +1 -1
  569. package/find-options/operator/MoreThan.js +1 -2
  570. package/find-options/operator/MoreThan.js.map +1 -1
  571. package/find-options/operator/MoreThanOrEqual.js +1 -2
  572. package/find-options/operator/MoreThanOrEqual.js.map +1 -1
  573. package/find-options/operator/Not.js +1 -2
  574. package/find-options/operator/Not.js.map +1 -1
  575. package/find-options/operator/Or.js +1 -2
  576. package/find-options/operator/Or.js.map +1 -1
  577. package/find-options/operator/Raw.js +1 -2
  578. package/find-options/operator/Raw.js.map +1 -1
  579. package/globals.js +14 -15
  580. package/globals.js.map +1 -1
  581. package/logger/AbstractLogger.js.map +1 -1
  582. package/logger/AdvancedConsoleLogger.js +1 -2
  583. package/logger/AdvancedConsoleLogger.js.map +1 -1
  584. package/logger/DebugLogger.js +1 -2
  585. package/logger/DebugLogger.js.map +1 -1
  586. package/logger/FileLogger.js +2 -3
  587. package/logger/FileLogger.js.map +1 -1
  588. package/logger/LoggerFactory.js.map +1 -1
  589. package/logger/SimpleConsoleLogger.js +1 -2
  590. package/logger/SimpleConsoleLogger.js.map +1 -1
  591. package/metadata/CheckMetadata.js.map +1 -1
  592. package/metadata/ColumnMetadata.js +19 -15
  593. package/metadata/ColumnMetadata.js.map +1 -1
  594. package/metadata/EmbeddedMetadata.js +1 -1
  595. package/metadata/EmbeddedMetadata.js.map +1 -1
  596. package/metadata/EntityListenerMetadata.js.map +1 -1
  597. package/metadata/EntityMetadata.js +3 -7
  598. package/metadata/EntityMetadata.js.map +1 -1
  599. package/metadata/ExclusionMetadata.js.map +1 -1
  600. package/metadata/IndexMetadata.js.map +1 -1
  601. package/metadata/RelationIdMetadata.js.map +1 -1
  602. package/metadata/RelationMetadata.js.map +1 -1
  603. package/metadata/UniqueMetadata.js.map +1 -1
  604. package/metadata-args/MetadataArgsStorage.js.map +1 -1
  605. package/metadata-builder/ClosureJunctionEntityMetadataBuilder.js.map +1 -1
  606. package/metadata-builder/EntityMetadataBuilder.js +5 -8
  607. package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
  608. package/metadata-builder/EntityMetadataValidator.js.map +1 -1
  609. package/metadata-builder/JunctionEntityMetadataBuilder.js +7 -8
  610. package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
  611. package/metadata-builder/MetadataUtils.js.map +1 -1
  612. package/metadata-builder/RelationJoinColumnBuilder.js +2 -3
  613. package/metadata-builder/RelationJoinColumnBuilder.js.map +1 -1
  614. package/migration/MigrationExecutor.js +2 -2
  615. package/migration/MigrationExecutor.js.map +1 -1
  616. package/naming-strategy/DefaultNamingStrategy.js.map +1 -1
  617. package/naming-strategy/LegacyOracleNamingStrategy.js.map +1 -1
  618. package/package.json +1 -1
  619. package/persistence/EntityPersistExecutor.js.map +1 -1
  620. package/persistence/Subject.js.map +1 -1
  621. package/persistence/SubjectChangedColumnsComputer.js.map +1 -1
  622. package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
  623. package/persistence/SubjectExecutor.js +3 -3
  624. package/persistence/SubjectExecutor.js.map +1 -1
  625. package/persistence/{SubjectTopoligicalSorter.d.ts → SubjectTopologicalSorter.d.ts} +1 -1
  626. package/persistence/{SubjectTopoligicalSorter.js → SubjectTopologicalSorter.js} +4 -4
  627. package/persistence/SubjectTopologicalSorter.js.map +1 -0
  628. package/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
  629. package/persistence/subject-builder/ManyToManySubjectBuilder.js.map +1 -1
  630. package/persistence/subject-builder/OneToManySubjectBuilder.js +1 -2
  631. package/persistence/subject-builder/OneToManySubjectBuilder.js.map +1 -1
  632. package/persistence/subject-builder/OneToOneInverseSideSubjectBuilder.js.map +1 -1
  633. package/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
  634. package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
  635. package/persistence/tree/NestedSetSubjectExecutor.js.map +1 -1
  636. package/platform/PlatformTools.d.ts +0 -1
  637. package/platform/PlatformTools.js +12 -18
  638. package/platform/PlatformTools.js.map +1 -1
  639. package/query-builder/DeleteQueryBuilder.js.map +1 -1
  640. package/query-builder/InsertQueryBuilder.js +15 -15
  641. package/query-builder/InsertQueryBuilder.js.map +1 -1
  642. package/query-builder/JoinAttribute.js.map +1 -1
  643. package/query-builder/QueryBuilder.d.ts +1 -1
  644. package/query-builder/QueryBuilder.js +12 -14
  645. package/query-builder/QueryBuilder.js.map +1 -1
  646. package/query-builder/QueryExpressionMap.js +2 -2
  647. package/query-builder/QueryExpressionMap.js.map +1 -1
  648. package/query-builder/RelationIdLoader.js.map +1 -1
  649. package/query-builder/RelationLoader.js.map +1 -1
  650. package/query-builder/RelationQueryBuilder.js.map +1 -1
  651. package/query-builder/RelationRemover.js.map +1 -1
  652. package/query-builder/RelationUpdater.js.map +1 -1
  653. package/query-builder/ReturningResultsEntityUpdator.js +5 -2
  654. package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
  655. package/query-builder/SelectQueryBuilder.d.ts +4 -5
  656. package/query-builder/SelectQueryBuilder.js +23 -22
  657. package/query-builder/SelectQueryBuilder.js.map +1 -1
  658. package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
  659. package/query-builder/UpdateQueryBuilder.js.map +1 -1
  660. package/query-builder/index.js +1 -2
  661. package/query-builder/index.js.map +1 -1
  662. package/query-builder/relation-count/RelationCountLoader.js.map +1 -1
  663. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js +2 -2
  664. package/query-builder/relation-count/RelationCountMetadataToAttributeTransformer.js.map +1 -1
  665. package/query-builder/relation-id/RelationIdLoader.js.map +1 -1
  666. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js +2 -2
  667. package/query-builder/relation-id/RelationIdMetadataToAttributeTransformer.js.map +1 -1
  668. package/query-builder/transformer/DocumentToEntityTransformer.js.map +1 -1
  669. package/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
  670. package/query-builder/transformer/PlainObjectToNewEntityTransformer.js.map +1 -1
  671. package/query-builder/transformer/RawSqlResultsToEntityTransformer.d.ts +9 -9
  672. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +94 -88
  673. package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
  674. package/query-runner/BaseQueryRunner.js.map +1 -1
  675. package/query-runner/QueryLock.js.map +1 -1
  676. package/query-runner/QueryRunner.d.ts +0 -1
  677. package/repository/BaseEntity.js.map +1 -1
  678. package/repository/Repository.d.ts +2 -0
  679. package/repository/Repository.js +2 -0
  680. package/repository/Repository.js.map +1 -1
  681. package/repository/TreeRepository.js.map +1 -1
  682. package/schema-builder/RdbmsSchemaBuilder.js +2 -1
  683. package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
  684. package/schema-builder/table/Table.js +2 -2
  685. package/schema-builder/table/Table.js.map +1 -1
  686. package/schema-builder/table/TableColumn.js.map +1 -1
  687. package/schema-builder/util/ViewUtils.js.map +1 -1
  688. package/schema-builder/view/View.js.map +1 -1
  689. package/subscriber/Broadcaster.js +6 -6
  690. package/subscriber/Broadcaster.js.map +1 -1
  691. package/subscriber/BroadcasterResult.js.map +1 -1
  692. package/util/ApplyValueTransformers.js.map +1 -1
  693. package/util/DateUtils.js.map +1 -1
  694. package/util/DepGraph.js +2 -2
  695. package/util/DepGraph.js.map +1 -1
  696. package/util/DirectoryExportedClassesLoader.js +2 -3
  697. package/util/DirectoryExportedClassesLoader.js.map +1 -1
  698. package/util/ImportUtils.js +24 -37
  699. package/util/ImportUtils.js.map +1 -1
  700. package/util/ObjectUtils.js.map +1 -1
  701. package/util/OrmUtils.js.map +1 -1
  702. package/util/PathUtils.js +4 -5
  703. package/util/PathUtils.js.map +1 -1
  704. package/util/RandomGenerator.js.map +1 -1
  705. package/util/StringUtils.js +6 -7
  706. package/util/StringUtils.js.map +1 -1
  707. package/util/TreeRepositoryUtils.js +3 -6
  708. package/util/TreeRepositoryUtils.js.map +1 -1
  709. package/browser/persistence/SubjectTopoligicalSorter.js.map +0 -1
  710. package/persistence/SubjectTopoligicalSorter.js.map +0 -1
@@ -1,6 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.hash = exports.shorten = exports.abbreviate = exports.titleCase = exports.snakeCase = exports.camelCase = void 0;
3
+ exports.camelCase = camelCase;
4
+ exports.snakeCase = snakeCase;
5
+ exports.titleCase = titleCase;
6
+ exports.abbreviate = abbreviate;
7
+ exports.shorten = shorten;
8
+ exports.hash = hash;
4
9
  const tslib_1 = require("tslib");
5
10
  const sha_js_1 = tslib_1.__importDefault(require("sha.js"));
6
11
  /**
@@ -17,7 +22,6 @@ function camelCase(str, firstCapital = false) {
17
22
  return p1.toLowerCase();
18
23
  });
19
24
  }
20
- exports.camelCase = camelCase;
21
25
  /**
22
26
  * Converts string into snake_case.
23
27
  *
@@ -30,7 +34,6 @@ function snakeCase(str) {
30
34
  .replace(/([a-z0-9])([A-Z])/g, "$1_$2")
31
35
  .toLowerCase());
32
36
  }
33
- exports.snakeCase = snakeCase;
34
37
  /**
35
38
  * Converts string into Title Case.
36
39
  *
@@ -39,7 +42,6 @@ exports.snakeCase = snakeCase;
39
42
  function titleCase(str) {
40
43
  return str.replace(/\w\S*/g, (txt) => txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase());
41
44
  }
42
- exports.titleCase = titleCase;
43
45
  /**
44
46
  * Builds abbreviated string from given string;
45
47
  */
@@ -52,7 +54,6 @@ function abbreviate(str, abbrLettersCount = 1) {
52
54
  return res;
53
55
  }, "");
54
56
  }
55
- exports.abbreviate = abbreviate;
56
57
  /**
57
58
  * Shorten a given `input`. Useful for RDBMS imposing a limit on the
58
59
  * maximum length of aliases and column names in SQL queries.
@@ -93,7 +94,6 @@ function shorten(input, options = {}) {
93
94
  }, []);
94
95
  return shortSegments.join(separator);
95
96
  }
96
- exports.shorten = shorten;
97
97
  /**
98
98
  * Returns a hashed input.
99
99
  *
@@ -109,6 +109,5 @@ function hash(input, options = {}) {
109
109
  }
110
110
  return hashedInput;
111
111
  }
112
- exports.hash = hash;
113
112
 
114
113
  //# sourceMappingURL=StringUtils.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/util/StringUtils.ts"],"names":[],"mappings":"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","file":"StringUtils.js","sourcesContent":["import shajs from \"sha.js\"\n\n/**\n * Converts string into camelCase.\n *\n * @see http://stackoverflow.com/questions/2970525/converting-any-string-into-camel-case\n */\nexport function camelCase(str: string, firstCapital: boolean = false): string {\n if (firstCapital) str = \" \" + str\n return str.replace(/^([A-Z])|[\\s-_](\\w)/g, function (match, p1, p2) {\n if (p2) return p2.toUpperCase()\n return p1.toLowerCase()\n })\n}\n\n/**\n * Converts string into snake_case.\n *\n */\nexport function snakeCase(str: string): string {\n return (\n str\n // ABc -> a_bc\n .replace(/([A-Z])([A-Z])([a-z])/g, \"$1_$2$3\")\n // aC -> a_c\n .replace(/([a-z0-9])([A-Z])/g, \"$1_$2\")\n .toLowerCase()\n )\n}\n\n/**\n * Converts string into Title Case.\n *\n * @see http://stackoverflow.com/questions/196972/convert-string-to-title-case-with-javascript\n */\nexport function titleCase(str: string): string {\n return str.replace(\n /\\w\\S*/g,\n (txt) => txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(),\n )\n}\n\n/**\n * Builds abbreviated string from given string;\n */\nexport function abbreviate(str: string, abbrLettersCount: number = 1): string {\n const words = str\n .replace(/([a-z\\xE0-\\xFF])([A-Z\\xC0\\xDF])/g, \"$1 $2\")\n .split(\" \")\n return words.reduce((res, word) => {\n res += word.substr(0, abbrLettersCount)\n return res\n }, \"\")\n}\n\nexport interface IShortenOptions {\n /** String used to split \"segments\" of the alias/column name */\n separator?: string\n /** Maximum length of any \"segment\" */\n segmentLength?: number\n /** Length of any \"term\" in a \"segment\"; \"OrderItem\" is a segment, \"Order\" and \"Items\" are terms */\n termLength?: number\n}\n\n/**\n * Shorten a given `input`. Useful for RDBMS imposing a limit on the\n * maximum length of aliases and column names in SQL queries.\n *\n * @param input String to be shortened.\n * @param options Default to `4` for segments length, `2` for terms length, `'__'` as a separator.\n *\n * @return Shortened `input`.\n *\n * @example\n * // returns: \"UsShCa__orde__mark__dire\"\n * shorten('UserShoppingCart__order__market__director')\n *\n * // returns: \"cat_wit_ver_lon_nam_pos_wit_ver_lon_nam_pos_wit_ver_lon_nam\"\n * shorten(\n * 'category_with_very_long_name_posts_with_very_long_name_post_with_very_long_name',\n * { separator: '_', segmentLength: 3 }\n * )\n *\n * // equals: UsShCa__orde__mark_market_id\n * `${shorten('UserShoppingCart__order__market')}_market_id`\n */\nexport function shorten(input: string, options: IShortenOptions = {}): string {\n const { segmentLength = 4, separator = \"__\", termLength = 2 } = options\n\n const segments = input.split(separator)\n const shortSegments = segments.reduce((acc: string[], val: string) => {\n // split the given segment into many terms based on an eventual camel cased name\n const segmentTerms = val\n .replace(/([a-z\\xE0-\\xFF])([A-Z\\xC0-\\xDF])/g, \"$1 $2\")\n .split(\" \")\n // \"OrderItemList\" becomes \"OrItLi\", while \"company\" becomes \"comp\"\n const length = segmentTerms.length > 1 ? termLength : segmentLength\n const shortSegment = segmentTerms\n .map((term) => term.substr(0, length))\n .join(\"\")\n\n acc.push(shortSegment)\n return acc\n }, [])\n\n return shortSegments.join(separator)\n}\n\ninterface IHashOptions {\n length?: number\n}\n\n/**\n * Returns a hashed input.\n *\n * @param input String to be hashed.\n * @param options.length Optionally, shorten the output to desired length.\n */\nexport function hash(input: string, options: IHashOptions = {}): string {\n const hashFunction = shajs(\"sha1\")\n hashFunction.update(input, \"utf8\")\n const hashedInput = hashFunction.digest(\"hex\")\n if (options.length) {\n return hashedInput.slice(0, options.length)\n }\n return hashedInput\n}\n"],"sourceRoot":".."}
1
+ {"version":3,"sources":["../../src/util/StringUtils.ts"],"names":[],"mappings":"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","file":"StringUtils.js","sourcesContent":["import shajs from \"sha.js\"\n\n/**\n * Converts string into camelCase.\n *\n * @see http://stackoverflow.com/questions/2970525/converting-any-string-into-camel-case\n */\nexport function camelCase(str: string, firstCapital: boolean = false): string {\n if (firstCapital) str = \" \" + str\n return str.replace(/^([A-Z])|[\\s-_](\\w)/g, function (match, p1, p2) {\n if (p2) return p2.toUpperCase()\n return p1.toLowerCase()\n })\n}\n\n/**\n * Converts string into snake_case.\n *\n */\nexport function snakeCase(str: string): string {\n return (\n str\n // ABc -> a_bc\n .replace(/([A-Z])([A-Z])([a-z])/g, \"$1_$2$3\")\n // aC -> a_c\n .replace(/([a-z0-9])([A-Z])/g, \"$1_$2\")\n .toLowerCase()\n )\n}\n\n/**\n * Converts string into Title Case.\n *\n * @see http://stackoverflow.com/questions/196972/convert-string-to-title-case-with-javascript\n */\nexport function titleCase(str: string): string {\n return str.replace(\n /\\w\\S*/g,\n (txt) => txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(),\n )\n}\n\n/**\n * Builds abbreviated string from given string;\n */\nexport function abbreviate(str: string, abbrLettersCount: number = 1): string {\n const words = str\n .replace(/([a-z\\xE0-\\xFF])([A-Z\\xC0\\xDF])/g, \"$1 $2\")\n .split(\" \")\n return words.reduce((res, word) => {\n res += word.substr(0, abbrLettersCount)\n return res\n }, \"\")\n}\n\nexport interface IShortenOptions {\n /** String used to split \"segments\" of the alias/column name */\n separator?: string\n /** Maximum length of any \"segment\" */\n segmentLength?: number\n /** Length of any \"term\" in a \"segment\"; \"OrderItem\" is a segment, \"Order\" and \"Items\" are terms */\n termLength?: number\n}\n\n/**\n * Shorten a given `input`. Useful for RDBMS imposing a limit on the\n * maximum length of aliases and column names in SQL queries.\n *\n * @param input String to be shortened.\n * @param options Default to `4` for segments length, `2` for terms length, `'__'` as a separator.\n *\n * @return Shortened `input`.\n *\n * @example\n * // returns: \"UsShCa__orde__mark__dire\"\n * shorten('UserShoppingCart__order__market__director')\n *\n * // returns: \"cat_wit_ver_lon_nam_pos_wit_ver_lon_nam_pos_wit_ver_lon_nam\"\n * shorten(\n * 'category_with_very_long_name_posts_with_very_long_name_post_with_very_long_name',\n * { separator: '_', segmentLength: 3 }\n * )\n *\n * // equals: UsShCa__orde__mark_market_id\n * `${shorten('UserShoppingCart__order__market')}_market_id`\n */\nexport function shorten(input: string, options: IShortenOptions = {}): string {\n const { segmentLength = 4, separator = \"__\", termLength = 2 } = options\n\n const segments = input.split(separator)\n const shortSegments = segments.reduce((acc: string[], val: string) => {\n // split the given segment into many terms based on an eventual camel cased name\n const segmentTerms = val\n .replace(/([a-z\\xE0-\\xFF])([A-Z\\xC0-\\xDF])/g, \"$1 $2\")\n .split(\" \")\n // \"OrderItemList\" becomes \"OrItLi\", while \"company\" becomes \"comp\"\n const length = segmentTerms.length > 1 ? termLength : segmentLength\n const shortSegment = segmentTerms\n .map((term) => term.substr(0, length))\n .join(\"\")\n\n acc.push(shortSegment)\n return acc\n }, [])\n\n return shortSegments.join(separator)\n}\n\ninterface IHashOptions {\n length?: number\n}\n\n/**\n * Returns a hashed input.\n *\n * @param input String to be hashed.\n * @param options.length Optionally, shorten the output to desired length.\n */\nexport function hash(input: string, options: IHashOptions = {}): string {\n const hashFunction = shajs(\"sha1\")\n hashFunction.update(input, \"utf8\")\n const hashedInput = hashFunction.digest(\"hex\")\n if (options.length) {\n return hashedInput.slice(0, options.length)\n }\n return hashedInput\n}\n"],"sourceRoot":".."}
@@ -11,9 +11,8 @@ class TreeRepositoryUtils {
11
11
  // -------------------------------------------------------------------------
12
12
  static createRelationMaps(manager, metadata, alias, rawResults) {
13
13
  return rawResults.map((rawResult) => {
14
- var _a;
15
14
  const joinColumn = metadata.treeParentRelation.joinColumns[0];
16
- const referencedColumn = (_a = joinColumn.referencedColumn) !== null && _a !== void 0 ? _a : metadata.primaryColumns[0];
15
+ const referencedColumn = joinColumn.referencedColumn ?? metadata.primaryColumns[0];
17
16
  // fixes issue #2518, default to databaseName property when givenDatabaseName is not set
18
17
  const joinColumnName = joinColumn.givenDatabaseName || joinColumn.databaseName;
19
18
  const referencedColumnName = referencedColumn.givenDatabaseName ||
@@ -27,14 +26,13 @@ class TreeRepositoryUtils {
27
26
  });
28
27
  }
29
28
  static buildChildrenEntityTree(metadata, entity, entities, relationMaps, options) {
30
- var _a;
31
29
  const childProperty = metadata.treeChildrenRelation.propertyName;
32
30
  if (options.depth === 0) {
33
31
  entity[childProperty] = [];
34
32
  return;
35
33
  }
36
34
  const joinColumn = metadata.treeParentRelation.joinColumns[0];
37
- const referencedColumn = (_a = joinColumn.referencedColumn) !== null && _a !== void 0 ? _a : metadata.primaryColumns[0];
35
+ const referencedColumn = joinColumn.referencedColumn ?? metadata.primaryColumns[0];
38
36
  const parentEntityId = referencedColumn.getEntityValue(entity);
39
37
  const childRelationMaps = relationMaps.filter((relationMap) => relationMap.parentId === parentEntityId);
40
38
  const childIds = new Set(childRelationMaps.map((relationMap) => relationMap.id));
@@ -47,10 +45,9 @@ class TreeRepositoryUtils {
47
45
  });
48
46
  }
49
47
  static buildParentEntityTree(metadata, entity, entities, relationMaps) {
50
- var _a;
51
48
  const parentProperty = metadata.treeParentRelation.propertyName;
52
49
  const joinColumn = metadata.treeParentRelation.joinColumns[0];
53
- const referencedColumn = (_a = joinColumn.referencedColumn) !== null && _a !== void 0 ? _a : metadata.primaryColumns[0];
50
+ const referencedColumn = joinColumn.referencedColumn ?? metadata.primaryColumns[0];
54
51
  const entityId = referencedColumn.getEntityValue(entity);
55
52
  const parentRelationMap = relationMaps.find((relationMap) => relationMap.id === entityId);
56
53
  const parentEntity = entities.find((entity) => {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/util/TreeRepositoryUtils.ts"],"names":[],"mappings":"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","file":"TreeRepositoryUtils.js","sourcesContent":["import { EntityManager } from \"../entity-manager/EntityManager\"\nimport { EntityMetadata } from \"../metadata/EntityMetadata\"\nimport { FindTreesOptions } from \"../repository/FindTreesOptions\"\n\n/**\n * Provides utilities for manipulating tree structures.\n *\n */\nexport class TreeRepositoryUtils {\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n static createRelationMaps(\n manager: EntityManager,\n metadata: EntityMetadata,\n alias: string,\n rawResults: any[],\n ): { id: any; parentId: any }[] {\n return rawResults.map((rawResult) => {\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n // fixes issue #2518, default to databaseName property when givenDatabaseName is not set\n const joinColumnName =\n joinColumn.givenDatabaseName || joinColumn.databaseName\n const referencedColumnName =\n referencedColumn.givenDatabaseName ||\n referencedColumn.databaseName\n const id = rawResult[alias + \"_\" + referencedColumnName]\n const parentId = rawResult[alias + \"_\" + joinColumnName]\n return {\n id: manager.connection.driver.prepareHydratedValue(\n id,\n referencedColumn,\n ),\n parentId: manager.connection.driver.prepareHydratedValue(\n parentId,\n joinColumn,\n ),\n }\n })\n }\n\n static buildChildrenEntityTree(\n metadata: EntityMetadata,\n entity: any,\n entities: any[],\n relationMaps: { id: any; parentId: any }[],\n options: FindTreesOptions & { depth: number },\n ): void {\n const childProperty = metadata.treeChildrenRelation!.propertyName\n if (options.depth === 0) {\n entity[childProperty] = []\n return\n }\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n const parentEntityId = referencedColumn.getEntityValue(entity)\n const childRelationMaps = relationMaps.filter(\n (relationMap) => relationMap.parentId === parentEntityId,\n )\n const childIds = new Set(\n childRelationMaps.map((relationMap) => relationMap.id),\n )\n entity[childProperty] = entities.filter((entity) =>\n childIds.has(referencedColumn.getEntityValue(entity)),\n )\n entity[childProperty].forEach((childEntity: any) => {\n TreeRepositoryUtils.buildChildrenEntityTree(\n metadata,\n childEntity,\n entities,\n relationMaps,\n {\n ...options,\n depth: options.depth - 1,\n },\n )\n })\n }\n\n static buildParentEntityTree(\n metadata: EntityMetadata,\n entity: any,\n entities: any[],\n relationMaps: { id: any; parentId: any }[],\n ): void {\n const parentProperty = metadata.treeParentRelation!.propertyName\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n const entityId = referencedColumn.getEntityValue(entity)\n const parentRelationMap = relationMaps.find(\n (relationMap) => relationMap.id === entityId,\n )\n const parentEntity = entities.find((entity) => {\n if (!parentRelationMap) return false\n\n return (\n referencedColumn.getEntityValue(entity) ===\n parentRelationMap.parentId\n )\n })\n if (parentEntity) {\n entity[parentProperty] = parentEntity\n TreeRepositoryUtils.buildParentEntityTree(\n metadata,\n entity[parentProperty],\n entities,\n relationMaps,\n )\n }\n }\n}\n"],"sourceRoot":".."}
1
+ {"version":3,"sources":["../../src/util/TreeRepositoryUtils.ts"],"names":[],"mappings":"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","file":"TreeRepositoryUtils.js","sourcesContent":["import { EntityManager } from \"../entity-manager/EntityManager\"\nimport { EntityMetadata } from \"../metadata/EntityMetadata\"\nimport { FindTreesOptions } from \"../repository/FindTreesOptions\"\n\n/**\n * Provides utilities for manipulating tree structures.\n *\n */\nexport class TreeRepositoryUtils {\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n static createRelationMaps(\n manager: EntityManager,\n metadata: EntityMetadata,\n alias: string,\n rawResults: any[],\n ): { id: any; parentId: any }[] {\n return rawResults.map((rawResult) => {\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n // fixes issue #2518, default to databaseName property when givenDatabaseName is not set\n const joinColumnName =\n joinColumn.givenDatabaseName || joinColumn.databaseName\n const referencedColumnName =\n referencedColumn.givenDatabaseName ||\n referencedColumn.databaseName\n const id = rawResult[alias + \"_\" + referencedColumnName]\n const parentId = rawResult[alias + \"_\" + joinColumnName]\n return {\n id: manager.connection.driver.prepareHydratedValue(\n id,\n referencedColumn,\n ),\n parentId: manager.connection.driver.prepareHydratedValue(\n parentId,\n joinColumn,\n ),\n }\n })\n }\n\n static buildChildrenEntityTree(\n metadata: EntityMetadata,\n entity: any,\n entities: any[],\n relationMaps: { id: any; parentId: any }[],\n options: FindTreesOptions & { depth: number },\n ): void {\n const childProperty = metadata.treeChildrenRelation!.propertyName\n if (options.depth === 0) {\n entity[childProperty] = []\n return\n }\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n const parentEntityId = referencedColumn.getEntityValue(entity)\n const childRelationMaps = relationMaps.filter(\n (relationMap) => relationMap.parentId === parentEntityId,\n )\n const childIds = new Set(\n childRelationMaps.map((relationMap) => relationMap.id),\n )\n entity[childProperty] = entities.filter((entity) =>\n childIds.has(referencedColumn.getEntityValue(entity)),\n )\n entity[childProperty].forEach((childEntity: any) => {\n TreeRepositoryUtils.buildChildrenEntityTree(\n metadata,\n childEntity,\n entities,\n relationMaps,\n {\n ...options,\n depth: options.depth - 1,\n },\n )\n })\n }\n\n static buildParentEntityTree(\n metadata: EntityMetadata,\n entity: any,\n entities: any[],\n relationMaps: { id: any; parentId: any }[],\n ): void {\n const parentProperty = metadata.treeParentRelation!.propertyName\n const joinColumn = metadata.treeParentRelation!.joinColumns[0]\n const referencedColumn =\n joinColumn.referencedColumn ?? metadata.primaryColumns[0]\n const entityId = referencedColumn.getEntityValue(entity)\n const parentRelationMap = relationMaps.find(\n (relationMap) => relationMap.id === entityId,\n )\n const parentEntity = entities.find((entity) => {\n if (!parentRelationMap) return false\n\n return (\n referencedColumn.getEntityValue(entity) ===\n parentRelationMap.parentId\n )\n })\n if (parentEntity) {\n entity[parentProperty] = parentEntity\n TreeRepositoryUtils.buildParentEntityTree(\n metadata,\n entity[parentProperty],\n entities,\n relationMaps,\n )\n }\n }\n}\n"],"sourceRoot":".."}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../browser/src/persistence/SubjectTopoligicalSorter.ts"],"names":[],"mappings":"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","file":"SubjectTopoligicalSorter.js","sourcesContent":["import { Subject } from \"./Subject\"\nimport { EntityMetadata } from \"../metadata/EntityMetadata\"\nimport { TypeORMError } from \"../error\"\n\n/**\n * Orders insert or remove subjects in proper order (using topological sorting)\n * to make sure insert or remove operations are executed in a proper order.\n */\nexport class SubjectTopoligicalSorter {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Insert subjects needs to be sorted.\n */\n subjects: Subject[]\n\n /**\n * Unique list of entity metadatas of this subject.\n */\n metadatas: EntityMetadata[]\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(subjects: Subject[]) {\n this.subjects = [...subjects] // copy subjects to prevent changing of sent array\n this.metadatas = this.getUniqueMetadatas(this.subjects)\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Sorts (orders) subjects in their topological order.\n */\n sort(direction: \"insert\" | \"delete\"): Subject[] {\n // if there are no metadatas it probably mean there is no subjects... we don't have to do anything here\n if (!this.metadatas.length) return this.subjects\n\n const sortedSubjects: Subject[] = []\n\n // first if we sort for deletion all junction subjects\n // junction subjects are subjects without entity and database entity set\n if (direction === \"delete\") {\n const junctionSubjects = this.subjects.filter(\n (subject) => !subject.entity && !subject.databaseEntity,\n )\n sortedSubjects.push(...junctionSubjects)\n this.removeAlreadySorted(junctionSubjects)\n }\n\n // next we always insert entities with non-nullable relations, sort them first\n const nonNullableDependencies = this.getNonNullableDependencies()\n let sortedNonNullableEntityTargets = this.toposort(\n nonNullableDependencies,\n )\n if (direction === \"insert\")\n sortedNonNullableEntityTargets =\n sortedNonNullableEntityTargets.reverse()\n\n // so we have a sorted entity targets\n // go thought each of them and find all subjects with sorted entity target\n // add those sorted targets and remove them from original array of targets\n sortedNonNullableEntityTargets.forEach((sortedEntityTarget) => {\n const entityTargetSubjects = this.subjects.filter(\n (subject) =>\n subject.metadata.targetName === sortedEntityTarget ||\n subject.metadata.inheritanceTree.some(\n (s) => s.name === sortedEntityTarget,\n ),\n )\n sortedSubjects.push(...entityTargetSubjects)\n this.removeAlreadySorted(entityTargetSubjects)\n })\n\n // next sort all other entities\n // same process as in above but with other entities\n const otherDependencies: string[][] = this.getDependencies()\n let sortedOtherEntityTargets = this.toposort(otherDependencies)\n if (direction === \"insert\")\n sortedOtherEntityTargets = sortedOtherEntityTargets.reverse()\n\n sortedOtherEntityTargets.forEach((sortedEntityTarget) => {\n const entityTargetSubjects = this.subjects.filter(\n (subject) => subject.metadata.targetName === sortedEntityTarget,\n )\n sortedSubjects.push(...entityTargetSubjects)\n this.removeAlreadySorted(entityTargetSubjects)\n })\n\n // if we have something left in the subjects add them as well\n sortedSubjects.push(...this.subjects)\n return sortedSubjects\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Removes already sorted subjects from this.subjects list of subjects.\n */\n protected removeAlreadySorted(subjects: Subject[]) {\n subjects.forEach((subject) => {\n this.subjects.splice(this.subjects.indexOf(subject), 1)\n })\n }\n\n /**\n * Extracts all unique metadatas from the given subjects.\n */\n protected getUniqueMetadatas(subjects: Subject[]) {\n const metadatas: EntityMetadata[] = []\n subjects.forEach((subject) => {\n if (metadatas.indexOf(subject.metadata) === -1)\n metadatas.push(subject.metadata)\n })\n return metadatas\n }\n\n /**\n * Gets dependency tree for all entity metadatas with non-nullable relations.\n * We need to execute insertions first for entities which non-nullable relations.\n */\n protected getNonNullableDependencies(): string[][] {\n return this.metadatas.reduce((dependencies, metadata) => {\n metadata.relationsWithJoinColumns.forEach((relation) => {\n if (relation.isNullable) return\n\n dependencies.push([\n metadata.targetName,\n relation.inverseEntityMetadata.targetName,\n ])\n })\n return dependencies\n }, [] as string[][])\n }\n\n /**\n * Gets dependency tree for all entity metadatas with non-nullable relations.\n * We need to execute insertions first for entities which non-nullable relations.\n */\n protected getDependencies(): string[][] {\n return this.metadatas.reduce((dependencies, metadata) => {\n metadata.relationsWithJoinColumns.forEach((relation) => {\n // if relation is self-referenced we skip it\n if (relation.inverseEntityMetadata === metadata) return\n\n dependencies.push([\n metadata.targetName,\n relation.inverseEntityMetadata.targetName,\n ])\n })\n return dependencies\n }, [] as string[][])\n }\n\n /**\n * Sorts given graph using topological sorting algorithm.\n *\n * Algorithm is kindly taken from https://github.com/marcelklehr/toposort repository.\n */\n protected toposort(edges: any[][]) {\n function uniqueNodes(arr: any[]) {\n let res = []\n for (let i = 0, len = arr.length; i < len; i++) {\n let edge: any = arr[i]\n if (res.indexOf(edge[0]) < 0) res.push(edge[0])\n if (res.indexOf(edge[1]) < 0) res.push(edge[1])\n }\n return res\n }\n\n const nodes = uniqueNodes(edges)\n let cursor = nodes.length,\n sorted = new Array(cursor),\n visited: any = {},\n i = cursor\n\n while (i--) {\n if (!visited[i]) visit(nodes[i], i, [])\n }\n\n function visit(node: any, i: number, predecessors: any[]) {\n if (predecessors.indexOf(node) >= 0) {\n throw new TypeORMError(\n \"Cyclic dependency: \" + JSON.stringify(node),\n ) // todo: better error\n }\n\n if (!~nodes.indexOf(node)) {\n throw new TypeORMError(\n \"Found unknown node. Make sure to provided all involved nodes. Unknown node: \" +\n JSON.stringify(node),\n )\n }\n\n if (visited[i]) return\n visited[i] = true\n\n // outgoing edges\n let outgoing = edges.filter(function (edge) {\n return edge[0] === node\n })\n if ((i = outgoing.length)) {\n let preds = predecessors.concat(node)\n do {\n let child = outgoing[--i][1]\n visit(child, nodes.indexOf(child), preds)\n } while (i)\n }\n\n sorted[--cursor] = node\n }\n\n return sorted\n }\n}\n"],"sourceRoot":".."}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/persistence/SubjectTopoligicalSorter.ts"],"names":[],"mappings":"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","file":"SubjectTopoligicalSorter.js","sourcesContent":["import { Subject } from \"./Subject\"\nimport { EntityMetadata } from \"../metadata/EntityMetadata\"\nimport { TypeORMError } from \"../error\"\n\n/**\n * Orders insert or remove subjects in proper order (using topological sorting)\n * to make sure insert or remove operations are executed in a proper order.\n */\nexport class SubjectTopoligicalSorter {\n // -------------------------------------------------------------------------\n // Public Properties\n // -------------------------------------------------------------------------\n\n /**\n * Insert subjects needs to be sorted.\n */\n subjects: Subject[]\n\n /**\n * Unique list of entity metadatas of this subject.\n */\n metadatas: EntityMetadata[]\n\n // -------------------------------------------------------------------------\n // Constructor\n // -------------------------------------------------------------------------\n\n constructor(subjects: Subject[]) {\n this.subjects = [...subjects] // copy subjects to prevent changing of sent array\n this.metadatas = this.getUniqueMetadatas(this.subjects)\n }\n\n // -------------------------------------------------------------------------\n // Public Methods\n // -------------------------------------------------------------------------\n\n /**\n * Sorts (orders) subjects in their topological order.\n */\n sort(direction: \"insert\" | \"delete\"): Subject[] {\n // if there are no metadatas it probably mean there is no subjects... we don't have to do anything here\n if (!this.metadatas.length) return this.subjects\n\n const sortedSubjects: Subject[] = []\n\n // first if we sort for deletion all junction subjects\n // junction subjects are subjects without entity and database entity set\n if (direction === \"delete\") {\n const junctionSubjects = this.subjects.filter(\n (subject) => !subject.entity && !subject.databaseEntity,\n )\n sortedSubjects.push(...junctionSubjects)\n this.removeAlreadySorted(junctionSubjects)\n }\n\n // next we always insert entities with non-nullable relations, sort them first\n const nonNullableDependencies = this.getNonNullableDependencies()\n let sortedNonNullableEntityTargets = this.toposort(\n nonNullableDependencies,\n )\n if (direction === \"insert\")\n sortedNonNullableEntityTargets =\n sortedNonNullableEntityTargets.reverse()\n\n // so we have a sorted entity targets\n // go thought each of them and find all subjects with sorted entity target\n // add those sorted targets and remove them from original array of targets\n sortedNonNullableEntityTargets.forEach((sortedEntityTarget) => {\n const entityTargetSubjects = this.subjects.filter(\n (subject) =>\n subject.metadata.targetName === sortedEntityTarget ||\n subject.metadata.inheritanceTree.some(\n (s) => s.name === sortedEntityTarget,\n ),\n )\n sortedSubjects.push(...entityTargetSubjects)\n this.removeAlreadySorted(entityTargetSubjects)\n })\n\n // next sort all other entities\n // same process as in above but with other entities\n const otherDependencies: string[][] = this.getDependencies()\n let sortedOtherEntityTargets = this.toposort(otherDependencies)\n if (direction === \"insert\")\n sortedOtherEntityTargets = sortedOtherEntityTargets.reverse()\n\n sortedOtherEntityTargets.forEach((sortedEntityTarget) => {\n const entityTargetSubjects = this.subjects.filter(\n (subject) => subject.metadata.targetName === sortedEntityTarget,\n )\n sortedSubjects.push(...entityTargetSubjects)\n this.removeAlreadySorted(entityTargetSubjects)\n })\n\n // if we have something left in the subjects add them as well\n sortedSubjects.push(...this.subjects)\n return sortedSubjects\n }\n\n // -------------------------------------------------------------------------\n // Protected Methods\n // -------------------------------------------------------------------------\n\n /**\n * Removes already sorted subjects from this.subjects list of subjects.\n */\n protected removeAlreadySorted(subjects: Subject[]) {\n subjects.forEach((subject) => {\n this.subjects.splice(this.subjects.indexOf(subject), 1)\n })\n }\n\n /**\n * Extracts all unique metadatas from the given subjects.\n */\n protected getUniqueMetadatas(subjects: Subject[]) {\n const metadatas: EntityMetadata[] = []\n subjects.forEach((subject) => {\n if (metadatas.indexOf(subject.metadata) === -1)\n metadatas.push(subject.metadata)\n })\n return metadatas\n }\n\n /**\n * Gets dependency tree for all entity metadatas with non-nullable relations.\n * We need to execute insertions first for entities which non-nullable relations.\n */\n protected getNonNullableDependencies(): string[][] {\n return this.metadatas.reduce((dependencies, metadata) => {\n metadata.relationsWithJoinColumns.forEach((relation) => {\n if (relation.isNullable) return\n\n dependencies.push([\n metadata.targetName,\n relation.inverseEntityMetadata.targetName,\n ])\n })\n return dependencies\n }, [] as string[][])\n }\n\n /**\n * Gets dependency tree for all entity metadatas with non-nullable relations.\n * We need to execute insertions first for entities which non-nullable relations.\n */\n protected getDependencies(): string[][] {\n return this.metadatas.reduce((dependencies, metadata) => {\n metadata.relationsWithJoinColumns.forEach((relation) => {\n // if relation is self-referenced we skip it\n if (relation.inverseEntityMetadata === metadata) return\n\n dependencies.push([\n metadata.targetName,\n relation.inverseEntityMetadata.targetName,\n ])\n })\n return dependencies\n }, [] as string[][])\n }\n\n /**\n * Sorts given graph using topological sorting algorithm.\n *\n * Algorithm is kindly taken from https://github.com/marcelklehr/toposort repository.\n */\n protected toposort(edges: any[][]) {\n function uniqueNodes(arr: any[]) {\n let res = []\n for (let i = 0, len = arr.length; i < len; i++) {\n let edge: any = arr[i]\n if (res.indexOf(edge[0]) < 0) res.push(edge[0])\n if (res.indexOf(edge[1]) < 0) res.push(edge[1])\n }\n return res\n }\n\n const nodes = uniqueNodes(edges)\n let cursor = nodes.length,\n sorted = new Array(cursor),\n visited: any = {},\n i = cursor\n\n while (i--) {\n if (!visited[i]) visit(nodes[i], i, [])\n }\n\n function visit(node: any, i: number, predecessors: any[]) {\n if (predecessors.indexOf(node) >= 0) {\n throw new TypeORMError(\n \"Cyclic dependency: \" + JSON.stringify(node),\n ) // todo: better error\n }\n\n if (!~nodes.indexOf(node)) {\n throw new TypeORMError(\n \"Found unknown node. Make sure to provided all involved nodes. Unknown node: \" +\n JSON.stringify(node),\n )\n }\n\n if (visited[i]) return\n visited[i] = true\n\n // outgoing edges\n let outgoing = edges.filter(function (edge) {\n return edge[0] === node\n })\n if ((i = outgoing.length)) {\n let preds = predecessors.concat(node)\n do {\n let child = outgoing[--i][1]\n visit(child, nodes.indexOf(child), preds)\n } while (i)\n }\n\n sorted[--cursor] = node\n }\n\n return sorted\n }\n}\n"],"sourceRoot":".."}