drizzle-orm 0.10.25 → 0.10.28
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/.eslintrc +28 -0
- package/.tslintignore +1 -0
- package/CHANGELOG.md +202 -0
- package/README.md +439 -0
- package/dist/builders/aggregators/abstractAggregator.d.ts +11 -0
- package/dist/builders/aggregators/abstractAggregator.js +35 -0
- package/dist/builders/aggregators/deleteAggregator.d.ts +16 -0
- package/dist/builders/aggregators/deleteAggregator.js +42 -0
- package/dist/builders/aggregators/insertAggregator.d.ts +22 -0
- package/dist/builders/aggregators/insertAggregator.js +106 -0
- package/dist/builders/aggregators/selectAggregator.d.ts +39 -0
- package/dist/builders/aggregators/selectAggregator.js +143 -0
- package/dist/builders/aggregators/updateAggregator.d.ts +19 -0
- package/dist/builders/aggregators/updateAggregator.js +50 -0
- package/dist/builders/highLvlBuilders/abstractRequestBuilder.d.ts +27 -0
- package/dist/builders/highLvlBuilders/abstractRequestBuilder.js +32 -0
- package/dist/builders/highLvlBuilders/deleteRequestBuilder.d.ts +19 -0
- package/dist/builders/highLvlBuilders/deleteRequestBuilder.js +61 -0
- package/dist/builders/highLvlBuilders/insertRequestBuilder.d.ts +20 -0
- package/dist/builders/highLvlBuilders/insertRequestBuilder.js +73 -0
- package/dist/builders/highLvlBuilders/order.d.ts +5 -0
- package/dist/builders/highLvlBuilders/order.js +8 -0
- package/dist/builders/highLvlBuilders/selectRequestBuilder.d.ts +47 -0
- package/dist/builders/highLvlBuilders/selectRequestBuilder.js +128 -0
- package/dist/builders/highLvlBuilders/updateRequestBuilder.d.ts +22 -0
- package/dist/builders/highLvlBuilders/updateRequestBuilder.js +80 -0
- package/dist/builders/index.d.ts +18 -0
- package/dist/builders/index.js +54 -0
- package/dist/builders/joinBuilders/builders/abstractJoinBuilder.d.ts +40 -0
- package/dist/builders/joinBuilders/builders/abstractJoinBuilder.js +78 -0
- package/dist/builders/joinBuilders/builders/selectWithFiveJoins.d.ts +35 -0
- package/dist/builders/joinBuilders/builders/selectWithFiveJoins.js +45 -0
- package/dist/builders/joinBuilders/builders/selectWithFourJoins.d.ts +55 -0
- package/dist/builders/joinBuilders/builders/selectWithFourJoins.js +78 -0
- package/dist/builders/joinBuilders/builders/selectWithJoin.d.ts +49 -0
- package/dist/builders/joinBuilders/builders/selectWithJoin.js +64 -0
- package/dist/builders/joinBuilders/builders/selectWithThreeJoins.d.ts +53 -0
- package/dist/builders/joinBuilders/builders/selectWithThreeJoins.js +73 -0
- package/dist/builders/joinBuilders/builders/selectWithTwoJoins.d.ts +51 -0
- package/dist/builders/joinBuilders/builders/selectWithTwoJoins.js +68 -0
- package/dist/builders/joinBuilders/join.d.ts +23 -0
- package/dist/builders/joinBuilders/join.js +28 -0
- package/dist/builders/joinBuilders/joinWith.d.ts +14 -0
- package/dist/builders/joinBuilders/joinWith.js +14 -0
- package/dist/builders/joinBuilders/responses/selectResponseFiveJoins.d.ts +20 -0
- package/dist/builders/joinBuilders/responses/selectResponseFiveJoins.js +35 -0
- package/dist/builders/joinBuilders/responses/selectResponseFourJoins.d.ts +19 -0
- package/dist/builders/joinBuilders/responses/selectResponseFourJoins.js +34 -0
- package/dist/builders/joinBuilders/responses/selectResponseThreeJoins.d.ts +18 -0
- package/dist/builders/joinBuilders/responses/selectResponseThreeJoins.js +33 -0
- package/dist/builders/joinBuilders/responses/selectResponseTwoJoins.d.ts +17 -0
- package/dist/builders/joinBuilders/responses/selectResponseTwoJoins.js +32 -0
- package/dist/builders/joinBuilders/responses/selectResponseWithJoin.d.ts +16 -0
- package/dist/builders/joinBuilders/responses/selectResponseWithJoin.js +31 -0
- package/dist/builders/joinBuilders/static.d.ts +5 -0
- package/dist/builders/joinBuilders/static.js +9 -0
- package/dist/builders/lowLvlBuilders/alter.d.ts +0 -0
- package/dist/builders/lowLvlBuilders/alter.js +1 -0
- package/dist/builders/lowLvlBuilders/create.d.ts +12 -0
- package/dist/builders/lowLvlBuilders/create.js +100 -0
- package/dist/builders/lowLvlBuilders/delets/delete.d.ts +5 -0
- package/dist/builders/lowLvlBuilders/delets/delete.js +15 -0
- package/dist/builders/lowLvlBuilders/delets/deleteFilter.d.ts +11 -0
- package/dist/builders/lowLvlBuilders/delets/deleteFilter.js +13 -0
- package/dist/builders/lowLvlBuilders/delets/deleteFrom.d.ts +12 -0
- package/dist/builders/lowLvlBuilders/delets/deleteFrom.js +14 -0
- package/dist/builders/lowLvlBuilders/inserts/insert.d.ts +5 -0
- package/dist/builders/lowLvlBuilders/inserts/insert.js +15 -0
- package/dist/builders/lowLvlBuilders/inserts/insertInto.d.ts +13 -0
- package/dist/builders/lowLvlBuilders/inserts/insertInto.js +16 -0
- package/dist/builders/lowLvlBuilders/inserts/onConflictInsert.d.ts +12 -0
- package/dist/builders/lowLvlBuilders/inserts/onConflictInsert.js +13 -0
- package/dist/builders/lowLvlBuilders/inserts/valuesInsert.d.ts +16 -0
- package/dist/builders/lowLvlBuilders/inserts/valuesInsert.js +19 -0
- package/dist/builders/lowLvlBuilders/selects/select.d.ts +9 -0
- package/dist/builders/lowLvlBuilders/selects/select.js +16 -0
- package/dist/builders/lowLvlBuilders/selects/selectFrom.d.ts +28 -0
- package/dist/builders/lowLvlBuilders/selects/selectFrom.js +34 -0
- package/dist/builders/lowLvlBuilders/selects/selectJoined.d.ts +26 -0
- package/dist/builders/lowLvlBuilders/selects/selectJoined.js +30 -0
- package/dist/builders/lowLvlBuilders/selects/whereSelect.d.ts +17 -0
- package/dist/builders/lowLvlBuilders/selects/whereSelect.js +25 -0
- package/dist/builders/lowLvlBuilders/updates/update.d.ts +5 -0
- package/dist/builders/lowLvlBuilders/updates/update.js +15 -0
- package/dist/builders/lowLvlBuilders/updates/updateIn.d.ts +13 -0
- package/dist/builders/lowLvlBuilders/updates/updateIn.js +15 -0
- package/dist/builders/lowLvlBuilders/updates/whereSelect.d.ts +11 -0
- package/dist/builders/lowLvlBuilders/updates/whereSelect.js +13 -0
- package/dist/builders/lowLvlBuilders/updates/whereSet.d.ts +14 -0
- package/dist/builders/lowLvlBuilders/updates/whereSet.js +18 -0
- package/dist/builders/requestBuilders/updates/combine.d.ts +9 -0
- package/dist/builders/requestBuilders/updates/combine.js +26 -0
- package/dist/builders/requestBuilders/updates/increment.d.ts +13 -0
- package/dist/builders/requestBuilders/updates/increment.js +18 -0
- package/dist/builders/requestBuilders/updates/setObjects.d.ts +12 -0
- package/dist/builders/requestBuilders/updates/setObjects.js +19 -0
- package/dist/builders/requestBuilders/updates/static.d.ts +7 -0
- package/dist/builders/requestBuilders/updates/static.js +15 -0
- package/dist/builders/requestBuilders/updates/updates.d.ts +9 -0
- package/dist/builders/requestBuilders/updates/updates.js +10 -0
- package/dist/builders/requestBuilders/where/and.d.ts +11 -0
- package/dist/builders/requestBuilders/where/and.js +31 -0
- package/dist/builders/requestBuilders/where/const.d.ts +9 -0
- package/dist/builders/requestBuilders/where/const.js +25 -0
- package/dist/builders/requestBuilders/where/constArray.d.ts +9 -0
- package/dist/builders/requestBuilders/where/constArray.js +39 -0
- package/dist/builders/requestBuilders/where/eqWhere.d.ts +12 -0
- package/dist/builders/requestBuilders/where/eqWhere.js +20 -0
- package/dist/builders/requestBuilders/where/greater.d.ts +15 -0
- package/dist/builders/requestBuilders/where/greater.js +20 -0
- package/dist/builders/requestBuilders/where/greaterEq.d.ts +15 -0
- package/dist/builders/requestBuilders/where/greaterEq.js +20 -0
- package/dist/builders/requestBuilders/where/in.d.ts +12 -0
- package/dist/builders/requestBuilders/where/in.js +20 -0
- package/dist/builders/requestBuilders/where/isNotNull.d.ts +11 -0
- package/dist/builders/requestBuilders/where/isNotNull.js +18 -0
- package/dist/builders/requestBuilders/where/isNull.d.ts +11 -0
- package/dist/builders/requestBuilders/where/isNull.js +18 -0
- package/dist/builders/requestBuilders/where/less.d.ts +15 -0
- package/dist/builders/requestBuilders/where/less.js +20 -0
- package/dist/builders/requestBuilders/where/lessEq.d.ts +15 -0
- package/dist/builders/requestBuilders/where/lessEq.js +20 -0
- package/dist/builders/requestBuilders/where/like.d.ts +12 -0
- package/dist/builders/requestBuilders/where/like.js +20 -0
- package/dist/builders/requestBuilders/where/notEqWhere.d.ts +12 -0
- package/dist/builders/requestBuilders/where/notEqWhere.js +20 -0
- package/dist/builders/requestBuilders/where/or.d.ts +11 -0
- package/dist/builders/requestBuilders/where/or.js +31 -0
- package/dist/builders/requestBuilders/where/rawWhere.d.ts +9 -0
- package/dist/builders/requestBuilders/where/rawWhere.js +15 -0
- package/dist/builders/requestBuilders/where/static.d.ts +17 -0
- package/dist/builders/requestBuilders/where/static.js +49 -0
- package/dist/builders/requestBuilders/where/var.d.ts +13 -0
- package/dist/builders/requestBuilders/where/var.js +18 -0
- package/dist/builders/requestBuilders/where/where.d.ts +8 -0
- package/dist/builders/requestBuilders/where/where.js +6 -0
- package/dist/builders/transaction/transaction.d.ts +8 -0
- package/dist/builders/transaction/transaction.js +20 -0
- package/dist/columns/column.d.ts +72 -0
- package/dist/columns/column.js +101 -0
- package/dist/columns/index.d.ts +10 -0
- package/dist/columns/index.js +27 -0
- package/dist/columns/types/columnType.d.ts +7 -0
- package/dist/columns/types/columnType.js +6 -0
- package/dist/columns/types/pgBigDecimal.d.ts +10 -0
- package/dist/columns/types/pgBigDecimal.js +31 -0
- package/dist/columns/types/pgBigInt.d.ts +15 -0
- package/dist/columns/types/pgBigInt.js +32 -0
- package/dist/columns/types/pgBigSerial.d.ts +15 -0
- package/dist/columns/types/pgBigSerial.js +32 -0
- package/dist/columns/types/pgBoolean.d.ts +8 -0
- package/dist/columns/types/pgBoolean.js +18 -0
- package/dist/columns/types/pgEnum.d.ts +9 -0
- package/dist/columns/types/pgEnum.js +18 -0
- package/dist/columns/types/pgInteger.d.ts +8 -0
- package/dist/columns/types/pgInteger.js +21 -0
- package/dist/columns/types/pgJsonb.d.ts +9 -0
- package/dist/columns/types/pgJsonb.js +20 -0
- package/dist/columns/types/pgSerial.d.ts +8 -0
- package/dist/columns/types/pgSerial.js +18 -0
- package/dist/columns/types/pgSmallInt.d.ts +8 -0
- package/dist/columns/types/pgSmallInt.js +18 -0
- package/dist/columns/types/pgText.d.ts +8 -0
- package/dist/columns/types/pgText.js +18 -0
- package/dist/columns/types/pgTime.d.ts +8 -0
- package/dist/columns/types/pgTime.js +18 -0
- package/dist/columns/types/pgTimestamp.d.ts +8 -0
- package/dist/columns/types/pgTimestamp.js +18 -0
- package/dist/columns/types/pgTimestamptz.d.ts +8 -0
- package/dist/columns/types/pgTimestamptz.js +18 -0
- package/dist/columns/types/pgVarChar.d.ts +9 -0
- package/dist/columns/types/pgVarChar.js +24 -0
- package/dist/db/db.d.ts +18 -0
- package/dist/db/db.js +25 -0
- package/dist/db/dbConnector.d.ts +9 -0
- package/dist/db/dbConnector.js +32 -0
- package/dist/db/dbStringConnector.d.ts +6 -0
- package/dist/db/dbStringConnector.js +29 -0
- package/dist/db/group_by.d.ts +0 -0
- package/dist/db/group_by.js +68 -0
- package/dist/db/index.d.ts +4 -0
- package/dist/db/index.js +14 -0
- package/dist/db/session.d.ts +9 -0
- package/dist/db/session.js +16 -0
- package/dist/docs/cases/simple_delete.d.ts +1 -0
- package/dist/docs/cases/simple_delete.js +35 -0
- package/dist/docs/cases/simple_insert.d.ts +1 -0
- package/dist/docs/cases/simple_insert.js +57 -0
- package/dist/docs/cases/simple_join.d.ts +1 -0
- package/dist/docs/cases/simple_join.js +115 -0
- package/dist/docs/cases/simple_select.d.ts +1 -0
- package/dist/docs/cases/simple_select.js +50 -0
- package/dist/docs/cases/simple_update.d.ts +1 -0
- package/dist/docs/cases/simple_update.js +39 -0
- package/dist/docs/tables/citiesTable.d.ts +14 -0
- package/dist/docs/tables/citiesTable.js +21 -0
- package/dist/docs/tables/userGroupsTable.d.ts +7 -0
- package/dist/docs/tables/userGroupsTable.js +18 -0
- package/dist/docs/tables/usersTable.d.ts +17 -0
- package/dist/docs/tables/usersTable.js +35 -0
- package/dist/docs/tables/usersToUserGroups.d.ts +7 -0
- package/dist/docs/tables/usersToUserGroups.js +20 -0
- package/dist/docs/types/rolesType.d.ts +1 -0
- package/dist/docs/types/rolesType.js +6 -0
- package/dist/errors/baseError.d.ts +22 -0
- package/dist/errors/baseError.js +35 -0
- package/dist/errors/builderError.d.ts +14 -0
- package/dist/errors/builderError.js +25 -0
- package/dist/errors/dbErrors.d.ts +12 -0
- package/dist/errors/dbErrors.js +28 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.js +31 -0
- package/dist/indexes/tableIndex.d.ts +11 -0
- package/dist/indexes/tableIndex.js +17 -0
- package/dist/logger/abstractLogger.d.ts +4 -0
- package/dist/logger/abstractLogger.js +5 -0
- package/dist/logger/consoleLogger.d.ts +5 -0
- package/dist/logger/consoleLogger.js +15 -0
- package/dist/mappers/index.d.ts +0 -0
- package/dist/mappers/index.js +1 -0
- package/dist/mappers/responseMapper.d.ts +10 -0
- package/dist/mappers/responseMapper.js +35 -0
- package/dist/migrator/index.d.ts +0 -0
- package/dist/migrator/index.js +1 -0
- package/dist/migrator/migrator.d.ts +11 -0
- package/dist/migrator/migrator.js +105 -0
- package/dist/serializer/serializer.d.ts +47 -0
- package/dist/serializer/serializer.js +258 -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/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 +3 -7
- package/pnpm-lock.yaml +1842 -0
- package/src/builders/aggregators/abstractAggregator.ts +41 -0
- package/src/builders/aggregators/deleteAggregator.ts +44 -0
- package/src/builders/aggregators/insertAggregator.ts +120 -0
- package/src/builders/aggregators/selectAggregator.ts +163 -0
- package/src/builders/aggregators/updateAggregator.ts +56 -0
- package/src/builders/highLvlBuilders/abstractRequestBuilder.ts +51 -0
- package/src/builders/highLvlBuilders/deleteRequestBuilder.ts +59 -0
- package/src/builders/highLvlBuilders/insertRequestBuilder.ts +75 -0
- package/src/builders/highLvlBuilders/order.ts +4 -0
- package/src/builders/highLvlBuilders/selectRequestBuilder.ts +229 -0
- package/src/builders/highLvlBuilders/updateRequestBuilder.ts +80 -0
- package/src/builders/index.ts +21 -0
- package/src/builders/joinBuilders/builders/abstractJoinBuilder.ts +98 -0
- package/src/builders/joinBuilders/builders/selectWithFiveJoins.ts +110 -0
- package/src/builders/joinBuilders/builders/selectWithFourJoins.ts +254 -0
- package/src/builders/joinBuilders/builders/selectWithJoin.ts +189 -0
- package/src/builders/joinBuilders/builders/selectWithThreeJoins.ts +231 -0
- package/src/builders/joinBuilders/builders/selectWithTwoJoins.ts +210 -0
- package/src/builders/joinBuilders/join.ts +40 -0
- package/src/builders/joinBuilders/joinWith.ts +21 -0
- package/src/builders/joinBuilders/responses/selectResponseFiveJoins.ts +82 -0
- package/src/builders/joinBuilders/responses/selectResponseFourJoins.ts +73 -0
- package/src/builders/joinBuilders/responses/selectResponseThreeJoins.ts +64 -0
- package/src/builders/joinBuilders/responses/selectResponseTwoJoins.ts +57 -0
- package/src/builders/joinBuilders/responses/selectResponseWithJoin.ts +49 -0
- package/src/builders/joinBuilders/static.ts +9 -0
- package/src/builders/lowLvlBuilders/alter.ts +0 -0
- package/src/builders/lowLvlBuilders/create.ts +115 -0
- package/src/builders/lowLvlBuilders/delets/delete.ts +13 -0
- package/src/builders/lowLvlBuilders/delets/deleteFilter.ts +17 -0
- package/src/builders/lowLvlBuilders/delets/deleteFrom.ts +15 -0
- package/src/builders/lowLvlBuilders/inserts/insert.ts +11 -0
- package/src/builders/lowLvlBuilders/inserts/insertInto.ts +16 -0
- package/src/builders/lowLvlBuilders/inserts/onConflictInsert.ts +19 -0
- package/src/builders/lowLvlBuilders/inserts/valuesInsert.ts +27 -0
- package/src/builders/lowLvlBuilders/selects/select.ts +14 -0
- package/src/builders/lowLvlBuilders/selects/selectFrom.ts +50 -0
- package/src/builders/lowLvlBuilders/selects/selectJoined.ts +44 -0
- package/src/builders/lowLvlBuilders/selects/whereSelect.ts +36 -0
- package/src/builders/lowLvlBuilders/updates/update.ts +13 -0
- package/src/builders/lowLvlBuilders/updates/updateIn.ts +17 -0
- package/src/builders/lowLvlBuilders/updates/whereSelect.ts +17 -0
- package/src/builders/lowLvlBuilders/updates/whereSet.ts +21 -0
- package/src/builders/requestBuilders/updates/combine.ts +34 -0
- package/src/builders/requestBuilders/updates/increment.ts +24 -0
- package/src/builders/requestBuilders/updates/setObjects.ts +27 -0
- package/src/builders/requestBuilders/updates/static.ts +15 -0
- package/src/builders/requestBuilders/updates/updates.ts +8 -0
- package/src/builders/requestBuilders/where/and.ts +35 -0
- package/src/builders/requestBuilders/where/const.ts +23 -0
- package/src/builders/requestBuilders/where/constArray.ts +37 -0
- package/src/builders/requestBuilders/where/eqWhere.ts +20 -0
- package/src/builders/requestBuilders/where/greater.ts +20 -0
- package/src/builders/requestBuilders/where/greaterEq.ts +20 -0
- package/src/builders/requestBuilders/where/in.ts +20 -0
- package/src/builders/requestBuilders/where/isNotNull.ts +17 -0
- package/src/builders/requestBuilders/where/isNull.ts +17 -0
- package/src/builders/requestBuilders/where/less.ts +20 -0
- package/src/builders/requestBuilders/where/lessEq.ts +20 -0
- package/src/builders/requestBuilders/where/like.ts +20 -0
- package/src/builders/requestBuilders/where/notEqWhere.ts +20 -0
- package/src/builders/requestBuilders/where/or.ts +35 -0
- package/src/builders/requestBuilders/where/rawWhere.ts +10 -0
- package/src/builders/requestBuilders/where/static.ts +60 -0
- package/src/builders/requestBuilders/where/var.ts +19 -0
- package/src/builders/requestBuilders/where/where.ts +5 -0
- package/src/builders/transaction/transaction.ts +21 -0
- package/src/columns/column.ts +195 -0
- package/src/columns/index.ts +10 -0
- package/src/columns/types/columnType.ts +8 -0
- package/src/columns/types/pgBigDecimal.ts +29 -0
- package/src/columns/types/pgBigInt.ts +36 -0
- package/src/columns/types/pgBigSerial.ts +36 -0
- package/src/columns/types/pgBoolean.ts +18 -0
- package/src/columns/types/pgEnum.ts +17 -0
- package/src/columns/types/pgInteger.ts +21 -0
- package/src/columns/types/pgJsonb.ts +21 -0
- package/src/columns/types/pgSerial.ts +18 -0
- package/src/columns/types/pgSmallInt.ts +18 -0
- package/src/columns/types/pgText.ts +18 -0
- package/src/columns/types/pgTime.ts +18 -0
- package/src/columns/types/pgTimestamp.ts +18 -0
- package/src/columns/types/pgTimestamptz.ts +18 -0
- package/src/columns/types/pgVarChar.ts +24 -0
- package/src/db/db.ts +43 -0
- package/src/db/dbConnector.ts +30 -0
- package/src/db/dbStringConnector.ts +29 -0
- package/src/db/group_by.ts +75 -0
- package/src/db/index.ts +4 -0
- package/src/db/session.ts +16 -0
- package/src/docs/cases/simple_delete.ts +35 -0
- package/src/docs/cases/simple_insert.ts +65 -0
- package/src/docs/cases/simple_join.ts +140 -0
- package/src/docs/cases/simple_select.ts +72 -0
- package/src/docs/cases/simple_update.ts +40 -0
- package/src/docs/tables/citiesTable.ts +22 -0
- package/src/docs/tables/userGroupsTable.ts +12 -0
- package/src/docs/tables/usersTable.ts +33 -0
- package/src/docs/tables/usersToUserGroups.ts +14 -0
- package/src/docs/types/rolesType.ts +4 -0
- package/src/errors/baseError.ts +47 -0
- package/src/errors/builderError.ts +31 -0
- package/src/errors/dbErrors.ts +24 -0
- package/src/index.ts +20 -0
- package/src/indexes/tableIndex.ts +25 -0
- package/src/logger/abstractLogger.ts +4 -0
- package/src/logger/consoleLogger.ts +11 -0
- package/src/mappers/index.ts +0 -0
- package/src/mappers/responseMapper.ts +46 -0
- package/src/migrator/index.ts +0 -0
- package/src/migrator/migrator.ts +97 -0
- package/src/serializer/serializer.ts +336 -0
- package/src/tables/abstractTable.ts +188 -0
- package/src/tables/index.ts +4 -0
- package/src/tables/inferTypes.ts +67 -0
- package/src/tables/migrationsTable.ts +11 -0
- package/src/types/type.ts +15 -0
- package/src/utils/ecranate.ts +4 -0
- package/tsconfig.json +13 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export interface Failure {
|
|
2
|
+
type: PgSessionError;
|
|
3
|
+
reason: Error;
|
|
4
|
+
}
|
|
5
|
+
export declare enum PgSessionError {
|
|
6
|
+
PgQueryExecutionError = 0
|
|
7
|
+
}
|
|
8
|
+
export declare type Either<L, A> = Left<L, A> | Right<L, A>;
|
|
9
|
+
export declare class Left<L, A> {
|
|
10
|
+
readonly value: L;
|
|
11
|
+
constructor(value: L);
|
|
12
|
+
isLeft(): this is Left<L, A>;
|
|
13
|
+
isRight(): this is Right<L, A>;
|
|
14
|
+
}
|
|
15
|
+
export declare class Right<L, A> {
|
|
16
|
+
readonly value: A;
|
|
17
|
+
constructor(value: A);
|
|
18
|
+
isLeft(): this is Left<L, A>;
|
|
19
|
+
isRight(): this is Right<L, A>;
|
|
20
|
+
}
|
|
21
|
+
export declare const left: <L, A>(l: L) => Either<L, A>;
|
|
22
|
+
export declare const right: <L, A>(a: A) => Either<L, A>;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.right = exports.left = exports.Right = exports.Left = exports.PgSessionError = void 0;
|
|
4
|
+
var PgSessionError;
|
|
5
|
+
(function (PgSessionError) {
|
|
6
|
+
PgSessionError[PgSessionError["PgQueryExecutionError"] = 0] = "PgQueryExecutionError";
|
|
7
|
+
})(PgSessionError = exports.PgSessionError || (exports.PgSessionError = {}));
|
|
8
|
+
class Left {
|
|
9
|
+
constructor(value) {
|
|
10
|
+
this.value = value;
|
|
11
|
+
}
|
|
12
|
+
isLeft() {
|
|
13
|
+
return true;
|
|
14
|
+
}
|
|
15
|
+
isRight() {
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.Left = Left;
|
|
20
|
+
class Right {
|
|
21
|
+
constructor(value) {
|
|
22
|
+
this.value = value;
|
|
23
|
+
}
|
|
24
|
+
isLeft() {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
isRight() {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.Right = Right;
|
|
32
|
+
const left = (l) => new Left(l);
|
|
33
|
+
exports.left = left;
|
|
34
|
+
const right = (a) => new Right(a);
|
|
35
|
+
exports.right = right;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import Expr from '../builders/requestBuilders/where/where';
|
|
2
|
+
import { AbstractColumn } from '../columns/column';
|
|
3
|
+
import ColumnType from '../columns/types/columnType';
|
|
4
|
+
export declare enum BuilderType {
|
|
5
|
+
SELECT = 0,
|
|
6
|
+
JOINED_SELECT = 1,
|
|
7
|
+
TWO_JOINED_SELECT = 2,
|
|
8
|
+
DELETE = 3,
|
|
9
|
+
INSERT = 4,
|
|
10
|
+
UPDATE = 5
|
|
11
|
+
}
|
|
12
|
+
export default class BuilderError extends Error {
|
|
13
|
+
constructor(builderType: BuilderType, tableName: string, columns: AbstractColumn<ColumnType>[], reason: Error, filter?: Expr);
|
|
14
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BuilderType = void 0;
|
|
4
|
+
var BuilderType;
|
|
5
|
+
(function (BuilderType) {
|
|
6
|
+
BuilderType[BuilderType["SELECT"] = 0] = "SELECT";
|
|
7
|
+
BuilderType[BuilderType["JOINED_SELECT"] = 1] = "JOINED_SELECT";
|
|
8
|
+
BuilderType[BuilderType["TWO_JOINED_SELECT"] = 2] = "TWO_JOINED_SELECT";
|
|
9
|
+
BuilderType[BuilderType["DELETE"] = 3] = "DELETE";
|
|
10
|
+
BuilderType[BuilderType["INSERT"] = 4] = "INSERT";
|
|
11
|
+
BuilderType[BuilderType["UPDATE"] = 5] = "UPDATE";
|
|
12
|
+
})(BuilderType = exports.BuilderType || (exports.BuilderType = {}));
|
|
13
|
+
class BuilderError extends Error {
|
|
14
|
+
constructor(builderType, tableName, columns, reason, filter) {
|
|
15
|
+
super('');
|
|
16
|
+
this.message = ` Error while building select query from ${tableName}\n-----\nIf you see current error, please create [github issue](https://github.com/lambda-direct/drizzle-orm/issues) and provide following information\n
|
|
17
|
+
Reason: ${reason.message}
|
|
18
|
+
Query builder: ${BuilderType[builderType]}
|
|
19
|
+
Table name: ${tableName}
|
|
20
|
+
Filter query: ${filter ? filter.toQuery().query : 'undefined'}
|
|
21
|
+
Values: ${filter ? filter.toQuery().values : 'undefined'}
|
|
22
|
+
Column names: ${columns.map((column) => column.getColumnName()).join(', ')}\n-----\n`;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.default = BuilderError;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export declare class DatabaseSelectError extends Error {
|
|
2
|
+
constructor(tableName: string, reason: Error, query: string);
|
|
3
|
+
}
|
|
4
|
+
export declare class DatabaseDeleteError extends Error {
|
|
5
|
+
constructor(tableName: string, reason: Error, query: string);
|
|
6
|
+
}
|
|
7
|
+
export declare class DatabaseInsertError extends Error {
|
|
8
|
+
constructor(tableName: string, reason: Error, query: string);
|
|
9
|
+
}
|
|
10
|
+
export declare class DatabaseUpdateError extends Error {
|
|
11
|
+
constructor(tableName: string, reason: Error, query: string);
|
|
12
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DatabaseUpdateError = exports.DatabaseInsertError = exports.DatabaseDeleteError = exports.DatabaseSelectError = void 0;
|
|
4
|
+
/* eslint-disable max-classes-per-file */
|
|
5
|
+
class DatabaseSelectError extends Error {
|
|
6
|
+
constructor(tableName, reason, query) {
|
|
7
|
+
super(` Got an error, while selecting from ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
exports.DatabaseSelectError = DatabaseSelectError;
|
|
11
|
+
class DatabaseDeleteError extends Error {
|
|
12
|
+
constructor(tableName, reason, query) {
|
|
13
|
+
super(` Got an error, while deleting from ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
exports.DatabaseDeleteError = DatabaseDeleteError;
|
|
17
|
+
class DatabaseInsertError extends Error {
|
|
18
|
+
constructor(tableName, reason, query) {
|
|
19
|
+
super(` Got an error, while inserting to ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
exports.DatabaseInsertError = DatabaseInsertError;
|
|
23
|
+
class DatabaseUpdateError extends Error {
|
|
24
|
+
constructor(tableName, reason, query) {
|
|
25
|
+
super(` Got an error, while updating ${tableName}. Reason: ${reason.message}. Query to database looks like:\n${query}\n`);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.DatabaseUpdateError = DatabaseUpdateError;
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ClientConfig } from 'pg';
|
|
2
|
+
import { DB } from './db';
|
|
3
|
+
import Migrator from './migrator/migrator';
|
|
4
|
+
export * from './db';
|
|
5
|
+
export * from './builders';
|
|
6
|
+
export * from './columns';
|
|
7
|
+
export * from './tables';
|
|
8
|
+
export declare const drizzle: {
|
|
9
|
+
connect(config: ClientConfig): Promise<DB>;
|
|
10
|
+
migrator(db: DB): Migrator;
|
|
11
|
+
};
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
13
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
14
|
+
};
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.drizzle = void 0;
|
|
17
|
+
const db_1 = require("./db");
|
|
18
|
+
const migrator_1 = __importDefault(require("./migrator/migrator"));
|
|
19
|
+
__exportStar(require("./db"), exports);
|
|
20
|
+
__exportStar(require("./builders"), exports);
|
|
21
|
+
__exportStar(require("./columns"), exports);
|
|
22
|
+
__exportStar(require("./tables"), exports);
|
|
23
|
+
exports.drizzle = {
|
|
24
|
+
async connect(config) {
|
|
25
|
+
const dbConnector = new db_1.DbConnector().params(config);
|
|
26
|
+
return dbConnector.connect();
|
|
27
|
+
},
|
|
28
|
+
migrator(db) {
|
|
29
|
+
return new migrator_1.default(db);
|
|
30
|
+
},
|
|
31
|
+
};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Column } from '../columns/column';
|
|
2
|
+
import ColumnType from '../columns/types/columnType';
|
|
3
|
+
export default class TableIndex {
|
|
4
|
+
private _columns;
|
|
5
|
+
private _tableName;
|
|
6
|
+
private _isUnique;
|
|
7
|
+
constructor(tableName: string, columns: Column<ColumnType<any>, boolean, boolean>[], isUnique?: boolean);
|
|
8
|
+
getColumns: () => Column<ColumnType<any>, boolean, boolean>[];
|
|
9
|
+
indexName: () => string;
|
|
10
|
+
isUnique: () => boolean;
|
|
11
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
class TableIndex {
|
|
4
|
+
constructor(tableName, columns, isUnique = false) {
|
|
5
|
+
this._columns = [];
|
|
6
|
+
this.getColumns = () => this._columns;
|
|
7
|
+
this.indexName = () => {
|
|
8
|
+
const columnNames = this._columns.map((column) => column.getColumnName());
|
|
9
|
+
return `${this._tableName}_${columnNames.join('_')}_index`;
|
|
10
|
+
};
|
|
11
|
+
this.isUnique = () => this._isUnique;
|
|
12
|
+
this._columns = columns;
|
|
13
|
+
this._tableName = tableName;
|
|
14
|
+
this._isUnique = isUnique;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
exports.default = TableIndex;
|
|
@@ -0,0 +1,15 @@
|
|
|
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 abstractLogger_1 = __importDefault(require("./abstractLogger"));
|
|
7
|
+
class ConsoleLogger extends abstractLogger_1.default {
|
|
8
|
+
info(msg) {
|
|
9
|
+
console.log(`INFO: ${msg}`);
|
|
10
|
+
}
|
|
11
|
+
error(msg) {
|
|
12
|
+
console.log(`ERROR: ${msg}`);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.default = ConsoleLogger;
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { QueryResult } from 'pg';
|
|
2
|
+
import { AbstractColumn } from '../columns/column';
|
|
3
|
+
import ColumnType from '../columns/types/columnType';
|
|
4
|
+
import { ExtractModel } from '../tables/inferTypes';
|
|
5
|
+
export default class QueryResponseMapper {
|
|
6
|
+
static map: <ITable>(mappedServiceToDb: { [name in keyof ExtractModel<ITable>]: AbstractColumn<ColumnType<{}>, true, false, any>; }, queryResult: QueryResult<any>, joinId?: number | undefined) => ExtractModel<ITable>[];
|
|
7
|
+
static partialMap: <T>(partial: {
|
|
8
|
+
[name: string]: AbstractColumn<ColumnType<{}>, true, false, any>;
|
|
9
|
+
}, queryResult: QueryResult<any>, joinId?: number | undefined) => ExtractModel<T>[];
|
|
10
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
// eslint-disable-next-line max-len
|
|
4
|
+
// const checkProperties = (obj: any) => Object.values(obj).every((x) => x === null || Number.isNaN(x));
|
|
5
|
+
class QueryResponseMapper {
|
|
6
|
+
}
|
|
7
|
+
exports.default = QueryResponseMapper;
|
|
8
|
+
QueryResponseMapper.map = (mappedServiceToDb, queryResult, joinId) => {
|
|
9
|
+
const response = [];
|
|
10
|
+
queryResult.rows.forEach((row) => {
|
|
11
|
+
const mappedRow = {};
|
|
12
|
+
Object.keys(mappedServiceToDb).forEach((key) => {
|
|
13
|
+
const column = mappedServiceToDb[key];
|
|
14
|
+
const alias = `${column.getAlias()}${joinId ? `_${joinId}` : ''}`;
|
|
15
|
+
const value = column.getColumnType().selectStrategy(row[alias]);
|
|
16
|
+
mappedRow[key] = value === null ? undefined : value;
|
|
17
|
+
});
|
|
18
|
+
response.push(mappedRow);
|
|
19
|
+
});
|
|
20
|
+
return response;
|
|
21
|
+
};
|
|
22
|
+
QueryResponseMapper.partialMap = (partial, queryResult, joinId) => {
|
|
23
|
+
const response = [];
|
|
24
|
+
queryResult.rows.forEach((row) => {
|
|
25
|
+
const mappedRow = {};
|
|
26
|
+
Object.keys(partial).forEach((key) => {
|
|
27
|
+
const column = partial[key];
|
|
28
|
+
const alias = `${column.getAlias()}${joinId ? `_${joinId}` : ''}`;
|
|
29
|
+
const value = column.getColumnType().selectStrategy(row[alias]);
|
|
30
|
+
mappedRow[key] = value === null ? undefined : value;
|
|
31
|
+
});
|
|
32
|
+
response.push(mappedRow);
|
|
33
|
+
});
|
|
34
|
+
return response;
|
|
35
|
+
};
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import Db from '../db/db';
|
|
2
|
+
export declare type InCodeConfig = {
|
|
3
|
+
migrationFolder: string;
|
|
4
|
+
};
|
|
5
|
+
export default class Migrator {
|
|
6
|
+
private db;
|
|
7
|
+
constructor(db: Db);
|
|
8
|
+
migrate(configPath: string): Promise<void>;
|
|
9
|
+
migrate(config: InCodeConfig): Promise<void>;
|
|
10
|
+
private generateHash;
|
|
11
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
10
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
11
|
+
}) : function(o, v) {
|
|
12
|
+
o["default"] = v;
|
|
13
|
+
});
|
|
14
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
15
|
+
if (mod && mod.__esModule) return mod;
|
|
16
|
+
var result = {};
|
|
17
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
18
|
+
__setModuleDefault(result, mod);
|
|
19
|
+
return result;
|
|
20
|
+
};
|
|
21
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
|
+
};
|
|
24
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
+
/* eslint-disable no-restricted-syntax */
|
|
26
|
+
/* eslint-disable import/export */
|
|
27
|
+
/* eslint-disable max-classes-per-file */
|
|
28
|
+
const fs = __importStar(require("fs"));
|
|
29
|
+
const path = __importStar(require("path"));
|
|
30
|
+
const crypto = __importStar(require("crypto"));
|
|
31
|
+
const builders_1 = require("../builders");
|
|
32
|
+
const transaction_1 = __importDefault(require("../builders/transaction/transaction"));
|
|
33
|
+
const tables_1 = require("../tables");
|
|
34
|
+
class Migrator {
|
|
35
|
+
constructor(db) {
|
|
36
|
+
this.db = db;
|
|
37
|
+
}
|
|
38
|
+
async migrate(configPath) {
|
|
39
|
+
let migrationFolderTo;
|
|
40
|
+
if (typeof configPath === 'string') {
|
|
41
|
+
const configAsString = fs.readFileSync(path.resolve('.', configPath), 'utf8');
|
|
42
|
+
const splitted = configAsString.trim().split('\n');
|
|
43
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
44
|
+
for (const split of splitted) {
|
|
45
|
+
const entry = split.trim().split(':');
|
|
46
|
+
const key = entry[0];
|
|
47
|
+
const value = entry[1].trim().replace(/['"]+/g, '');
|
|
48
|
+
if (key === 'migrationRootFolder') {
|
|
49
|
+
// proceed value
|
|
50
|
+
migrationFolderTo = value;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
migrationFolderTo = configPath.migrationFolder;
|
|
56
|
+
}
|
|
57
|
+
if (!migrationFolderTo) {
|
|
58
|
+
throw Error('no migration folder defined');
|
|
59
|
+
}
|
|
60
|
+
const migrationTable = new tables_1.MigrationsTable(this.db);
|
|
61
|
+
await this.db.session().execute(builders_1.Create.table(migrationTable).build());
|
|
62
|
+
const dbMigrations = await migrationTable.select().all();
|
|
63
|
+
const lastDbMigration = dbMigrations.length > 0
|
|
64
|
+
? dbMigrations[dbMigrations.length - 1]
|
|
65
|
+
: undefined;
|
|
66
|
+
const files = fs.readdirSync(migrationFolderTo);
|
|
67
|
+
const transaction = new transaction_1.default(this.db.session());
|
|
68
|
+
await transaction.begin();
|
|
69
|
+
try {
|
|
70
|
+
for await (const migrationFolder of files) {
|
|
71
|
+
const migrationFiles = fs.readdirSync(`${migrationFolderTo}/${migrationFolder}`);
|
|
72
|
+
const migrationFile = migrationFiles.filter((file) => file === 'migration.sql')[0];
|
|
73
|
+
const query = fs.readFileSync(`${migrationFolderTo}/${migrationFolder}/${migrationFile}`).toString();
|
|
74
|
+
const year = Number(migrationFolder.slice(0, 4));
|
|
75
|
+
// second param for Date() is month index, that started from 0, so we need
|
|
76
|
+
// to decrement a value for month
|
|
77
|
+
const month = Number(migrationFolder.slice(4, 6)) - 1;
|
|
78
|
+
const day = Number(migrationFolder.slice(6, 8));
|
|
79
|
+
const hour = Number(migrationFolder.slice(8, 10));
|
|
80
|
+
const min = Number(migrationFolder.slice(10, 12));
|
|
81
|
+
const sec = Number(migrationFolder.slice(12, 14));
|
|
82
|
+
const folderAsMillis = new Date(year, month, day, hour, min, sec).getTime();
|
|
83
|
+
if (!lastDbMigration || lastDbMigration.createdAt < folderAsMillis) {
|
|
84
|
+
await this.db.session().execute(query);
|
|
85
|
+
await migrationTable.insert({
|
|
86
|
+
hash: this.generateHash(query),
|
|
87
|
+
createdAt: folderAsMillis,
|
|
88
|
+
}).execute();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
await transaction.commit();
|
|
92
|
+
}
|
|
93
|
+
catch (e) {
|
|
94
|
+
// if (this.db.logger()) {
|
|
95
|
+
// this.db.logger()!.error(e);
|
|
96
|
+
// }
|
|
97
|
+
transaction.rollback();
|
|
98
|
+
throw e;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
generateHash(value) {
|
|
102
|
+
return crypto.createHash('sha256').update(value).digest('hex');
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
exports.default = Migrator;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { DB } from '../db';
|
|
2
|
+
import { AbstractTable } from '../tables';
|
|
3
|
+
import Enum from '../types/type';
|
|
4
|
+
interface EnumsAsObject {
|
|
5
|
+
[name: string]: {
|
|
6
|
+
name: string;
|
|
7
|
+
values: string[];
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
interface ColumnAsObject {
|
|
11
|
+
[name: string]: {
|
|
12
|
+
name?: string;
|
|
13
|
+
type?: string;
|
|
14
|
+
primaryKey?: boolean;
|
|
15
|
+
unique?: boolean;
|
|
16
|
+
default?: any;
|
|
17
|
+
notNull?: boolean;
|
|
18
|
+
references?: string;
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
interface TableAsObject {
|
|
22
|
+
[name: string]: {
|
|
23
|
+
name: string;
|
|
24
|
+
columns: ColumnAsObject;
|
|
25
|
+
indexes: {
|
|
26
|
+
[name: string]: {
|
|
27
|
+
name?: string;
|
|
28
|
+
type?: string;
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export default class MigrationSerializer {
|
|
34
|
+
generate: (tables: AbstractTable<any>[], enums: Enum<any>[]) => {
|
|
35
|
+
version: string;
|
|
36
|
+
tables: TableAsObject;
|
|
37
|
+
enums: {
|
|
38
|
+
[key: string]: Enum<any>;
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
fromDatabase: (db: DB) => Promise<{
|
|
42
|
+
version: string;
|
|
43
|
+
tables: TableAsObject;
|
|
44
|
+
enums: EnumsAsObject;
|
|
45
|
+
}>;
|
|
46
|
+
}
|
|
47
|
+
export {};
|