drizzle-orm 0.10.21 → 0.10.24
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 +674 -0
- package/{builders → dist/builders}/aggregators/abstractAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/abstractAggregator.js +0 -0
- package/{builders → dist/builders}/aggregators/deleteAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/deleteAggregator.js +4 -1
- package/{builders → dist/builders}/aggregators/insertAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/insertAggregator.js +4 -1
- package/{builders → dist/builders}/aggregators/selectAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/selectAggregator.js +24 -9
- package/{builders → dist/builders}/aggregators/updateAggregator.d.ts +0 -0
- package/{builders → dist/builders}/aggregators/updateAggregator.js +4 -1
- package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/abstractRequestBuilder.js +0 -0
- package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/deleteRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/insertRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/order.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/order.js +0 -0
- package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/selectRequestBuilder.js +26 -4
- package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.d.ts +0 -0
- package/{builders → dist/builders}/highLvlBuilders/updateRequestBuilder.js +26 -4
- package/{builders → dist/builders}/index.d.ts +0 -0
- package/{builders → dist/builders}/index.js +19 -16
- package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/abstractJoinBuilder.js +25 -3
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFiveJoins.js +5 -2
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithFourJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithJoin.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithThreeJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/builders/selectWithTwoJoins.js +7 -4
- package/{builders → dist/builders}/joinBuilders/join.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/join.js +0 -0
- package/{builders → dist/builders}/joinBuilders/joinWith.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/joinWith.js +4 -1
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFiveJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseFourJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseThreeJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseTwoJoins.js +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/responses/selectResponseWithJoin.js +0 -0
- package/{builders → dist/builders}/joinBuilders/static.d.ts +0 -0
- package/{builders → dist/builders}/joinBuilders/static.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/alter.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/alter.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/create.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/create.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/delets/delete.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/delete.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFilter.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/delets/deleteFrom.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insert.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/insertInto.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/onConflictInsert.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/inserts/valuesInsert.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/selects/select.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/select.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectFrom.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/selectJoined.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/selects/whereSelect.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/update.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/update.js +5 -2
- package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/updateIn.js +4 -1
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSelect.js +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.d.ts +0 -0
- package/{builders → dist/builders}/lowLvlBuilders/updates/whereSet.js +4 -1
- package/{builders → dist/builders}/requestBuilders/updates/combine.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/combine.js +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/increment.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/increment.js +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/setObjects.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/setObjects.js +5 -2
- package/{builders → dist/builders}/requestBuilders/updates/static.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/static.js +6 -3
- package/{builders → dist/builders}/requestBuilders/updates/updates.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/updates/updates.js +0 -0
- package/{builders → dist/builders}/requestBuilders/where/and.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/and.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/const.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/const.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/constArray.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/constArray.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/eqWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/eqWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/greater.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/greater.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/greaterEq.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/greaterEq.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/in.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/in.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/isNotNull.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/isNotNull.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/isNull.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/isNull.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/less.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/less.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/lessEq.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/lessEq.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/like.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/like.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/notEqWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/notEqWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/or.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/or.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/rawWhere.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/rawWhere.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/static.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/static.js +19 -16
- package/{builders → dist/builders}/requestBuilders/where/var.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/var.js +4 -1
- package/{builders → dist/builders}/requestBuilders/where/where.d.ts +0 -0
- package/{builders → dist/builders}/requestBuilders/where/where.js +0 -0
- package/{builders → dist/builders}/transaction/transaction.d.ts +0 -0
- package/{builders → dist/builders}/transaction/transaction.js +0 -0
- package/{columns → dist/columns}/column.d.ts +0 -0
- package/{columns → dist/columns}/column.js +0 -0
- package/{columns → dist/columns}/index.d.ts +0 -0
- package/{columns → dist/columns}/index.js +12 -9
- package/{columns → dist/columns}/types/columnType.d.ts +0 -0
- package/{columns → dist/columns}/types/columnType.js +0 -0
- package/{columns → dist/columns}/types/pgBigDecimal.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigDecimal.js +4 -1
- package/{columns → dist/columns}/types/pgBigInt.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigInt.js +4 -1
- package/{columns → dist/columns}/types/pgBigSerial.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBigSerial.js +4 -1
- package/{columns → dist/columns}/types/pgBoolean.d.ts +0 -0
- package/{columns → dist/columns}/types/pgBoolean.js +4 -1
- package/{columns → dist/columns}/types/pgEnum.d.ts +0 -0
- package/{columns → dist/columns}/types/pgEnum.js +4 -1
- package/{columns → dist/columns}/types/pgInteger.d.ts +0 -0
- package/{columns → dist/columns}/types/pgInteger.js +4 -1
- package/{columns → dist/columns}/types/pgJsonb.d.ts +0 -0
- package/{columns → dist/columns}/types/pgJsonb.js +4 -1
- package/{columns → dist/columns}/types/pgSerial.d.ts +0 -0
- package/{columns → dist/columns}/types/pgSerial.js +4 -1
- package/{columns → dist/columns}/types/pgSmallInt.d.ts +0 -0
- package/{columns → dist/columns}/types/pgSmallInt.js +4 -1
- package/{columns → dist/columns}/types/pgText.d.ts +0 -0
- package/{columns → dist/columns}/types/pgText.js +4 -1
- package/{columns → dist/columns}/types/pgTime.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTime.js +4 -1
- package/{columns → dist/columns}/types/pgTimestamp.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTimestamp.js +4 -1
- package/{columns → dist/columns}/types/pgTimestamptz.d.ts +0 -0
- package/{columns → dist/columns}/types/pgTimestamptz.js +4 -1
- package/{columns → dist/columns}/types/pgVarChar.d.ts +0 -0
- package/{columns → dist/columns}/types/pgVarChar.js +4 -1
- package/{db → dist/db}/db.d.ts +0 -0
- package/{db → dist/db}/db.js +0 -0
- package/{db → dist/db}/dbConnector.d.ts +0 -0
- package/{db → dist/db}/dbConnector.js +6 -3
- package/{db → dist/db}/dbStringConnector.d.ts +0 -0
- package/{db → dist/db}/dbStringConnector.js +5 -2
- package/{db → dist/db}/group_by.d.ts +0 -0
- package/{db → dist/db}/group_by.js +0 -0
- package/{db → dist/db}/index.d.ts +0 -0
- package/{db → dist/db}/index.js +6 -3
- package/{db → dist/db}/session.d.ts +0 -0
- package/{db → dist/db}/session.js +0 -0
- package/{docs → dist/docs}/cases/simple_delete.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_delete.js +7 -4
- package/{docs → dist/docs}/cases/simple_insert.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_insert.js +8 -5
- package/{docs → dist/docs}/cases/simple_join.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_join.js +8 -5
- package/{docs → dist/docs}/cases/simple_select.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_select.js +6 -3
- package/{docs → dist/docs}/cases/simple_update.d.ts +0 -0
- package/{docs → dist/docs}/cases/simple_update.js +7 -4
- package/{docs → dist/docs}/tables/citiesTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/citiesTable.js +6 -2
- package/{docs → dist/docs}/tables/userGroupsTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/userGroupsTable.js +4 -1
- package/{docs → dist/docs}/tables/usersTable.d.ts +0 -0
- package/{docs → dist/docs}/tables/usersTable.js +4 -1
- package/{docs → dist/docs}/tables/usersToUserGroups.d.ts +0 -0
- package/{docs → dist/docs}/tables/usersToUserGroups.js +6 -3
- package/{docs → dist/docs}/types/rolesType.d.ts +0 -0
- package/{docs → dist/docs}/types/rolesType.js +0 -0
- package/{errors → dist/errors}/baseError.d.ts +0 -0
- package/{errors → dist/errors}/baseError.js +0 -0
- package/{errors → dist/errors}/builderError.d.ts +0 -0
- package/{errors → dist/errors}/builderError.js +2 -1
- package/{errors → dist/errors}/dbErrors.d.ts +0 -0
- package/{errors → dist/errors}/dbErrors.js +0 -0
- package/{index.d.ts → dist/index.d.ts} +0 -0
- package/{index.js → dist/index.js} +4 -1
- package/{indexes → dist/indexes}/tableIndex.d.ts +0 -0
- package/{indexes → dist/indexes}/tableIndex.js +0 -0
- package/{logger → dist/logger}/abstractLogger.d.ts +0 -0
- package/{logger → dist/logger}/abstractLogger.js +0 -0
- package/{logger → dist/logger}/consoleLogger.d.ts +0 -0
- package/{logger → dist/logger}/consoleLogger.js +4 -1
- package/{mappers → dist/mappers}/index.d.ts +0 -0
- package/{mappers → dist/mappers}/index.js +0 -0
- package/{mappers → dist/mappers}/responseMapper.d.ts +0 -0
- package/{mappers → dist/mappers}/responseMapper.js +0 -0
- package/{migrator → dist/migrator}/index.d.ts +0 -0
- package/{migrator → dist/migrator}/index.js +0 -0
- package/{migrator → dist/migrator}/migrator.d.ts +0 -0
- package/{migrator → dist/migrator}/migrator.js +26 -4
- package/dist/serializer/serializer.d.ts +47 -0
- package/dist/serializer/serializer.js +258 -0
- package/dist/src/builders/aggregators/abstractAggregator.d.ts +11 -0
- package/dist/src/builders/aggregators/abstractAggregator.js +35 -0
- package/dist/src/builders/aggregators/deleteAggregator.d.ts +16 -0
- package/dist/src/builders/aggregators/deleteAggregator.js +42 -0
- package/dist/src/builders/aggregators/insertAggregator.d.ts +22 -0
- package/dist/src/builders/aggregators/insertAggregator.js +106 -0
- package/dist/src/builders/aggregators/selectAggregator.d.ts +39 -0
- package/dist/src/builders/aggregators/selectAggregator.js +143 -0
- package/dist/src/builders/aggregators/updateAggregator.d.ts +19 -0
- package/dist/src/builders/aggregators/updateAggregator.js +50 -0
- package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.d.ts +27 -0
- package/dist/src/builders/highLvlBuilders/abstractRequestBuilder.js +32 -0
- package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.d.ts +19 -0
- package/dist/src/builders/highLvlBuilders/deleteRequestBuilder.js +61 -0
- package/dist/src/builders/highLvlBuilders/insertRequestBuilder.d.ts +20 -0
- package/dist/src/builders/highLvlBuilders/insertRequestBuilder.js +73 -0
- package/dist/src/builders/highLvlBuilders/order.d.ts +5 -0
- package/dist/src/builders/highLvlBuilders/order.js +8 -0
- package/dist/src/builders/highLvlBuilders/selectRequestBuilder.d.ts +47 -0
- package/dist/src/builders/highLvlBuilders/selectRequestBuilder.js +128 -0
- package/dist/src/builders/highLvlBuilders/updateRequestBuilder.d.ts +22 -0
- package/dist/src/builders/highLvlBuilders/updateRequestBuilder.js +80 -0
- package/dist/src/builders/index.d.ts +18 -0
- package/dist/src/builders/index.js +54 -0
- package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +40 -0
- package/dist/src/builders/joinBuilders/builders/abstractJoinBuilder.js +78 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +35 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFiveJoins.js +45 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.d.ts +55 -0
- package/dist/src/builders/joinBuilders/builders/selectWithFourJoins.js +78 -0
- package/dist/src/builders/joinBuilders/builders/selectWithJoin.d.ts +49 -0
- package/dist/src/builders/joinBuilders/builders/selectWithJoin.js +64 -0
- package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +53 -0
- package/dist/src/builders/joinBuilders/builders/selectWithThreeJoins.js +73 -0
- package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +51 -0
- package/dist/src/builders/joinBuilders/builders/selectWithTwoJoins.js +68 -0
- package/dist/src/builders/joinBuilders/join.d.ts +23 -0
- package/dist/src/builders/joinBuilders/join.js +28 -0
- package/dist/src/builders/joinBuilders/joinWith.d.ts +14 -0
- package/dist/src/builders/joinBuilders/joinWith.js +14 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +20 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFiveJoins.js +35 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +19 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseFourJoins.js +34 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +18 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseThreeJoins.js +33 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +17 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseTwoJoins.js +32 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +16 -0
- package/dist/src/builders/joinBuilders/responses/selectResponseWithJoin.js +31 -0
- package/dist/src/builders/joinBuilders/static.d.ts +5 -0
- package/dist/src/builders/joinBuilders/static.js +9 -0
- package/dist/src/builders/lowLvlBuilders/alter.d.ts +0 -0
- package/dist/src/builders/lowLvlBuilders/alter.js +1 -0
- package/dist/src/builders/lowLvlBuilders/create.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/create.js +100 -0
- package/dist/src/builders/lowLvlBuilders/delets/delete.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/delets/delete.js +15 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.d.ts +11 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFilter.js +13 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/delets/deleteFrom.js +14 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insert.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insert.js +15 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insertInto.d.ts +13 -0
- package/dist/src/builders/lowLvlBuilders/inserts/insertInto.js +16 -0
- package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +12 -0
- package/dist/src/builders/lowLvlBuilders/inserts/onConflictInsert.js +13 -0
- package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +16 -0
- package/dist/src/builders/lowLvlBuilders/inserts/valuesInsert.js +19 -0
- package/dist/src/builders/lowLvlBuilders/selects/select.d.ts +9 -0
- package/dist/src/builders/lowLvlBuilders/selects/select.js +16 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectFrom.d.ts +28 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectFrom.js +34 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectJoined.d.ts +26 -0
- package/dist/src/builders/lowLvlBuilders/selects/selectJoined.js +30 -0
- package/dist/src/builders/lowLvlBuilders/selects/whereSelect.d.ts +17 -0
- package/dist/src/builders/lowLvlBuilders/selects/whereSelect.js +25 -0
- package/dist/src/builders/lowLvlBuilders/updates/update.d.ts +5 -0
- package/dist/src/builders/lowLvlBuilders/updates/update.js +15 -0
- package/dist/src/builders/lowLvlBuilders/updates/updateIn.d.ts +13 -0
- package/dist/src/builders/lowLvlBuilders/updates/updateIn.js +15 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSelect.d.ts +11 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSelect.js +13 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSet.d.ts +14 -0
- package/dist/src/builders/lowLvlBuilders/updates/whereSet.js +18 -0
- package/dist/src/builders/requestBuilders/updates/combine.d.ts +9 -0
- package/dist/src/builders/requestBuilders/updates/combine.js +26 -0
- package/dist/src/builders/requestBuilders/updates/increment.d.ts +13 -0
- package/dist/src/builders/requestBuilders/updates/increment.js +18 -0
- package/dist/src/builders/requestBuilders/updates/setObjects.d.ts +12 -0
- package/dist/src/builders/requestBuilders/updates/setObjects.js +19 -0
- package/dist/src/builders/requestBuilders/updates/static.d.ts +7 -0
- package/dist/src/builders/requestBuilders/updates/static.js +15 -0
- package/dist/src/builders/requestBuilders/updates/updates.d.ts +9 -0
- package/dist/src/builders/requestBuilders/updates/updates.js +10 -0
- package/dist/src/builders/requestBuilders/where/and.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/and.js +31 -0
- package/dist/src/builders/requestBuilders/where/const.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/const.js +25 -0
- package/dist/src/builders/requestBuilders/where/constArray.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/constArray.js +39 -0
- package/dist/src/builders/requestBuilders/where/eqWhere.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/eqWhere.js +20 -0
- package/dist/src/builders/requestBuilders/where/greater.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/greater.js +20 -0
- package/dist/src/builders/requestBuilders/where/greaterEq.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/greaterEq.js +20 -0
- package/dist/src/builders/requestBuilders/where/in.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/in.js +20 -0
- package/dist/src/builders/requestBuilders/where/isNotNull.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/isNotNull.js +18 -0
- package/dist/src/builders/requestBuilders/where/isNull.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/isNull.js +18 -0
- package/dist/src/builders/requestBuilders/where/less.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/less.js +20 -0
- package/dist/src/builders/requestBuilders/where/lessEq.d.ts +15 -0
- package/dist/src/builders/requestBuilders/where/lessEq.js +20 -0
- package/dist/src/builders/requestBuilders/where/like.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/like.js +20 -0
- package/dist/src/builders/requestBuilders/where/notEqWhere.d.ts +12 -0
- package/dist/src/builders/requestBuilders/where/notEqWhere.js +20 -0
- package/dist/src/builders/requestBuilders/where/or.d.ts +11 -0
- package/dist/src/builders/requestBuilders/where/or.js +31 -0
- package/dist/src/builders/requestBuilders/where/rawWhere.d.ts +9 -0
- package/dist/src/builders/requestBuilders/where/rawWhere.js +15 -0
- package/dist/src/builders/requestBuilders/where/static.d.ts +17 -0
- package/dist/src/builders/requestBuilders/where/static.js +49 -0
- package/dist/src/builders/requestBuilders/where/var.d.ts +13 -0
- package/dist/src/builders/requestBuilders/where/var.js +18 -0
- package/dist/src/builders/requestBuilders/where/where.d.ts +8 -0
- package/dist/src/builders/requestBuilders/where/where.js +6 -0
- package/dist/src/builders/transaction/transaction.d.ts +8 -0
- package/dist/src/builders/transaction/transaction.js +20 -0
- package/dist/src/columns/column.d.ts +72 -0
- package/dist/src/columns/column.js +101 -0
- package/dist/src/columns/index.d.ts +10 -0
- package/dist/src/columns/index.js +27 -0
- package/dist/src/columns/types/columnType.d.ts +7 -0
- package/dist/src/columns/types/columnType.js +6 -0
- package/dist/src/columns/types/pgBigDecimal.d.ts +10 -0
- package/dist/src/columns/types/pgBigDecimal.js +31 -0
- package/dist/src/columns/types/pgBigInt.d.ts +15 -0
- package/dist/src/columns/types/pgBigInt.js +32 -0
- package/dist/src/columns/types/pgBigSerial.d.ts +15 -0
- package/dist/src/columns/types/pgBigSerial.js +32 -0
- package/dist/src/columns/types/pgBoolean.d.ts +8 -0
- package/dist/src/columns/types/pgBoolean.js +18 -0
- package/dist/src/columns/types/pgEnum.d.ts +9 -0
- package/dist/src/columns/types/pgEnum.js +18 -0
- package/dist/src/columns/types/pgInteger.d.ts +8 -0
- package/dist/src/columns/types/pgInteger.js +21 -0
- package/dist/src/columns/types/pgJsonb.d.ts +9 -0
- package/dist/src/columns/types/pgJsonb.js +20 -0
- package/dist/src/columns/types/pgSerial.d.ts +8 -0
- package/dist/src/columns/types/pgSerial.js +18 -0
- package/dist/src/columns/types/pgSmallInt.d.ts +8 -0
- package/dist/src/columns/types/pgSmallInt.js +18 -0
- package/dist/src/columns/types/pgText.d.ts +8 -0
- package/dist/src/columns/types/pgText.js +18 -0
- package/dist/src/columns/types/pgTime.d.ts +8 -0
- package/dist/src/columns/types/pgTime.js +18 -0
- package/dist/src/columns/types/pgTimestamp.d.ts +8 -0
- package/dist/src/columns/types/pgTimestamp.js +18 -0
- package/dist/src/columns/types/pgTimestamptz.d.ts +8 -0
- package/dist/src/columns/types/pgTimestamptz.js +18 -0
- package/dist/src/columns/types/pgVarChar.d.ts +9 -0
- package/dist/src/columns/types/pgVarChar.js +24 -0
- package/dist/src/db/db.d.ts +18 -0
- package/dist/src/db/db.js +25 -0
- package/dist/src/db/dbConnector.d.ts +9 -0
- package/dist/src/db/dbConnector.js +32 -0
- package/dist/src/db/dbStringConnector.d.ts +6 -0
- package/dist/src/db/dbStringConnector.js +29 -0
- package/dist/src/db/group_by.d.ts +0 -0
- package/dist/src/db/group_by.js +68 -0
- package/dist/src/db/index.d.ts +4 -0
- package/dist/src/db/index.js +14 -0
- package/dist/src/db/session.d.ts +9 -0
- package/dist/src/db/session.js +16 -0
- package/{test.d.ts → dist/src/docs/cases/simple_delete.d.ts} +0 -0
- package/dist/src/docs/cases/simple_delete.js +35 -0
- package/dist/src/docs/cases/simple_insert.d.ts +1 -0
- package/dist/src/docs/cases/simple_insert.js +57 -0
- package/dist/src/docs/cases/simple_join.d.ts +1 -0
- package/dist/src/docs/cases/simple_join.js +115 -0
- package/dist/src/docs/cases/simple_select.d.ts +1 -0
- package/dist/src/docs/cases/simple_select.js +50 -0
- package/dist/src/docs/cases/simple_update.d.ts +1 -0
- package/dist/src/docs/cases/simple_update.js +39 -0
- package/dist/src/docs/tables/citiesTable.d.ts +14 -0
- package/dist/src/docs/tables/citiesTable.js +21 -0
- package/dist/src/docs/tables/userGroupsTable.d.ts +7 -0
- package/dist/src/docs/tables/userGroupsTable.js +18 -0
- package/dist/src/docs/tables/usersTable.d.ts +17 -0
- package/dist/src/docs/tables/usersTable.js +35 -0
- package/dist/src/docs/tables/usersToUserGroups.d.ts +7 -0
- package/dist/src/docs/tables/usersToUserGroups.js +20 -0
- package/dist/src/docs/types/rolesType.d.ts +1 -0
- package/dist/src/docs/types/rolesType.js +6 -0
- package/dist/src/errors/baseError.d.ts +22 -0
- package/dist/src/errors/baseError.js +35 -0
- package/dist/src/errors/builderError.d.ts +14 -0
- package/dist/src/errors/builderError.js +25 -0
- package/dist/src/errors/dbErrors.d.ts +12 -0
- package/dist/src/errors/dbErrors.js +28 -0
- package/dist/src/index.d.ts +11 -0
- package/dist/src/index.js +31 -0
- package/dist/src/indexes/tableIndex.d.ts +11 -0
- package/dist/src/indexes/tableIndex.js +17 -0
- package/dist/src/logger/abstractLogger.d.ts +4 -0
- package/dist/src/logger/abstractLogger.js +5 -0
- package/dist/src/logger/consoleLogger.d.ts +5 -0
- package/dist/src/logger/consoleLogger.js +15 -0
- package/dist/src/mappers/index.d.ts +0 -0
- package/dist/src/mappers/index.js +1 -0
- package/dist/src/mappers/responseMapper.d.ts +10 -0
- package/dist/src/mappers/responseMapper.js +35 -0
- package/dist/src/migrator/index.d.ts +0 -0
- package/dist/src/migrator/index.js +1 -0
- package/dist/src/migrator/migrator.d.ts +11 -0
- package/dist/src/migrator/migrator.js +105 -0
- package/{serializer → dist/src/serializer}/serializer.d.ts +0 -0
- package/{serializer → dist/src/serializer}/serializer.js +4 -1
- package/{tables → dist/src/tables}/abstractTable.d.ts +0 -0
- package/{tables → dist/src/tables}/abstractTable.js +41 -19
- package/{tables → dist/src/tables}/index.d.ts +0 -0
- package/{tables → dist/src/tables}/index.js +5 -2
- package/{tables → dist/src/tables}/inferTypes.d.ts +0 -0
- package/{tables → dist/src/tables}/inferTypes.js +0 -0
- package/{tables → dist/src/tables}/migrationsTable.d.ts +0 -0
- package/{tables → dist/src/tables}/migrationsTable.js +4 -1
- package/dist/src/test.d.ts +1 -0
- package/{test.js → dist/src/test.js} +23 -8
- package/{types → dist/src/types}/type.d.ts +0 -0
- package/{types → dist/src/types}/type.js +0 -0
- package/{utils → dist/src/utils}/ecranate.d.ts +0 -0
- package/{utils → dist/src/utils}/ecranate.js +0 -0
- package/dist/tables/abstractTable.d.ts +68 -0
- package/dist/tables/abstractTable.js +151 -0
- package/dist/tables/index.d.ts +3 -0
- package/dist/tables/index.js +11 -0
- package/dist/tables/inferTypes.d.ts +39 -0
- package/dist/tables/inferTypes.js +2 -0
- package/dist/tables/migrationsTable.d.ts +7 -0
- package/dist/tables/migrationsTable.js +18 -0
- package/dist/test.d.ts +1 -0
- package/dist/test.js +65 -0
- package/dist/tsconfig.tsbuildinfo +5054 -0
- package/dist/types/type.d.ts +10 -0
- package/dist/types/type.js +14 -0
- package/dist/utils/ecranate.d.ts +2 -0
- package/dist/utils/ecranate.js +8 -0
- package/package.json +18 -13
- package/tables/aggregators.d.ts +0 -27
- package/tables/aggregators.js +0 -56
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/* eslint-disable max-classes-per-file */
|
|
3
|
+
/* eslint-disable import/no-named-as-default-member */
|
|
4
|
+
/* eslint-disable import/no-named-as-default */
|
|
5
|
+
/* eslint-disable no-param-reassign */
|
|
6
|
+
/* eslint-disable no-restricted-syntax */
|
|
7
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
8
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
9
|
+
};
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
const columns_1 = require("../columns");
|
|
12
|
+
const tableIndex_1 = __importDefault(require("../indexes/tableIndex"));
|
|
13
|
+
const serialiseForeignKey = (fkName, table, column, onDelete, onUpdate) => {
|
|
14
|
+
return `${fkName};${table};${column};${onDelete !== null && onDelete !== void 0 ? onDelete : ''};${onUpdate !== null && onUpdate !== void 0 ? onUpdate : ''}`;
|
|
15
|
+
};
|
|
16
|
+
class MigrationSerializer {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.generate = (tables, enums) => {
|
|
19
|
+
const result = {};
|
|
20
|
+
for (const table of tables) {
|
|
21
|
+
const tableEntries = Object.entries(table);
|
|
22
|
+
const columnToReturn = {};
|
|
23
|
+
const indexToReturn = {};
|
|
24
|
+
for (const properties of tableEntries) {
|
|
25
|
+
const value = properties[1];
|
|
26
|
+
if (value instanceof tableIndex_1.default) {
|
|
27
|
+
const columns = value.getColumns();
|
|
28
|
+
const name = value.indexName();
|
|
29
|
+
const indexColumnToReturn = {};
|
|
30
|
+
for (const column of columns) {
|
|
31
|
+
const columnName = column.getColumnName();
|
|
32
|
+
indexColumnToReturn[columnName] = {
|
|
33
|
+
name: columnName,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
indexToReturn[name] = {
|
|
37
|
+
name,
|
|
38
|
+
columns: indexColumnToReturn,
|
|
39
|
+
isUnique: value.isUnique(),
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
if (value instanceof columns_1.Column) {
|
|
43
|
+
columnToReturn[value.getColumnName()] = {
|
|
44
|
+
name: value.getColumnName(),
|
|
45
|
+
type: value.getColumnType().getDbName(),
|
|
46
|
+
primaryKey: !!value.primaryKeyName,
|
|
47
|
+
// unique: !!value.uniqueKeyName,
|
|
48
|
+
// default: value.getDefaultValue() === null ? undefined : value.getDefaultValue(),
|
|
49
|
+
notNull: !value.isNullableFlag,
|
|
50
|
+
};
|
|
51
|
+
if (value.getDefaultValue() !== undefined && value.getDefaultValue() !== null) {
|
|
52
|
+
columnToReturn[value.getColumnName()].default = value.getDefaultValue();
|
|
53
|
+
}
|
|
54
|
+
if (value.uniqueKeyName) {
|
|
55
|
+
const indexName = `${value.getParent().tableName()}_${value.getColumnName()}_index`;
|
|
56
|
+
const indexColumnToReturn = {};
|
|
57
|
+
indexColumnToReturn[value.getColumnName()] = {
|
|
58
|
+
name: value.getColumnName(),
|
|
59
|
+
};
|
|
60
|
+
indexToReturn[indexName] = {
|
|
61
|
+
name: indexName,
|
|
62
|
+
columns: indexColumnToReturn,
|
|
63
|
+
isUnique: true,
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
const referenced = value.getReferenced();
|
|
67
|
+
if (referenced) {
|
|
68
|
+
const fkName = `${value.getParent().tableName()}_${value.getColumnName()}_fkey`;
|
|
69
|
+
const table = referenced.getParentName();
|
|
70
|
+
const column = referenced.getColumnName();
|
|
71
|
+
const onDelete = value.getOnDelete();
|
|
72
|
+
const onUpdate = value.getOnUpdate();
|
|
73
|
+
const referenceString = serialiseForeignKey(fkName, table, column, onDelete, onUpdate);
|
|
74
|
+
columnToReturn[value.getColumnName()].references = referenceString;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
result[table.tableName()] = {
|
|
79
|
+
name: table.tableName(),
|
|
80
|
+
columns: columnToReturn,
|
|
81
|
+
indexes: indexToReturn,
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
const enumsToReturn = enums.reduce((map, obj) => {
|
|
85
|
+
const key = obj.name;
|
|
86
|
+
const newValues = obj.values.reduce((mapped, value) => {
|
|
87
|
+
mapped[value] = value;
|
|
88
|
+
return mapped;
|
|
89
|
+
}, {});
|
|
90
|
+
map[key] = { name: obj.name, values: newValues };
|
|
91
|
+
return map;
|
|
92
|
+
}, {});
|
|
93
|
+
return { version: '2', tables: result, enums: enumsToReturn };
|
|
94
|
+
};
|
|
95
|
+
this.fromDatabase = async (db) => {
|
|
96
|
+
var _a;
|
|
97
|
+
const result = {};
|
|
98
|
+
const allTables = await db.session().execute('SELECT table_schema, table_name FROM information_schema.tables WHERE table_schema != \'pg_catalog\' and table_schema != \'information_schema\';');
|
|
99
|
+
for await (const row of allTables.rows) {
|
|
100
|
+
try {
|
|
101
|
+
// const tableSchema = row.table_schema;
|
|
102
|
+
const tableName = row.table_name;
|
|
103
|
+
const columnToReturn = {};
|
|
104
|
+
const indexToReturn = {};
|
|
105
|
+
const tableResponse = await db.session().execute(`SELECT a.attrelid::regclass::text, a.attname
|
|
106
|
+
, CASE WHEN a.atttypid = ANY ('{int,int8,int2}'::regtype[])
|
|
107
|
+
AND EXISTS (
|
|
108
|
+
SELECT FROM pg_attrdef ad
|
|
109
|
+
WHERE ad.adrelid = a.attrelid
|
|
110
|
+
AND ad.adnum = a.attnum
|
|
111
|
+
AND pg_get_expr(ad.adbin, ad.adrelid)
|
|
112
|
+
= 'nextval('''
|
|
113
|
+
|| (pg_get_serial_sequence (a.attrelid::regclass::text
|
|
114
|
+
, a.attname))::regclass
|
|
115
|
+
|| '''::regclass)'
|
|
116
|
+
)
|
|
117
|
+
THEN CASE a.atttypid
|
|
118
|
+
WHEN 'int'::regtype THEN 'serial'
|
|
119
|
+
WHEN 'int8'::regtype THEN 'bigserial'
|
|
120
|
+
WHEN 'int2'::regtype THEN 'smallserial'
|
|
121
|
+
END
|
|
122
|
+
ELSE format_type(a.atttypid, a.atttypmod)
|
|
123
|
+
END AS data_type, INFORMATION_SCHEMA.COLUMNS.table_name, INFORMATION_SCHEMA.COLUMNS.column_name, INFORMATION_SCHEMA.COLUMNS.column_default
|
|
124
|
+
FROM pg_attribute a
|
|
125
|
+
JOIN INFORMATION_SCHEMA.COLUMNS ON INFORMATION_SCHEMA.COLUMNS.column_name = a.attname
|
|
126
|
+
WHERE a.attrelid = '${tableName}'::regclass and INFORMATION_SCHEMA.COLUMNS.table_name = '${tableName}'
|
|
127
|
+
AND a.attnum > 0
|
|
128
|
+
AND NOT a.attisdropped
|
|
129
|
+
ORDER BY a.attnum;`);
|
|
130
|
+
const tableConstraints = await db.session().execute(`SELECT c.column_name, c.data_type, constraint_type, constraint_name
|
|
131
|
+
FROM information_schema.table_constraints tc
|
|
132
|
+
JOIN information_schema.constraint_column_usage AS ccu USING (constraint_schema, constraint_name)
|
|
133
|
+
JOIN information_schema.columns AS c ON c.table_schema = tc.constraint_schema
|
|
134
|
+
AND tc.table_name = c.table_name AND ccu.column_name = c.column_name
|
|
135
|
+
WHERE tc.table_name = '${tableName}';`);
|
|
136
|
+
const tableForeignKeys = await db.session().execute(`SELECT
|
|
137
|
+
tc.table_schema,
|
|
138
|
+
tc.constraint_name,
|
|
139
|
+
tc.table_name,
|
|
140
|
+
kcu.column_name,
|
|
141
|
+
ccu.table_schema AS foreign_table_schema,
|
|
142
|
+
ccu.table_name AS foreign_table_name,
|
|
143
|
+
ccu.column_name AS foreign_column_name,
|
|
144
|
+
rc.delete_rule, rc.update_rule
|
|
145
|
+
FROM
|
|
146
|
+
information_schema.table_constraints AS tc
|
|
147
|
+
JOIN information_schema.key_column_usage AS kcu
|
|
148
|
+
ON tc.constraint_name = kcu.constraint_name
|
|
149
|
+
AND tc.table_schema = kcu.table_schema
|
|
150
|
+
JOIN information_schema.constraint_column_usage AS ccu
|
|
151
|
+
ON ccu.constraint_name = tc.constraint_name
|
|
152
|
+
AND ccu.table_schema = tc.table_schema
|
|
153
|
+
JOIN information_schema.referential_constraints AS rc
|
|
154
|
+
ON ccu.constraint_name = rc.constraint_name
|
|
155
|
+
WHERE tc.constraint_type = 'FOREIGN KEY' AND tc.table_name='${tableName}';`);
|
|
156
|
+
const mappedRefernces = {};
|
|
157
|
+
for (const fk of tableForeignKeys.rows) {
|
|
158
|
+
// const tableFrom = fk.table_name;
|
|
159
|
+
const columnFrom = fk.column_name;
|
|
160
|
+
const tableTo = fk.foreign_table_name;
|
|
161
|
+
const columnTo = fk.foreign_column_name;
|
|
162
|
+
const foreignKeyName = fk.constraint_name;
|
|
163
|
+
const onUpdate = fk.update_rule;
|
|
164
|
+
const onDelete = fk.delete_rule;
|
|
165
|
+
const references = serialiseForeignKey(foreignKeyName, tableTo, columnTo, onDelete, onUpdate);
|
|
166
|
+
mappedRefernces[columnFrom] = references;
|
|
167
|
+
}
|
|
168
|
+
for (const columnResponse of tableResponse.rows) {
|
|
169
|
+
const columnName = columnResponse.attname;
|
|
170
|
+
const columnType = columnResponse.data_type;
|
|
171
|
+
const primaryKey = tableConstraints.rows.filter((mapRow) => columnName === mapRow.column_name && mapRow.constraint_type === 'PRIMARY KEY');
|
|
172
|
+
const uniqueKey = tableConstraints.rows.filter((mapRow) => columnName === mapRow.column_name && mapRow.constraint_type === 'UNIQUE');
|
|
173
|
+
const defaultValue = columnResponse.column_default === null
|
|
174
|
+
? undefined : columnResponse.column_default;
|
|
175
|
+
const isSerial = columnType === 'serial';
|
|
176
|
+
columnToReturn[columnName] = {
|
|
177
|
+
name: columnName,
|
|
178
|
+
type: columnType,
|
|
179
|
+
primaryKey: !!primaryKey[0],
|
|
180
|
+
unique: !!uniqueKey[0],
|
|
181
|
+
default: isSerial ? undefined : defaultValue,
|
|
182
|
+
notNull: !columnResponse.is_nullable,
|
|
183
|
+
references: (_a = mappedRefernces[columnName]) !== null && _a !== void 0 ? _a : undefined,
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
const dbIndexes = await db.session().execute(`select
|
|
187
|
+
t.relname as table_name,
|
|
188
|
+
i.relname as index_name,
|
|
189
|
+
a.attname as column_name
|
|
190
|
+
from
|
|
191
|
+
pg_class t,
|
|
192
|
+
pg_class i,
|
|
193
|
+
pg_index ix,
|
|
194
|
+
pg_attribute a
|
|
195
|
+
where
|
|
196
|
+
t.oid = ix.indrelid
|
|
197
|
+
and i.oid = ix.indexrelid
|
|
198
|
+
and a.attrelid = t.oid
|
|
199
|
+
and a.attnum = ANY(ix.indkey)
|
|
200
|
+
and t.relkind = 'r'
|
|
201
|
+
and t.relname = '${tableName}'
|
|
202
|
+
order by
|
|
203
|
+
t.relname,
|
|
204
|
+
i.relname;`);
|
|
205
|
+
for (const dbIndex of dbIndexes.rows) {
|
|
206
|
+
const indexName = dbIndex.index_name;
|
|
207
|
+
const indexColumnName = dbIndex.column_name;
|
|
208
|
+
if (indexToReturn[indexName] !== undefined && indexToReturn[indexName] !== null) {
|
|
209
|
+
indexToReturn[indexName].columns[indexColumnName] = {
|
|
210
|
+
name: indexColumnName,
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
indexToReturn[indexName] = {
|
|
215
|
+
name: indexName,
|
|
216
|
+
columns: {
|
|
217
|
+
[indexColumnName]: {
|
|
218
|
+
name: indexColumnName,
|
|
219
|
+
},
|
|
220
|
+
},
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
result[tableName] = {
|
|
225
|
+
name: tableName,
|
|
226
|
+
columns: columnToReturn,
|
|
227
|
+
indexes: indexToReturn,
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
catch (e) {
|
|
231
|
+
console.log(e);
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
const allEnums = await db.session().execute(`select n.nspname as enum_schema,
|
|
235
|
+
t.typname as enum_name,
|
|
236
|
+
e.enumlabel as enum_value
|
|
237
|
+
from pg_type t
|
|
238
|
+
join pg_enum e on t.oid = e.enumtypid
|
|
239
|
+
join pg_catalog.pg_namespace n ON n.oid = t.typnamespace;`);
|
|
240
|
+
const enumsToReturn = {};
|
|
241
|
+
for (const dbEnum of allEnums.rows) {
|
|
242
|
+
const enumName = dbEnum.enum_name;
|
|
243
|
+
const enumValue = dbEnum.enum_value;
|
|
244
|
+
if (enumsToReturn[enumName] !== undefined && enumsToReturn[enumName] !== null) {
|
|
245
|
+
enumsToReturn[enumName].values.push(enumValue);
|
|
246
|
+
}
|
|
247
|
+
else {
|
|
248
|
+
enumsToReturn[enumName] = {
|
|
249
|
+
name: enumName,
|
|
250
|
+
values: [enumValue],
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
return { version: '2', tables: result, enums: enumsToReturn };
|
|
255
|
+
};
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
exports.default = MigrationSerializer;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import { AbstractTable } from '../../tables';
|
|
4
|
+
export default class Aggregator {
|
|
5
|
+
protected _fields: Array<string>;
|
|
6
|
+
protected _table: AbstractTable<any>;
|
|
7
|
+
constructor(table: AbstractTable<any>, partial?: {
|
|
8
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, AbstractTable<any>>;
|
|
9
|
+
});
|
|
10
|
+
protected generateSelectArray: (table: string, columns: AbstractColumn<ColumnType>[], id?: number | undefined) => string[];
|
|
11
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
/* eslint-disable max-len */
|
|
4
|
+
const column_1 = require("../../columns/column");
|
|
5
|
+
const ecranate_1 = require("../../utils/ecranate");
|
|
6
|
+
// eslint-disable-next-line max-len
|
|
7
|
+
class Aggregator {
|
|
8
|
+
constructor(table, partial) {
|
|
9
|
+
this._fields = [];
|
|
10
|
+
this.generateSelectArray = (table, columns, id) => {
|
|
11
|
+
const selectFields = [];
|
|
12
|
+
columns.forEach((field) => {
|
|
13
|
+
if (field instanceof column_1.Column) {
|
|
14
|
+
selectFields.push(' ');
|
|
15
|
+
selectFields.push(table);
|
|
16
|
+
selectFields.push('.');
|
|
17
|
+
selectFields.push(ecranate_1.ecranate(field.getColumnName()));
|
|
18
|
+
selectFields.push(' AS ');
|
|
19
|
+
selectFields.push(ecranate_1.ecranate(`${field.getAlias()}${id ? `_${id}` : ''}`));
|
|
20
|
+
selectFields.push(',');
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
selectFields.pop();
|
|
24
|
+
return selectFields;
|
|
25
|
+
};
|
|
26
|
+
this._table = table;
|
|
27
|
+
if (!partial) {
|
|
28
|
+
this._fields = this.generateSelectArray(this._table.tableName(), Object.values(this._table.mapServiceToDb()));
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
this._fields = this.generateSelectArray(this._table.tableName(), Object.values(partial));
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
exports.default = Aggregator;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { AbstractTable } from '../../tables';
|
|
2
|
+
import Expr from '../requestBuilders/where/where';
|
|
3
|
+
import Aggregator from './abstractAggregator';
|
|
4
|
+
export default class DeleteAggregator extends Aggregator {
|
|
5
|
+
private _from;
|
|
6
|
+
private _filters;
|
|
7
|
+
private _values;
|
|
8
|
+
private _delete;
|
|
9
|
+
constructor(table: AbstractTable<any>);
|
|
10
|
+
filters: (filters: Expr) => DeleteAggregator;
|
|
11
|
+
appendFrom: (tableName: string) => DeleteAggregator;
|
|
12
|
+
buildQuery: () => {
|
|
13
|
+
query: string;
|
|
14
|
+
values: Array<any>;
|
|
15
|
+
};
|
|
16
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
|
|
7
|
+
class DeleteAggregator extends abstractAggregator_1.default {
|
|
8
|
+
constructor(table) {
|
|
9
|
+
super(table);
|
|
10
|
+
this._from = [];
|
|
11
|
+
this._filters = [];
|
|
12
|
+
this._values = [];
|
|
13
|
+
this._delete = ['DELETE'];
|
|
14
|
+
this.filters = (filters) => {
|
|
15
|
+
if (filters) {
|
|
16
|
+
const filterQuery = filters.toQuery();
|
|
17
|
+
this._filters.push('WHERE ');
|
|
18
|
+
this._filters.push(filterQuery.query);
|
|
19
|
+
this._values = filterQuery.values;
|
|
20
|
+
}
|
|
21
|
+
return this;
|
|
22
|
+
};
|
|
23
|
+
this.appendFrom = (tableName) => {
|
|
24
|
+
this._from.push(' FROM ');
|
|
25
|
+
this._from.push(tableName);
|
|
26
|
+
return this;
|
|
27
|
+
};
|
|
28
|
+
this.buildQuery = () => {
|
|
29
|
+
// this._delete.push(this._fields.join(''));
|
|
30
|
+
this._delete.push('\n');
|
|
31
|
+
this._delete.push(this._from.join(''));
|
|
32
|
+
this._delete.push('\n');
|
|
33
|
+
this._delete.push(this._filters.join(''));
|
|
34
|
+
this._delete.push('\n');
|
|
35
|
+
this._delete.push('RETURNING');
|
|
36
|
+
this._delete.push('\n');
|
|
37
|
+
this._delete.push(this._fields.join(''));
|
|
38
|
+
return { query: this._delete.join(''), values: this._values };
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
exports.default = DeleteAggregator;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { AbstractTable } from '../../tables';
|
|
2
|
+
import { Indexing } from '../../tables/inferTypes';
|
|
3
|
+
import { UpdateExpr } from '../requestBuilders/updates/updates';
|
|
4
|
+
import Aggregator from './abstractAggregator';
|
|
5
|
+
export default class InsertAggregator extends Aggregator {
|
|
6
|
+
private _onConflict;
|
|
7
|
+
private _columns;
|
|
8
|
+
private _query;
|
|
9
|
+
private _values;
|
|
10
|
+
private _from;
|
|
11
|
+
private _insert;
|
|
12
|
+
constructor(table: AbstractTable<any>);
|
|
13
|
+
appendColumns: () => void;
|
|
14
|
+
appendValues: (values: {
|
|
15
|
+
[name: string]: any;
|
|
16
|
+
}[]) => void;
|
|
17
|
+
appendOnConflict: (column: Indexing, updates?: UpdateExpr | undefined) => this;
|
|
18
|
+
buildQuery: () => {
|
|
19
|
+
query: string;
|
|
20
|
+
values: Array<any>;
|
|
21
|
+
};
|
|
22
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
/* eslint-disable @typescript-eslint/no-loop-func */
|
|
7
|
+
const column_1 = require("../../columns/column");
|
|
8
|
+
const abstractAggregator_1 = __importDefault(require("./abstractAggregator"));
|
|
9
|
+
class InsertAggregator extends abstractAggregator_1.default {
|
|
10
|
+
constructor(table) {
|
|
11
|
+
super(table);
|
|
12
|
+
this._onConflict = [];
|
|
13
|
+
this._columns = [];
|
|
14
|
+
this._query = [];
|
|
15
|
+
this._values = [];
|
|
16
|
+
this._from = [];
|
|
17
|
+
this._insert = ['INSERT INTO'];
|
|
18
|
+
this.appendColumns = () => {
|
|
19
|
+
const mapper = this._table.mapServiceToDb();
|
|
20
|
+
const columns = Object.values(mapper);
|
|
21
|
+
for (let i = 0; i < columns.length; i += 1) {
|
|
22
|
+
const column = columns[i];
|
|
23
|
+
this._columns.push('"');
|
|
24
|
+
this._columns.push(column.getColumnName());
|
|
25
|
+
this._columns.push('"');
|
|
26
|
+
if (i < columns.length - 1) {
|
|
27
|
+
this._columns.push(', ');
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
this.appendValues = (values) => {
|
|
32
|
+
// @TODO Check if values not empty
|
|
33
|
+
const mapper = this._table.mapServiceToDb();
|
|
34
|
+
let position = 0;
|
|
35
|
+
for (let i = 0; i < values.length; i += 1) {
|
|
36
|
+
const value = values[i];
|
|
37
|
+
this._query.push('(');
|
|
38
|
+
const entries = Object.entries(mapper);
|
|
39
|
+
entries.forEach(([key], index) => {
|
|
40
|
+
const valueToInsert = value[key];
|
|
41
|
+
const isKeyExistsInValue = key.toString() in value;
|
|
42
|
+
const column = mapper[key];
|
|
43
|
+
if (isKeyExistsInValue) {
|
|
44
|
+
if (valueToInsert !== undefined && valueToInsert !== null) {
|
|
45
|
+
position += 1;
|
|
46
|
+
this._query.push(`$${position}`);
|
|
47
|
+
this._values.push(column.getColumnType().insertStrategy(valueToInsert));
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this._query.push('null');
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
this._query.push('DEFAULT');
|
|
55
|
+
}
|
|
56
|
+
if (index < entries.length - 1) {
|
|
57
|
+
this._query.push(', ');
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
if (i < values.length - 1) {
|
|
61
|
+
this._query.push('),\n');
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this._query.push(')\n');
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
this.appendOnConflict = (column, updates) => {
|
|
69
|
+
if (column) {
|
|
70
|
+
const indexName = column instanceof column_1.IndexedColumn
|
|
71
|
+
? column.getColumnName() : column.getColumns().map((it) => it.getColumnName()).join(',');
|
|
72
|
+
this._onConflict.push(`ON CONFLICT (${indexName})\n`);
|
|
73
|
+
if (updates) {
|
|
74
|
+
const currentPointerPosition = this._values.length > 0
|
|
75
|
+
? this._values.length + 1 : undefined;
|
|
76
|
+
const updatesQuery = updates.toQuery(currentPointerPosition);
|
|
77
|
+
this._onConflict.push('DO UPDATE\n');
|
|
78
|
+
this._onConflict.push(`SET ${updatesQuery.query}`);
|
|
79
|
+
this._values.push(...updatesQuery.values);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
this._onConflict.push('DO NOTHING\n');
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return this;
|
|
86
|
+
};
|
|
87
|
+
this.buildQuery = () => {
|
|
88
|
+
this._insert.push(this._from.join(''));
|
|
89
|
+
this._insert.push(' (');
|
|
90
|
+
this._insert.push(this._columns.join(''));
|
|
91
|
+
this._insert.push(') ');
|
|
92
|
+
this._insert.push('VALUES\n');
|
|
93
|
+
this._insert.push(this._query.join(''));
|
|
94
|
+
this._insert.push('\n');
|
|
95
|
+
this._insert.push(this._onConflict.join(''));
|
|
96
|
+
this._insert.push('\n');
|
|
97
|
+
this._insert.push('RETURNING');
|
|
98
|
+
this._insert.push('\n');
|
|
99
|
+
this._insert.push(this._fields.join(''));
|
|
100
|
+
return { query: this._insert.join(''), values: this._values };
|
|
101
|
+
};
|
|
102
|
+
this._from.push(' ');
|
|
103
|
+
this._from.push(table.tableName());
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
exports.default = InsertAggregator;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { AbstractColumn } from '../../columns/column';
|
|
2
|
+
import ColumnType from '../../columns/types/columnType';
|
|
3
|
+
import { AbstractTable } from '../../tables';
|
|
4
|
+
import Order from '../highLvlBuilders/order';
|
|
5
|
+
import Join from '../joinBuilders/join';
|
|
6
|
+
import Expr from '../requestBuilders/where/where';
|
|
7
|
+
import Aggregator from './abstractAggregator';
|
|
8
|
+
export default class SelectAggregator extends Aggregator {
|
|
9
|
+
private _from;
|
|
10
|
+
private _filters;
|
|
11
|
+
private _select;
|
|
12
|
+
private _join;
|
|
13
|
+
private _limit;
|
|
14
|
+
private _offset;
|
|
15
|
+
private _distinct;
|
|
16
|
+
private _orderBy;
|
|
17
|
+
private _values;
|
|
18
|
+
private _joinCache;
|
|
19
|
+
constructor(table: AbstractTable<any>, partial?: {
|
|
20
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, AbstractTable<any>>;
|
|
21
|
+
});
|
|
22
|
+
filters: (filters: Expr) => SelectAggregator;
|
|
23
|
+
limit: (limit?: number | undefined) => SelectAggregator;
|
|
24
|
+
offset: (offset?: number | undefined) => SelectAggregator;
|
|
25
|
+
orderBy: (column?: AbstractColumn<ColumnType<{}>, boolean, boolean, any> | undefined, order?: Order | undefined) => SelectAggregator;
|
|
26
|
+
distinct: (column?: AbstractColumn<ColumnType<{}>, boolean, boolean, any> | undefined) => SelectAggregator;
|
|
27
|
+
appendFrom: (tableName: string) => SelectAggregator;
|
|
28
|
+
join: (joins: {
|
|
29
|
+
join: Join<any>;
|
|
30
|
+
partial?: {
|
|
31
|
+
[name: string]: AbstractColumn<ColumnType<any>, boolean, boolean, any>;
|
|
32
|
+
} | undefined;
|
|
33
|
+
id?: number | undefined;
|
|
34
|
+
}[]) => SelectAggregator;
|
|
35
|
+
buildQuery: () => {
|
|
36
|
+
query: string;
|
|
37
|
+
values: Array<any>;
|
|
38
|
+
};
|
|
39
|
+
}
|