@stingerloom/orm 0.1.0
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/LICENSE +21 -0
- package/README.md +53 -0
- package/dist/DatabaseClient.d.ts +23 -0
- package/dist/DatabaseClient.d.ts.map +1 -0
- package/dist/DatabaseClient.js +125 -0
- package/dist/DatabaseClient.js.map +1 -0
- package/dist/core/BaseEntityManager.d.ts +29 -0
- package/dist/core/BaseEntityManager.d.ts.map +1 -0
- package/dist/core/BaseEntityManager.js +7 -0
- package/dist/core/BaseEntityManager.js.map +1 -0
- package/dist/core/BaseInsertQueryBuilder.d.ts +8 -0
- package/dist/core/BaseInsertQueryBuilder.d.ts.map +1 -0
- package/dist/core/BaseInsertQueryBuilder.js +3 -0
- package/dist/core/BaseInsertQueryBuilder.js.map +1 -0
- package/dist/core/BaseRawQueryBuilder.d.ts +33 -0
- package/dist/core/BaseRawQueryBuilder.d.ts.map +1 -0
- package/dist/core/BaseRawQueryBuilder.js +3 -0
- package/dist/core/BaseRawQueryBuilder.js.map +1 -0
- package/dist/core/BaseRepository.d.ts +37 -0
- package/dist/core/BaseRepository.d.ts.map +1 -0
- package/dist/core/BaseRepository.js +77 -0
- package/dist/core/BaseRepository.js.map +1 -0
- package/dist/core/BaseResultTransformer.d.ts +11 -0
- package/dist/core/BaseResultTransformer.d.ts.map +1 -0
- package/dist/core/BaseResultTransformer.js +3 -0
- package/dist/core/BaseResultTransformer.js.map +1 -0
- package/dist/core/Conditions.d.ts +33 -0
- package/dist/core/Conditions.d.ts.map +1 -0
- package/dist/core/Conditions.js +154 -0
- package/dist/core/Conditions.js.map +1 -0
- package/dist/core/CursorPagination.d.ts +19 -0
- package/dist/core/CursorPagination.d.ts.map +1 -0
- package/dist/core/CursorPagination.js +27 -0
- package/dist/core/CursorPagination.js.map +1 -0
- package/dist/core/DatabaseClientOptions.d.ts +41 -0
- package/dist/core/DatabaseClientOptions.d.ts.map +1 -0
- package/dist/core/DatabaseClientOptions.js +3 -0
- package/dist/core/DatabaseClientOptions.js.map +1 -0
- package/dist/core/EntityEventEmitter.d.ts +14 -0
- package/dist/core/EntityEventEmitter.d.ts.map +1 -0
- package/dist/core/EntityEventEmitter.js +35 -0
- package/dist/core/EntityEventEmitter.js.map +1 -0
- package/dist/core/EntityManager.d.ts +115 -0
- package/dist/core/EntityManager.d.ts.map +1 -0
- package/dist/core/EntityManager.js +2347 -0
- package/dist/core/EntityManager.js.map +1 -0
- package/dist/core/EntitySubscriber.d.ts +31 -0
- package/dist/core/EntitySubscriber.d.ts.map +1 -0
- package/dist/core/EntitySubscriber.js +3 -0
- package/dist/core/EntitySubscriber.js.map +1 -0
- package/dist/core/EntityValidator.d.ts +6 -0
- package/dist/core/EntityValidator.d.ts.map +1 -0
- package/dist/core/EntityValidator.js +43 -0
- package/dist/core/EntityValidator.js.map +1 -0
- package/dist/core/ExplainResult.d.ts +9 -0
- package/dist/core/ExplainResult.d.ts.map +1 -0
- package/dist/core/ExplainResult.js +3 -0
- package/dist/core/ExplainResult.js.map +1 -0
- package/dist/core/IConnector.d.ts +18 -0
- package/dist/core/IConnector.d.ts.map +1 -0
- package/dist/core/IConnector.js +7 -0
- package/dist/core/IConnector.js.map +1 -0
- package/dist/core/LazyLoader.d.ts +6 -0
- package/dist/core/LazyLoader.d.ts.map +1 -0
- package/dist/core/LazyLoader.js +94 -0
- package/dist/core/LazyLoader.js.map +1 -0
- package/dist/core/MyClassConstructor.d.ts +4 -0
- package/dist/core/MyClassConstructor.d.ts.map +1 -0
- package/dist/core/MyClassConstructor.js +3 -0
- package/dist/core/MyClassConstructor.js.map +1 -0
- package/dist/core/QueryTracker.d.ts +37 -0
- package/dist/core/QueryTracker.d.ts.map +1 -0
- package/dist/core/QueryTracker.js +111 -0
- package/dist/core/QueryTracker.js.map +1 -0
- package/dist/core/RawQueryBuilder.d.ts +40 -0
- package/dist/core/RawQueryBuilder.d.ts.map +1 -0
- package/dist/core/RawQueryBuilder.js +211 -0
- package/dist/core/RawQueryBuilder.js.map +1 -0
- package/dist/core/RawQueryBuilderFactory.d.ts +6 -0
- package/dist/core/RawQueryBuilderFactory.d.ts.map +1 -0
- package/dist/core/RawQueryBuilderFactory.js +14 -0
- package/dist/core/RawQueryBuilderFactory.js.map +1 -0
- package/dist/core/ResultTransformer.d.ts +24 -0
- package/dist/core/ResultTransformer.d.ts.map +1 -0
- package/dist/core/ResultTransformer.js +134 -0
- package/dist/core/ResultTransformer.js.map +1 -0
- package/dist/core/ResultTransformerFactory.d.ts +5 -0
- package/dist/core/ResultTransformerFactory.d.ts.map +1 -0
- package/dist/core/ResultTransformerFactory.js +11 -0
- package/dist/core/ResultTransformerFactory.js.map +1 -0
- package/dist/core/SelectUtils.d.ts +14 -0
- package/dist/core/SelectUtils.d.ts.map +1 -0
- package/dist/core/SelectUtils.js +19 -0
- package/dist/core/SelectUtils.js.map +1 -0
- package/dist/core/deserializer/ClassTransformerDeserializer.d.ts +7 -0
- package/dist/core/deserializer/ClassTransformerDeserializer.d.ts.map +1 -0
- package/dist/core/deserializer/ClassTransformerDeserializer.js +14 -0
- package/dist/core/deserializer/ClassTransformerDeserializer.js.map +1 -0
- package/dist/core/deserializer/DeserializeEntity.d.ts +7 -0
- package/dist/core/deserializer/DeserializeEntity.d.ts.map +1 -0
- package/dist/core/deserializer/DeserializeEntity.js +17 -0
- package/dist/core/deserializer/DeserializeEntity.js.map +1 -0
- package/dist/core/deserializer/DeserializeOptions.d.ts +9 -0
- package/dist/core/deserializer/DeserializeOptions.d.ts.map +1 -0
- package/dist/core/deserializer/DeserializeOptions.js +3 -0
- package/dist/core/deserializer/DeserializeOptions.js.map +1 -0
- package/dist/core/deserializer/Deserializer.d.ts +6 -0
- package/dist/core/deserializer/Deserializer.d.ts.map +1 -0
- package/dist/core/deserializer/Deserializer.js +3 -0
- package/dist/core/deserializer/Deserializer.js.map +1 -0
- package/dist/core/deserializer/DeserializerRegistry.d.ts +13 -0
- package/dist/core/deserializer/DeserializerRegistry.d.ts.map +1 -0
- package/dist/core/deserializer/DeserializerRegistry.js +26 -0
- package/dist/core/deserializer/DeserializerRegistry.js.map +1 -0
- package/dist/core/deserializer/index.d.ts +6 -0
- package/dist/core/deserializer/index.d.ts.map +1 -0
- package/dist/core/deserializer/index.js +22 -0
- package/dist/core/deserializer/index.js.map +1 -0
- package/dist/core/generators/SchemaDiff.d.ts +34 -0
- package/dist/core/generators/SchemaDiff.d.ts.map +1 -0
- package/dist/core/generators/SchemaDiff.js +231 -0
- package/dist/core/generators/SchemaDiff.js.map +1 -0
- package/dist/core/generators/SchemaDiffMigrationGenerator.d.ts +11 -0
- package/dist/core/generators/SchemaDiffMigrationGenerator.d.ts.map +1 -0
- package/dist/core/generators/SchemaDiffMigrationGenerator.js +108 -0
- package/dist/core/generators/SchemaDiffMigrationGenerator.js.map +1 -0
- package/dist/core/generators/SchemaGenerator.d.ts +37 -0
- package/dist/core/generators/SchemaGenerator.d.ts.map +1 -0
- package/dist/core/generators/SchemaGenerator.js +379 -0
- package/dist/core/generators/SchemaGenerator.js.map +1 -0
- package/dist/core/generators/index.d.ts +4 -0
- package/dist/core/generators/index.d.ts.map +1 -0
- package/dist/core/generators/index.js +20 -0
- package/dist/core/generators/index.js.map +1 -0
- package/dist/core/index.d.ts +20 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +36 -0
- package/dist/core/index.js.map +1 -0
- package/dist/decorators/Column.d.ts +19 -0
- package/dist/decorators/Column.d.ts.map +1 -0
- package/dist/decorators/Column.js +53 -0
- package/dist/decorators/Column.js.map +1 -0
- package/dist/decorators/CustomColumn.d.ts +6 -0
- package/dist/decorators/CustomColumn.d.ts.map +1 -0
- package/dist/decorators/CustomColumn.js +13 -0
- package/dist/decorators/CustomColumn.js.map +1 -0
- package/dist/decorators/DeletedAt.d.ts +3 -0
- package/dist/decorators/DeletedAt.d.ts.map +1 -0
- package/dist/decorators/DeletedAt.js +16 -0
- package/dist/decorators/DeletedAt.js.map +1 -0
- package/dist/decorators/Entity.d.ts +16 -0
- package/dist/decorators/Entity.d.ts.map +1 -0
- package/dist/decorators/Entity.js +32 -0
- package/dist/decorators/Entity.js.map +1 -0
- package/dist/decorators/Hooks.d.ts +14 -0
- package/dist/decorators/Hooks.d.ts.map +1 -0
- package/dist/decorators/Hooks.js +36 -0
- package/dist/decorators/Hooks.js.map +1 -0
- package/dist/decorators/Indexer.d.ts +11 -0
- package/dist/decorators/Indexer.d.ts.map +1 -0
- package/dist/decorators/Indexer.js +21 -0
- package/dist/decorators/Indexer.js.map +1 -0
- package/dist/decorators/InjectEntityManager.d.ts +3 -0
- package/dist/decorators/InjectEntityManager.d.ts.map +1 -0
- package/dist/decorators/InjectEntityManager.js +13 -0
- package/dist/decorators/InjectEntityManager.js.map +1 -0
- package/dist/decorators/InjectRepository.d.ts +4 -0
- package/dist/decorators/InjectRepository.d.ts.map +1 -0
- package/dist/decorators/InjectRepository.js +22 -0
- package/dist/decorators/InjectRepository.js.map +1 -0
- package/dist/decorators/ManyToMany.d.ts +21 -0
- package/dist/decorators/ManyToMany.d.ts.map +1 -0
- package/dist/decorators/ManyToMany.js +29 -0
- package/dist/decorators/ManyToMany.js.map +1 -0
- package/dist/decorators/ManyToOne.d.ts +27 -0
- package/dist/decorators/ManyToOne.d.ts.map +1 -0
- package/dist/decorators/ManyToOne.js +35 -0
- package/dist/decorators/ManyToOne.js.map +1 -0
- package/dist/decorators/OneToMany.d.ts +17 -0
- package/dist/decorators/OneToMany.d.ts.map +1 -0
- package/dist/decorators/OneToMany.js +29 -0
- package/dist/decorators/OneToMany.js.map +1 -0
- package/dist/decorators/OneToOne.d.ts +20 -0
- package/dist/decorators/OneToOne.d.ts.map +1 -0
- package/dist/decorators/OneToOne.js +30 -0
- package/dist/decorators/OneToOne.js.map +1 -0
- package/dist/decorators/PrimaryColumn.d.ts +3 -0
- package/dist/decorators/PrimaryColumn.d.ts.map +1 -0
- package/dist/decorators/PrimaryColumn.js +14 -0
- package/dist/decorators/PrimaryColumn.js.map +1 -0
- package/dist/decorators/PrimaryGeneratedColumn.d.ts +3 -0
- package/dist/decorators/PrimaryGeneratedColumn.d.ts.map +1 -0
- package/dist/decorators/PrimaryGeneratedColumn.js +17 -0
- package/dist/decorators/PrimaryGeneratedColumn.js.map +1 -0
- package/dist/decorators/Transactional.d.ts +15 -0
- package/dist/decorators/Transactional.d.ts.map +1 -0
- package/dist/decorators/Transactional.js +76 -0
- package/dist/decorators/Transactional.js.map +1 -0
- package/dist/decorators/UniqueIndex.d.ts +7 -0
- package/dist/decorators/UniqueIndex.d.ts.map +1 -0
- package/dist/decorators/UniqueIndex.js +12 -0
- package/dist/decorators/UniqueIndex.js.map +1 -0
- package/dist/decorators/Validation.d.ts +15 -0
- package/dist/decorators/Validation.d.ts.map +1 -0
- package/dist/decorators/Validation.js +64 -0
- package/dist/decorators/Validation.js.map +1 -0
- package/dist/decorators/Version.d.ts +3 -0
- package/dist/decorators/Version.d.ts.map +1 -0
- package/dist/decorators/Version.js +17 -0
- package/dist/decorators/Version.js.map +1 -0
- package/dist/decorators/index.d.ts +19 -0
- package/dist/decorators/index.d.ts.map +1 -0
- package/dist/decorators/index.js +35 -0
- package/dist/decorators/index.js.map +1 -0
- package/dist/dialects/ConnectionLeakDetector.d.ts +19 -0
- package/dist/dialects/ConnectionLeakDetector.d.ts.map +1 -0
- package/dist/dialects/ConnectionLeakDetector.js +50 -0
- package/dist/dialects/ConnectionLeakDetector.js.map +1 -0
- package/dist/dialects/EntityNotFound.d.ts +4 -0
- package/dist/dialects/EntityNotFound.d.ts.map +1 -0
- package/dist/dialects/EntityNotFound.js +10 -0
- package/dist/dialects/EntityNotFound.js.map +1 -0
- package/dist/dialects/FindOption.d.ts +20 -0
- package/dist/dialects/FindOption.d.ts.map +1 -0
- package/dist/dialects/FindOption.js +3 -0
- package/dist/dialects/FindOption.js.map +1 -0
- package/dist/dialects/IConnection.d.ts +7 -0
- package/dist/dialects/IConnection.d.ts.map +1 -0
- package/dist/dialects/IConnection.js +3 -0
- package/dist/dialects/IConnection.js.map +1 -0
- package/dist/dialects/IDataSource.d.ts +12 -0
- package/dist/dialects/IDataSource.d.ts.map +1 -0
- package/dist/dialects/IDataSource.js +3 -0
- package/dist/dialects/IDataSource.js.map +1 -0
- package/dist/dialects/IOrderBy.d.ts +4 -0
- package/dist/dialects/IOrderBy.d.ts.map +1 -0
- package/dist/dialects/IOrderBy.js +3 -0
- package/dist/dialects/IOrderBy.js.map +1 -0
- package/dist/dialects/IQueryEngine.d.ts +15 -0
- package/dist/dialects/IQueryEngine.d.ts.map +1 -0
- package/dist/dialects/IQueryEngine.js +7 -0
- package/dist/dialects/IQueryEngine.js.map +1 -0
- package/dist/dialects/ISelectOption.d.ts +7 -0
- package/dist/dialects/ISelectOption.d.ts.map +1 -0
- package/dist/dialects/ISelectOption.js +3 -0
- package/dist/dialects/ISelectOption.js.map +1 -0
- package/dist/dialects/ITenantMigrationRunner.d.ts +16 -0
- package/dist/dialects/ITenantMigrationRunner.d.ts.map +1 -0
- package/dist/dialects/ITenantMigrationRunner.js +3 -0
- package/dist/dialects/ITenantMigrationRunner.js.map +1 -0
- package/dist/dialects/ITxEngine.d.ts +9 -0
- package/dist/dialects/ITxEngine.d.ts.map +1 -0
- package/dist/dialects/ITxEngine.js +3 -0
- package/dist/dialects/ITxEngine.js.map +1 -0
- package/dist/dialects/IsolationLevel.d.ts +2 -0
- package/dist/dialects/IsolationLevel.d.ts.map +1 -0
- package/dist/dialects/IsolationLevel.js +3 -0
- package/dist/dialects/IsolationLevel.js.map +1 -0
- package/dist/dialects/ReplicationRouter.d.ts +28 -0
- package/dist/dialects/ReplicationRouter.d.ts.map +1 -0
- package/dist/dialects/ReplicationRouter.js +64 -0
- package/dist/dialects/ReplicationRouter.js.map +1 -0
- package/dist/dialects/SqlDriver.d.ts +43 -0
- package/dist/dialects/SqlDriver.d.ts.map +1 -0
- package/dist/dialects/SqlDriver.js +3 -0
- package/dist/dialects/SqlDriver.js.map +1 -0
- package/dist/dialects/TransactionSessionManager.d.ts +21 -0
- package/dist/dialects/TransactionSessionManager.d.ts.map +1 -0
- package/dist/dialects/TransactionSessionManager.js +112 -0
- package/dist/dialects/TransactionSessionManager.js.map +1 -0
- package/dist/dialects/index.d.ts +32 -0
- package/dist/dialects/index.d.ts.map +1 -0
- package/dist/dialects/index.js +65 -0
- package/dist/dialects/index.js.map +1 -0
- package/dist/dialects/mysql/BaseSchema.d.ts +9 -0
- package/dist/dialects/mysql/BaseSchema.d.ts.map +1 -0
- package/dist/dialects/mysql/BaseSchema.js +3 -0
- package/dist/dialects/mysql/BaseSchema.js.map +1 -0
- package/dist/dialects/mysql/Connection.d.ts +9 -0
- package/dist/dialects/mysql/Connection.d.ts.map +1 -0
- package/dist/dialects/mysql/Connection.js +3 -0
- package/dist/dialects/mysql/Connection.js.map +1 -0
- package/dist/dialects/mysql/ConnectionNotFound.d.ts +4 -0
- package/dist/dialects/mysql/ConnectionNotFound.d.ts.map +1 -0
- package/dist/dialects/mysql/ConnectionNotFound.js +10 -0
- package/dist/dialects/mysql/ConnectionNotFound.js.map +1 -0
- package/dist/dialects/mysql/MySqlConnectionError.d.ts +4 -0
- package/dist/dialects/mysql/MySqlConnectionError.d.ts.map +1 -0
- package/dist/dialects/mysql/MySqlConnectionError.js +10 -0
- package/dist/dialects/mysql/MySqlConnectionError.js.map +1 -0
- package/dist/dialects/mysql/MySqlConnector.d.ts +26 -0
- package/dist/dialects/mysql/MySqlConnector.d.ts.map +1 -0
- package/dist/dialects/mysql/MySqlConnector.js +195 -0
- package/dist/dialects/mysql/MySqlConnector.js.map +1 -0
- package/dist/dialects/mysql/MySqlDataSource.d.ts +17 -0
- package/dist/dialects/mysql/MySqlDataSource.d.ts.map +1 -0
- package/dist/dialects/mysql/MySqlDataSource.js +63 -0
- package/dist/dialects/mysql/MySqlDataSource.js.map +1 -0
- package/dist/dialects/mysql/MySqlDriver.d.ts +49 -0
- package/dist/dialects/mysql/MySqlDriver.d.ts.map +1 -0
- package/dist/dialects/mysql/MySqlDriver.js +260 -0
- package/dist/dialects/mysql/MySqlDriver.js.map +1 -0
- package/dist/dialects/mysql/MySqlTenantMigrationRunner.d.ts +11 -0
- package/dist/dialects/mysql/MySqlTenantMigrationRunner.d.ts.map +1 -0
- package/dist/dialects/mysql/MySqlTenantMigrationRunner.js +31 -0
- package/dist/dialects/mysql/MySqlTenantMigrationRunner.js.map +1 -0
- package/dist/dialects/mysql/MysqlConnection.d.ts +12 -0
- package/dist/dialects/mysql/MysqlConnection.d.ts.map +1 -0
- package/dist/dialects/mysql/MysqlConnection.js +26 -0
- package/dist/dialects/mysql/MysqlConnection.js.map +1 -0
- package/dist/dialects/mysql/PoolNotFound.d.ts +4 -0
- package/dist/dialects/mysql/PoolNotFound.d.ts.map +1 -0
- package/dist/dialects/mysql/PoolNotFound.js +10 -0
- package/dist/dialects/mysql/PoolNotFound.js.map +1 -0
- package/dist/dialects/mysql/index.d.ts +10 -0
- package/dist/dialects/mysql/index.d.ts.map +1 -0
- package/dist/dialects/mysql/index.js +26 -0
- package/dist/dialects/mysql/index.js.map +1 -0
- package/dist/dialects/postgres/ConnectionNotFound.d.ts +4 -0
- package/dist/dialects/postgres/ConnectionNotFound.d.ts.map +1 -0
- package/dist/dialects/postgres/ConnectionNotFound.js +10 -0
- package/dist/dialects/postgres/ConnectionNotFound.js.map +1 -0
- package/dist/dialects/postgres/PoolNotFound.d.ts +4 -0
- package/dist/dialects/postgres/PoolNotFound.d.ts.map +1 -0
- package/dist/dialects/postgres/PoolNotFound.js +10 -0
- package/dist/dialects/postgres/PoolNotFound.js.map +1 -0
- package/dist/dialects/postgres/PostgresConnection.d.ts +12 -0
- package/dist/dialects/postgres/PostgresConnection.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresConnection.js +26 -0
- package/dist/dialects/postgres/PostgresConnection.js.map +1 -0
- package/dist/dialects/postgres/PostgresConnectionError.d.ts +4 -0
- package/dist/dialects/postgres/PostgresConnectionError.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresConnectionError.js +10 -0
- package/dist/dialects/postgres/PostgresConnectionError.js.map +1 -0
- package/dist/dialects/postgres/PostgresConnector.d.ts +24 -0
- package/dist/dialects/postgres/PostgresConnector.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresConnector.js +158 -0
- package/dist/dialects/postgres/PostgresConnector.js.map +1 -0
- package/dist/dialects/postgres/PostgresDataSource.d.ts +18 -0
- package/dist/dialects/postgres/PostgresDataSource.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresDataSource.js +66 -0
- package/dist/dialects/postgres/PostgresDataSource.js.map +1 -0
- package/dist/dialects/postgres/PostgresDriver.d.ts +71 -0
- package/dist/dialects/postgres/PostgresDriver.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresDriver.js +440 -0
- package/dist/dialects/postgres/PostgresDriver.js.map +1 -0
- package/dist/dialects/postgres/PostgresTenantMigrationRunner.d.ts +18 -0
- package/dist/dialects/postgres/PostgresTenantMigrationRunner.d.ts.map +1 -0
- package/dist/dialects/postgres/PostgresTenantMigrationRunner.js +78 -0
- package/dist/dialects/postgres/PostgresTenantMigrationRunner.js.map +1 -0
- package/dist/dialects/postgres/index.d.ts +8 -0
- package/dist/dialects/postgres/index.d.ts.map +1 -0
- package/dist/dialects/postgres/index.js +26 -0
- package/dist/dialects/postgres/index.js.map +1 -0
- package/dist/dialects/sqlite/ConnectionNotFound.d.ts +4 -0
- package/dist/dialects/sqlite/ConnectionNotFound.d.ts.map +1 -0
- package/dist/dialects/sqlite/ConnectionNotFound.js +10 -0
- package/dist/dialects/sqlite/ConnectionNotFound.js.map +1 -0
- package/dist/dialects/sqlite/SqliteConnection.d.ts +12 -0
- package/dist/dialects/sqlite/SqliteConnection.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteConnection.js +23 -0
- package/dist/dialects/sqlite/SqliteConnection.js.map +1 -0
- package/dist/dialects/sqlite/SqliteConnectionError.d.ts +4 -0
- package/dist/dialects/sqlite/SqliteConnectionError.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteConnectionError.js +10 -0
- package/dist/dialects/sqlite/SqliteConnectionError.js.map +1 -0
- package/dist/dialects/sqlite/SqliteConnector.d.ts +24 -0
- package/dist/dialects/sqlite/SqliteConnector.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteConnector.js +119 -0
- package/dist/dialects/sqlite/SqliteConnector.js.map +1 -0
- package/dist/dialects/sqlite/SqliteDataSource.d.ts +18 -0
- package/dist/dialects/sqlite/SqliteDataSource.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteDataSource.js +56 -0
- package/dist/dialects/sqlite/SqliteDataSource.js.map +1 -0
- package/dist/dialects/sqlite/SqliteDriver.d.ts +49 -0
- package/dist/dialects/sqlite/SqliteDriver.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteDriver.js +234 -0
- package/dist/dialects/sqlite/SqliteDriver.js.map +1 -0
- package/dist/dialects/sqlite/SqliteTenantMigrationRunner.d.ts +11 -0
- package/dist/dialects/sqlite/SqliteTenantMigrationRunner.d.ts.map +1 -0
- package/dist/dialects/sqlite/SqliteTenantMigrationRunner.js +31 -0
- package/dist/dialects/sqlite/SqliteTenantMigrationRunner.js.map +1 -0
- package/dist/dialects/sqlite/index.d.ts +7 -0
- package/dist/dialects/sqlite/index.d.ts.map +1 -0
- package/dist/dialects/sqlite/index.js +23 -0
- package/dist/dialects/sqlite/index.js.map +1 -0
- package/dist/errors/AdvisoryLockError.d.ts +5 -0
- package/dist/errors/AdvisoryLockError.d.ts.map +1 -0
- package/dist/errors/AdvisoryLockError.js +13 -0
- package/dist/errors/AdvisoryLockError.js.map +1 -0
- package/dist/errors/DatabaseConnectionFailedError.d.ts +5 -0
- package/dist/errors/DatabaseConnectionFailedError.d.ts.map +1 -0
- package/dist/errors/DatabaseConnectionFailedError.js +11 -0
- package/dist/errors/DatabaseConnectionFailedError.js.map +1 -0
- package/dist/errors/DatabaseNotConnectedError.d.ts +5 -0
- package/dist/errors/DatabaseNotConnectedError.d.ts.map +1 -0
- package/dist/errors/DatabaseNotConnectedError.js +11 -0
- package/dist/errors/DatabaseNotConnectedError.js.map +1 -0
- package/dist/errors/DeleteWithoutConditionsError.d.ts +5 -0
- package/dist/errors/DeleteWithoutConditionsError.d.ts.map +1 -0
- package/dist/errors/DeleteWithoutConditionsError.js +13 -0
- package/dist/errors/DeleteWithoutConditionsError.js.map +1 -0
- package/dist/errors/EntityMetadataNotFoundError.d.ts +5 -0
- package/dist/errors/EntityMetadataNotFoundError.d.ts.map +1 -0
- package/dist/errors/EntityMetadataNotFoundError.js +13 -0
- package/dist/errors/EntityMetadataNotFoundError.js.map +1 -0
- package/dist/errors/EntityNotFoundError.d.ts +5 -0
- package/dist/errors/EntityNotFoundError.d.ts.map +1 -0
- package/dist/errors/EntityNotFoundError.js +13 -0
- package/dist/errors/EntityNotFoundError.js.map +1 -0
- package/dist/errors/Exception.d.ts +5 -0
- package/dist/errors/Exception.d.ts.map +1 -0
- package/dist/errors/Exception.js +11 -0
- package/dist/errors/Exception.js.map +1 -0
- package/dist/errors/InvalidQueryError.d.ts +5 -0
- package/dist/errors/InvalidQueryError.d.ts.map +1 -0
- package/dist/errors/InvalidQueryError.js +13 -0
- package/dist/errors/InvalidQueryError.js.map +1 -0
- package/dist/errors/NotSupportedDatabaseTypeError.d.ts +5 -0
- package/dist/errors/NotSupportedDatabaseTypeError.d.ts.map +1 -0
- package/dist/errors/NotSupportedDatabaseTypeError.js +11 -0
- package/dist/errors/NotSupportedDatabaseTypeError.js.map +1 -0
- package/dist/errors/OrmError.d.ts +6 -0
- package/dist/errors/OrmError.d.ts.map +1 -0
- package/dist/errors/OrmError.js +12 -0
- package/dist/errors/OrmError.js.map +1 -0
- package/dist/errors/OrmErrorCode.d.ts +16 -0
- package/dist/errors/OrmErrorCode.d.ts.map +1 -0
- package/dist/errors/OrmErrorCode.js +20 -0
- package/dist/errors/OrmErrorCode.js.map +1 -0
- package/dist/errors/PrimaryKeyNotFoundError.d.ts +5 -0
- package/dist/errors/PrimaryKeyNotFoundError.d.ts.map +1 -0
- package/dist/errors/PrimaryKeyNotFoundError.js +13 -0
- package/dist/errors/PrimaryKeyNotFoundError.js.map +1 -0
- package/dist/errors/QueryTimeoutError.d.ts +5 -0
- package/dist/errors/QueryTimeoutError.d.ts.map +1 -0
- package/dist/errors/QueryTimeoutError.js +13 -0
- package/dist/errors/QueryTimeoutError.js.map +1 -0
- package/dist/errors/TransactionError.d.ts +5 -0
- package/dist/errors/TransactionError.d.ts.map +1 -0
- package/dist/errors/TransactionError.js +13 -0
- package/dist/errors/TransactionError.js.map +1 -0
- package/dist/errors/ValidationError.d.ts +6 -0
- package/dist/errors/ValidationError.d.ts.map +1 -0
- package/dist/errors/ValidationError.js +13 -0
- package/dist/errors/ValidationError.js.map +1 -0
- package/dist/errors/index.d.ts +16 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +32 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +34 -0
- package/dist/index.js.map +1 -0
- package/dist/metadata/LayeredMetadataScanner.d.ts +32 -0
- package/dist/metadata/LayeredMetadataScanner.d.ts.map +1 -0
- package/dist/metadata/LayeredMetadataScanner.js +119 -0
- package/dist/metadata/LayeredMetadataScanner.js.map +1 -0
- package/dist/metadata/LayeredMetadataStore.d.ts +30 -0
- package/dist/metadata/LayeredMetadataStore.d.ts.map +1 -0
- package/dist/metadata/LayeredMetadataStore.js +150 -0
- package/dist/metadata/LayeredMetadataStore.js.map +1 -0
- package/dist/metadata/MetadataContext.d.ts +11 -0
- package/dist/metadata/MetadataContext.d.ts.map +1 -0
- package/dist/metadata/MetadataContext.js +23 -0
- package/dist/metadata/MetadataContext.js.map +1 -0
- package/dist/metadata/MetadataLayer.d.ts +27 -0
- package/dist/metadata/MetadataLayer.d.ts.map +1 -0
- package/dist/metadata/MetadataLayer.js +78 -0
- package/dist/metadata/MetadataLayer.js.map +1 -0
- package/dist/metadata/MetadataPath.d.ts +24 -0
- package/dist/metadata/MetadataPath.d.ts.map +1 -0
- package/dist/metadata/MetadataPath.js +104 -0
- package/dist/metadata/MetadataPath.js.map +1 -0
- package/dist/metadata/MultiTenantMetadataManager.d.ts +27 -0
- package/dist/metadata/MultiTenantMetadataManager.d.ts.map +1 -0
- package/dist/metadata/MultiTenantMetadataManager.js +69 -0
- package/dist/metadata/MultiTenantMetadataManager.js.map +1 -0
- package/dist/metadata/index.d.ts +7 -0
- package/dist/metadata/index.d.ts.map +1 -0
- package/dist/metadata/index.js +23 -0
- package/dist/metadata/index.js.map +1 -0
- package/dist/migration/Migration.d.ts +11 -0
- package/dist/migration/Migration.d.ts.map +1 -0
- package/dist/migration/Migration.js +10 -0
- package/dist/migration/Migration.js.map +1 -0
- package/dist/migration/MigrationCli.d.ts +25 -0
- package/dist/migration/MigrationCli.d.ts.map +1 -0
- package/dist/migration/MigrationCli.js +108 -0
- package/dist/migration/MigrationCli.js.map +1 -0
- package/dist/migration/MigrationRunner.d.ts +47 -0
- package/dist/migration/MigrationRunner.d.ts.map +1 -0
- package/dist/migration/MigrationRunner.js +182 -0
- package/dist/migration/MigrationRunner.js.map +1 -0
- package/dist/migration/index.d.ts +4 -0
- package/dist/migration/index.d.ts.map +1 -0
- package/dist/migration/index.js +20 -0
- package/dist/migration/index.js.map +1 -0
- package/dist/scanner/ColumnScanner.d.ts +16 -0
- package/dist/scanner/ColumnScanner.d.ts.map +1 -0
- package/dist/scanner/ColumnScanner.js +30 -0
- package/dist/scanner/ColumnScanner.js.map +1 -0
- package/dist/scanner/EntityScanner.d.ts +14 -0
- package/dist/scanner/EntityScanner.d.ts.map +1 -0
- package/dist/scanner/EntityScanner.js +38 -0
- package/dist/scanner/EntityScanner.js.map +1 -0
- package/dist/scanner/ManyToManyScanner.d.ts +9 -0
- package/dist/scanner/ManyToManyScanner.d.ts.map +1 -0
- package/dist/scanner/ManyToManyScanner.js +39 -0
- package/dist/scanner/ManyToManyScanner.js.map +1 -0
- package/dist/scanner/ManyToOneScanner.d.ts +9 -0
- package/dist/scanner/ManyToOneScanner.d.ts.map +1 -0
- package/dist/scanner/ManyToOneScanner.js +38 -0
- package/dist/scanner/ManyToOneScanner.js.map +1 -0
- package/dist/scanner/MetadataScanner.d.ts +45 -0
- package/dist/scanner/MetadataScanner.d.ts.map +1 -0
- package/dist/scanner/MetadataScanner.js +200 -0
- package/dist/scanner/MetadataScanner.js.map +1 -0
- package/dist/scanner/OneToManyScanner.d.ts +9 -0
- package/dist/scanner/OneToManyScanner.d.ts.map +1 -0
- package/dist/scanner/OneToManyScanner.js +39 -0
- package/dist/scanner/OneToManyScanner.js.map +1 -0
- package/dist/scanner/OneToOneScanner.d.ts +9 -0
- package/dist/scanner/OneToOneScanner.d.ts.map +1 -0
- package/dist/scanner/OneToOneScanner.js +39 -0
- package/dist/scanner/OneToOneScanner.js.map +1 -0
- package/dist/scanner/index.d.ts +9 -0
- package/dist/scanner/index.d.ts.map +1 -0
- package/dist/scanner/index.js +27 -0
- package/dist/scanner/index.js.map +1 -0
- package/dist/types/CascadeType.d.ts +5 -0
- package/dist/types/CascadeType.d.ts.map +1 -0
- package/dist/types/CascadeType.js +19 -0
- package/dist/types/CascadeType.js.map +1 -0
- package/dist/types/ColumnPaths.d.ts +7 -0
- package/dist/types/ColumnPaths.d.ts.map +1 -0
- package/dist/types/ColumnPaths.js +3 -0
- package/dist/types/ColumnPaths.js.map +1 -0
- package/dist/types/DeepPartial.d.ts +4 -0
- package/dist/types/DeepPartial.d.ts.map +1 -0
- package/dist/types/DeepPartial.js +3 -0
- package/dist/types/DeepPartial.js.map +1 -0
- package/dist/types/DeleteResult.d.ts +4 -0
- package/dist/types/DeleteResult.d.ts.map +1 -0
- package/dist/types/DeleteResult.js +3 -0
- package/dist/types/DeleteResult.js.map +1 -0
- package/dist/types/EntityResult.d.ts +3 -0
- package/dist/types/EntityResult.d.ts.map +1 -0
- package/dist/types/EntityResult.js +3 -0
- package/dist/types/EntityResult.js.map +1 -0
- package/dist/types/FindCondition.d.ts +16 -0
- package/dist/types/FindCondition.d.ts.map +1 -0
- package/dist/types/FindCondition.js +3 -0
- package/dist/types/FindCondition.js.map +1 -0
- package/dist/types/OrderByOption.d.ts +5 -0
- package/dist/types/OrderByOption.d.ts.map +1 -0
- package/dist/types/OrderByOption.js +3 -0
- package/dist/types/OrderByOption.js.map +1 -0
- package/dist/types/QueryResult.d.ts +5 -0
- package/dist/types/QueryResult.d.ts.map +1 -0
- package/dist/types/QueryResult.js +3 -0
- package/dist/types/QueryResult.js.map +1 -0
- package/dist/types/SchemaOption.d.ts +3 -0
- package/dist/types/SchemaOption.d.ts.map +1 -0
- package/dist/types/SchemaOption.js +3 -0
- package/dist/types/SchemaOption.js.map +1 -0
- package/dist/types/index.d.ts +9 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +25 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/Logger.d.ts +15 -0
- package/dist/utils/Logger.d.ts.map +1 -0
- package/dist/utils/Logger.js +75 -0
- package/dist/utils/Logger.js.map +1 -0
- package/dist/utils/ReflectManager.d.ts +12 -0
- package/dist/utils/ReflectManager.d.ts.map +1 -0
- package/dist/utils/ReflectManager.js +34 -0
- package/dist/utils/ReflectManager.js.map +1 -0
- package/dist/utils/camelToSnakeCase.d.ts +2 -0
- package/dist/utils/camelToSnakeCase.d.ts.map +1 -0
- package/dist/utils/camelToSnakeCase.js +7 -0
- package/dist/utils/camelToSnakeCase.js.map +1 -0
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +22 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/scanner.d.ts +2 -0
- package/dist/utils/scanner.d.ts.map +1 -0
- package/dist/utils/scanner.js +8 -0
- package/dist/utils/scanner.js.map +1 -0
- package/dist/utils/types.d.ts +5 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +3 -0
- package/dist/utils/types.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { IConnector } from "../../core/IConnector";
|
|
2
|
+
import { MysqlSchemaInterface } from "../mysql/BaseSchema";
|
|
3
|
+
import { ColumnType } from "../../decorators";
|
|
4
|
+
import { ISqlDriver } from "../SqlDriver";
|
|
5
|
+
import { SchemaOptions } from "../../types/SchemaOption";
|
|
6
|
+
export declare class PostgresDriver implements ISqlDriver {
|
|
7
|
+
private readonly connector;
|
|
8
|
+
private readonly clientType;
|
|
9
|
+
private readonly schema;
|
|
10
|
+
constructor(connector: IConnector, clientType?: string, schema?: string);
|
|
11
|
+
getSchema(): string;
|
|
12
|
+
hasSchema(schemaName?: string): Promise<any>;
|
|
13
|
+
createSchema(schemaName?: string): Promise<any>;
|
|
14
|
+
dropSchema(schemaName: string, cascade?: boolean): Promise<any>;
|
|
15
|
+
listSchemas(): Promise<any>;
|
|
16
|
+
setSearchPath(schemaName?: string): Promise<any>;
|
|
17
|
+
listTables(schemaName?: string): Promise<any>;
|
|
18
|
+
moveTableToSchema(tableName: string, targetSchema: string): Promise<any>;
|
|
19
|
+
hasTable(name: string): Promise<any>;
|
|
20
|
+
executeRaw(sqlStr: string): Promise<any>;
|
|
21
|
+
addPrimaryKey(tableName: string, columnName: string): Promise<any>;
|
|
22
|
+
addAutoIncrement(tableName: string, columnName: string): Promise<any>;
|
|
23
|
+
dropPrimaryKey(tableName: string): Promise<any>;
|
|
24
|
+
addUniqueKey(tableName: string, columnName: string): Promise<any>;
|
|
25
|
+
dropUniqueKey(tableName: string, columnName: string): Promise<any>;
|
|
26
|
+
addColumn(tableName: string, columnName: string, columnType: string): Promise<any>;
|
|
27
|
+
dropColumn(tableName: string, columnName: string): Promise<any>;
|
|
28
|
+
addForeignKey(tableName: string, columnName: string, foreignTableName: string, foreignColumnName: string): Promise<any>;
|
|
29
|
+
generateForeignKeyName(sourceTable: string, targetTable: string, sourceColumn: string): string;
|
|
30
|
+
dropForeignKey(tableName: string, columnName: string): Promise<any>;
|
|
31
|
+
addIndex(tableName: string, columnName: string, indexName: string): Promise<any>;
|
|
32
|
+
hasIndex(tableName: string, indexName: string): Promise<any>;
|
|
33
|
+
dropIndex(tableName: string, indexName: string): Promise<any>;
|
|
34
|
+
hasEnumType(enumName: string): Promise<any>;
|
|
35
|
+
createEnumType(enumName: string, values: string[]): Promise<any>;
|
|
36
|
+
dropEnumType(enumName: string, cascade?: boolean): Promise<any>;
|
|
37
|
+
addEnumValue(enumName: string, value: string, placement?: {
|
|
38
|
+
before?: string;
|
|
39
|
+
after?: string;
|
|
40
|
+
}): Promise<any>;
|
|
41
|
+
renameEnumValue(enumName: string, oldValue: string, newValue: string): Promise<any>;
|
|
42
|
+
listEnumValues(enumName: string): Promise<{
|
|
43
|
+
enumlabel: string;
|
|
44
|
+
}[]>;
|
|
45
|
+
getSchemas(tableName: string): Promise<MysqlSchemaInterface[]>;
|
|
46
|
+
getIndexes(tableName: string): Promise<MysqlSchemaInterface[]>;
|
|
47
|
+
getForeignKeys(tableName: string): Promise<MysqlSchemaInterface[]>;
|
|
48
|
+
getPrimaryKeys(tableName: string): Promise<MysqlSchemaInterface[]>;
|
|
49
|
+
createTable(tableName: string, columns: SchemaOptions[]): Promise<any>;
|
|
50
|
+
wrap(name: string): string;
|
|
51
|
+
wrapQualified(name: string): string;
|
|
52
|
+
getColumnType(type: any): string;
|
|
53
|
+
castType(type: ColumnType): string;
|
|
54
|
+
isMySqlFamily(): boolean;
|
|
55
|
+
setQueryTimeout(ms: number): string;
|
|
56
|
+
supportsExplain(): boolean;
|
|
57
|
+
buildExplainSql(selectSql: string): string;
|
|
58
|
+
buildUpsertSql(tableName: string, columns: string[], conflictColumns: string[], updateColumns: string[]): string;
|
|
59
|
+
hasColumn(tableName: string, columnName: string): Promise<boolean>;
|
|
60
|
+
hasForeignKey(tableName: string, constraintName: string): Promise<boolean>;
|
|
61
|
+
addCompositeUniqueIndex(tableName: string, columns: string[], indexName: string): Promise<any>;
|
|
62
|
+
acquireAdvisoryLock(lockId: string, timeoutMs?: number): Promise<boolean>;
|
|
63
|
+
releaseAdvisoryLock(lockId: string): Promise<void>;
|
|
64
|
+
private hashLockId;
|
|
65
|
+
createSavepointSql(name: string): string;
|
|
66
|
+
rollbackToSavepointSql(name: string): string;
|
|
67
|
+
releaseSavepointSql(name: string): string;
|
|
68
|
+
clear(tableName: string): Promise<any>;
|
|
69
|
+
getForUpdateNoWait(): string;
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=PostgresDriver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostgresDriver.d.ts","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresDriver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,440 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.PostgresDriver = void 0;
|
|
37
|
+
const sql_template_tag_1 = __importStar(require("sql-template-tag"));
|
|
38
|
+
const errors_1 = require("../../errors");
|
|
39
|
+
const SchemaGenerator_1 = require("../../core/generators/SchemaGenerator");
|
|
40
|
+
class PostgresDriver {
|
|
41
|
+
constructor(connector, clientType = "postgres", schema) {
|
|
42
|
+
this.connector = connector;
|
|
43
|
+
this.clientType = clientType;
|
|
44
|
+
this.schema = schema ?? "public";
|
|
45
|
+
}
|
|
46
|
+
getSchema() {
|
|
47
|
+
return this.schema;
|
|
48
|
+
}
|
|
49
|
+
hasSchema(schemaName) {
|
|
50
|
+
const name = schemaName ?? this.schema;
|
|
51
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT schema_name FROM information_schema.schemata WHERE schema_name = ${name}`);
|
|
52
|
+
}
|
|
53
|
+
createSchema(schemaName) {
|
|
54
|
+
const name = schemaName ?? this.schema;
|
|
55
|
+
return this.connector.query(`CREATE SCHEMA IF NOT EXISTS ${this.wrap(name)}`);
|
|
56
|
+
}
|
|
57
|
+
dropSchema(schemaName, cascade = false) {
|
|
58
|
+
const suffix = cascade ? " CASCADE" : "";
|
|
59
|
+
return this.connector.query(`DROP SCHEMA IF EXISTS ${this.wrap(schemaName)}${suffix}`);
|
|
60
|
+
}
|
|
61
|
+
listSchemas() {
|
|
62
|
+
return this.connector.query(`SELECT schema_name FROM information_schema.schemata
|
|
63
|
+
WHERE schema_name NOT LIKE 'pg_%'
|
|
64
|
+
AND schema_name != 'information_schema'
|
|
65
|
+
ORDER BY schema_name`);
|
|
66
|
+
}
|
|
67
|
+
setSearchPath(schemaName) {
|
|
68
|
+
const name = schemaName ?? this.schema;
|
|
69
|
+
return this.connector.query(`SET search_path TO ${this.wrap(name)}`);
|
|
70
|
+
}
|
|
71
|
+
listTables(schemaName) {
|
|
72
|
+
const name = schemaName ?? this.schema;
|
|
73
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT tablename FROM pg_tables WHERE schemaname = ${name} ORDER BY tablename`);
|
|
74
|
+
}
|
|
75
|
+
moveTableToSchema(tableName, targetSchema) {
|
|
76
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} SET SCHEMA ${this.wrap(targetSchema)}`);
|
|
77
|
+
}
|
|
78
|
+
hasTable(name) {
|
|
79
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT tablename FROM pg_tables WHERE schemaname = ${this.schema} AND tablename = ${name}`);
|
|
80
|
+
}
|
|
81
|
+
executeRaw(sqlStr) {
|
|
82
|
+
return this.connector.query(sqlStr);
|
|
83
|
+
}
|
|
84
|
+
addPrimaryKey(tableName, columnName) {
|
|
85
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD PRIMARY KEY (${this.wrap(columnName)})`);
|
|
86
|
+
}
|
|
87
|
+
addAutoIncrement(tableName, columnName) {
|
|
88
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ALTER COLUMN ${this.wrap(columnName)} ADD GENERATED ALWAYS AS IDENTITY`);
|
|
89
|
+
}
|
|
90
|
+
async dropPrimaryKey(tableName) {
|
|
91
|
+
const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
|
|
92
|
+
FROM pg_constraint c
|
|
93
|
+
JOIN pg_class t ON c.conrelid = t.oid
|
|
94
|
+
JOIN pg_namespace n ON t.relnamespace = n.oid
|
|
95
|
+
WHERE c.contype = 'p'
|
|
96
|
+
AND t.relname = ${tableName}
|
|
97
|
+
AND n.nspname = ${this.schema}`);
|
|
98
|
+
if (!rows || rows.length === 0) {
|
|
99
|
+
throw new errors_1.Exception(`테이블 "${tableName}"에서 PRIMARY KEY 제약조건을 찾을 수 없습니다.`, 404);
|
|
100
|
+
}
|
|
101
|
+
const constraintName = rows[0].conname;
|
|
102
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
|
|
103
|
+
}
|
|
104
|
+
addUniqueKey(tableName, columnName) {
|
|
105
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD UNIQUE (${this.wrap(columnName)})`);
|
|
106
|
+
}
|
|
107
|
+
async dropUniqueKey(tableName, columnName) {
|
|
108
|
+
const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
|
|
109
|
+
FROM pg_constraint c
|
|
110
|
+
JOIN pg_class t ON c.conrelid = t.oid
|
|
111
|
+
JOIN pg_namespace n ON t.relnamespace = n.oid
|
|
112
|
+
JOIN pg_attribute a ON a.attrelid = t.oid
|
|
113
|
+
AND a.attnum = ANY(c.conkey)
|
|
114
|
+
WHERE c.contype = 'u'
|
|
115
|
+
AND t.relname = ${tableName}
|
|
116
|
+
AND n.nspname = ${this.schema}
|
|
117
|
+
AND a.attname = ${columnName}`);
|
|
118
|
+
if (!rows || rows.length === 0) {
|
|
119
|
+
throw new errors_1.Exception(`테이블 "${tableName}"의 컬럼 "${columnName}"에 대한 UNIQUE 제약조건을 찾을 수 없습니다.`, 404);
|
|
120
|
+
}
|
|
121
|
+
const constraintName = rows[0].conname;
|
|
122
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
|
|
123
|
+
}
|
|
124
|
+
addColumn(tableName, columnName, columnType) {
|
|
125
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD COLUMN ${this.wrap(columnName)} ${columnType}`);
|
|
126
|
+
}
|
|
127
|
+
dropColumn(tableName, columnName) {
|
|
128
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP COLUMN ${this.wrap(columnName)}`);
|
|
129
|
+
}
|
|
130
|
+
addForeignKey(tableName, columnName, foreignTableName, foreignColumnName) {
|
|
131
|
+
const foreignKeyName = this.generateForeignKeyName(tableName, foreignTableName, columnName);
|
|
132
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} ADD CONSTRAINT ${foreignKeyName} FOREIGN KEY (${this.wrap(columnName)}) REFERENCES ${this.wrapQualified(foreignTableName)}(${this.wrap(foreignColumnName)}) ON DELETE NO ACTION ON UPDATE NO ACTION`);
|
|
133
|
+
}
|
|
134
|
+
generateForeignKeyName(sourceTable, targetTable, sourceColumn) {
|
|
135
|
+
return SchemaGenerator_1.SchemaGenerator.generateForeignKeyName(sourceTable, sourceColumn, targetTable);
|
|
136
|
+
}
|
|
137
|
+
async dropForeignKey(tableName, columnName) {
|
|
138
|
+
const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT c.conname
|
|
139
|
+
FROM pg_constraint c
|
|
140
|
+
JOIN pg_class t ON c.conrelid = t.oid
|
|
141
|
+
JOIN pg_namespace n ON t.relnamespace = n.oid
|
|
142
|
+
JOIN pg_attribute a ON a.attrelid = t.oid
|
|
143
|
+
AND a.attnum = ANY(c.conkey)
|
|
144
|
+
WHERE c.contype = 'f'
|
|
145
|
+
AND t.relname = ${tableName}
|
|
146
|
+
AND n.nspname = ${this.schema}
|
|
147
|
+
AND a.attname = ${columnName}`);
|
|
148
|
+
if (!rows || rows.length === 0) {
|
|
149
|
+
throw new errors_1.Exception(`테이블 "${tableName}"의 컬럼 "${columnName}"에 대한 FOREIGN KEY 제약조건을 찾을 수 없습니다.`, 404);
|
|
150
|
+
}
|
|
151
|
+
const constraintName = rows[0].conname;
|
|
152
|
+
return this.connector.query(`ALTER TABLE ${this.wrapQualified(tableName)} DROP CONSTRAINT ${this.wrap(constraintName)}`);
|
|
153
|
+
}
|
|
154
|
+
addIndex(tableName, columnName, indexName) {
|
|
155
|
+
return this.connector.query(`CREATE INDEX ${this.wrap(indexName)} ON ${this.wrapQualified(tableName)} (${this.wrap(columnName)})`);
|
|
156
|
+
}
|
|
157
|
+
hasIndex(tableName, indexName) {
|
|
158
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT COUNT(*) as count FROM pg_indexes WHERE tablename = ${tableName} AND indexname = ${indexName}`);
|
|
159
|
+
}
|
|
160
|
+
dropIndex(tableName, indexName) {
|
|
161
|
+
return this.connector.query(`DROP INDEX IF EXISTS ${this.wrapQualified(indexName)}`);
|
|
162
|
+
}
|
|
163
|
+
hasEnumType(enumName) {
|
|
164
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT pg_type.typname
|
|
165
|
+
FROM pg_type
|
|
166
|
+
JOIN pg_namespace ON pg_type.typnamespace = pg_namespace.oid
|
|
167
|
+
WHERE pg_type.typname = ${enumName}
|
|
168
|
+
AND pg_type.typtype = 'e'
|
|
169
|
+
AND pg_namespace.nspname = ${this.schema}`);
|
|
170
|
+
}
|
|
171
|
+
async createEnumType(enumName, values) {
|
|
172
|
+
const rows = await this.hasEnumType(enumName);
|
|
173
|
+
if (rows && rows.length > 0) {
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
const escapedValues = values
|
|
177
|
+
.map((v) => `'${v.replace(/'/g, "''")}'`)
|
|
178
|
+
.join(", ");
|
|
179
|
+
return this.connector.query(`CREATE TYPE ${this.wrapQualified(enumName)} AS ENUM (${escapedValues})`);
|
|
180
|
+
}
|
|
181
|
+
dropEnumType(enumName, cascade = false) {
|
|
182
|
+
const suffix = cascade ? " CASCADE" : "";
|
|
183
|
+
return this.connector.query(`DROP TYPE IF EXISTS ${this.wrapQualified(enumName)}${suffix}`);
|
|
184
|
+
}
|
|
185
|
+
addEnumValue(enumName, value, placement) {
|
|
186
|
+
const escaped = `'${value.replace(/'/g, "''")}'`;
|
|
187
|
+
let suffix = "";
|
|
188
|
+
if (placement?.before) {
|
|
189
|
+
suffix = ` BEFORE '${placement.before.replace(/'/g, "''")}'`;
|
|
190
|
+
}
|
|
191
|
+
else if (placement?.after) {
|
|
192
|
+
suffix = ` AFTER '${placement.after.replace(/'/g, "''")}'`;
|
|
193
|
+
}
|
|
194
|
+
return this.connector.query(`ALTER TYPE ${this.wrapQualified(enumName)} ADD VALUE IF NOT EXISTS ${escaped}${suffix}`);
|
|
195
|
+
}
|
|
196
|
+
renameEnumValue(enumName, oldValue, newValue) {
|
|
197
|
+
return this.connector.query(`ALTER TYPE ${this.wrapQualified(enumName)} RENAME VALUE '${oldValue.replace(/'/g, "''")}' TO '${newValue.replace(/'/g, "''")}'`);
|
|
198
|
+
}
|
|
199
|
+
listEnumValues(enumName) {
|
|
200
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT e.enumlabel
|
|
201
|
+
FROM pg_enum e
|
|
202
|
+
JOIN pg_type t ON t.oid = e.enumtypid
|
|
203
|
+
WHERE t.typname = ${enumName}
|
|
204
|
+
ORDER BY e.enumsortorder`);
|
|
205
|
+
}
|
|
206
|
+
getSchemas(tableName) {
|
|
207
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT
|
|
208
|
+
column_name AS "Field",
|
|
209
|
+
data_type AS "Type",
|
|
210
|
+
is_nullable AS "Null",
|
|
211
|
+
CASE
|
|
212
|
+
WHEN column_name IN (
|
|
213
|
+
SELECT kcu.column_name
|
|
214
|
+
FROM information_schema.table_constraints tc
|
|
215
|
+
JOIN information_schema.key_column_usage kcu
|
|
216
|
+
ON tc.constraint_name = kcu.constraint_name
|
|
217
|
+
WHERE tc.table_name = ${tableName} AND tc.constraint_type = 'PRIMARY KEY'
|
|
218
|
+
) THEN 'PRI'
|
|
219
|
+
ELSE ''
|
|
220
|
+
END AS "Key",
|
|
221
|
+
column_default AS "Default",
|
|
222
|
+
CASE
|
|
223
|
+
WHEN column_default LIKE 'nextval%' THEN 'auto_increment'
|
|
224
|
+
ELSE ''
|
|
225
|
+
END AS "Extra"
|
|
226
|
+
FROM information_schema.columns
|
|
227
|
+
WHERE table_schema = ${this.schema} AND table_name = ${tableName}
|
|
228
|
+
ORDER BY ordinal_position`);
|
|
229
|
+
}
|
|
230
|
+
getIndexes(tableName) {
|
|
231
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT indexname AS "Field", indexdef AS "Type", '' AS "Null", 'MUL' AS "Key", NULL AS "Default", '' AS "Extra"
|
|
232
|
+
FROM pg_indexes WHERE schemaname = ${this.schema} AND tablename = ${tableName}`);
|
|
233
|
+
}
|
|
234
|
+
getForeignKeys(tableName) {
|
|
235
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT
|
|
236
|
+
kcu.column_name AS "COLUMN_NAME",
|
|
237
|
+
ccu.table_name AS "REFERENCED_TABLE_NAME",
|
|
238
|
+
ccu.column_name AS "REFERENCED_COLUMN_NAME"
|
|
239
|
+
FROM information_schema.table_constraints tc
|
|
240
|
+
JOIN information_schema.key_column_usage kcu
|
|
241
|
+
ON tc.constraint_name = kcu.constraint_name
|
|
242
|
+
JOIN information_schema.constraint_column_usage ccu
|
|
243
|
+
ON ccu.constraint_name = tc.constraint_name
|
|
244
|
+
WHERE tc.constraint_type = 'FOREIGN KEY'
|
|
245
|
+
AND tc.table_schema = ${this.schema}
|
|
246
|
+
AND tc.table_name = ${tableName}`);
|
|
247
|
+
}
|
|
248
|
+
getPrimaryKeys(tableName) {
|
|
249
|
+
return this.connector.query((0, sql_template_tag_1.default) `SELECT kcu.column_name AS "COLUMN_NAME"
|
|
250
|
+
FROM information_schema.table_constraints tc
|
|
251
|
+
JOIN information_schema.key_column_usage kcu
|
|
252
|
+
ON tc.constraint_name = kcu.constraint_name
|
|
253
|
+
WHERE tc.constraint_type = 'PRIMARY KEY'
|
|
254
|
+
AND tc.table_schema = ${this.schema}
|
|
255
|
+
AND tc.table_name = ${tableName}`);
|
|
256
|
+
}
|
|
257
|
+
createTable(tableName, columns) {
|
|
258
|
+
const columnsMap = columns.map((column) => {
|
|
259
|
+
const option = (column.options ?? {
|
|
260
|
+
type: "varchar",
|
|
261
|
+
length: 255,
|
|
262
|
+
nullable: false,
|
|
263
|
+
});
|
|
264
|
+
let type = this.castType(option.type ?? "varchar");
|
|
265
|
+
if (option.type === "boolean") {
|
|
266
|
+
type = "BOOLEAN";
|
|
267
|
+
}
|
|
268
|
+
if (option.type === "enum") {
|
|
269
|
+
const resolvedEnumName = option.enumName ?? `${tableName}_${column.name}_enum`;
|
|
270
|
+
type = this.wrapQualified(resolvedEnumName);
|
|
271
|
+
}
|
|
272
|
+
if (type.startsWith("NUMERIC")) {
|
|
273
|
+
if (option.precision !== undefined && option.precision > 1000) {
|
|
274
|
+
throw new errors_1.Exception("PostgreSQL에서 지원하는 NUMERIC 타입의 precision은 1000 이하입니다.", 400);
|
|
275
|
+
}
|
|
276
|
+
type = type.replace("$precision", option.precision?.toString() || "10");
|
|
277
|
+
type = type.replace("$scale", option.scale?.toString() || "2");
|
|
278
|
+
}
|
|
279
|
+
const nullable = option.nullable ?? false;
|
|
280
|
+
if (option.autoIncrement) {
|
|
281
|
+
return (0, sql_template_tag_1.raw)(`${this.wrap(column.name)} SERIAL ${nullable ? "NULL" : "NOT NULL"} ${option.primary ? "PRIMARY KEY" : ""}`);
|
|
282
|
+
}
|
|
283
|
+
const needsLength = ["VARCHAR", "CHAR"].some((t) => type.toUpperCase().startsWith(t));
|
|
284
|
+
const typeWithLength = needsLength && option.length ? `${type}(${option.length})` : type;
|
|
285
|
+
return (0, sql_template_tag_1.raw)(`${this.wrap(column.name)} ${typeWithLength} ${nullable ? "NULL" : "NOT NULL"} ${option.primary ? "PRIMARY KEY" : ""}`);
|
|
286
|
+
});
|
|
287
|
+
const result = (0, sql_template_tag_1.default) `CREATE TABLE IF NOT EXISTS ${(0, sql_template_tag_1.raw)(this.wrapQualified(tableName))} (${(0, sql_template_tag_1.join)(columnsMap, ",")})`;
|
|
288
|
+
return this.connector.query(result);
|
|
289
|
+
}
|
|
290
|
+
wrap(name) {
|
|
291
|
+
return `"${name.replace(/"/g, '""')}"`;
|
|
292
|
+
}
|
|
293
|
+
wrapQualified(name) {
|
|
294
|
+
return `${this.wrap(this.schema)}.${this.wrap(name)}`;
|
|
295
|
+
}
|
|
296
|
+
getColumnType(type) {
|
|
297
|
+
switch (type) {
|
|
298
|
+
case String:
|
|
299
|
+
return "VARCHAR";
|
|
300
|
+
case Number:
|
|
301
|
+
return "INTEGER";
|
|
302
|
+
case Boolean:
|
|
303
|
+
return "BOOLEAN";
|
|
304
|
+
case Date:
|
|
305
|
+
return "TIMESTAMP";
|
|
306
|
+
case Buffer:
|
|
307
|
+
return "BYTEA";
|
|
308
|
+
default:
|
|
309
|
+
return "TEXT";
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
castType(type) {
|
|
313
|
+
switch (type) {
|
|
314
|
+
case "varchar":
|
|
315
|
+
return "VARCHAR";
|
|
316
|
+
case "int":
|
|
317
|
+
case "number":
|
|
318
|
+
return "INTEGER";
|
|
319
|
+
case "boolean":
|
|
320
|
+
return "BOOLEAN";
|
|
321
|
+
case "datetime":
|
|
322
|
+
return "TIMESTAMP";
|
|
323
|
+
case "date":
|
|
324
|
+
return "DATE";
|
|
325
|
+
case "timestamp":
|
|
326
|
+
return "TIMESTAMP";
|
|
327
|
+
case "float":
|
|
328
|
+
return "REAL";
|
|
329
|
+
case "double":
|
|
330
|
+
return "NUMERIC($precision, $scale)";
|
|
331
|
+
case "blob":
|
|
332
|
+
return "BYTEA";
|
|
333
|
+
case "text":
|
|
334
|
+
case "longtext":
|
|
335
|
+
return "TEXT";
|
|
336
|
+
case "bigint":
|
|
337
|
+
return "BIGINT";
|
|
338
|
+
case "json":
|
|
339
|
+
return "JSON";
|
|
340
|
+
case "jsonb":
|
|
341
|
+
return "JSONB";
|
|
342
|
+
case "char":
|
|
343
|
+
return "CHAR";
|
|
344
|
+
case "enum":
|
|
345
|
+
return "TEXT";
|
|
346
|
+
case "array":
|
|
347
|
+
return "ARRAY";
|
|
348
|
+
default:
|
|
349
|
+
return type;
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
isMySqlFamily() {
|
|
353
|
+
return false;
|
|
354
|
+
}
|
|
355
|
+
setQueryTimeout(ms) {
|
|
356
|
+
return `SET LOCAL statement_timeout = '${Math.max(0, Math.floor(ms))}ms'`;
|
|
357
|
+
}
|
|
358
|
+
supportsExplain() {
|
|
359
|
+
return true;
|
|
360
|
+
}
|
|
361
|
+
buildExplainSql(selectSql) {
|
|
362
|
+
return `EXPLAIN (FORMAT JSON) ${selectSql}`;
|
|
363
|
+
}
|
|
364
|
+
buildUpsertSql(tableName, columns, conflictColumns, updateColumns) {
|
|
365
|
+
const columnList = columns.join(", ");
|
|
366
|
+
const valuePlaceholders = columns
|
|
367
|
+
.map((_, i) => `$${i + 1}`)
|
|
368
|
+
.join(", ");
|
|
369
|
+
const conflictList = conflictColumns.join(", ");
|
|
370
|
+
const updateSet = updateColumns
|
|
371
|
+
.map((col) => `${col} = EXCLUDED.${col}`)
|
|
372
|
+
.join(", ");
|
|
373
|
+
return `INSERT INTO ${tableName} (${columnList}) VALUES (${valuePlaceholders}) ON CONFLICT (${conflictList}) DO UPDATE SET ${updateSet}`;
|
|
374
|
+
}
|
|
375
|
+
async hasColumn(tableName, columnName) {
|
|
376
|
+
const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT column_name FROM information_schema.columns WHERE table_schema = ${this.schema} AND table_name = ${tableName} AND column_name = ${columnName}`);
|
|
377
|
+
return Array.isArray(rows) && rows.length > 0;
|
|
378
|
+
}
|
|
379
|
+
async hasForeignKey(tableName, constraintName) {
|
|
380
|
+
const rows = await this.connector.query((0, sql_template_tag_1.default) `SELECT constraint_name FROM information_schema.table_constraints WHERE table_schema = ${this.schema} AND table_name = ${tableName} AND constraint_name = ${constraintName} AND constraint_type = 'FOREIGN KEY'`);
|
|
381
|
+
return Array.isArray(rows) && rows.length > 0;
|
|
382
|
+
}
|
|
383
|
+
addCompositeUniqueIndex(tableName, columns, indexName) {
|
|
384
|
+
const columnList = columns.map((col) => this.wrap(col)).join(", ");
|
|
385
|
+
return this.connector.query(`CREATE UNIQUE INDEX IF NOT EXISTS ${this.wrap(indexName)} ON ${this.wrapQualified(tableName)} (${columnList})`);
|
|
386
|
+
}
|
|
387
|
+
async acquireAdvisoryLock(lockId, timeoutMs = 0) {
|
|
388
|
+
const hash = this.hashLockId(lockId);
|
|
389
|
+
if (timeoutMs <= 0) {
|
|
390
|
+
const result = await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_try_advisory_lock(${hash}) AS lock_result`);
|
|
391
|
+
const rows = Array.isArray(result) ? result : result?.rows ?? [];
|
|
392
|
+
if (rows.length === 0)
|
|
393
|
+
return false;
|
|
394
|
+
return rows[0]?.lock_result === true;
|
|
395
|
+
}
|
|
396
|
+
const savedTimeout = await this.connector.query(`SHOW statement_timeout`);
|
|
397
|
+
await this.connector.query(`SET LOCAL statement_timeout = '${Math.floor(timeoutMs)}ms'`);
|
|
398
|
+
try {
|
|
399
|
+
await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_advisory_lock(${hash})`);
|
|
400
|
+
return true;
|
|
401
|
+
}
|
|
402
|
+
catch {
|
|
403
|
+
return false;
|
|
404
|
+
}
|
|
405
|
+
finally {
|
|
406
|
+
const rows = Array.isArray(savedTimeout) ? savedTimeout : savedTimeout?.rows ?? [];
|
|
407
|
+
const original = rows.length > 0 ? rows[0]?.statement_timeout ?? "0" : "0";
|
|
408
|
+
await this.connector.query(`SET LOCAL statement_timeout = '${original}'`);
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
async releaseAdvisoryLock(lockId) {
|
|
412
|
+
const hash = this.hashLockId(lockId);
|
|
413
|
+
await this.connector.query((0, sql_template_tag_1.default) `SELECT pg_advisory_unlock(${hash})`);
|
|
414
|
+
}
|
|
415
|
+
hashLockId(lockId) {
|
|
416
|
+
let hash = 0;
|
|
417
|
+
for (let i = 0; i < lockId.length; i++) {
|
|
418
|
+
const char = lockId.charCodeAt(i);
|
|
419
|
+
hash = ((hash << 5) - hash + char) | 0;
|
|
420
|
+
}
|
|
421
|
+
return hash;
|
|
422
|
+
}
|
|
423
|
+
createSavepointSql(name) {
|
|
424
|
+
return `SAVEPOINT ${this.wrap(name)}`;
|
|
425
|
+
}
|
|
426
|
+
rollbackToSavepointSql(name) {
|
|
427
|
+
return `ROLLBACK TO SAVEPOINT ${this.wrap(name)}`;
|
|
428
|
+
}
|
|
429
|
+
releaseSavepointSql(name) {
|
|
430
|
+
return `RELEASE SAVEPOINT ${this.wrap(name)}`;
|
|
431
|
+
}
|
|
432
|
+
clear(tableName) {
|
|
433
|
+
return this.connector.query(`TRUNCATE TABLE ${this.wrapQualified(tableName)} RESTART IDENTITY CASCADE`);
|
|
434
|
+
}
|
|
435
|
+
getForUpdateNoWait() {
|
|
436
|
+
return " FOR UPDATE NOWAIT";
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
exports.PostgresDriver = PostgresDriver;
|
|
440
|
+
//# sourceMappingURL=PostgresDriver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostgresDriver.js","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresDriver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { PostgresDriver } from "./PostgresDriver";
|
|
2
|
+
import { ITenantMigrationRunner, TenantMigrationRunnerOptions, TenantSyncResult } from "../ITenantMigrationRunner";
|
|
3
|
+
export declare class PostgresTenantMigrationRunner implements ITenantMigrationRunner {
|
|
4
|
+
private readonly driver;
|
|
5
|
+
private readonly provisionedSchemas;
|
|
6
|
+
private readonly provisioningLocks;
|
|
7
|
+
private readonly sourceSchema;
|
|
8
|
+
private readonly logger;
|
|
9
|
+
constructor(driver: PostgresDriver, options?: TenantMigrationRunnerOptions);
|
|
10
|
+
discoverSchemas(): Promise<string[]>;
|
|
11
|
+
ensureSchema(tenantId: string): Promise<void>;
|
|
12
|
+
syncTenantSchemas(tenantIds: string[]): Promise<TenantSyncResult>;
|
|
13
|
+
isProvisioned(tenantId: string): boolean;
|
|
14
|
+
getProvisionedSchemas(): string[];
|
|
15
|
+
reset(): void;
|
|
16
|
+
private provision;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=PostgresTenantMigrationRunner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostgresTenantMigrationRunner.d.ts","sourceRoot":"","sources":["../../../src/dialects/postgres/PostgresTenantMigrationRunner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,EACL,sBAAsB,EACtB,4BAA4B,EAC5B,gBAAgB,EACjB,MAAM,2BAA2B,CAAC;AAYnC,qBAAa,6BAA8B,YAAW,sBAAsB;IAOxE,OAAO,CAAC,QAAQ,CAAC,MAAM;IANzB,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAqB;IACxD,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAoC;IACtE,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+C;gBAGnD,MAAM,EAAE,cAAc,EACvC,OAAO,CAAC,EAAE,4BAA4B;IAKlC,eAAe,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;IAKpC,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAsB7C,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC;IA0BvE,aAAa,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAIxC,qBAAqB,IAAI,MAAM,EAAE;IAIjC,KAAK,IAAI,IAAI;YAKC,SAAS;CAoBxB"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PostgresTenantMigrationRunner = void 0;
|
|
4
|
+
const utils_1 = require("../../utils");
|
|
5
|
+
class PostgresTenantMigrationRunner {
|
|
6
|
+
constructor(driver, options) {
|
|
7
|
+
this.driver = driver;
|
|
8
|
+
this.provisionedSchemas = new Set();
|
|
9
|
+
this.provisioningLocks = new Map();
|
|
10
|
+
this.logger = new utils_1.Logger("PostgresTenantMigrationRunner");
|
|
11
|
+
this.sourceSchema = options?.sourceSchema ?? "public";
|
|
12
|
+
}
|
|
13
|
+
async discoverSchemas() {
|
|
14
|
+
const rows = await this.driver.listSchemas();
|
|
15
|
+
return rows.map((r) => r.schema_name);
|
|
16
|
+
}
|
|
17
|
+
async ensureSchema(tenantId) {
|
|
18
|
+
if (tenantId === this.sourceSchema ||
|
|
19
|
+
this.provisionedSchemas.has(tenantId)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const existing = this.provisioningLocks.get(tenantId);
|
|
23
|
+
if (existing) {
|
|
24
|
+
return existing;
|
|
25
|
+
}
|
|
26
|
+
const promise = this.provision(tenantId).then(() => {
|
|
27
|
+
this.provisionedSchemas.add(tenantId);
|
|
28
|
+
this.provisioningLocks.delete(tenantId);
|
|
29
|
+
});
|
|
30
|
+
this.provisioningLocks.set(tenantId, promise);
|
|
31
|
+
return promise;
|
|
32
|
+
}
|
|
33
|
+
async syncTenantSchemas(tenantIds) {
|
|
34
|
+
const existingSchemas = new Set(await this.discoverSchemas());
|
|
35
|
+
const created = [];
|
|
36
|
+
const skipped = [];
|
|
37
|
+
for (const tenantId of tenantIds) {
|
|
38
|
+
if (tenantId === this.sourceSchema) {
|
|
39
|
+
skipped.push(tenantId);
|
|
40
|
+
continue;
|
|
41
|
+
}
|
|
42
|
+
if (existingSchemas.has(tenantId)) {
|
|
43
|
+
this.provisionedSchemas.add(tenantId);
|
|
44
|
+
skipped.push(tenantId);
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
this.logger.info(`Provisioning schema: ${tenantId}`);
|
|
48
|
+
await this.provision(tenantId);
|
|
49
|
+
this.provisionedSchemas.add(tenantId);
|
|
50
|
+
created.push(tenantId);
|
|
51
|
+
}
|
|
52
|
+
return { created, skipped };
|
|
53
|
+
}
|
|
54
|
+
isProvisioned(tenantId) {
|
|
55
|
+
return this.provisionedSchemas.has(tenantId);
|
|
56
|
+
}
|
|
57
|
+
getProvisionedSchemas() {
|
|
58
|
+
return Array.from(this.provisionedSchemas);
|
|
59
|
+
}
|
|
60
|
+
reset() {
|
|
61
|
+
this.provisionedSchemas.clear();
|
|
62
|
+
this.provisioningLocks.clear();
|
|
63
|
+
}
|
|
64
|
+
async provision(tenantId) {
|
|
65
|
+
await this.driver.createSchema(tenantId);
|
|
66
|
+
const tables = await this.driver.listTables(this.sourceSchema);
|
|
67
|
+
for (const row of tables) {
|
|
68
|
+
const tableName = row.tablename;
|
|
69
|
+
const escapedTenant = tenantId.replace(/"/g, '""');
|
|
70
|
+
const escapedTable = tableName.replace(/"/g, '""');
|
|
71
|
+
const escapedSource = this.sourceSchema.replace(/"/g, '""');
|
|
72
|
+
await this.driver.executeRaw(`CREATE TABLE IF NOT EXISTS "${escapedTenant}"."${escapedTable}" (LIKE "${escapedSource}"."${escapedTable}" INCLUDING ALL)`);
|
|
73
|
+
}
|
|
74
|
+
this.logger.info(`Schema "${tenantId}" provisioned with ${tables.length} tables`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
exports.PostgresTenantMigrationRunner = PostgresTenantMigrationRunner;
|
|
78
|
+
//# sourceMappingURL=PostgresTenantMigrationRunner.js.map
|