typeorm 0.2.25 → 0.2.29
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.
- package/README.md +16 -7
- package/browser/cache/DbQueryResultCache.js +14 -14
- package/browser/cache/DbQueryResultCache.js.map +1 -1
- package/browser/cache/RedisQueryResultCache.js +19 -14
- package/browser/cache/RedisQueryResultCache.js.map +1 -1
- package/browser/common/DeepPartial.d.ts +1 -1
- package/browser/common/DeepPartial.js.map +1 -1
- package/browser/common/EntityTarget.d.ts +9 -0
- package/browser/common/EntityTarget.js +3 -0
- package/browser/common/EntityTarget.js.map +1 -0
- package/browser/connection/Connection.d.ts +11 -10
- package/browser/connection/Connection.js +63 -40
- package/browser/connection/Connection.js.map +1 -1
- package/browser/connection/ConnectionMetadataBuilder.js +8 -8
- package/browser/connection/ConnectionMetadataBuilder.js.map +1 -1
- package/browser/connection/ConnectionOptions.d.ts +2 -1
- package/browser/connection/ConnectionOptions.js.map +1 -1
- package/browser/connection/ConnectionOptionsReader.js +48 -43
- package/browser/connection/ConnectionOptionsReader.js.map +1 -1
- package/browser/connection/options-reader/ConnectionOptionsEnvReader.d.ts +5 -1
- package/browser/connection/options-reader/ConnectionOptionsEnvReader.js +45 -31
- package/browser/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
- package/browser/connection/options-reader/ConnectionOptionsXmlReader.js +4 -4
- package/browser/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
- package/browser/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
- package/browser/connection/options-reader/ConnectionOptionsYmlReader.js +15 -4
- package/browser/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
- package/browser/decorator/Check.d.ts +2 -2
- package/browser/decorator/Check.js.map +1 -1
- package/browser/decorator/EntityRepository.d.ts +1 -1
- package/browser/decorator/EntityRepository.js.map +1 -1
- package/browser/decorator/Exclusion.d.ts +2 -2
- package/browser/decorator/Exclusion.js.map +1 -1
- package/browser/decorator/Generated.d.ts +1 -1
- package/browser/decorator/Generated.js.map +1 -1
- package/browser/decorator/Index.d.ts +7 -7
- package/browser/decorator/Index.js.map +1 -1
- package/browser/decorator/Unique.d.ts +4 -4
- package/browser/decorator/Unique.js +12 -1
- package/browser/decorator/Unique.js.map +1 -1
- package/browser/decorator/columns/Column.d.ts +12 -12
- package/browser/decorator/columns/Column.js.map +1 -1
- package/browser/decorator/columns/CreateDateColumn.d.ts +1 -1
- package/browser/decorator/columns/CreateDateColumn.js.map +1 -1
- package/browser/decorator/columns/DeleteDateColumn.d.ts +1 -1
- package/browser/decorator/columns/DeleteDateColumn.js.map +1 -1
- package/browser/decorator/columns/ObjectIdColumn.d.ts +1 -1
- package/browser/decorator/columns/ObjectIdColumn.js.map +1 -1
- package/browser/decorator/columns/PrimaryColumn.d.ts +2 -2
- package/browser/decorator/columns/PrimaryColumn.js.map +1 -1
- package/browser/decorator/columns/PrimaryGeneratedColumn.d.ts +5 -5
- package/browser/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
- package/browser/decorator/columns/UpdateDateColumn.d.ts +1 -1
- package/browser/decorator/columns/UpdateDateColumn.js.map +1 -1
- package/browser/decorator/columns/VersionColumn.d.ts +1 -1
- package/browser/decorator/columns/VersionColumn.js.map +1 -1
- package/browser/decorator/columns/ViewColumn.d.ts +1 -1
- package/browser/decorator/columns/ViewColumn.js.map +1 -1
- package/browser/decorator/entity/ChildEntity.d.ts +1 -1
- package/browser/decorator/entity/ChildEntity.js +1 -1
- package/browser/decorator/entity/ChildEntity.js.map +1 -1
- package/browser/decorator/entity/TableInheritance.d.ts +1 -1
- package/browser/decorator/entity/TableInheritance.js.map +1 -1
- package/browser/decorator/entity-view/ViewEntity.d.ts +2 -2
- package/browser/decorator/entity-view/ViewEntity.js.map +1 -1
- package/browser/decorator/listeners/AfterInsert.d.ts +1 -1
- package/browser/decorator/listeners/AfterInsert.js.map +1 -1
- package/browser/decorator/listeners/AfterLoad.d.ts +1 -1
- package/browser/decorator/listeners/AfterLoad.js.map +1 -1
- package/browser/decorator/listeners/AfterRemove.d.ts +1 -1
- package/browser/decorator/listeners/AfterRemove.js.map +1 -1
- package/browser/decorator/listeners/AfterUpdate.d.ts +1 -1
- package/browser/decorator/listeners/AfterUpdate.js.map +1 -1
- package/browser/decorator/listeners/BeforeInsert.d.ts +1 -1
- package/browser/decorator/listeners/BeforeInsert.js.map +1 -1
- package/browser/decorator/listeners/BeforeRemove.d.ts +1 -1
- package/browser/decorator/listeners/BeforeRemove.js.map +1 -1
- package/browser/decorator/listeners/BeforeUpdate.d.ts +1 -1
- package/browser/decorator/listeners/BeforeUpdate.js.map +1 -1
- package/browser/decorator/listeners/EventSubscriber.d.ts +1 -1
- package/browser/decorator/listeners/EventSubscriber.js.map +1 -1
- package/browser/decorator/options/ColumnOptions.js.map +1 -1
- package/browser/decorator/options/TransactionOptions.js.map +1 -1
- package/browser/decorator/relations/JoinColumn.d.ts +3 -3
- package/browser/decorator/relations/JoinColumn.js.map +1 -1
- package/browser/decorator/relations/JoinTable.d.ts +3 -3
- package/browser/decorator/relations/JoinTable.js.map +1 -1
- package/browser/decorator/relations/ManyToMany.d.ts +2 -2
- package/browser/decorator/relations/ManyToMany.js.map +1 -1
- package/browser/decorator/relations/ManyToOne.d.ts +2 -2
- package/browser/decorator/relations/ManyToOne.js.map +1 -1
- package/browser/decorator/relations/OneToMany.d.ts +3 -3
- package/browser/decorator/relations/OneToMany.js +2 -2
- package/browser/decorator/relations/OneToMany.js.map +1 -1
- package/browser/decorator/relations/OneToOne.d.ts +2 -2
- package/browser/decorator/relations/OneToOne.js.map +1 -1
- package/browser/decorator/relations/RelationCount.d.ts +1 -1
- package/browser/decorator/relations/RelationCount.js.map +1 -1
- package/browser/decorator/relations/RelationId.d.ts +1 -1
- package/browser/decorator/relations/RelationId.js.map +1 -1
- package/browser/decorator/transaction/Transaction.js +4 -4
- package/browser/decorator/transaction/Transaction.js.map +1 -1
- package/browser/decorator/transaction/TransactionManager.d.ts +1 -1
- package/browser/decorator/transaction/TransactionManager.js.map +1 -1
- package/browser/decorator/tree/Tree.d.ts +1 -1
- package/browser/decorator/tree/Tree.js.map +1 -1
- package/browser/decorator/tree/TreeChildren.d.ts +1 -1
- package/browser/decorator/tree/TreeChildren.js.map +1 -1
- package/browser/decorator/tree/TreeLevelColumn.d.ts +1 -1
- package/browser/decorator/tree/TreeLevelColumn.js.map +1 -1
- package/browser/decorator/tree/TreeParent.d.ts +1 -1
- package/browser/decorator/tree/TreeParent.js.map +1 -1
- package/browser/driver/Driver.d.ts +7 -2
- package/browser/driver/Driver.js.map +1 -1
- package/browser/driver/DriverFactory.js +4 -1
- package/browser/driver/DriverFactory.js.map +1 -1
- package/browser/driver/DriverUtils.d.ts +2 -2
- package/browser/driver/DriverUtils.js +27 -15
- package/browser/driver/DriverUtils.js.map +1 -1
- package/browser/driver/aurora-data-api/AuroraDataApiConnection.d.ts +2 -1
- package/browser/driver/aurora-data-api/AuroraDataApiConnection.js +2 -3
- package/browser/driver/aurora-data-api/AuroraDataApiConnection.js.map +1 -1
- package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +3 -0
- package/browser/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
- package/browser/driver/aurora-data-api/AuroraDataApiDriver.d.ts +6 -1
- package/browser/driver/aurora-data-api/AuroraDataApiDriver.js +14 -9
- package/browser/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
- package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.d.ts +5 -0
- package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js +283 -149
- package/browser/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +6 -0
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.d.ts +57 -0
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +99 -0
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -0
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.d.ts +4 -3
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +66 -20
- package/browser/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
- package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +50 -0
- package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js +3 -0
- package/browser/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -0
- package/browser/driver/better-sqlite3/BetterSqlite3Driver.d.ts +46 -0
- package/browser/driver/better-sqlite3/BetterSqlite3Driver.js +125 -0
- package/browser/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -0
- package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +22 -0
- package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js +113 -0
- package/browser/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -0
- package/browser/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
- package/browser/driver/cockroachdb/CockroachDriver.d.ts +6 -1
- package/browser/driver/cockroachdb/CockroachDriver.js +21 -16
- package/browser/driver/cockroachdb/CockroachDriver.js.map +1 -1
- package/browser/driver/cockroachdb/CockroachQueryRunner.d.ts +7 -1
- package/browser/driver/cockroachdb/CockroachQueryRunner.js +509 -211
- package/browser/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
- package/browser/driver/cordova/CordovaDriver.d.ts +2 -1
- package/browser/driver/cordova/CordovaDriver.js +4 -5
- package/browser/driver/cordova/CordovaDriver.js.map +1 -1
- package/browser/driver/cordova/CordovaQueryRunner.js +4 -4
- package/browser/driver/cordova/CordovaQueryRunner.js.map +1 -1
- package/browser/driver/expo/ExpoDriver.d.ts +2 -1
- package/browser/driver/expo/ExpoDriver.js +4 -5
- package/browser/driver/expo/ExpoDriver.js.map +1 -1
- package/browser/driver/expo/ExpoQueryRunner.js +82 -24
- package/browser/driver/expo/ExpoQueryRunner.js.map +1 -1
- package/browser/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
- package/browser/driver/mongodb/MongoConnectionOptions.js.map +1 -1
- package/browser/driver/mongodb/MongoDriver.d.ts +13 -4
- package/browser/driver/mongodb/MongoDriver.js +24 -18
- package/browser/driver/mongodb/MongoDriver.js.map +1 -1
- package/browser/driver/mongodb/MongoQueryRunner.d.ts +4 -3
- package/browser/driver/mongodb/MongoQueryRunner.js +175 -175
- package/browser/driver/mongodb/MongoQueryRunner.js.map +1 -1
- package/browser/driver/mongodb/typings.js.map +1 -1
- package/browser/driver/mysql/MysqlDriver.d.ts +7 -2
- package/browser/driver/mysql/MysqlDriver.js +20 -13
- package/browser/driver/mysql/MysqlDriver.js.map +1 -1
- package/browser/driver/mysql/MysqlQueryRunner.d.ts +11 -1
- package/browser/driver/mysql/MysqlQueryRunner.js +351 -185
- package/browser/driver/mysql/MysqlQueryRunner.js.map +1 -1
- package/browser/driver/nativescript/NativescriptDriver.d.ts +2 -1
- package/browser/driver/nativescript/NativescriptDriver.js +4 -5
- package/browser/driver/nativescript/NativescriptDriver.js.map +1 -1
- package/browser/driver/nativescript/NativescriptQueryRunner.js +2 -2
- package/browser/driver/nativescript/NativescriptQueryRunner.js.map +1 -1
- package/browser/driver/oracle/OracleDriver.d.ts +6 -1
- package/browser/driver/oracle/OracleDriver.js +17 -12
- package/browser/driver/oracle/OracleDriver.js.map +1 -1
- package/browser/driver/oracle/OracleQueryRunner.d.ts +3 -1
- package/browser/driver/oracle/OracleQueryRunner.js +247 -134
- package/browser/driver/oracle/OracleQueryRunner.js.map +1 -1
- package/browser/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
- package/browser/driver/postgres/PostgresConnectionOptions.d.ts +9 -0
- package/browser/driver/postgres/PostgresConnectionOptions.js.map +1 -1
- package/browser/driver/postgres/PostgresDriver.d.ts +18 -55
- package/browser/driver/postgres/PostgresDriver.js +196 -206
- package/browser/driver/postgres/PostgresDriver.js.map +1 -1
- package/browser/driver/postgres/PostgresQueryRunner.d.ts +11 -1
- package/browser/driver/postgres/PostgresQueryRunner.js +517 -209
- package/browser/driver/postgres/PostgresQueryRunner.js.map +1 -1
- package/browser/driver/react-native/ReactNativeDriver.d.ts +2 -1
- package/browser/driver/react-native/ReactNativeDriver.js +4 -5
- package/browser/driver/react-native/ReactNativeDriver.js.map +1 -1
- package/browser/driver/react-native/ReactNativeQueryRunner.js +4 -4
- package/browser/driver/react-native/ReactNativeQueryRunner.js.map +1 -1
- package/browser/driver/sap/SapDriver.d.ts +6 -1
- package/browser/driver/sap/SapDriver.js +12 -7
- package/browser/driver/sap/SapDriver.js.map +1 -1
- package/browser/driver/sap/SapQueryRunner.d.ts +3 -1
- package/browser/driver/sap/SapQueryRunner.js +276 -160
- package/browser/driver/sap/SapQueryRunner.js.map +1 -1
- package/browser/driver/sqlite/SqliteConnectionOptions.d.ts +18 -0
- package/browser/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
- package/browser/driver/sqlite/SqliteDriver.d.ts +2 -1
- package/browser/driver/sqlite/SqliteDriver.js +31 -17
- package/browser/driver/sqlite/SqliteDriver.js.map +1 -1
- package/browser/driver/sqlite/SqliteQueryRunner.js +37 -18
- package/browser/driver/sqlite/SqliteQueryRunner.js.map +1 -1
- package/browser/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +7 -2
- package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js +36 -9
- package/browser/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
- package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.d.ts +1 -0
- package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +189 -127
- package/browser/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
- package/browser/driver/sqljs/SqljsDriver.d.ts +2 -1
- package/browser/driver/sqljs/SqljsDriver.js +14 -15
- package/browser/driver/sqljs/SqljsDriver.js.map +1 -1
- package/browser/driver/sqljs/SqljsQueryRunner.js +7 -6
- package/browser/driver/sqljs/SqljsQueryRunner.js.map +1 -1
- package/browser/driver/sqlserver/SqlServerDriver.d.ts +6 -1
- package/browser/driver/sqlserver/SqlServerDriver.js +13 -8
- package/browser/driver/sqlserver/SqlServerDriver.js.map +1 -1
- package/browser/driver/sqlserver/SqlServerQueryRunner.d.ts +3 -1
- package/browser/driver/sqlserver/SqlServerQueryRunner.js +368 -230
- package/browser/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
- package/browser/driver/types/ColumnTypes.d.ts +1 -1
- package/browser/driver/types/ColumnTypes.js.map +1 -1
- package/browser/driver/types/DatabaseType.d.ts +1 -1
- package/browser/driver/types/DatabaseType.js.map +1 -1
- package/browser/driver/types/ReplicationMode.d.ts +1 -0
- package/browser/driver/types/ReplicationMode.js +3 -0
- package/browser/driver/types/ReplicationMode.js.map +1 -0
- package/browser/entity-manager/EntityManager.d.ts +41 -256
- package/browser/entity-manager/EntityManager.js +32 -42
- package/browser/entity-manager/EntityManager.js.map +1 -1
- package/browser/entity-manager/MongoEntityManager.d.ts +46 -46
- package/browser/entity-manager/MongoEntityManager.js +31 -20
- package/browser/entity-manager/MongoEntityManager.js.map +1 -1
- package/browser/entity-manager/SqljsEntityManager.js +6 -6
- package/browser/entity-manager/SqljsEntityManager.js.map +1 -1
- package/browser/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
- package/browser/entity-schema/EntitySchemaRelationOptions.d.ts +1 -1
- package/browser/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
- package/browser/entity-schema/EntitySchemaTransformer.js +22 -7
- package/browser/entity-schema/EntitySchemaTransformer.js.map +1 -1
- package/browser/error/AlreadyHasActiveConnectionError.js +2 -2
- package/browser/error/AlreadyHasActiveConnectionError.js.map +1 -1
- package/browser/error/CannotAttachTreeChildrenEntityError.js +2 -2
- package/browser/error/CannotAttachTreeChildrenEntityError.js.map +1 -1
- package/browser/error/CannotConnectAlreadyConnectedError.js +2 -2
- package/browser/error/CannotConnectAlreadyConnectedError.js.map +1 -1
- package/browser/error/CannotCreateEntityIdMapError.js +2 -2
- package/browser/error/CannotCreateEntityIdMapError.js.map +1 -1
- package/browser/error/CannotDetermineEntityError.js +2 -2
- package/browser/error/CannotDetermineEntityError.js.map +1 -1
- package/browser/error/CannotExecuteNotConnectedError.js +2 -2
- package/browser/error/CannotExecuteNotConnectedError.js.map +1 -1
- package/browser/error/CannotGetEntityManagerNotConnectedError.js +2 -2
- package/browser/error/CannotGetEntityManagerNotConnectedError.js.map +1 -1
- package/browser/error/CannotReflectMethodParameterTypeError.js +2 -2
- package/browser/error/CannotReflectMethodParameterTypeError.js.map +1 -1
- package/browser/error/CircularRelationsError.js +2 -2
- package/browser/error/CircularRelationsError.js.map +1 -1
- package/browser/error/ColumnTypeUndefinedError.js +2 -2
- package/browser/error/ColumnTypeUndefinedError.js.map +1 -1
- package/browser/error/ConnectionIsNotSetError.js +2 -2
- package/browser/error/ConnectionIsNotSetError.js.map +1 -1
- package/browser/error/ConnectionNotFoundError.js +2 -2
- package/browser/error/ConnectionNotFoundError.js.map +1 -1
- package/browser/error/CustomRepositoryCannotInheritRepositoryError.js +2 -2
- package/browser/error/CustomRepositoryCannotInheritRepositoryError.js.map +1 -1
- package/browser/error/CustomRepositoryDoesNotHaveEntityError.js +2 -2
- package/browser/error/CustomRepositoryDoesNotHaveEntityError.js.map +1 -1
- package/browser/error/CustomRepositoryNotFoundError.js +2 -2
- package/browser/error/CustomRepositoryNotFoundError.js.map +1 -1
- package/browser/error/DataTypeNotSupportedError.js +2 -2
- package/browser/error/DataTypeNotSupportedError.js.map +1 -1
- package/browser/error/DriverOptionNotSetError.js +2 -2
- package/browser/error/DriverOptionNotSetError.js.map +1 -1
- package/browser/error/DriverPackageNotInstalledError.js +2 -2
- package/browser/error/DriverPackageNotInstalledError.js.map +1 -1
- package/browser/error/EntityColumnNotFound.js +2 -2
- package/browser/error/EntityColumnNotFound.js.map +1 -1
- package/browser/error/EntityMetadataNotFoundError.d.ts +2 -2
- package/browser/error/EntityMetadataNotFoundError.js +5 -2
- package/browser/error/EntityMetadataNotFoundError.js.map +1 -1
- package/browser/error/EntityNotFoundError.d.ts +2 -3
- package/browser/error/EntityNotFoundError.js +5 -2
- package/browser/error/EntityNotFoundError.js.map +1 -1
- package/browser/error/FindRelationsNotFoundError.js +4 -4
- package/browser/error/FindRelationsNotFoundError.js.map +1 -1
- package/browser/error/InitializedRelationError.js +2 -2
- package/browser/error/InitializedRelationError.js.map +1 -1
- package/browser/error/InsertValuesMissingError.js +2 -2
- package/browser/error/InsertValuesMissingError.js.map +1 -1
- package/browser/error/LimitOnUpdateNotSupportedError.js +2 -2
- package/browser/error/LimitOnUpdateNotSupportedError.js.map +1 -1
- package/browser/error/LockNotSupportedOnGivenDriverError.js +2 -2
- package/browser/error/LockNotSupportedOnGivenDriverError.js.map +1 -1
- package/browser/error/MetadataAlreadyExistsError.js +2 -2
- package/browser/error/MetadataAlreadyExistsError.js.map +1 -1
- package/browser/error/MetadataWithSuchNameAlreadyExistsError.js +2 -2
- package/browser/error/MetadataWithSuchNameAlreadyExistsError.js.map +1 -1
- package/browser/error/MissingDeleteDateColumnError.js +2 -2
- package/browser/error/MissingDeleteDateColumnError.js.map +1 -1
- package/browser/error/MissingDriverError.js +3 -3
- package/browser/error/MissingDriverError.js.map +1 -1
- package/browser/error/MissingJoinColumnError.js +2 -2
- package/browser/error/MissingJoinColumnError.js.map +1 -1
- package/browser/error/MissingJoinTableError.js +2 -2
- package/browser/error/MissingJoinTableError.js.map +1 -1
- package/browser/error/MissingPrimaryColumnError.js +2 -2
- package/browser/error/MissingPrimaryColumnError.js.map +1 -1
- package/browser/error/MustBeEntityError.js +2 -2
- package/browser/error/MustBeEntityError.js.map +1 -1
- package/browser/error/NamingStrategyNotFoundError.js +2 -2
- package/browser/error/NamingStrategyNotFoundError.js.map +1 -1
- package/browser/error/NoConnectionForRepositoryError.js +2 -2
- package/browser/error/NoConnectionForRepositoryError.js.map +1 -1
- package/browser/error/NoConnectionOptionError.js +2 -2
- package/browser/error/NoConnectionOptionError.js.map +1 -1
- package/browser/error/NoNeedToReleaseEntityManagerError.js +2 -2
- package/browser/error/NoNeedToReleaseEntityManagerError.js.map +1 -1
- package/browser/error/NoVersionOrUpdateDateColumnError.js +2 -2
- package/browser/error/NoVersionOrUpdateDateColumnError.js.map +1 -1
- package/browser/error/OffsetWithoutLimitNotSupportedError.js +2 -2
- package/browser/error/OffsetWithoutLimitNotSupportedError.js.map +1 -1
- package/browser/error/OptimisticLockCanNotBeUsedError.js +2 -2
- package/browser/error/OptimisticLockCanNotBeUsedError.js.map +1 -1
- package/browser/error/OptimisticLockVersionMismatchError.js +2 -2
- package/browser/error/OptimisticLockVersionMismatchError.js.map +1 -1
- package/browser/error/PersistedEntityNotFoundError.js +2 -2
- package/browser/error/PersistedEntityNotFoundError.js.map +1 -1
- package/browser/error/PessimisticLockTransactionRequiredError.js +2 -2
- package/browser/error/PessimisticLockTransactionRequiredError.js.map +1 -1
- package/browser/error/PrimaryColumnCannotBeNullableError.js +2 -2
- package/browser/error/PrimaryColumnCannotBeNullableError.js.map +1 -1
- package/browser/error/QueryFailedError.js +3 -3
- package/browser/error/QueryFailedError.js.map +1 -1
- package/browser/error/QueryRunnerAlreadyReleasedError.js +2 -2
- package/browser/error/QueryRunnerAlreadyReleasedError.js.map +1 -1
- package/browser/error/QueryRunnerProviderAlreadyReleasedError.js +2 -2
- package/browser/error/QueryRunnerProviderAlreadyReleasedError.js.map +1 -1
- package/browser/error/RepositoryNotFoundError.d.ts +2 -2
- package/browser/error/RepositoryNotFoundError.js +5 -2
- package/browser/error/RepositoryNotFoundError.js.map +1 -1
- package/browser/error/RepositoryNotTreeError.d.ts +2 -2
- package/browser/error/RepositoryNotTreeError.js +11 -8
- package/browser/error/RepositoryNotTreeError.js.map +1 -1
- package/browser/error/ReturningStatementNotSupportedError.js +2 -2
- package/browser/error/ReturningStatementNotSupportedError.js.map +1 -1
- package/browser/error/SubjectRemovedAndUpdatedError.js +2 -2
- package/browser/error/SubjectRemovedAndUpdatedError.js.map +1 -1
- package/browser/error/SubjectWithoutIdentifierError.js +2 -2
- package/browser/error/SubjectWithoutIdentifierError.js.map +1 -1
- package/browser/error/TransactionAlreadyStartedError.js +2 -2
- package/browser/error/TransactionAlreadyStartedError.js.map +1 -1
- package/browser/error/TransactionNotStartedError.js +2 -2
- package/browser/error/TransactionNotStartedError.js.map +1 -1
- package/browser/error/TreeRepositoryNotSupportedError.js +2 -2
- package/browser/error/TreeRepositoryNotSupportedError.js.map +1 -1
- package/browser/error/UpdateValuesMissingError.js +2 -2
- package/browser/error/UpdateValuesMissingError.js.map +1 -1
- package/browser/error/UsingJoinColumnIsNotAllowedError.js +2 -2
- package/browser/error/UsingJoinColumnIsNotAllowedError.js.map +1 -1
- package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js +2 -2
- package/browser/error/UsingJoinColumnOnlyOnOneSideAllowedError.js.map +1 -1
- package/browser/error/UsingJoinTableIsNotAllowedError.js +2 -2
- package/browser/error/UsingJoinTableIsNotAllowedError.js.map +1 -1
- package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js +2 -2
- package/browser/error/UsingJoinTableOnlyOnOneSideAllowedError.js.map +1 -1
- package/browser/find-options/FindOneOptions.d.ts +4 -0
- package/browser/find-options/FindOneOptions.js.map +1 -1
- package/browser/find-options/FindOperator.d.ts +26 -4
- package/browser/find-options/FindOperator.js +49 -50
- package/browser/find-options/FindOperator.js.map +1 -1
- package/browser/find-options/FindOperatorType.d.ts +1 -1
- package/browser/find-options/FindOperatorType.js.map +1 -1
- package/browser/find-options/FindOptionsUtils.d.ts +2 -2
- package/browser/find-options/FindOptionsUtils.js +5 -1
- package/browser/find-options/FindOptionsUtils.js.map +1 -1
- package/browser/find-options/operator/Any.d.ts +1 -1
- package/browser/find-options/operator/Any.js.map +1 -1
- package/browser/find-options/operator/Between.d.ts +1 -1
- package/browser/find-options/operator/Between.js.map +1 -1
- package/browser/find-options/operator/ILike.d.ts +6 -0
- package/browser/find-options/operator/ILike.js +10 -0
- package/browser/find-options/operator/ILike.js.map +1 -0
- package/browser/find-options/operator/In.d.ts +1 -1
- package/browser/find-options/operator/In.js.map +1 -1
- package/browser/find-options/operator/Raw.d.ts +14 -2
- package/browser/find-options/operator/Raw.js +5 -6
- package/browser/find-options/operator/Raw.js.map +1 -1
- package/browser/index.d.ts +10 -11
- package/browser/index.js +9 -15
- package/browser/index.js.map +1 -1
- package/browser/logger/DebugLogger.d.ts +0 -1
- package/browser/logger/DebugLogger.js +9 -9
- package/browser/logger/DebugLogger.js.map +1 -1
- package/browser/logger/FileLogger.d.ts +3 -1
- package/browser/logger/FileLogger.js +9 -3
- package/browser/logger/FileLogger.js.map +1 -1
- package/browser/logger/Logger.d.ts +1 -1
- package/browser/logger/Logger.js.map +1 -1
- package/browser/logger/LoggerOptions.d.ts +9 -0
- package/browser/logger/LoggerOptions.js.map +1 -1
- package/browser/metadata/ColumnMetadata.js +29 -19
- package/browser/metadata/ColumnMetadata.js.map +1 -1
- package/browser/metadata/EmbeddedMetadata.js +2 -2
- package/browser/metadata/EmbeddedMetadata.js.map +1 -1
- package/browser/metadata/EntityMetadata.d.ts +1 -0
- package/browser/metadata/EntityMetadata.js +13 -5
- package/browser/metadata/EntityMetadata.js.map +1 -1
- package/browser/metadata/RelationMetadata.js +7 -7
- package/browser/metadata/RelationMetadata.js.map +1 -1
- package/browser/metadata/types/EventListenerTypes.d.ts +7 -7
- package/browser/metadata/types/EventListenerTypes.js.map +1 -1
- package/browser/metadata-args/EntityRepositoryMetadataArgs.d.ts +2 -2
- package/browser/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
- package/browser/metadata-args/RelationCountMetadataArgs.js.map +1 -1
- package/browser/metadata-args/RelationIdMetadataArgs.js.map +1 -1
- package/browser/metadata-builder/EntityMetadataBuilder.js +21 -15
- package/browser/metadata-builder/EntityMetadataBuilder.js.map +1 -1
- package/browser/metadata-builder/EntityMetadataValidator.js +8 -5
- package/browser/metadata-builder/EntityMetadataValidator.js.map +1 -1
- package/browser/metadata-builder/JunctionEntityMetadataBuilder.js +3 -2
- package/browser/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
- package/browser/migration/MigrationExecutor.js +132 -103
- package/browser/migration/MigrationExecutor.js.map +1 -1
- package/browser/naming-strategy/DefaultNamingStrategy.js +6 -6
- package/browser/naming-strategy/DefaultNamingStrategy.js.map +1 -1
- package/browser/persistence/EntityPersistExecutor.js +65 -47
- package/browser/persistence/EntityPersistExecutor.js.map +1 -1
- package/browser/persistence/Subject.js +4 -3
- package/browser/persistence/Subject.js.map +1 -1
- package/browser/persistence/SubjectDatabaseEntityLoader.js +9 -8
- package/browser/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
- package/browser/persistence/SubjectExecutor.js +263 -206
- package/browser/persistence/SubjectExecutor.js.map +1 -1
- package/browser/persistence/SubjectTopoligicalSorter.js +6 -6
- package/browser/persistence/SubjectTopoligicalSorter.js.map +1 -1
- package/browser/persistence/subject-builder/CascadesSubjectBuilder.js +2 -2
- package/browser/persistence/subject-builder/CascadesSubjectBuilder.js.map +1 -1
- package/browser/persistence/tree/ClosureSubjectExecutor.js +4 -4
- package/browser/persistence/tree/ClosureSubjectExecutor.js.map +1 -1
- package/browser/persistence/tree/MaterializedPathSubjectExecutor.js +5 -4
- package/browser/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
- package/browser/persistence/tree/NestedSetSubjectExecutor.js +3 -3
- package/browser/platform/BrowserConnectionOptionsReaderDummy.d.ts +38 -0
- package/browser/platform/BrowserConnectionOptionsReaderDummy.js +93 -0
- package/browser/platform/BrowserConnectionOptionsReaderDummy.js.map +1 -0
- package/browser/platform/BrowserDirectoryExportedClassesLoader.d.ts +15 -0
- package/browser/platform/BrowserDirectoryExportedClassesLoader.js +22 -0
- package/browser/platform/BrowserDirectoryExportedClassesLoader.js.map +1 -0
- package/browser/platform/BrowserDisabledDriversDummy.d.ts +32 -2
- package/browser/platform/BrowserDisabledDriversDummy.js +52 -2
- package/browser/platform/BrowserDisabledDriversDummy.js.map +1 -1
- package/browser/platform/BrowserFileLoggerDummy.d.ts +33 -0
- package/browser/platform/BrowserFileLoggerDummy.js +58 -0
- package/browser/platform/BrowserFileLoggerDummy.js.map +1 -0
- package/browser/platform/BrowserPlatformTools.d.ts +74 -0
- package/browser/platform/BrowserPlatformTools.js +157 -0
- package/browser/platform/BrowserPlatformTools.js.map +1 -0
- package/browser/platform/PlatformTools.d.ts +15 -21
- package/browser/platform/PlatformTools.js +142 -81
- package/browser/platform/PlatformTools.js.map +1 -1
- package/browser/query-builder/Alias.js.map +1 -1
- package/browser/query-builder/DeleteQueryBuilder.d.ts +2 -3
- package/browser/query-builder/DeleteQueryBuilder.js +12 -6
- package/browser/query-builder/DeleteQueryBuilder.js.map +1 -1
- package/browser/query-builder/InsertQueryBuilder.d.ts +2 -3
- package/browser/query-builder/InsertQueryBuilder.js +49 -16
- package/browser/query-builder/InsertQueryBuilder.js.map +1 -1
- package/browser/query-builder/JoinAttribute.js +2 -2
- package/browser/query-builder/JoinAttribute.js.map +1 -1
- package/browser/query-builder/QueryBuilder.d.ts +18 -15
- package/browser/query-builder/QueryBuilder.js +205 -55
- package/browser/query-builder/QueryBuilder.js.map +1 -1
- package/browser/query-builder/QueryBuilderUtils.js +2 -2
- package/browser/query-builder/QueryBuilderUtils.js.map +1 -1
- package/browser/query-builder/QueryExpressionMap.d.ts +4 -0
- package/browser/query-builder/QueryExpressionMap.js +4 -4
- package/browser/query-builder/QueryExpressionMap.js.map +1 -1
- package/browser/query-builder/QueryPartialEntity.d.ts +1 -1
- package/browser/query-builder/QueryPartialEntity.js.map +1 -1
- package/browser/query-builder/RelationIdLoader.js +5 -5
- package/browser/query-builder/RelationLoader.js +3 -3
- package/browser/query-builder/RelationLoader.js.map +1 -1
- package/browser/query-builder/RelationQueryBuilder.js +14 -14
- package/browser/query-builder/RelationQueryBuilder.js.map +1 -1
- package/browser/query-builder/RelationRemover.js +7 -7
- package/browser/query-builder/RelationRemover.js.map +1 -1
- package/browser/query-builder/RelationUpdater.js +3 -3
- package/browser/query-builder/ReturningResultsEntityUpdator.js +30 -31
- package/browser/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
- package/browser/query-builder/SelectQueryBuilder.d.ts +9 -3
- package/browser/query-builder/SelectQueryBuilder.js +116 -68
- package/browser/query-builder/SelectQueryBuilder.js.map +1 -1
- package/browser/query-builder/SoftDeleteQueryBuilder.d.ts +2 -3
- package/browser/query-builder/SoftDeleteQueryBuilder.js +6 -6
- package/browser/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
- package/browser/query-builder/UpdateQueryBuilder.js +13 -7
- package/browser/query-builder/UpdateQueryBuilder.js.map +1 -1
- package/browser/query-builder/relation-count/RelationCountAttribute.js +3 -3
- package/browser/query-builder/relation-count/RelationCountAttribute.js.map +1 -1
- package/browser/query-builder/relation-count/RelationCountLoader.js +5 -5
- package/browser/query-builder/relation-id/RelationIdAttribute.js +2 -2
- package/browser/query-builder/relation-id/RelationIdAttribute.js.map +1 -1
- package/browser/query-builder/relation-id/RelationIdLoader.js +6 -6
- package/browser/query-builder/relation-id/RelationIdLoader.js.map +1 -1
- package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js +4 -4
- package/browser/query-builder/transformer/PlainObjectToDatabaseEntityTransformer.js.map +1 -1
- package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js +9 -6
- package/browser/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
- package/browser/query-runner/BaseQueryRunner.d.ts +2 -5
- package/browser/query-runner/BaseQueryRunner.js +106 -56
- package/browser/query-runner/BaseQueryRunner.js.map +1 -1
- package/browser/query-runner/QueryRunner.d.ts +2 -1
- package/browser/query-runner/QueryRunner.js.map +1 -1
- package/browser/repository/AbstractRepository.js.map +1 -1
- package/browser/repository/BaseEntity.js +5 -5
- package/browser/repository/BaseEntity.js.map +1 -1
- package/browser/repository/MongoRepository.js +2 -2
- package/browser/repository/MongoRepository.js.map +1 -1
- package/browser/repository/Repository.js +3 -3
- package/browser/repository/Repository.js.map +1 -1
- package/browser/repository/TreeRepository.js +6 -6
- package/browser/repository/TreeRepository.js.map +1 -1
- package/browser/schema-builder/MongoSchemaBuilder.js +4 -4
- package/browser/schema-builder/MongoSchemaBuilder.js.map +1 -1
- package/browser/schema-builder/RdbmsSchemaBuilder.js +924 -368
- package/browser/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
- package/browser/schema-builder/options/TableIndexOptions.d.ts +1 -1
- package/browser/schema-builder/options/TableIndexOptions.js.map +1 -1
- package/browser/schema-builder/table/TableCheck.js +2 -2
- package/browser/schema-builder/table/TableCheck.js.map +1 -1
- package/browser/schema-builder/table/TableForeignKey.js +3 -3
- package/browser/schema-builder/table/TableForeignKey.js.map +1 -1
- package/browser/schema-builder/table/TableIndex.js +2 -2
- package/browser/schema-builder/table/TableIndex.js.map +1 -1
- package/browser/schema-builder/table/TableUnique.js +2 -2
- package/browser/schema-builder/table/TableUnique.js.map +1 -1
- package/browser/schema-builder/view/View.d.ts +1 -2
- package/browser/schema-builder/view/View.js.map +1 -1
- package/browser/subscriber/Broadcaster.d.ts +24 -0
- package/browser/subscriber/Broadcaster.js +120 -0
- package/browser/subscriber/Broadcaster.js.map +1 -1
- package/browser/subscriber/EntitySubscriberInterface.d.ts +27 -0
- package/browser/subscriber/EntitySubscriberInterface.js.map +1 -1
- package/browser/subscriber/event/TransactionCommitEvent.d.ts +22 -0
- package/browser/subscriber/event/TransactionCommitEvent.js +3 -0
- package/browser/subscriber/event/TransactionCommitEvent.js.map +1 -0
- package/browser/subscriber/event/TransactionRollbackEvent.d.ts +22 -0
- package/browser/subscriber/event/TransactionRollbackEvent.js +3 -0
- package/browser/subscriber/event/TransactionRollbackEvent.js.map +1 -0
- package/browser/subscriber/event/TransactionStartEvent.d.ts +22 -0
- package/browser/subscriber/event/TransactionStartEvent.js +3 -0
- package/browser/subscriber/event/TransactionStartEvent.js.map +1 -0
- package/browser/util/ApplyValueTransformers.js.map +1 -1
- package/browser/util/DateUtils.js +3 -9
- package/browser/util/DateUtils.js.map +1 -1
- package/browser/util/DirectoryExportedClassesLoader.js +6 -5
- package/browser/util/DirectoryExportedClassesLoader.js.map +1 -1
- package/browser/util/ObjectUtils.js +4 -4
- package/browser/util/ObjectUtils.js.map +1 -1
- package/browser/util/OrmUtils.js +5 -8
- package/browser/util/OrmUtils.js.map +1 -1
- package/cache/DbQueryResultCache.js +1 -1
- package/cache/DbQueryResultCache.js.map +1 -1
- package/cache/RedisQueryResultCache.js +6 -1
- package/cache/RedisQueryResultCache.js.map +1 -1
- package/commands/CacheClearCommand.js +4 -4
- package/commands/CacheClearCommand.js.map +1 -1
- package/commands/CommandUtils.d.ts +1 -1
- package/commands/CommandUtils.js +2 -2
- package/commands/CommandUtils.js.map +1 -1
- package/commands/EntityCreateCommand.js +9 -6
- package/commands/EntityCreateCommand.js.map +1 -1
- package/commands/InitCommand.js +15 -5
- package/commands/InitCommand.js.map +1 -1
- package/commands/MigrationCreateCommand.js +8 -5
- package/commands/MigrationCreateCommand.js.map +1 -1
- package/commands/MigrationGenerateCommand.d.ts +7 -1
- package/commands/MigrationGenerateCommand.js +53 -32
- package/commands/MigrationGenerateCommand.js.map +1 -1
- package/commands/MigrationRevertCommand.js +2 -2
- package/commands/MigrationRevertCommand.js.map +1 -1
- package/commands/MigrationRunCommand.js +2 -2
- package/commands/MigrationRunCommand.js.map +1 -1
- package/commands/MigrationShowCommand.js +2 -2
- package/commands/MigrationShowCommand.js.map +1 -1
- package/commands/QueryCommand.d.ts +2 -0
- package/commands/QueryCommand.js +16 -7
- package/commands/QueryCommand.js.map +1 -1
- package/commands/SchemaDropCommand.js +3 -3
- package/commands/SchemaDropCommand.js.map +1 -1
- package/commands/SchemaLogCommand.js +6 -6
- package/commands/SchemaLogCommand.js.map +1 -1
- package/commands/SchemaSyncCommand.js +3 -3
- package/commands/SchemaSyncCommand.js.map +1 -1
- package/commands/SubscriberCreateCommand.js +8 -5
- package/commands/SubscriberCreateCommand.js.map +1 -1
- package/commands/VersionCommand.js +2 -2
- package/commands/VersionCommand.js.map +1 -1
- package/common/DeepPartial.d.ts +1 -1
- package/common/DeepPartial.js.map +1 -1
- package/common/EntityTarget.d.ts +9 -0
- package/common/EntityTarget.js +4 -0
- package/common/EntityTarget.js.map +1 -0
- package/connection/Connection.d.ts +11 -10
- package/connection/Connection.js +45 -22
- package/connection/Connection.js.map +1 -1
- package/connection/ConnectionOptions.d.ts +2 -1
- package/connection/ConnectionOptions.js.map +1 -1
- package/connection/ConnectionOptionsReader.js +39 -34
- package/connection/ConnectionOptionsReader.js.map +1 -1
- package/connection/options-reader/ConnectionOptionsEnvReader.d.ts +5 -1
- package/connection/options-reader/ConnectionOptionsEnvReader.js +45 -31
- package/connection/options-reader/ConnectionOptionsEnvReader.js.map +1 -1
- package/connection/options-reader/ConnectionOptionsXmlReader.js +2 -2
- package/connection/options-reader/ConnectionOptionsXmlReader.js.map +1 -1
- package/connection/options-reader/ConnectionOptionsYmlReader.d.ts +1 -1
- package/connection/options-reader/ConnectionOptionsYmlReader.js +15 -4
- package/connection/options-reader/ConnectionOptionsYmlReader.js.map +1 -1
- package/decorator/Check.d.ts +2 -2
- package/decorator/Check.js.map +1 -1
- package/decorator/EntityRepository.d.ts +1 -1
- package/decorator/EntityRepository.js.map +1 -1
- package/decorator/Exclusion.d.ts +2 -2
- package/decorator/Exclusion.js.map +1 -1
- package/decorator/Generated.d.ts +1 -1
- package/decorator/Generated.js.map +1 -1
- package/decorator/Index.d.ts +7 -7
- package/decorator/Index.js.map +1 -1
- package/decorator/Unique.d.ts +4 -4
- package/decorator/Unique.js +12 -1
- package/decorator/Unique.js.map +1 -1
- package/decorator/columns/Column.d.ts +12 -12
- package/decorator/columns/Column.js.map +1 -1
- package/decorator/columns/CreateDateColumn.d.ts +1 -1
- package/decorator/columns/CreateDateColumn.js.map +1 -1
- package/decorator/columns/DeleteDateColumn.d.ts +1 -1
- package/decorator/columns/DeleteDateColumn.js.map +1 -1
- package/decorator/columns/ObjectIdColumn.d.ts +1 -1
- package/decorator/columns/ObjectIdColumn.js.map +1 -1
- package/decorator/columns/PrimaryColumn.d.ts +2 -2
- package/decorator/columns/PrimaryColumn.js.map +1 -1
- package/decorator/columns/PrimaryGeneratedColumn.d.ts +5 -5
- package/decorator/columns/PrimaryGeneratedColumn.js.map +1 -1
- package/decorator/columns/UpdateDateColumn.d.ts +1 -1
- package/decorator/columns/UpdateDateColumn.js.map +1 -1
- package/decorator/columns/VersionColumn.d.ts +1 -1
- package/decorator/columns/VersionColumn.js.map +1 -1
- package/decorator/columns/ViewColumn.d.ts +1 -1
- package/decorator/columns/ViewColumn.js.map +1 -1
- package/decorator/entity/ChildEntity.d.ts +1 -1
- package/decorator/entity/ChildEntity.js +1 -1
- package/decorator/entity/ChildEntity.js.map +1 -1
- package/decorator/entity/TableInheritance.d.ts +1 -1
- package/decorator/entity/TableInheritance.js.map +1 -1
- package/decorator/entity-view/ViewEntity.d.ts +2 -2
- package/decorator/entity-view/ViewEntity.js.map +1 -1
- package/decorator/listeners/AfterInsert.d.ts +1 -1
- package/decorator/listeners/AfterInsert.js.map +1 -1
- package/decorator/listeners/AfterLoad.d.ts +1 -1
- package/decorator/listeners/AfterLoad.js.map +1 -1
- package/decorator/listeners/AfterRemove.d.ts +1 -1
- package/decorator/listeners/AfterRemove.js.map +1 -1
- package/decorator/listeners/AfterUpdate.d.ts +1 -1
- package/decorator/listeners/AfterUpdate.js.map +1 -1
- package/decorator/listeners/BeforeInsert.d.ts +1 -1
- package/decorator/listeners/BeforeInsert.js.map +1 -1
- package/decorator/listeners/BeforeRemove.d.ts +1 -1
- package/decorator/listeners/BeforeRemove.js.map +1 -1
- package/decorator/listeners/BeforeUpdate.d.ts +1 -1
- package/decorator/listeners/BeforeUpdate.js.map +1 -1
- package/decorator/listeners/EventSubscriber.d.ts +1 -1
- package/decorator/listeners/EventSubscriber.js.map +1 -1
- package/decorator/options/ColumnOptions.js.map +1 -1
- package/decorator/options/TransactionOptions.js.map +1 -1
- package/decorator/relations/JoinColumn.d.ts +3 -3
- package/decorator/relations/JoinColumn.js.map +1 -1
- package/decorator/relations/JoinTable.d.ts +3 -3
- package/decorator/relations/JoinTable.js.map +1 -1
- package/decorator/relations/ManyToMany.d.ts +2 -2
- package/decorator/relations/ManyToMany.js.map +1 -1
- package/decorator/relations/ManyToOne.d.ts +2 -2
- package/decorator/relations/ManyToOne.js.map +1 -1
- package/decorator/relations/OneToMany.d.ts +3 -3
- package/decorator/relations/OneToMany.js +2 -2
- package/decorator/relations/OneToMany.js.map +1 -1
- package/decorator/relations/OneToOne.d.ts +2 -2
- package/decorator/relations/OneToOne.js.map +1 -1
- package/decorator/relations/RelationCount.d.ts +1 -1
- package/decorator/relations/RelationCount.js.map +1 -1
- package/decorator/relations/RelationId.d.ts +1 -1
- package/decorator/relations/RelationId.js.map +1 -1
- package/decorator/transaction/TransactionManager.d.ts +1 -1
- package/decorator/transaction/TransactionManager.js.map +1 -1
- package/decorator/tree/Tree.d.ts +1 -1
- package/decorator/tree/Tree.js.map +1 -1
- package/decorator/tree/TreeChildren.d.ts +1 -1
- package/decorator/tree/TreeChildren.js.map +1 -1
- package/decorator/tree/TreeLevelColumn.d.ts +1 -1
- package/decorator/tree/TreeLevelColumn.js.map +1 -1
- package/decorator/tree/TreeParent.d.ts +1 -1
- package/decorator/tree/TreeParent.js.map +1 -1
- package/driver/Driver.d.ts +7 -2
- package/driver/Driver.js.map +1 -1
- package/driver/DriverFactory.js +5 -2
- package/driver/DriverFactory.js.map +1 -1
- package/driver/DriverUtils.d.ts +2 -2
- package/driver/DriverUtils.js +25 -13
- package/driver/DriverUtils.js.map +1 -1
- package/driver/aurora-data-api/AuroraDataApiConnection.d.ts +2 -1
- package/driver/aurora-data-api/AuroraDataApiConnection.js +0 -1
- package/driver/aurora-data-api/AuroraDataApiConnection.js.map +1 -1
- package/driver/aurora-data-api/AuroraDataApiConnectionOptions.d.ts +3 -0
- package/driver/aurora-data-api/AuroraDataApiConnectionOptions.js.map +1 -1
- package/driver/aurora-data-api/AuroraDataApiDriver.d.ts +6 -1
- package/driver/aurora-data-api/AuroraDataApiDriver.js +7 -2
- package/driver/aurora-data-api/AuroraDataApiDriver.js.map +1 -1
- package/driver/aurora-data-api/AuroraDataApiQueryRunner.d.ts +4 -0
- package/driver/aurora-data-api/AuroraDataApiQueryRunner.js +159 -25
- package/driver/aurora-data-api/AuroraDataApiQueryRunner.js.map +1 -1
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.d.ts +6 -0
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresConnectionOptions.js.map +1 -1
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.d.ts +57 -0
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js +101 -0
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresDriver.js.map +1 -0
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.d.ts +4 -3
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js +53 -7
- package/driver/aurora-data-api-pg/AuroraDataApiPostgresQueryRunner.js.map +1 -1
- package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.d.ts +50 -0
- package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js +4 -0
- package/driver/better-sqlite3/BetterSqlite3ConnectionOptions.js.map +1 -0
- package/driver/better-sqlite3/BetterSqlite3Driver.d.ts +46 -0
- package/driver/better-sqlite3/BetterSqlite3Driver.js +127 -0
- package/driver/better-sqlite3/BetterSqlite3Driver.js.map +1 -0
- package/driver/better-sqlite3/BetterSqlite3QueryRunner.d.ts +22 -0
- package/driver/better-sqlite3/BetterSqlite3QueryRunner.js +115 -0
- package/driver/better-sqlite3/BetterSqlite3QueryRunner.js.map +1 -0
- package/driver/cockroachdb/CockroachConnectionCredentialsOptions.js.map +1 -1
- package/driver/cockroachdb/CockroachDriver.d.ts +6 -1
- package/driver/cockroachdb/CockroachDriver.js +9 -4
- package/driver/cockroachdb/CockroachDriver.js.map +1 -1
- package/driver/cockroachdb/CockroachQueryRunner.d.ts +6 -1
- package/driver/cockroachdb/CockroachQueryRunner.js +392 -94
- package/driver/cockroachdb/CockroachQueryRunner.js.map +1 -1
- package/driver/cordova/CordovaDriver.d.ts +2 -1
- package/driver/cordova/CordovaDriver.js +0 -1
- package/driver/cordova/CordovaDriver.js.map +1 -1
- package/driver/expo/ExpoDriver.d.ts +2 -1
- package/driver/expo/ExpoDriver.js +0 -1
- package/driver/expo/ExpoDriver.js.map +1 -1
- package/driver/expo/ExpoQueryRunner.js +72 -14
- package/driver/expo/ExpoQueryRunner.js.map +1 -1
- package/driver/mongodb/MongoConnectionOptions.d.ts +4 -0
- package/driver/mongodb/MongoConnectionOptions.js.map +1 -1
- package/driver/mongodb/MongoDriver.d.ts +13 -4
- package/driver/mongodb/MongoDriver.js +21 -15
- package/driver/mongodb/MongoDriver.js.map +1 -1
- package/driver/mongodb/MongoQueryRunner.d.ts +3 -3
- package/driver/mongodb/MongoQueryRunner.js.map +1 -1
- package/driver/mongodb/typings.js.map +1 -1
- package/driver/mysql/MysqlDriver.d.ts +7 -2
- package/driver/mysql/MysqlDriver.js +14 -7
- package/driver/mysql/MysqlDriver.js.map +1 -1
- package/driver/mysql/MysqlQueryRunner.d.ts +10 -1
- package/driver/mysql/MysqlQueryRunner.js +227 -61
- package/driver/mysql/MysqlQueryRunner.js.map +1 -1
- package/driver/nativescript/NativescriptDriver.d.ts +2 -1
- package/driver/nativescript/NativescriptDriver.js +0 -1
- package/driver/nativescript/NativescriptDriver.js.map +1 -1
- package/driver/oracle/OracleDriver.d.ts +6 -1
- package/driver/oracle/OracleDriver.js +8 -3
- package/driver/oracle/OracleDriver.js.map +1 -1
- package/driver/oracle/OracleQueryRunner.d.ts +2 -1
- package/driver/oracle/OracleQueryRunner.js +139 -26
- package/driver/oracle/OracleQueryRunner.js.map +1 -1
- package/driver/postgres/PostgresConnectionCredentialsOptions.js.map +1 -1
- package/driver/postgres/PostgresConnectionOptions.d.ts +9 -0
- package/driver/postgres/PostgresConnectionOptions.js.map +1 -1
- package/driver/postgres/PostgresDriver.d.ts +18 -55
- package/driver/postgres/PostgresDriver.js +181 -191
- package/driver/postgres/PostgresDriver.js.map +1 -1
- package/driver/postgres/PostgresQueryRunner.d.ts +10 -1
- package/driver/postgres/PostgresQueryRunner.js +389 -81
- package/driver/postgres/PostgresQueryRunner.js.map +1 -1
- package/driver/react-native/ReactNativeDriver.d.ts +2 -1
- package/driver/react-native/ReactNativeDriver.js +0 -1
- package/driver/react-native/ReactNativeDriver.js.map +1 -1
- package/driver/sap/SapDriver.d.ts +6 -1
- package/driver/sap/SapDriver.js +6 -1
- package/driver/sap/SapDriver.js.map +1 -1
- package/driver/sap/SapQueryRunner.d.ts +2 -1
- package/driver/sap/SapQueryRunner.js +143 -27
- package/driver/sap/SapQueryRunner.js.map +1 -1
- package/driver/sqlite/SqliteConnectionOptions.d.ts +18 -0
- package/driver/sqlite/SqliteConnectionOptions.js.map +1 -1
- package/driver/sqlite/SqliteDriver.d.ts +2 -1
- package/driver/sqlite/SqliteDriver.js +25 -11
- package/driver/sqlite/SqliteDriver.js.map +1 -1
- package/driver/sqlite/SqliteQueryRunner.js +33 -14
- package/driver/sqlite/SqliteQueryRunner.js.map +1 -1
- package/driver/sqlite-abstract/AbstractSqliteDriver.d.ts +7 -2
- package/driver/sqlite-abstract/AbstractSqliteDriver.js +31 -4
- package/driver/sqlite-abstract/AbstractSqliteDriver.js.map +1 -1
- package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js +72 -10
- package/driver/sqlite-abstract/AbstractSqliteQueryRunner.js.map +1 -1
- package/driver/sqljs/SqljsDriver.d.ts +2 -1
- package/driver/sqljs/SqljsDriver.js +0 -1
- package/driver/sqljs/SqljsDriver.js.map +1 -1
- package/driver/sqljs/SqljsQueryRunner.js +1 -0
- package/driver/sqljs/SqljsQueryRunner.js.map +1 -1
- package/driver/sqlserver/SqlServerDriver.d.ts +6 -1
- package/driver/sqlserver/SqlServerDriver.js +6 -1
- package/driver/sqlserver/SqlServerDriver.js.map +1 -1
- package/driver/sqlserver/SqlServerQueryRunner.d.ts +2 -1
- package/driver/sqlserver/SqlServerQueryRunner.js +224 -86
- package/driver/sqlserver/SqlServerQueryRunner.js.map +1 -1
- package/driver/types/ColumnTypes.d.ts +1 -1
- package/driver/types/ColumnTypes.js.map +1 -1
- package/driver/types/DatabaseType.d.ts +1 -1
- package/driver/types/DatabaseType.js.map +1 -1
- package/driver/types/ReplicationMode.d.ts +1 -0
- package/driver/types/ReplicationMode.js +4 -0
- package/driver/types/ReplicationMode.js.map +1 -0
- package/entity-manager/EntityManager.d.ts +41 -256
- package/entity-manager/EntityManager.js +3 -13
- package/entity-manager/EntityManager.js.map +1 -1
- package/entity-manager/MongoEntityManager.d.ts +46 -46
- package/entity-manager/MongoEntityManager.js +14 -3
- package/entity-manager/MongoEntityManager.js.map +1 -1
- package/entity-schema/EntitySchemaColumnOptions.js.map +1 -1
- package/entity-schema/EntitySchemaRelationOptions.d.ts +1 -1
- package/entity-schema/EntitySchemaRelationOptions.js.map +1 -1
- package/entity-schema/EntitySchemaTransformer.js +22 -7
- package/entity-schema/EntitySchemaTransformer.js.map +1 -1
- package/error/EntityMetadataNotFoundError.d.ts +2 -2
- package/error/EntityMetadataNotFoundError.js +3 -0
- package/error/EntityMetadataNotFoundError.js.map +1 -1
- package/error/EntityNotFoundError.d.ts +2 -3
- package/error/EntityNotFoundError.js +3 -0
- package/error/EntityNotFoundError.js.map +1 -1
- package/error/FindRelationsNotFoundError.js +2 -2
- package/error/FindRelationsNotFoundError.js.map +1 -1
- package/error/MissingDriverError.js +1 -1
- package/error/MissingDriverError.js.map +1 -1
- package/error/QueryFailedError.js +1 -1
- package/error/QueryFailedError.js.map +1 -1
- package/error/RepositoryNotFoundError.d.ts +2 -2
- package/error/RepositoryNotFoundError.js +3 -0
- package/error/RepositoryNotFoundError.js.map +1 -1
- package/error/RepositoryNotTreeError.d.ts +2 -2
- package/error/RepositoryNotTreeError.js +9 -6
- package/error/RepositoryNotTreeError.js.map +1 -1
- package/find-options/FindOneOptions.d.ts +4 -0
- package/find-options/FindOneOptions.js.map +1 -1
- package/find-options/FindOperator.d.ts +26 -4
- package/find-options/FindOperator.js +49 -50
- package/find-options/FindOperator.js.map +1 -1
- package/find-options/FindOperatorType.d.ts +1 -1
- package/find-options/FindOperatorType.js.map +1 -1
- package/find-options/FindOptionsUtils.d.ts +2 -2
- package/find-options/FindOptionsUtils.js +5 -1
- package/find-options/FindOptionsUtils.js.map +1 -1
- package/find-options/operator/Any.d.ts +1 -1
- package/find-options/operator/Any.js.map +1 -1
- package/find-options/operator/Between.d.ts +1 -1
- package/find-options/operator/Between.js.map +1 -1
- package/find-options/operator/ILike.d.ts +6 -0
- package/find-options/operator/ILike.js +13 -0
- package/find-options/operator/ILike.js.map +1 -0
- package/find-options/operator/In.d.ts +1 -1
- package/find-options/operator/In.js.map +1 -1
- package/find-options/operator/Raw.d.ts +14 -2
- package/find-options/operator/Raw.js +5 -6
- package/find-options/operator/Raw.js.map +1 -1
- package/index.d.ts +10 -11
- package/index.js +2 -14
- package/index.js.map +1 -1
- package/logger/DebugLogger.d.ts +0 -1
- package/logger/DebugLogger.js +10 -9
- package/logger/DebugLogger.js.map +1 -1
- package/logger/FileLogger.d.ts +3 -1
- package/logger/FileLogger.js +10 -3
- package/logger/FileLogger.js.map +1 -1
- package/logger/Logger.d.ts +1 -1
- package/logger/Logger.js.map +1 -1
- package/logger/LoggerOptions.d.ts +9 -0
- package/logger/LoggerOptions.js.map +1 -1
- package/metadata/ColumnMetadata.js +24 -14
- package/metadata/ColumnMetadata.js.map +1 -1
- package/metadata/EntityMetadata.d.ts +1 -0
- package/metadata/EntityMetadata.js +11 -3
- package/metadata/EntityMetadata.js.map +1 -1
- package/metadata/RelationMetadata.js +2 -2
- package/metadata/RelationMetadata.js.map +1 -1
- package/metadata/types/EventListenerTypes.d.ts +7 -7
- package/metadata/types/EventListenerTypes.js.map +1 -1
- package/metadata-args/EntityRepositoryMetadataArgs.d.ts +2 -2
- package/metadata-args/EntityRepositoryMetadataArgs.js.map +1 -1
- package/metadata-args/RelationCountMetadataArgs.js.map +1 -1
- package/metadata-args/RelationIdMetadataArgs.js.map +1 -1
- package/metadata-builder/EntityMetadataBuilder.js +15 -9
- package/metadata-builder/EntityMetadataBuilder.js.map +1 -1
- package/metadata-builder/EntityMetadataValidator.js +8 -5
- package/metadata-builder/EntityMetadataValidator.js.map +1 -1
- package/metadata-builder/JunctionEntityMetadataBuilder.js +1 -0
- package/metadata-builder/JunctionEntityMetadataBuilder.js.map +1 -1
- package/migration/MigrationExecutor.js +103 -74
- package/migration/MigrationExecutor.js.map +1 -1
- package/package.json +72 -51
- package/persistence/EntityPersistExecutor.js +61 -43
- package/persistence/EntityPersistExecutor.js.map +1 -1
- package/persistence/Subject.js +2 -1
- package/persistence/Subject.js.map +1 -1
- package/persistence/SubjectDatabaseEntityLoader.js +2 -1
- package/persistence/SubjectDatabaseEntityLoader.js.map +1 -1
- package/persistence/SubjectExecutor.js +244 -187
- package/persistence/SubjectExecutor.js.map +1 -1
- package/persistence/tree/MaterializedPathSubjectExecutor.js +2 -1
- package/persistence/tree/MaterializedPathSubjectExecutor.js.map +1 -1
- package/platform/PlatformTools.d.ts +7 -1
- package/platform/PlatformTools.js +42 -41
- package/platform/PlatformTools.js.map +1 -1
- package/query-builder/Alias.js.map +1 -1
- package/query-builder/DeleteQueryBuilder.d.ts +2 -3
- package/query-builder/DeleteQueryBuilder.js +7 -1
- package/query-builder/DeleteQueryBuilder.js.map +1 -1
- package/query-builder/InsertQueryBuilder.d.ts +2 -3
- package/query-builder/InsertQueryBuilder.js +44 -11
- package/query-builder/InsertQueryBuilder.js.map +1 -1
- package/query-builder/QueryBuilder.d.ts +18 -15
- package/query-builder/QueryBuilder.js +198 -48
- package/query-builder/QueryBuilder.js.map +1 -1
- package/query-builder/QueryExpressionMap.d.ts +4 -0
- package/query-builder/QueryExpressionMap.js.map +1 -1
- package/query-builder/QueryPartialEntity.d.ts +1 -1
- package/query-builder/QueryPartialEntity.js.map +1 -1
- package/query-builder/ReturningResultsEntityUpdator.js +23 -24
- package/query-builder/ReturningResultsEntityUpdator.js.map +1 -1
- package/query-builder/SelectQueryBuilder.d.ts +8 -3
- package/query-builder/SelectQueryBuilder.js +80 -32
- package/query-builder/SelectQueryBuilder.js.map +1 -1
- package/query-builder/SoftDeleteQueryBuilder.d.ts +2 -3
- package/query-builder/SoftDeleteQueryBuilder.js +1 -1
- package/query-builder/SoftDeleteQueryBuilder.js.map +1 -1
- package/query-builder/UpdateQueryBuilder.js +8 -2
- package/query-builder/UpdateQueryBuilder.js.map +1 -1
- package/query-builder/transformer/RawSqlResultsToEntityTransformer.js +6 -3
- package/query-builder/transformer/RawSqlResultsToEntityTransformer.js.map +1 -1
- package/query-runner/BaseQueryRunner.d.ts +2 -5
- package/query-runner/BaseQueryRunner.js +90 -40
- package/query-runner/BaseQueryRunner.js.map +1 -1
- package/query-runner/QueryRunner.d.ts +1 -1
- package/query-runner/QueryRunner.js.map +1 -1
- package/repository/AbstractRepository.js.map +1 -1
- package/repository/BaseEntity.js +1 -1
- package/repository/BaseEntity.js.map +1 -1
- package/repository/MongoRepository.js.map +1 -1
- package/repository/Repository.js +1 -1
- package/repository/Repository.js.map +1 -1
- package/repository/TreeRepository.js +2 -2
- package/repository/TreeRepository.js.map +1 -1
- package/schema-builder/MongoSchemaBuilder.js +1 -1
- package/schema-builder/MongoSchemaBuilder.js.map +1 -1
- package/schema-builder/RdbmsSchemaBuilder.js +875 -319
- package/schema-builder/RdbmsSchemaBuilder.js.map +1 -1
- package/schema-builder/options/TableIndexOptions.d.ts +1 -1
- package/schema-builder/options/TableIndexOptions.js.map +1 -1
- package/schema-builder/view/View.d.ts +1 -2
- package/schema-builder/view/View.js.map +1 -1
- package/subscriber/Broadcaster.d.ts +24 -0
- package/subscriber/Broadcaster.js +120 -0
- package/subscriber/Broadcaster.js.map +1 -1
- package/subscriber/EntitySubscriberInterface.d.ts +27 -0
- package/subscriber/EntitySubscriberInterface.js.map +1 -1
- package/subscriber/event/TransactionCommitEvent.d.ts +22 -0
- package/subscriber/event/TransactionCommitEvent.js +4 -0
- package/subscriber/event/TransactionCommitEvent.js.map +1 -0
- package/subscriber/event/TransactionRollbackEvent.d.ts +22 -0
- package/subscriber/event/TransactionRollbackEvent.js +4 -0
- package/subscriber/event/TransactionRollbackEvent.js.map +1 -0
- package/subscriber/event/TransactionStartEvent.d.ts +22 -0
- package/subscriber/event/TransactionStartEvent.js +4 -0
- package/subscriber/event/TransactionStartEvent.js.map +1 -0
- package/typeorm-class-transformer-shim.js +16 -2
- package/typeorm-model-shim.js +146 -111
- package/util/ApplyValueTransformers.js.map +1 -1
- package/util/DateUtils.js +1 -7
- package/util/DateUtils.js.map +1 -1
- package/util/DirectoryExportedClassesLoader.js +7 -5
- package/util/DirectoryExportedClassesLoader.js.map +1 -1
- package/util/ObjectUtils.js +2 -2
- package/util/ObjectUtils.js.map +1 -1
- package/util/OrmUtils.js +3 -6
- package/util/OrmUtils.js.map +1 -1
- package/browser/util/PromiseUtils.d.ts +0 -24
- package/browser/util/PromiseUtils.js +0 -62
- package/browser/util/PromiseUtils.js.map +0 -1
- package/util/PromiseUtils.d.ts +0 -24
- package/util/PromiseUtils.js +0 -64
- package/util/PromiseUtils.js.map +0 -1
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
var tslib_1 = require("tslib");
|
|
4
|
-
var __1 = require("../../");
|
|
5
4
|
var QueryFailedError_1 = require("../../error/QueryFailedError");
|
|
6
5
|
var QueryRunnerAlreadyReleasedError_1 = require("../../error/QueryRunnerAlreadyReleasedError");
|
|
7
6
|
var TransactionAlreadyStartedError_1 = require("../../error/TransactionAlreadyStartedError");
|
|
@@ -18,6 +17,7 @@ var View_1 = require("../../schema-builder/view/View");
|
|
|
18
17
|
var Broadcaster_1 = require("../../subscriber/Broadcaster");
|
|
19
18
|
var OrmUtils_1 = require("../../util/OrmUtils");
|
|
20
19
|
var Query_1 = require("../Query");
|
|
20
|
+
var BroadcasterResult_1 = require("../../subscriber/BroadcasterResult");
|
|
21
21
|
/**
|
|
22
22
|
* Runs queries on a single postgres database connection.
|
|
23
23
|
*/
|
|
@@ -27,7 +27,6 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
27
27
|
// Constructor
|
|
28
28
|
// -------------------------------------------------------------------------
|
|
29
29
|
function PostgresQueryRunner(driver, mode) {
|
|
30
|
-
if (mode === void 0) { mode = "master"; }
|
|
31
30
|
var _this = _super.call(this) || this;
|
|
32
31
|
_this.driver = driver;
|
|
33
32
|
_this.connection = driver.connection;
|
|
@@ -53,7 +52,12 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
53
52
|
var _b = tslib_1.__read(_a, 2), connection = _b[0], release = _b[1];
|
|
54
53
|
_this.driver.connectedQueryRunners.push(_this);
|
|
55
54
|
_this.databaseConnection = connection;
|
|
56
|
-
|
|
55
|
+
var onErrorCallback = function () { return _this.release(); };
|
|
56
|
+
_this.releaseCallback = function () {
|
|
57
|
+
_this.databaseConnection.removeListener("error", onErrorCallback);
|
|
58
|
+
release();
|
|
59
|
+
};
|
|
60
|
+
_this.databaseConnection.on("error", onErrorCallback);
|
|
57
61
|
return _this.databaseConnection;
|
|
58
62
|
});
|
|
59
63
|
}
|
|
@@ -62,7 +66,12 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
62
66
|
var _b = tslib_1.__read(_a, 2), connection = _b[0], release = _b[1];
|
|
63
67
|
_this.driver.connectedQueryRunners.push(_this);
|
|
64
68
|
_this.databaseConnection = connection;
|
|
65
|
-
|
|
69
|
+
var onErrorCallback = function () { return _this.release(); };
|
|
70
|
+
_this.releaseCallback = function () {
|
|
71
|
+
_this.databaseConnection.removeListener("error", onErrorCallback);
|
|
72
|
+
release();
|
|
73
|
+
};
|
|
74
|
+
_this.databaseConnection.on("error", onErrorCallback);
|
|
66
75
|
return _this.databaseConnection;
|
|
67
76
|
});
|
|
68
77
|
}
|
|
@@ -73,6 +82,9 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
73
82
|
* You cannot use query runner methods once its released.
|
|
74
83
|
*/
|
|
75
84
|
PostgresQueryRunner.prototype.release = function () {
|
|
85
|
+
if (this.isReleased) {
|
|
86
|
+
return Promise.resolve();
|
|
87
|
+
}
|
|
76
88
|
this.isReleased = true;
|
|
77
89
|
if (this.releaseCallback)
|
|
78
90
|
this.releaseCallback();
|
|
@@ -86,21 +98,38 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
86
98
|
*/
|
|
87
99
|
PostgresQueryRunner.prototype.startTransaction = function (isolationLevel) {
|
|
88
100
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
101
|
+
var beforeBroadcastResult, afterBroadcastResult;
|
|
89
102
|
return tslib_1.__generator(this, function (_a) {
|
|
90
103
|
switch (_a.label) {
|
|
91
104
|
case 0:
|
|
92
105
|
if (this.isTransactionActive)
|
|
93
106
|
throw new TransactionAlreadyStartedError_1.TransactionAlreadyStartedError();
|
|
107
|
+
beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
108
|
+
this.broadcaster.broadcastBeforeTransactionStartEvent(beforeBroadcastResult);
|
|
109
|
+
if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
|
|
110
|
+
return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
|
|
111
|
+
case 1:
|
|
112
|
+
_a.sent();
|
|
113
|
+
_a.label = 2;
|
|
114
|
+
case 2:
|
|
94
115
|
this.isTransactionActive = true;
|
|
95
116
|
return [4 /*yield*/, this.query("START TRANSACTION")];
|
|
96
|
-
case
|
|
117
|
+
case 3:
|
|
97
118
|
_a.sent();
|
|
98
|
-
if (!isolationLevel) return [3 /*break*/,
|
|
119
|
+
if (!isolationLevel) return [3 /*break*/, 5];
|
|
99
120
|
return [4 /*yield*/, this.query("SET TRANSACTION ISOLATION LEVEL " + isolationLevel)];
|
|
100
|
-
case
|
|
121
|
+
case 4:
|
|
101
122
|
_a.sent();
|
|
102
|
-
_a.label =
|
|
103
|
-
case
|
|
123
|
+
_a.label = 5;
|
|
124
|
+
case 5:
|
|
125
|
+
afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
126
|
+
this.broadcaster.broadcastAfterTransactionStartEvent(afterBroadcastResult);
|
|
127
|
+
if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 7];
|
|
128
|
+
return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
|
|
129
|
+
case 6:
|
|
130
|
+
_a.sent();
|
|
131
|
+
_a.label = 7;
|
|
132
|
+
case 7: return [2 /*return*/];
|
|
104
133
|
}
|
|
105
134
|
});
|
|
106
135
|
});
|
|
@@ -111,16 +140,31 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
111
140
|
*/
|
|
112
141
|
PostgresQueryRunner.prototype.commitTransaction = function () {
|
|
113
142
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
143
|
+
var beforeBroadcastResult, afterBroadcastResult;
|
|
114
144
|
return tslib_1.__generator(this, function (_a) {
|
|
115
145
|
switch (_a.label) {
|
|
116
146
|
case 0:
|
|
117
147
|
if (!this.isTransactionActive)
|
|
118
148
|
throw new TransactionNotStartedError_1.TransactionNotStartedError();
|
|
119
|
-
|
|
149
|
+
beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
150
|
+
this.broadcaster.broadcastBeforeTransactionCommitEvent(beforeBroadcastResult);
|
|
151
|
+
if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
|
|
152
|
+
return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
|
|
120
153
|
case 1:
|
|
154
|
+
_a.sent();
|
|
155
|
+
_a.label = 2;
|
|
156
|
+
case 2: return [4 /*yield*/, this.query("COMMIT")];
|
|
157
|
+
case 3:
|
|
121
158
|
_a.sent();
|
|
122
159
|
this.isTransactionActive = false;
|
|
123
|
-
|
|
160
|
+
afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
161
|
+
this.broadcaster.broadcastAfterTransactionCommitEvent(afterBroadcastResult);
|
|
162
|
+
if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
|
|
163
|
+
return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
|
|
164
|
+
case 4:
|
|
165
|
+
_a.sent();
|
|
166
|
+
_a.label = 5;
|
|
167
|
+
case 5: return [2 /*return*/];
|
|
124
168
|
}
|
|
125
169
|
});
|
|
126
170
|
});
|
|
@@ -131,16 +175,31 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
131
175
|
*/
|
|
132
176
|
PostgresQueryRunner.prototype.rollbackTransaction = function () {
|
|
133
177
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
178
|
+
var beforeBroadcastResult, afterBroadcastResult;
|
|
134
179
|
return tslib_1.__generator(this, function (_a) {
|
|
135
180
|
switch (_a.label) {
|
|
136
181
|
case 0:
|
|
137
182
|
if (!this.isTransactionActive)
|
|
138
183
|
throw new TransactionNotStartedError_1.TransactionNotStartedError();
|
|
139
|
-
|
|
184
|
+
beforeBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
185
|
+
this.broadcaster.broadcastBeforeTransactionRollbackEvent(beforeBroadcastResult);
|
|
186
|
+
if (!(beforeBroadcastResult.promises.length > 0)) return [3 /*break*/, 2];
|
|
187
|
+
return [4 /*yield*/, Promise.all(beforeBroadcastResult.promises)];
|
|
140
188
|
case 1:
|
|
189
|
+
_a.sent();
|
|
190
|
+
_a.label = 2;
|
|
191
|
+
case 2: return [4 /*yield*/, this.query("ROLLBACK")];
|
|
192
|
+
case 3:
|
|
141
193
|
_a.sent();
|
|
142
194
|
this.isTransactionActive = false;
|
|
143
|
-
|
|
195
|
+
afterBroadcastResult = new BroadcasterResult_1.BroadcasterResult();
|
|
196
|
+
this.broadcaster.broadcastAfterTransactionRollbackEvent(afterBroadcastResult);
|
|
197
|
+
if (!(afterBroadcastResult.promises.length > 0)) return [3 /*break*/, 5];
|
|
198
|
+
return [4 /*yield*/, Promise.all(afterBroadcastResult.promises)];
|
|
199
|
+
case 4:
|
|
200
|
+
_a.sent();
|
|
201
|
+
_a.label = 5;
|
|
202
|
+
case 5: return [2 /*return*/];
|
|
144
203
|
}
|
|
145
204
|
});
|
|
146
205
|
});
|
|
@@ -562,7 +621,8 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
562
621
|
*/
|
|
563
622
|
PostgresQueryRunner.prototype.renameTable = function (oldTableOrName, newTableName) {
|
|
564
623
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
565
|
-
var
|
|
624
|
+
var upQueries, downQueries, oldTable, _a, newTable, oldTableName, schemaName, columnNames, oldPkName, newPkName, enumColumns, enumColumns_1, enumColumns_1_1, column, oldEnumType, e_1_1;
|
|
625
|
+
var e_1, _b;
|
|
566
626
|
var _this = this;
|
|
567
627
|
return tslib_1.__generator(this, function (_c) {
|
|
568
628
|
switch (_c.label) {
|
|
@@ -570,14 +630,14 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
570
630
|
upQueries = [];
|
|
571
631
|
downQueries = [];
|
|
572
632
|
if (!(oldTableOrName instanceof Table_1.Table)) return [3 /*break*/, 1];
|
|
573
|
-
|
|
633
|
+
_a = oldTableOrName;
|
|
574
634
|
return [3 /*break*/, 3];
|
|
575
635
|
case 1: return [4 /*yield*/, this.getCachedTable(oldTableOrName)];
|
|
576
636
|
case 2:
|
|
577
|
-
|
|
637
|
+
_a = _c.sent();
|
|
578
638
|
_c.label = 3;
|
|
579
639
|
case 3:
|
|
580
|
-
oldTable =
|
|
640
|
+
oldTable = _a;
|
|
581
641
|
newTable = oldTable.clone();
|
|
582
642
|
oldTableName = oldTable.name.indexOf(".") === -1 ? oldTable.name : oldTable.name.split(".")[1];
|
|
583
643
|
schemaName = oldTable.name.indexOf(".") === -1 ? undefined : oldTable.name.split(".")[0];
|
|
@@ -650,7 +710,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
650
710
|
return [3 /*break*/, 11];
|
|
651
711
|
case 10:
|
|
652
712
|
try {
|
|
653
|
-
if (enumColumns_1_1 && !enumColumns_1_1.done && (
|
|
713
|
+
if (enumColumns_1_1 && !enumColumns_1_1.done && (_b = enumColumns_1.return)) _b.call(enumColumns_1);
|
|
654
714
|
}
|
|
655
715
|
finally { if (e_1) throw e_1.error; }
|
|
656
716
|
return [7 /*endfinally*/];
|
|
@@ -726,6 +786,11 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
726
786
|
upQueries.push(new Query_1.Query("ALTER TABLE " + this.escapePath(table) + " ADD CONSTRAINT \"" + uniqueConstraint.name + "\" UNIQUE (\"" + column.name + "\")"));
|
|
727
787
|
downQueries.push(new Query_1.Query("ALTER TABLE " + this.escapePath(table) + " DROP CONSTRAINT \"" + uniqueConstraint.name + "\""));
|
|
728
788
|
}
|
|
789
|
+
// create column's comment
|
|
790
|
+
if (column.comment) {
|
|
791
|
+
upQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + column.name + "\" IS " + this.escapeComment(column.comment)));
|
|
792
|
+
downQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + column.name + "\" IS " + this.escapeComment(column.comment)));
|
|
793
|
+
}
|
|
729
794
|
return [4 /*yield*/, this.executeQueries(upQueries, downQueries)];
|
|
730
795
|
case 6:
|
|
731
796
|
_b.sent();
|
|
@@ -741,13 +806,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
741
806
|
*/
|
|
742
807
|
PostgresQueryRunner.prototype.addColumns = function (tableOrName, columns) {
|
|
743
808
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
744
|
-
var
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
809
|
+
var columns_1, columns_1_1, column, e_2_1;
|
|
810
|
+
var e_2, _a;
|
|
811
|
+
return tslib_1.__generator(this, function (_b) {
|
|
812
|
+
switch (_b.label) {
|
|
813
|
+
case 0:
|
|
814
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
815
|
+
columns_1 = tslib_1.__values(columns), columns_1_1 = columns_1.next();
|
|
816
|
+
_b.label = 1;
|
|
748
817
|
case 1:
|
|
749
|
-
|
|
750
|
-
|
|
818
|
+
if (!!columns_1_1.done) return [3 /*break*/, 4];
|
|
819
|
+
column = columns_1_1.value;
|
|
820
|
+
return [4 /*yield*/, this.addColumn(tableOrName, column)];
|
|
821
|
+
case 2:
|
|
822
|
+
_b.sent();
|
|
823
|
+
_b.label = 3;
|
|
824
|
+
case 3:
|
|
825
|
+
columns_1_1 = columns_1.next();
|
|
826
|
+
return [3 /*break*/, 1];
|
|
827
|
+
case 4: return [3 /*break*/, 7];
|
|
828
|
+
case 5:
|
|
829
|
+
e_2_1 = _b.sent();
|
|
830
|
+
e_2 = { error: e_2_1 };
|
|
831
|
+
return [3 /*break*/, 7];
|
|
832
|
+
case 6:
|
|
833
|
+
try {
|
|
834
|
+
if (columns_1_1 && !columns_1_1.done && (_a = columns_1.return)) _a.call(columns_1);
|
|
835
|
+
}
|
|
836
|
+
finally { if (e_2) throw e_2.error; }
|
|
837
|
+
return [7 /*endfinally*/];
|
|
838
|
+
case 7: return [2 /*return*/];
|
|
751
839
|
}
|
|
752
840
|
});
|
|
753
841
|
});
|
|
@@ -954,8 +1042,8 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
954
1042
|
}
|
|
955
1043
|
}
|
|
956
1044
|
if (oldColumn.comment !== newColumn.comment) {
|
|
957
|
-
upQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + oldColumn.name + "\" IS
|
|
958
|
-
downQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + newColumn.name + "\" IS
|
|
1045
|
+
upQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + oldColumn.name + "\" IS " + this.escapeComment(newColumn.comment)));
|
|
1046
|
+
downQueries.push(new Query_1.Query("COMMENT ON COLUMN " + this.escapePath(table) + ".\"" + newColumn.name + "\" IS " + this.escapeComment(oldColumn.comment)));
|
|
959
1047
|
}
|
|
960
1048
|
if (newColumn.isPrimary !== oldColumn.isPrimary) {
|
|
961
1049
|
primaryColumns = clonedTable.primaryColumns;
|
|
@@ -1056,13 +1144,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1056
1144
|
*/
|
|
1057
1145
|
PostgresQueryRunner.prototype.changeColumns = function (tableOrName, changedColumns) {
|
|
1058
1146
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1059
|
-
var
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1147
|
+
var changedColumns_1, changedColumns_1_1, _a, oldColumn, newColumn, e_3_1;
|
|
1148
|
+
var e_3, _b;
|
|
1149
|
+
return tslib_1.__generator(this, function (_c) {
|
|
1150
|
+
switch (_c.label) {
|
|
1151
|
+
case 0:
|
|
1152
|
+
_c.trys.push([0, 5, 6, 7]);
|
|
1153
|
+
changedColumns_1 = tslib_1.__values(changedColumns), changedColumns_1_1 = changedColumns_1.next();
|
|
1154
|
+
_c.label = 1;
|
|
1063
1155
|
case 1:
|
|
1064
|
-
|
|
1065
|
-
|
|
1156
|
+
if (!!changedColumns_1_1.done) return [3 /*break*/, 4];
|
|
1157
|
+
_a = changedColumns_1_1.value, oldColumn = _a.oldColumn, newColumn = _a.newColumn;
|
|
1158
|
+
return [4 /*yield*/, this.changeColumn(tableOrName, oldColumn, newColumn)];
|
|
1159
|
+
case 2:
|
|
1160
|
+
_c.sent();
|
|
1161
|
+
_c.label = 3;
|
|
1162
|
+
case 3:
|
|
1163
|
+
changedColumns_1_1 = changedColumns_1.next();
|
|
1164
|
+
return [3 /*break*/, 1];
|
|
1165
|
+
case 4: return [3 /*break*/, 7];
|
|
1166
|
+
case 5:
|
|
1167
|
+
e_3_1 = _c.sent();
|
|
1168
|
+
e_3 = { error: e_3_1 };
|
|
1169
|
+
return [3 /*break*/, 7];
|
|
1170
|
+
case 6:
|
|
1171
|
+
try {
|
|
1172
|
+
if (changedColumns_1_1 && !changedColumns_1_1.done && (_b = changedColumns_1.return)) _b.call(changedColumns_1);
|
|
1173
|
+
}
|
|
1174
|
+
finally { if (e_3) throw e_3.error; }
|
|
1175
|
+
return [7 /*endfinally*/];
|
|
1176
|
+
case 7: return [2 /*return*/];
|
|
1066
1177
|
}
|
|
1067
1178
|
});
|
|
1068
1179
|
});
|
|
@@ -1154,13 +1265,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1154
1265
|
*/
|
|
1155
1266
|
PostgresQueryRunner.prototype.dropColumns = function (tableOrName, columns) {
|
|
1156
1267
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1157
|
-
var
|
|
1158
|
-
|
|
1159
|
-
|
|
1160
|
-
|
|
1268
|
+
var columns_2, columns_2_1, column, e_4_1;
|
|
1269
|
+
var e_4, _a;
|
|
1270
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1271
|
+
switch (_b.label) {
|
|
1272
|
+
case 0:
|
|
1273
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1274
|
+
columns_2 = tslib_1.__values(columns), columns_2_1 = columns_2.next();
|
|
1275
|
+
_b.label = 1;
|
|
1161
1276
|
case 1:
|
|
1162
|
-
|
|
1163
|
-
|
|
1277
|
+
if (!!columns_2_1.done) return [3 /*break*/, 4];
|
|
1278
|
+
column = columns_2_1.value;
|
|
1279
|
+
return [4 /*yield*/, this.dropColumn(tableOrName, column)];
|
|
1280
|
+
case 2:
|
|
1281
|
+
_b.sent();
|
|
1282
|
+
_b.label = 3;
|
|
1283
|
+
case 3:
|
|
1284
|
+
columns_2_1 = columns_2.next();
|
|
1285
|
+
return [3 /*break*/, 1];
|
|
1286
|
+
case 4: return [3 /*break*/, 7];
|
|
1287
|
+
case 5:
|
|
1288
|
+
e_4_1 = _b.sent();
|
|
1289
|
+
e_4 = { error: e_4_1 };
|
|
1290
|
+
return [3 /*break*/, 7];
|
|
1291
|
+
case 6:
|
|
1292
|
+
try {
|
|
1293
|
+
if (columns_2_1 && !columns_2_1.done && (_a = columns_2.return)) _a.call(columns_2);
|
|
1294
|
+
}
|
|
1295
|
+
finally { if (e_4) throw e_4.error; }
|
|
1296
|
+
return [7 /*endfinally*/];
|
|
1297
|
+
case 7: return [2 /*return*/];
|
|
1164
1298
|
}
|
|
1165
1299
|
});
|
|
1166
1300
|
});
|
|
@@ -1314,13 +1448,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1314
1448
|
*/
|
|
1315
1449
|
PostgresQueryRunner.prototype.createUniqueConstraints = function (tableOrName, uniqueConstraints) {
|
|
1316
1450
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1317
|
-
var
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1451
|
+
var uniqueConstraints_1, uniqueConstraints_1_1, uniqueConstraint, e_5_1;
|
|
1452
|
+
var e_5, _a;
|
|
1453
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1454
|
+
switch (_b.label) {
|
|
1455
|
+
case 0:
|
|
1456
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1457
|
+
uniqueConstraints_1 = tslib_1.__values(uniqueConstraints), uniqueConstraints_1_1 = uniqueConstraints_1.next();
|
|
1458
|
+
_b.label = 1;
|
|
1321
1459
|
case 1:
|
|
1322
|
-
|
|
1323
|
-
|
|
1460
|
+
if (!!uniqueConstraints_1_1.done) return [3 /*break*/, 4];
|
|
1461
|
+
uniqueConstraint = uniqueConstraints_1_1.value;
|
|
1462
|
+
return [4 /*yield*/, this.createUniqueConstraint(tableOrName, uniqueConstraint)];
|
|
1463
|
+
case 2:
|
|
1464
|
+
_b.sent();
|
|
1465
|
+
_b.label = 3;
|
|
1466
|
+
case 3:
|
|
1467
|
+
uniqueConstraints_1_1 = uniqueConstraints_1.next();
|
|
1468
|
+
return [3 /*break*/, 1];
|
|
1469
|
+
case 4: return [3 /*break*/, 7];
|
|
1470
|
+
case 5:
|
|
1471
|
+
e_5_1 = _b.sent();
|
|
1472
|
+
e_5 = { error: e_5_1 };
|
|
1473
|
+
return [3 /*break*/, 7];
|
|
1474
|
+
case 6:
|
|
1475
|
+
try {
|
|
1476
|
+
if (uniqueConstraints_1_1 && !uniqueConstraints_1_1.done && (_a = uniqueConstraints_1.return)) _a.call(uniqueConstraints_1);
|
|
1477
|
+
}
|
|
1478
|
+
finally { if (e_5) throw e_5.error; }
|
|
1479
|
+
return [7 /*endfinally*/];
|
|
1480
|
+
case 7: return [2 /*return*/];
|
|
1324
1481
|
}
|
|
1325
1482
|
});
|
|
1326
1483
|
});
|
|
@@ -1362,13 +1519,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1362
1519
|
*/
|
|
1363
1520
|
PostgresQueryRunner.prototype.dropUniqueConstraints = function (tableOrName, uniqueConstraints) {
|
|
1364
1521
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1365
|
-
var
|
|
1366
|
-
|
|
1367
|
-
|
|
1368
|
-
|
|
1522
|
+
var uniqueConstraints_2, uniqueConstraints_2_1, uniqueConstraint, e_6_1;
|
|
1523
|
+
var e_6, _a;
|
|
1524
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1525
|
+
switch (_b.label) {
|
|
1526
|
+
case 0:
|
|
1527
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1528
|
+
uniqueConstraints_2 = tslib_1.__values(uniqueConstraints), uniqueConstraints_2_1 = uniqueConstraints_2.next();
|
|
1529
|
+
_b.label = 1;
|
|
1369
1530
|
case 1:
|
|
1370
|
-
|
|
1371
|
-
|
|
1531
|
+
if (!!uniqueConstraints_2_1.done) return [3 /*break*/, 4];
|
|
1532
|
+
uniqueConstraint = uniqueConstraints_2_1.value;
|
|
1533
|
+
return [4 /*yield*/, this.dropUniqueConstraint(tableOrName, uniqueConstraint)];
|
|
1534
|
+
case 2:
|
|
1535
|
+
_b.sent();
|
|
1536
|
+
_b.label = 3;
|
|
1537
|
+
case 3:
|
|
1538
|
+
uniqueConstraints_2_1 = uniqueConstraints_2.next();
|
|
1539
|
+
return [3 /*break*/, 1];
|
|
1540
|
+
case 4: return [3 /*break*/, 7];
|
|
1541
|
+
case 5:
|
|
1542
|
+
e_6_1 = _b.sent();
|
|
1543
|
+
e_6 = { error: e_6_1 };
|
|
1544
|
+
return [3 /*break*/, 7];
|
|
1545
|
+
case 6:
|
|
1546
|
+
try {
|
|
1547
|
+
if (uniqueConstraints_2_1 && !uniqueConstraints_2_1.done && (_a = uniqueConstraints_2.return)) _a.call(uniqueConstraints_2);
|
|
1548
|
+
}
|
|
1549
|
+
finally { if (e_6) throw e_6.error; }
|
|
1550
|
+
return [7 /*endfinally*/];
|
|
1551
|
+
case 7: return [2 /*return*/];
|
|
1372
1552
|
}
|
|
1373
1553
|
});
|
|
1374
1554
|
});
|
|
@@ -1614,13 +1794,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1614
1794
|
*/
|
|
1615
1795
|
PostgresQueryRunner.prototype.createForeignKeys = function (tableOrName, foreignKeys) {
|
|
1616
1796
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1617
|
-
var
|
|
1618
|
-
|
|
1619
|
-
|
|
1620
|
-
|
|
1797
|
+
var foreignKeys_1, foreignKeys_1_1, foreignKey, e_7_1;
|
|
1798
|
+
var e_7, _a;
|
|
1799
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1800
|
+
switch (_b.label) {
|
|
1801
|
+
case 0:
|
|
1802
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1803
|
+
foreignKeys_1 = tslib_1.__values(foreignKeys), foreignKeys_1_1 = foreignKeys_1.next();
|
|
1804
|
+
_b.label = 1;
|
|
1621
1805
|
case 1:
|
|
1622
|
-
|
|
1623
|
-
|
|
1806
|
+
if (!!foreignKeys_1_1.done) return [3 /*break*/, 4];
|
|
1807
|
+
foreignKey = foreignKeys_1_1.value;
|
|
1808
|
+
return [4 /*yield*/, this.createForeignKey(tableOrName, foreignKey)];
|
|
1809
|
+
case 2:
|
|
1810
|
+
_b.sent();
|
|
1811
|
+
_b.label = 3;
|
|
1812
|
+
case 3:
|
|
1813
|
+
foreignKeys_1_1 = foreignKeys_1.next();
|
|
1814
|
+
return [3 /*break*/, 1];
|
|
1815
|
+
case 4: return [3 /*break*/, 7];
|
|
1816
|
+
case 5:
|
|
1817
|
+
e_7_1 = _b.sent();
|
|
1818
|
+
e_7 = { error: e_7_1 };
|
|
1819
|
+
return [3 /*break*/, 7];
|
|
1820
|
+
case 6:
|
|
1821
|
+
try {
|
|
1822
|
+
if (foreignKeys_1_1 && !foreignKeys_1_1.done && (_a = foreignKeys_1.return)) _a.call(foreignKeys_1);
|
|
1823
|
+
}
|
|
1824
|
+
finally { if (e_7) throw e_7.error; }
|
|
1825
|
+
return [7 /*endfinally*/];
|
|
1826
|
+
case 7: return [2 /*return*/];
|
|
1624
1827
|
}
|
|
1625
1828
|
});
|
|
1626
1829
|
});
|
|
@@ -1662,13 +1865,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1662
1865
|
*/
|
|
1663
1866
|
PostgresQueryRunner.prototype.dropForeignKeys = function (tableOrName, foreignKeys) {
|
|
1664
1867
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1665
|
-
var
|
|
1666
|
-
|
|
1667
|
-
|
|
1668
|
-
|
|
1868
|
+
var foreignKeys_2, foreignKeys_2_1, foreignKey, e_8_1;
|
|
1869
|
+
var e_8, _a;
|
|
1870
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1871
|
+
switch (_b.label) {
|
|
1872
|
+
case 0:
|
|
1873
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1874
|
+
foreignKeys_2 = tslib_1.__values(foreignKeys), foreignKeys_2_1 = foreignKeys_2.next();
|
|
1875
|
+
_b.label = 1;
|
|
1669
1876
|
case 1:
|
|
1670
|
-
|
|
1671
|
-
|
|
1877
|
+
if (!!foreignKeys_2_1.done) return [3 /*break*/, 4];
|
|
1878
|
+
foreignKey = foreignKeys_2_1.value;
|
|
1879
|
+
return [4 /*yield*/, this.dropForeignKey(tableOrName, foreignKey)];
|
|
1880
|
+
case 2:
|
|
1881
|
+
_b.sent();
|
|
1882
|
+
_b.label = 3;
|
|
1883
|
+
case 3:
|
|
1884
|
+
foreignKeys_2_1 = foreignKeys_2.next();
|
|
1885
|
+
return [3 /*break*/, 1];
|
|
1886
|
+
case 4: return [3 /*break*/, 7];
|
|
1887
|
+
case 5:
|
|
1888
|
+
e_8_1 = _b.sent();
|
|
1889
|
+
e_8 = { error: e_8_1 };
|
|
1890
|
+
return [3 /*break*/, 7];
|
|
1891
|
+
case 6:
|
|
1892
|
+
try {
|
|
1893
|
+
if (foreignKeys_2_1 && !foreignKeys_2_1.done && (_a = foreignKeys_2.return)) _a.call(foreignKeys_2);
|
|
1894
|
+
}
|
|
1895
|
+
finally { if (e_8) throw e_8.error; }
|
|
1896
|
+
return [7 /*endfinally*/];
|
|
1897
|
+
case 7: return [2 /*return*/];
|
|
1672
1898
|
}
|
|
1673
1899
|
});
|
|
1674
1900
|
});
|
|
@@ -1710,13 +1936,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1710
1936
|
*/
|
|
1711
1937
|
PostgresQueryRunner.prototype.createIndices = function (tableOrName, indices) {
|
|
1712
1938
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1713
|
-
var
|
|
1714
|
-
|
|
1715
|
-
|
|
1716
|
-
|
|
1939
|
+
var indices_1, indices_1_1, index, e_9_1;
|
|
1940
|
+
var e_9, _a;
|
|
1941
|
+
return tslib_1.__generator(this, function (_b) {
|
|
1942
|
+
switch (_b.label) {
|
|
1943
|
+
case 0:
|
|
1944
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
1945
|
+
indices_1 = tslib_1.__values(indices), indices_1_1 = indices_1.next();
|
|
1946
|
+
_b.label = 1;
|
|
1717
1947
|
case 1:
|
|
1718
|
-
|
|
1719
|
-
|
|
1948
|
+
if (!!indices_1_1.done) return [3 /*break*/, 4];
|
|
1949
|
+
index = indices_1_1.value;
|
|
1950
|
+
return [4 /*yield*/, this.createIndex(tableOrName, index)];
|
|
1951
|
+
case 2:
|
|
1952
|
+
_b.sent();
|
|
1953
|
+
_b.label = 3;
|
|
1954
|
+
case 3:
|
|
1955
|
+
indices_1_1 = indices_1.next();
|
|
1956
|
+
return [3 /*break*/, 1];
|
|
1957
|
+
case 4: return [3 /*break*/, 7];
|
|
1958
|
+
case 5:
|
|
1959
|
+
e_9_1 = _b.sent();
|
|
1960
|
+
e_9 = { error: e_9_1 };
|
|
1961
|
+
return [3 /*break*/, 7];
|
|
1962
|
+
case 6:
|
|
1963
|
+
try {
|
|
1964
|
+
if (indices_1_1 && !indices_1_1.done && (_a = indices_1.return)) _a.call(indices_1);
|
|
1965
|
+
}
|
|
1966
|
+
finally { if (e_9) throw e_9.error; }
|
|
1967
|
+
return [7 /*endfinally*/];
|
|
1968
|
+
case 7: return [2 /*return*/];
|
|
1720
1969
|
}
|
|
1721
1970
|
});
|
|
1722
1971
|
});
|
|
@@ -1758,13 +2007,36 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1758
2007
|
*/
|
|
1759
2008
|
PostgresQueryRunner.prototype.dropIndices = function (tableOrName, indices) {
|
|
1760
2009
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1761
|
-
var
|
|
1762
|
-
|
|
1763
|
-
|
|
1764
|
-
|
|
2010
|
+
var indices_2, indices_2_1, index, e_10_1;
|
|
2011
|
+
var e_10, _a;
|
|
2012
|
+
return tslib_1.__generator(this, function (_b) {
|
|
2013
|
+
switch (_b.label) {
|
|
2014
|
+
case 0:
|
|
2015
|
+
_b.trys.push([0, 5, 6, 7]);
|
|
2016
|
+
indices_2 = tslib_1.__values(indices), indices_2_1 = indices_2.next();
|
|
2017
|
+
_b.label = 1;
|
|
1765
2018
|
case 1:
|
|
1766
|
-
|
|
1767
|
-
|
|
2019
|
+
if (!!indices_2_1.done) return [3 /*break*/, 4];
|
|
2020
|
+
index = indices_2_1.value;
|
|
2021
|
+
return [4 /*yield*/, this.dropIndex(tableOrName, index)];
|
|
2022
|
+
case 2:
|
|
2023
|
+
_b.sent();
|
|
2024
|
+
_b.label = 3;
|
|
2025
|
+
case 3:
|
|
2026
|
+
indices_2_1 = indices_2.next();
|
|
2027
|
+
return [3 /*break*/, 1];
|
|
2028
|
+
case 4: return [3 /*break*/, 7];
|
|
2029
|
+
case 5:
|
|
2030
|
+
e_10_1 = _b.sent();
|
|
2031
|
+
e_10 = { error: e_10_1 };
|
|
2032
|
+
return [3 /*break*/, 7];
|
|
2033
|
+
case 6:
|
|
2034
|
+
try {
|
|
2035
|
+
if (indices_2_1 && !indices_2_1.done && (_a = indices_2.return)) _a.call(indices_2);
|
|
2036
|
+
}
|
|
2037
|
+
finally { if (e_10) throw e_10.error; }
|
|
2038
|
+
return [7 /*endfinally*/];
|
|
2039
|
+
case 7: return [2 /*return*/];
|
|
1768
2040
|
}
|
|
1769
2041
|
});
|
|
1770
2042
|
});
|
|
@@ -1900,7 +2172,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1900
2172
|
*/
|
|
1901
2173
|
PostgresQueryRunner.prototype.loadTables = function (tableNames) {
|
|
1902
2174
|
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
1903
|
-
var currentSchemaQuery, currentSchema, tablesCondition, tablesSql, columnsSql, constraintsCondition, constraintsSql, indicesSql, foreignKeysCondition, foreignKeysSql, _a, dbTables, dbColumns, dbConstraints, dbIndices, dbForeignKeys;
|
|
2175
|
+
var currentSchemaQuery, currentSchema, tablesCondition, tablesSql, columnsSql, constraintsCondition, constraintsSql, indicesSql, foreignKeysCondition, hasRelispartitionColumn, isPartitionCondition, foreignKeysSql, _a, dbTables, dbColumns, dbConstraints, dbIndices, dbForeignKeys;
|
|
1904
2176
|
var _this = this;
|
|
1905
2177
|
return tslib_1.__generator(this, function (_b) {
|
|
1906
2178
|
switch (_b.label) {
|
|
@@ -1921,7 +2193,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1921
2193
|
return "(\"table_schema\" = '" + schema + "' AND \"table_name\" = '" + name + "')";
|
|
1922
2194
|
}).join(" OR ");
|
|
1923
2195
|
tablesSql = "SELECT * FROM \"information_schema\".\"tables\" WHERE " + tablesCondition;
|
|
1924
|
-
columnsSql = "SELECT
|
|
2196
|
+
columnsSql = "\n SELECT\n *,\n pg_catalog.col_description(('\"' || table_catalog || '\".\"' || table_schema || '\".\"' || table_name || '\"')::regclass::oid, ordinal_position) as description,\n ('\"' || \"udt_schema\" || '\".\"' || \"udt_name\" || '\"')::\"regtype\" AS \"regtype\"\n FROM \"information_schema\".\"columns\"\n WHERE\n " + tablesCondition;
|
|
1925
2197
|
constraintsCondition = tableNames.map(function (tableName) {
|
|
1926
2198
|
var _a = tslib_1.__read(tableName.split("."), 2), schema = _a[0], name = _a[1];
|
|
1927
2199
|
if (!name) {
|
|
@@ -1937,7 +2209,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1937
2209
|
"INNER JOIN \"pg_class\" \"t\" ON \"t\".\"oid\" = \"cnst\".\"conrelid\" " +
|
|
1938
2210
|
"INNER JOIN \"pg_namespace\" \"ns\" ON \"ns\".\"oid\" = \"cnst\".\"connamespace\" " +
|
|
1939
2211
|
"LEFT JOIN \"pg_attribute\" \"a\" ON \"a\".\"attrelid\" = \"cnst\".\"conrelid\" AND \"a\".\"attnum\" = ANY (\"cnst\".\"conkey\") " +
|
|
1940
|
-
("WHERE \"t\".\"relkind\"
|
|
2212
|
+
("WHERE \"t\".\"relkind\" IN ('r', 'p') AND (" + constraintsCondition + ")");
|
|
1941
2213
|
indicesSql = "SELECT \"ns\".\"nspname\" AS \"table_schema\", \"t\".\"relname\" AS \"table_name\", \"i\".\"relname\" AS \"constraint_name\", \"a\".\"attname\" AS \"column_name\", " +
|
|
1942
2214
|
"CASE \"ix\".\"indisunique\" WHEN 't' THEN 'TRUE' ELSE'FALSE' END AS \"is_unique\", pg_get_expr(\"ix\".\"indpred\", \"ix\".\"indrelid\") AS \"condition\", " +
|
|
1943
2215
|
"\"types\".\"typname\" AS \"type_name\" " +
|
|
@@ -1948,7 +2220,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1948
2220
|
"INNER JOIN \"pg_class\" \"i\" ON \"i\".\"oid\" = \"ix\".\"indexrelid\" " +
|
|
1949
2221
|
"INNER JOIN \"pg_type\" \"types\" ON \"types\".\"oid\" = \"a\".\"atttypid\" " +
|
|
1950
2222
|
"LEFT JOIN \"pg_constraint\" \"cnst\" ON \"cnst\".\"conname\" = \"i\".\"relname\" " +
|
|
1951
|
-
("WHERE \"t\".\"relkind\"
|
|
2223
|
+
("WHERE \"t\".\"relkind\" IN ('r', 'p') AND \"cnst\".\"contype\" IS NULL AND (" + constraintsCondition + ")");
|
|
1952
2224
|
foreignKeysCondition = tableNames.map(function (tableName) {
|
|
1953
2225
|
var _a = tslib_1.__read(tableName.split("."), 2), schema = _a[0], name = _a[1];
|
|
1954
2226
|
if (!name) {
|
|
@@ -1957,6 +2229,10 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1957
2229
|
}
|
|
1958
2230
|
return "(\"ns\".\"nspname\" = '" + schema + "' AND \"cl\".\"relname\" = '" + name + "')";
|
|
1959
2231
|
}).join(" OR ");
|
|
2232
|
+
return [4 /*yield*/, this.hasSupportForPartitionedTables()];
|
|
2233
|
+
case 2:
|
|
2234
|
+
hasRelispartitionColumn = _b.sent();
|
|
2235
|
+
isPartitionCondition = hasRelispartitionColumn ? " AND \"cl\".\"relispartition\" = 'f'" : "";
|
|
1960
2236
|
foreignKeysSql = "SELECT \"con\".\"conname\" AS \"constraint_name\", \"con\".\"nspname\" AS \"table_schema\", \"con\".\"relname\" AS \"table_name\", \"att2\".\"attname\" AS \"column_name\", " +
|
|
1961
2237
|
"\"ns\".\"nspname\" AS \"referenced_table_schema\", \"cl\".\"relname\" AS \"referenced_table_name\", \"att\".\"attname\" AS \"referenced_column_name\", \"con\".\"confdeltype\" AS \"on_delete\", " +
|
|
1962
2238
|
"\"con\".\"confupdtype\" AS \"on_update\", \"con\".\"condeferrable\" AS \"deferrable\", \"con\".\"condeferred\" AS \"deferred\" " +
|
|
@@ -1972,7 +2248,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1972
2248
|
("WHERE \"con1\".\"contype\" = 'f' AND (" + foreignKeysCondition + ") ") +
|
|
1973
2249
|
") \"con\" " +
|
|
1974
2250
|
"INNER JOIN \"pg_attribute\" \"att\" ON \"att\".\"attrelid\" = \"con\".\"confrelid\" AND \"att\".\"attnum\" = \"con\".\"child\" " +
|
|
1975
|
-
"INNER JOIN \"pg_class\" \"cl\" ON \"cl\".\"oid\" = \"con\".\"confrelid\" " +
|
|
2251
|
+
("INNER JOIN \"pg_class\" \"cl\" ON \"cl\".\"oid\" = \"con\".\"confrelid\" " + isPartitionCondition) +
|
|
1976
2252
|
"INNER JOIN \"pg_namespace\" \"ns\" ON \"cl\".\"relnamespace\" = \"ns\".\"oid\" " +
|
|
1977
2253
|
"INNER JOIN \"pg_attribute\" \"att2\" ON \"att2\".\"attrelid\" = \"con\".\"conrelid\" AND \"att2\".\"attnum\" = \"con\".\"parent\"";
|
|
1978
2254
|
return [4 /*yield*/, Promise.all([
|
|
@@ -1982,7 +2258,7 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
1982
2258
|
this.query(indicesSql),
|
|
1983
2259
|
this.query(foreignKeysSql),
|
|
1984
2260
|
])];
|
|
1985
|
-
case
|
|
2261
|
+
case 3:
|
|
1986
2262
|
_a = tslib_1.__read.apply(void 0, [_b.sent(), 5]), dbTables = _a[0], dbColumns = _a[1], dbConstraints = _a[2], dbIndices = _a[3], dbForeignKeys = _a[4];
|
|
1987
2263
|
// if tables were not found in the db, no need to proceed
|
|
1988
2264
|
if (!dbTables.length)
|
|
@@ -2098,9 +2374,10 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
2098
2374
|
}
|
|
2099
2375
|
else {
|
|
2100
2376
|
tableColumn.default = dbColumn["column_default"].replace(/::.*/, "");
|
|
2377
|
+
tableColumn.default = tableColumn.default.replace(/^(-?\d+)$/, "'$1'");
|
|
2101
2378
|
}
|
|
2102
2379
|
}
|
|
2103
|
-
tableColumn.comment = ""
|
|
2380
|
+
tableColumn.comment = dbColumn["description"] == null ? undefined : dbColumn["description"];
|
|
2104
2381
|
if (dbColumn["character_set_name"])
|
|
2105
2382
|
tableColumn.charset = dbColumn["character_set_name"];
|
|
2106
2383
|
if (dbColumn["collation_name"])
|
|
@@ -2253,6 +2530,9 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
2253
2530
|
sql += ", CONSTRAINT \"" + primaryKeyName + "\" PRIMARY KEY (" + columnNames + ")";
|
|
2254
2531
|
}
|
|
2255
2532
|
sql += ")";
|
|
2533
|
+
table.columns
|
|
2534
|
+
.filter(function (it) { return it.comment; })
|
|
2535
|
+
.forEach(function (it) { return sql += "; COMMENT ON COLUMN " + _this.escapePath(table) + ".\"" + it.name + "\" IS " + _this.escapeComment(it.comment); });
|
|
2256
2536
|
return new Query_1.Query(sql);
|
|
2257
2537
|
};
|
|
2258
2538
|
/**
|
|
@@ -2572,6 +2852,18 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
2572
2852
|
});
|
|
2573
2853
|
});
|
|
2574
2854
|
};
|
|
2855
|
+
/**
|
|
2856
|
+
* Escapes a given comment so it's safe to include in a query.
|
|
2857
|
+
*/
|
|
2858
|
+
PostgresQueryRunner.prototype.escapeComment = function (comment) {
|
|
2859
|
+
if (comment === undefined || comment.length === 0) {
|
|
2860
|
+
return 'NULL';
|
|
2861
|
+
}
|
|
2862
|
+
comment = comment
|
|
2863
|
+
.replace("'", "''")
|
|
2864
|
+
.replace("\0", ""); // Null bytes aren't allowed in comments
|
|
2865
|
+
return "'" + comment + "'";
|
|
2866
|
+
};
|
|
2575
2867
|
/**
|
|
2576
2868
|
* Escapes given table or view path.
|
|
2577
2869
|
*/
|
|
@@ -2633,6 +2925,22 @@ var PostgresQueryRunner = /** @class */ (function (_super) {
|
|
|
2633
2925
|
c += " DEFAULT " + this.driver.uuidGenerator;
|
|
2634
2926
|
return c;
|
|
2635
2927
|
};
|
|
2928
|
+
/**
|
|
2929
|
+
* Checks if the PostgreSQL server has support for partitioned tables
|
|
2930
|
+
*/
|
|
2931
|
+
PostgresQueryRunner.prototype.hasSupportForPartitionedTables = function () {
|
|
2932
|
+
return tslib_1.__awaiter(this, void 0, void 0, function () {
|
|
2933
|
+
var result;
|
|
2934
|
+
return tslib_1.__generator(this, function (_a) {
|
|
2935
|
+
switch (_a.label) {
|
|
2936
|
+
case 0: return [4 /*yield*/, this.query("SELECT TRUE FROM information_schema.columns WHERE table_name = 'pg_class' and column_name = 'relispartition'")];
|
|
2937
|
+
case 1:
|
|
2938
|
+
result = _a.sent();
|
|
2939
|
+
return [2 /*return*/, result.length ? true : false];
|
|
2940
|
+
}
|
|
2941
|
+
});
|
|
2942
|
+
});
|
|
2943
|
+
};
|
|
2636
2944
|
return PostgresQueryRunner;
|
|
2637
2945
|
}(BaseQueryRunner_1.BaseQueryRunner));
|
|
2638
2946
|
exports.PostgresQueryRunner = PostgresQueryRunner;
|