@revisium/core 2.2.0 → 2.3.0-alpha.2
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/dist/package.json +16 -7
- package/dist/src/api/graphql-api/branch/model/branch.model.js +2 -1
- package/dist/src/api/graphql-api/branch/model/branch.model.js.map +1 -1
- package/dist/src/api/graphql-api/branch/parent-branch.resolver.d.ts +15 -2
- package/dist/src/api/graphql-api/branch/parent-branch.resolver.js +6 -4
- package/dist/src/api/graphql-api/branch/parent-branch.resolver.js.map +1 -1
- package/dist/src/api/graphql-api/draft/input/create-row.input.js +2 -2
- package/dist/src/api/graphql-api/draft/input/create-row.input.js.map +1 -1
- package/dist/src/api/graphql-api/draft/input/create-table.input.js +2 -2
- package/dist/src/api/graphql-api/draft/input/create-table.input.js.map +1 -1
- package/dist/src/api/graphql-api/draft/input/patch-row.input.js +2 -2
- package/dist/src/api/graphql-api/draft/input/patch-row.input.js.map +1 -1
- package/dist/src/api/graphql-api/draft/input/update-row.input.js +2 -2
- package/dist/src/api/graphql-api/draft/input/update-row.input.js.map +1 -1
- package/dist/src/api/graphql-api/draft/input/update-table.input.js +2 -2
- package/dist/src/api/graphql-api/draft/input/update-table.input.js.map +1 -1
- package/dist/src/api/graphql-api/endpoint/model/endpoint.model.js +2 -1
- package/dist/src/api/graphql-api/endpoint/model/endpoint.model.js.map +1 -1
- package/dist/src/api/graphql-api/graphql-api.module.js +2 -2
- package/dist/src/api/graphql-api/graphql-api.module.js.map +1 -1
- package/dist/src/api/graphql-api/project/model/project.model.js +2 -1
- package/dist/src/api/graphql-api/project/model/project.model.js.map +1 -1
- package/dist/src/api/graphql-api/revision/child-branch.resolver.d.ts +15 -2
- package/dist/src/api/graphql-api/revision/child-branch.resolver.js +6 -4
- package/dist/src/api/graphql-api/revision/child-branch.resolver.js.map +1 -1
- package/dist/src/api/graphql-api/revision/model/revision.model.js +2 -1
- package/dist/src/api/graphql-api/revision/model/revision.model.js.map +1 -1
- package/dist/src/api/graphql-api/revision/revision.resolver.d.ts +15 -2
- package/dist/src/api/graphql-api/revision/revision.resolver.js +6 -4
- package/dist/src/api/graphql-api/revision/revision.resolver.js.map +1 -1
- package/dist/src/api/graphql-api/row/inputs/get-rows.input.js +5 -5
- package/dist/src/api/graphql-api/row/inputs/get-rows.input.js.map +1 -1
- package/dist/src/api/graphql-api/row/model/row.model.js +5 -5
- package/dist/src/api/graphql-api/row/model/row.model.js.map +1 -1
- package/dist/src/api/graphql-api/row/row.resolver.js +7 -3
- package/dist/src/api/graphql-api/row/row.resolver.js.map +1 -1
- package/dist/src/api/graphql-api/table/model/table.model.js +4 -4
- package/dist/src/api/graphql-api/table/model/table.model.js.map +1 -1
- package/dist/src/api/rest-api/revision/revision-by-id.controller.js +1 -1
- package/dist/src/api/rest-api/revision/revision-by-id.controller.js.map +1 -1
- package/dist/src/api/rest-api/row/row-by-id.controller.d.ts +2 -3
- package/dist/src/api/rest-api/row/row-by-id.controller.js +2 -4
- package/dist/src/api/rest-api/row/row-by-id.controller.js.map +1 -1
- package/dist/src/core/core.module.js +2 -0
- package/dist/src/core/core.module.js.map +1 -1
- package/dist/src/features/auth/auth.module.js +3 -1
- package/dist/src/features/auth/auth.module.js.map +1 -1
- package/dist/src/features/auth/casl-ability.factory.d.ts +3 -1
- package/dist/src/features/auth/casl-ability.factory.js +6 -3
- package/dist/src/features/auth/casl-ability.factory.js.map +1 -1
- package/dist/src/features/auth/commands/auth-api.service.d.ts +11 -0
- package/dist/src/features/auth/commands/auth-api.service.js +44 -0
- package/dist/src/features/auth/commands/auth-api.service.js.map +1 -0
- package/dist/src/features/auth/commands/handlers/check-organization-permission.handler.d.ts +2 -2
- package/dist/src/features/auth/commands/handlers/check-organization-permission.handler.js.map +1 -1
- package/dist/src/features/auth/commands/handlers/check-project-permission.handler.d.ts +2 -2
- package/dist/src/features/auth/commands/handlers/check-project-permission.handler.js.map +1 -1
- package/dist/src/features/auth/commands/impl/check-organization-permission.command.d.ts +2 -0
- package/dist/src/features/auth/commands/impl/check-project-permission.command.d.ts +2 -0
- package/dist/src/features/auth/commands/impl/check-system-permission.command.d.ts +1 -0
- package/dist/src/features/auth/guards/base-persmission.guard.d.ts +4 -2
- package/dist/src/features/auth/guards/base-persmission.guard.js +6 -4
- package/dist/src/features/auth/guards/base-persmission.guard.js.map +1 -1
- package/dist/src/features/auth/guards/organization.guard.d.ts +2 -3
- package/dist/src/features/auth/guards/organization.guard.js +2 -3
- package/dist/src/features/auth/guards/organization.guard.js.map +1 -1
- package/dist/src/features/auth/guards/project.guard.d.ts +29 -3
- package/dist/src/features/auth/guards/project.guard.js +11 -8
- package/dist/src/features/auth/guards/project.guard.js.map +1 -1
- package/dist/src/features/auth/guards/system.guard.d.ts +1 -2
- package/dist/src/features/auth/guards/system.guard.js +2 -3
- package/dist/src/features/auth/guards/system.guard.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/__tests__/utils.d.ts +2 -0
- package/dist/src/features/draft/commands/handlers/__tests__/utils.js +8 -0
- package/dist/src/features/draft/commands/handlers/__tests__/utils.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-base-row.handler.d.ts +2 -1
- package/dist/src/features/draft/commands/handlers/api-base-row.handler.js +2 -1
- package/dist/src/features/draft/commands/handlers/api-base-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-create-revision.handler.d.ts +16 -4
- package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js +6 -6
- package/dist/src/features/draft/commands/handlers/api-create-revision.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-create-row.handler.js +1 -0
- package/dist/src/features/draft/commands/handlers/api-create-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js +1 -0
- package/dist/src/features/draft/commands/handlers/api-patch-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js +1 -0
- package/dist/src/features/draft/commands/handlers/api-rename-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-update-row.handler.js +1 -0
- package/dist/src/features/draft/commands/handlers/api-update-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js +1 -0
- package/dist/src/features/draft/commands/handlers/api-upload-file.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/create-revision.handler.d.ts +13 -6
- package/dist/src/features/draft/commands/handlers/create-revision.handler.js +17 -2
- package/dist/src/features/draft/commands/handlers/create-revision.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/create-row.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/create-row.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/create-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/patch-row.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/patch-row.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/patch-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/remove-row.handler.d.ts +4 -1
- package/dist/src/features/draft/commands/handlers/remove-row.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/remove-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/remove-table.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/remove-table.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/remove-table.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/rename-table.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/rename-table.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/rename-table.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/revert-changes.handler.d.ts +4 -1
- package/dist/src/features/draft/commands/handlers/revert-changes.handler.js +10 -2
- package/dist/src/features/draft/commands/handlers/revert-changes.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js +10 -2
- package/dist/src/features/draft/commands/handlers/transactional/internal-rename-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.d.ts +4 -1
- package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js +10 -2
- package/dist/src/features/draft/commands/handlers/transactional/internal-update-row.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.d.ts +5 -1
- package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.js +32 -18
- package/dist/src/features/draft/commands/handlers/transactional/resolve-draft-revision.handler.js.map +1 -1
- package/dist/src/features/draft/commands/handlers/update-table.handler.d.ts +4 -2
- package/dist/src/features/draft/commands/handlers/update-table.handler.js +9 -1
- package/dist/src/features/draft/commands/handlers/update-table.handler.js.map +1 -1
- package/dist/src/features/draft/commands/types/create-revision.handler.types.d.ts +2 -0
- package/dist/src/features/draft/draft.handler.d.ts +1 -1
- package/dist/src/features/draft/draft.module.js +2 -0
- package/dist/src/features/draft/draft.module.js.map +1 -1
- package/dist/src/features/revision/index.d.ts +2 -0
- package/dist/src/{utils/prisma-sql-generator → features/revision}/index.js +2 -5
- package/dist/src/features/revision/index.js.map +1 -0
- package/dist/src/features/revision/internal-revisions-api.service.d.ts +19 -0
- package/dist/src/features/revision/internal-revisions-api.service.js +32 -0
- package/dist/src/features/revision/internal-revisions-api.service.js.map +1 -0
- package/dist/src/features/revision/queries/impl/get-revision.query.d.ts +1 -0
- package/dist/src/features/revision/revision.module.js +6 -1
- package/dist/src/features/revision/revision.module.js.map +1 -1
- package/dist/src/features/revision/revisions-api.service.d.ts +19 -5
- package/dist/src/features/revision/revisions-api.service.js +11 -6
- package/dist/src/features/revision/revisions-api.service.js.map +1 -1
- package/dist/src/features/row/index.d.ts +2 -0
- package/dist/src/features/row/index.js +19 -0
- package/dist/src/features/row/index.js.map +1 -0
- package/dist/src/features/row/internal-row-api.service.d.ts +13 -0
- package/dist/src/features/row/internal-row-api.service.js +47 -0
- package/dist/src/features/row/internal-row-api.service.js.map +1 -0
- package/dist/src/features/row/queries/handlers/get-rows.handler.d.ts +2 -4
- package/dist/src/features/row/queries/handlers/get-rows.handler.js +9 -29
- package/dist/src/features/row/queries/handlers/get-rows.handler.js.map +1 -1
- package/dist/src/features/row/queries/impl/get-row-by-id.query.d.ts +2 -0
- package/dist/src/features/row/queries/impl/get-row-by-id.query.js.map +1 -1
- package/dist/src/features/row/queries/impl/get-rows.query.d.ts +3 -3
- package/dist/src/features/row/queries/impl/get-rows.query.js.map +1 -1
- package/dist/src/features/row/row-api.service.d.ts +13 -9
- package/dist/src/features/row/row-api.service.js +27 -14
- package/dist/src/features/row/row-api.service.js.map +1 -1
- package/dist/src/features/row/row.module.js +2 -1
- package/dist/src/features/row/row.module.js.map +1 -1
- package/dist/src/features/row/utils/get-rows-sql.d.ts +5 -0
- package/dist/src/features/row/utils/get-rows-sql.js +70 -0
- package/dist/src/features/row/utils/get-rows-sql.js.map +1 -0
- package/dist/src/infrastructure/cache/constants/auth-cache.constants.d.ts +18 -0
- package/dist/src/infrastructure/cache/constants/auth-cache.constants.js +22 -0
- package/dist/src/infrastructure/cache/constants/auth-cache.constants.js.map +1 -0
- package/dist/src/infrastructure/cache/constants/revision-cache.constants.d.ts +10 -0
- package/dist/src/infrastructure/cache/constants/revision-cache.constants.js +14 -0
- package/dist/src/infrastructure/cache/constants/revision-cache.constants.js.map +1 -0
- package/dist/src/infrastructure/cache/constants/row-cache.constants.d.ts +13 -0
- package/dist/src/infrastructure/cache/constants/row-cache.constants.js +17 -0
- package/dist/src/infrastructure/cache/constants/row-cache.constants.js.map +1 -0
- package/dist/src/infrastructure/cache/events/base.event.d.ts +4 -0
- package/dist/src/infrastructure/cache/events/base.event.js +10 -0
- package/dist/src/infrastructure/cache/events/base.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/index.d.ts +10 -0
- package/dist/src/infrastructure/cache/events/index.js +27 -0
- package/dist/src/infrastructure/cache/events/index.js.map +1 -0
- package/dist/src/infrastructure/cache/events/revision/revision-committed.event.d.ts +6 -0
- package/dist/src/infrastructure/cache/events/revision/revision-committed.event.js +13 -0
- package/dist/src/infrastructure/cache/events/revision/revision-committed.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.d.ts +5 -0
- package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.js +12 -0
- package/dist/src/infrastructure/cache/events/revision/revision-reverted.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/row/row-created.event.d.ts +7 -0
- package/dist/src/infrastructure/cache/events/row/row-created.event.js +14 -0
- package/dist/src/infrastructure/cache/events/row/row-created.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/row/row-deleted.event.d.ts +7 -0
- package/dist/src/infrastructure/cache/events/row/row-deleted.event.js +14 -0
- package/dist/src/infrastructure/cache/events/row/row-deleted.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/row/row-renamed.event.d.ts +8 -0
- package/dist/src/infrastructure/cache/events/row/row-renamed.event.js +15 -0
- package/dist/src/infrastructure/cache/events/row/row-renamed.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/row/row-updated.event.d.ts +7 -0
- package/dist/src/infrastructure/cache/events/row/row-updated.event.js +14 -0
- package/dist/src/infrastructure/cache/events/row/row-updated.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/table/table-deleted.event.d.ts +6 -0
- package/dist/src/infrastructure/cache/events/table/table-deleted.event.js +13 -0
- package/dist/src/infrastructure/cache/events/table/table-deleted.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/table/table-renamed.event.d.ts +7 -0
- package/dist/src/infrastructure/cache/events/table/table-renamed.event.js +14 -0
- package/dist/src/infrastructure/cache/events/table/table-renamed.event.js.map +1 -0
- package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.d.ts +6 -0
- package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.js +13 -0
- package/dist/src/infrastructure/cache/events/table/table-schema-updated.event.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/index.d.ts +10 -0
- package/dist/src/infrastructure/cache/handlers/index.js +24 -0
- package/dist/src/infrastructure/cache/handlers/index.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.js +32 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-committed.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.js +29 -0
- package/dist/src/infrastructure/cache/handlers/revision/revision-reverted.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/row/row-created.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/row/row-created.handler.js +29 -0
- package/dist/src/infrastructure/cache/handlers/row/row-created.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.js +30 -0
- package/dist/src/infrastructure/cache/handlers/row/row-deleted.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.js +34 -0
- package/dist/src/infrastructure/cache/handlers/row/row-renamed.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.js +30 -0
- package/dist/src/infrastructure/cache/handlers/row/row-updated.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.js +29 -0
- package/dist/src/infrastructure/cache/handlers/table/table-deleted.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.js +32 -0
- package/dist/src/infrastructure/cache/handlers/table/table-renamed.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.d.ts +8 -0
- package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.js +29 -0
- package/dist/src/infrastructure/cache/handlers/table/table-schema-updated.handler.js.map +1 -0
- package/dist/src/infrastructure/cache/index.d.ts +7 -0
- package/dist/src/infrastructure/cache/index.js +24 -0
- package/dist/src/infrastructure/cache/index.js.map +1 -0
- package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.d.ts +37 -0
- package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.js +228 -0
- package/dist/src/infrastructure/cache/pg-bus/pg-bus.driver.js.map +1 -0
- package/dist/src/infrastructure/cache/revisium-cache.module.d.ts +4 -0
- package/dist/src/infrastructure/cache/revisium-cache.module.js +140 -0
- package/dist/src/infrastructure/cache/revisium-cache.module.js.map +1 -0
- package/dist/src/infrastructure/cache/services/auth-cache.service.d.ts +22 -0
- package/dist/src/infrastructure/cache/services/auth-cache.service.js +112 -0
- package/dist/src/infrastructure/cache/services/auth-cache.service.js.map +1 -0
- package/dist/src/infrastructure/cache/services/cache.service.d.ts +11 -0
- package/dist/src/infrastructure/cache/services/cache.service.js +38 -0
- package/dist/src/infrastructure/cache/services/cache.service.js.map +1 -0
- package/dist/src/infrastructure/cache/services/cache.tokens.d.ts +1 -0
- package/dist/src/infrastructure/cache/services/cache.tokens.js +5 -0
- package/dist/src/infrastructure/cache/services/cache.tokens.js.map +1 -0
- package/dist/src/infrastructure/cache/services/noop-cache.service.d.ts +6 -0
- package/dist/src/infrastructure/cache/services/noop-cache.service.js +24 -0
- package/dist/src/infrastructure/cache/services/noop-cache.service.js.map +1 -0
- package/dist/src/infrastructure/cache/services/revision-cache.service.d.ts +10 -0
- package/dist/src/infrastructure/cache/services/revision-cache.service.js +39 -0
- package/dist/src/infrastructure/cache/services/revision-cache.service.js.map +1 -0
- package/dist/src/infrastructure/cache/services/row-cache.service.d.ts +26 -0
- package/dist/src/infrastructure/cache/services/row-cache.service.js +68 -0
- package/dist/src/infrastructure/cache/services/row-cache.service.js.map +1 -0
- package/dist/src/utils/utils/parse-bool.d.ts +1 -0
- package/dist/src/utils/utils/parse-bool.js +10 -0
- package/dist/src/utils/utils/parse-bool.js.map +1 -0
- package/dist/src/utils/utils/stable-cache-key.d.ts +12 -0
- package/dist/src/utils/utils/stable-cache-key.js +46 -0
- package/dist/src/utils/utils/stable-cache-key.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +16 -7
- package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.d.ts +0 -16
- package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js +0 -70
- package/dist/src/utils/prisma-sql-generator/__tests__/shared-helpers.js.map +0 -1
- package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.d.ts +0 -52
- package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js +0 -531
- package/dist/src/utils/prisma-sql-generator/__tests__/test-helpers.js.map +0 -1
- package/dist/src/utils/prisma-sql-generator/index.d.ts +0 -2
- package/dist/src/utils/prisma-sql-generator/index.js.map +0 -1
- package/dist/src/utils/prisma-sql-generator/json-path.d.ts +0 -14
- package/dist/src/utils/prisma-sql-generator/json-path.js +0 -121
- package/dist/src/utils/prisma-sql-generator/json-path.js.map +0 -1
- package/dist/src/utils/prisma-sql-generator/types.d.ts +0 -105
- package/dist/src/utils/prisma-sql-generator/types.js +0 -3
- package/dist/src/utils/prisma-sql-generator/types.js.map +0 -1
- package/dist/src/utils/prisma-sql-generator/where-generator.prisma.d.ts +0 -21
- package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js +0 -499
- package/dist/src/utils/prisma-sql-generator/where-generator.prisma.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"json-path.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/json-path.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
export interface WhereConditions {
|
|
2
|
-
versionId?: string | StringFilter;
|
|
3
|
-
createdId?: string | StringFilter;
|
|
4
|
-
id?: string | StringFilter;
|
|
5
|
-
hash?: string | StringFilter;
|
|
6
|
-
schemaHash?: string | StringFilter;
|
|
7
|
-
readonly?: boolean | BoolFilter;
|
|
8
|
-
createdAt?: string | Date | DateFilter;
|
|
9
|
-
updatedAt?: string | Date | DateFilter;
|
|
10
|
-
publishedAt?: string | Date | DateFilter;
|
|
11
|
-
data?: JsonFilter;
|
|
12
|
-
meta?: JsonFilter;
|
|
13
|
-
AND?: WhereConditions[];
|
|
14
|
-
OR?: WhereConditions[];
|
|
15
|
-
NOT?: WhereConditions;
|
|
16
|
-
}
|
|
17
|
-
export interface SqlResult {
|
|
18
|
-
sql: string;
|
|
19
|
-
params: any[];
|
|
20
|
-
}
|
|
21
|
-
export interface JsonFilter {
|
|
22
|
-
path: string[];
|
|
23
|
-
equals?: any;
|
|
24
|
-
string_contains?: string;
|
|
25
|
-
string_starts_with?: string;
|
|
26
|
-
string_ends_with?: string;
|
|
27
|
-
gt?: number;
|
|
28
|
-
gte?: number;
|
|
29
|
-
lt?: number;
|
|
30
|
-
lte?: number;
|
|
31
|
-
in?: any[];
|
|
32
|
-
notIn?: any[];
|
|
33
|
-
array_contains?: any;
|
|
34
|
-
array_starts_with?: any;
|
|
35
|
-
array_ends_with?: any;
|
|
36
|
-
not?: any;
|
|
37
|
-
mode?: 'default' | 'insensitive';
|
|
38
|
-
}
|
|
39
|
-
export interface DateFilter {
|
|
40
|
-
equals?: string | Date;
|
|
41
|
-
gt?: string | Date;
|
|
42
|
-
gte?: string | Date;
|
|
43
|
-
lt?: string | Date;
|
|
44
|
-
lte?: string | Date;
|
|
45
|
-
in?: (string | Date)[];
|
|
46
|
-
notIn?: (string | Date)[];
|
|
47
|
-
}
|
|
48
|
-
export interface BoolFilter {
|
|
49
|
-
equals?: boolean;
|
|
50
|
-
not?: boolean;
|
|
51
|
-
}
|
|
52
|
-
export interface StringFilter {
|
|
53
|
-
equals?: string;
|
|
54
|
-
contains?: string;
|
|
55
|
-
startsWith?: string;
|
|
56
|
-
endsWith?: string;
|
|
57
|
-
in?: string[];
|
|
58
|
-
notIn?: string[];
|
|
59
|
-
lt?: string;
|
|
60
|
-
lte?: string;
|
|
61
|
-
gt?: string;
|
|
62
|
-
gte?: string;
|
|
63
|
-
not?: string;
|
|
64
|
-
search?: string;
|
|
65
|
-
mode?: 'default' | 'insensitive';
|
|
66
|
-
}
|
|
67
|
-
export interface JsonOrderInput {
|
|
68
|
-
path: string | string[];
|
|
69
|
-
direction?: 'asc' | 'desc';
|
|
70
|
-
type?: JsonValueType;
|
|
71
|
-
aggregation?: JsonAggregation;
|
|
72
|
-
subPath?: string;
|
|
73
|
-
}
|
|
74
|
-
export interface RowOrderInput {
|
|
75
|
-
versionId?: 'asc' | 'desc';
|
|
76
|
-
createdId?: 'asc' | 'desc';
|
|
77
|
-
id?: 'asc' | 'desc';
|
|
78
|
-
readonly?: 'asc' | 'desc';
|
|
79
|
-
createdAt?: 'asc' | 'desc';
|
|
80
|
-
updatedAt?: 'asc' | 'desc';
|
|
81
|
-
publishedAt?: 'asc' | 'desc';
|
|
82
|
-
data?: 'asc' | 'desc' | JsonOrderInput;
|
|
83
|
-
meta?: 'asc' | 'desc' | JsonOrderInput;
|
|
84
|
-
hash?: 'asc' | 'desc';
|
|
85
|
-
schemaHash?: 'asc' | 'desc';
|
|
86
|
-
}
|
|
87
|
-
export type JsonValueType = 'text' | 'int' | 'float' | 'boolean' | 'timestamp';
|
|
88
|
-
export type JsonAggregation = 'min' | 'max' | 'avg' | 'first' | 'last';
|
|
89
|
-
export interface GetRowsQueryParams {
|
|
90
|
-
tableId: string;
|
|
91
|
-
take: number;
|
|
92
|
-
skip: number;
|
|
93
|
-
whereConditions?: WhereConditions;
|
|
94
|
-
orderBy?: RowOrderInput[];
|
|
95
|
-
}
|
|
96
|
-
export interface RenderedQuery {
|
|
97
|
-
sql: string;
|
|
98
|
-
params: any[];
|
|
99
|
-
}
|
|
100
|
-
export interface GetRowsOptions {
|
|
101
|
-
take?: number;
|
|
102
|
-
skip?: number;
|
|
103
|
-
orderBy?: RowOrderInput | RowOrderInput[];
|
|
104
|
-
where?: WhereConditions;
|
|
105
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/utils/prisma-sql-generator/types.ts"],"names":[],"mappings":""}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Prisma } from '@prisma/client';
|
|
2
|
-
import { WhereConditions, GetRowsOptions, RowOrderInput } from './types';
|
|
3
|
-
export declare class WhereGeneratorPrisma {
|
|
4
|
-
generateWhere(conditions?: WhereConditions): Prisma.Sql;
|
|
5
|
-
private processConditions;
|
|
6
|
-
private combineWithAnd;
|
|
7
|
-
private combineWithOr;
|
|
8
|
-
generateOrderBy(orderBy?: any[]): Prisma.Sql;
|
|
9
|
-
private processStringField;
|
|
10
|
-
private processBoolField;
|
|
11
|
-
private processDateField;
|
|
12
|
-
private processJsonField;
|
|
13
|
-
private static readonly VALID_ORDER_FIELDS;
|
|
14
|
-
private getFieldReference;
|
|
15
|
-
private combineOrderBy;
|
|
16
|
-
private generateJsonOrderBy;
|
|
17
|
-
private generateArrayAggregationOrder;
|
|
18
|
-
generateGetRowsQueryPrisma(tableId: string, options?: GetRowsOptions): Prisma.Sql;
|
|
19
|
-
generateGetRowsQuery(tableId: string, take: number, skip: number, whereConditions?: WhereConditions, orderBy?: RowOrderInput[]): Prisma.Sql;
|
|
20
|
-
}
|
|
21
|
-
export declare function generateGetRowsQueryPrisma(tableId: string, take: number, skip: number, whereConditions?: WhereConditions, orderBy?: any[]): Prisma.Sql;
|
|
@@ -1,499 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.WhereGeneratorPrisma = void 0;
|
|
4
|
-
exports.generateGetRowsQueryPrisma = generateGetRowsQueryPrisma;
|
|
5
|
-
const client_1 = require("@prisma/client");
|
|
6
|
-
const json_path_1 = require("./json-path");
|
|
7
|
-
class WhereGeneratorPrisma {
|
|
8
|
-
generateWhere(conditions) {
|
|
9
|
-
if (!conditions || Object.keys(conditions).length === 0) {
|
|
10
|
-
return client_1.Prisma.sql `TRUE`;
|
|
11
|
-
}
|
|
12
|
-
return this.processConditions(conditions);
|
|
13
|
-
}
|
|
14
|
-
processConditions(conditions) {
|
|
15
|
-
const clauses = [];
|
|
16
|
-
if (Array.isArray(conditions.AND) && conditions.AND.length > 0) {
|
|
17
|
-
const andClauses = conditions.AND.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
|
|
18
|
-
if (andClauses.length > 0) {
|
|
19
|
-
clauses.push(client_1.Prisma.sql `(${this.combineWithAnd(andClauses)})`);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
if (Array.isArray(conditions.OR) && conditions.OR.length > 0) {
|
|
23
|
-
const orClauses = conditions.OR.map((cond) => this.processConditions(cond)).filter((c) => c.inspect().sql !== 'TRUE');
|
|
24
|
-
if (orClauses.length > 0) {
|
|
25
|
-
clauses.push(client_1.Prisma.sql `(${this.combineWithOr(orClauses)})`);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
if (conditions.NOT) {
|
|
29
|
-
const notClause = this.processConditions(conditions.NOT);
|
|
30
|
-
clauses.push(client_1.Prisma.sql `NOT (${notClause})`);
|
|
31
|
-
}
|
|
32
|
-
if (conditions.versionId !== undefined) {
|
|
33
|
-
clauses.push(this.processStringField('versionId', conditions.versionId));
|
|
34
|
-
}
|
|
35
|
-
if (conditions.createdId !== undefined) {
|
|
36
|
-
clauses.push(this.processStringField('createdId', conditions.createdId));
|
|
37
|
-
}
|
|
38
|
-
if (conditions.id !== undefined) {
|
|
39
|
-
clauses.push(this.processStringField('id', conditions.id));
|
|
40
|
-
}
|
|
41
|
-
if (conditions.hash !== undefined) {
|
|
42
|
-
clauses.push(this.processStringField('hash', conditions.hash));
|
|
43
|
-
}
|
|
44
|
-
if (conditions.schemaHash !== undefined) {
|
|
45
|
-
clauses.push(this.processStringField('schemaHash', conditions.schemaHash));
|
|
46
|
-
}
|
|
47
|
-
if (conditions.readonly !== undefined) {
|
|
48
|
-
clauses.push(this.processBoolField('readonly', conditions.readonly));
|
|
49
|
-
}
|
|
50
|
-
if (conditions.createdAt !== undefined) {
|
|
51
|
-
clauses.push(this.processDateField('createdAt', conditions.createdAt));
|
|
52
|
-
}
|
|
53
|
-
if (conditions.updatedAt !== undefined) {
|
|
54
|
-
clauses.push(this.processDateField('updatedAt', conditions.updatedAt));
|
|
55
|
-
}
|
|
56
|
-
if (conditions.publishedAt !== undefined) {
|
|
57
|
-
clauses.push(this.processDateField('publishedAt', conditions.publishedAt));
|
|
58
|
-
}
|
|
59
|
-
if (conditions.data !== undefined) {
|
|
60
|
-
clauses.push(this.processJsonField('data', conditions.data));
|
|
61
|
-
}
|
|
62
|
-
if (conditions.meta !== undefined) {
|
|
63
|
-
clauses.push(this.processJsonField('meta', conditions.meta));
|
|
64
|
-
}
|
|
65
|
-
if (clauses.length === 0) {
|
|
66
|
-
return client_1.Prisma.sql `TRUE`;
|
|
67
|
-
}
|
|
68
|
-
if (clauses.length === 1) {
|
|
69
|
-
return clauses[0];
|
|
70
|
-
}
|
|
71
|
-
return this.combineWithAnd(clauses);
|
|
72
|
-
}
|
|
73
|
-
combineWithAnd(clauses) {
|
|
74
|
-
if (clauses.length === 0) {
|
|
75
|
-
return client_1.Prisma.sql `TRUE`;
|
|
76
|
-
}
|
|
77
|
-
if (clauses.length === 1) {
|
|
78
|
-
return clauses[0];
|
|
79
|
-
}
|
|
80
|
-
let result = clauses[0];
|
|
81
|
-
for (let i = 1; i < clauses.length; i++) {
|
|
82
|
-
result = client_1.Prisma.sql `${result} AND ${clauses[i]}`;
|
|
83
|
-
}
|
|
84
|
-
return result;
|
|
85
|
-
}
|
|
86
|
-
combineWithOr(clauses) {
|
|
87
|
-
if (clauses.length === 0) {
|
|
88
|
-
return client_1.Prisma.sql `FALSE`;
|
|
89
|
-
}
|
|
90
|
-
if (clauses.length === 1) {
|
|
91
|
-
return clauses[0];
|
|
92
|
-
}
|
|
93
|
-
let result = clauses[0];
|
|
94
|
-
for (let i = 1; i < clauses.length; i++) {
|
|
95
|
-
result = client_1.Prisma.sql `${result} OR ${clauses[i]}`;
|
|
96
|
-
}
|
|
97
|
-
return result;
|
|
98
|
-
}
|
|
99
|
-
generateOrderBy(orderBy) {
|
|
100
|
-
if (!orderBy || orderBy.length === 0) {
|
|
101
|
-
return client_1.Prisma.sql `r."createdAt" DESC`;
|
|
102
|
-
}
|
|
103
|
-
const orderClauses = [];
|
|
104
|
-
for (const orderItem of orderBy) {
|
|
105
|
-
for (const [field, direction] of Object.entries(orderItem)) {
|
|
106
|
-
if (typeof direction === 'string') {
|
|
107
|
-
const fieldRef = this.getFieldReference(field);
|
|
108
|
-
const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
|
|
109
|
-
orderClauses.push(client_1.Prisma.sql `${fieldRef} ${sortOrder}`);
|
|
110
|
-
}
|
|
111
|
-
else if (typeof direction === 'object' && direction !== null) {
|
|
112
|
-
const jsonOrderClause = this.generateJsonOrderBy(field, direction);
|
|
113
|
-
orderClauses.push(jsonOrderClause);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
return orderClauses.length > 0
|
|
118
|
-
? this.combineOrderBy(orderClauses)
|
|
119
|
-
: client_1.Prisma.sql `r."createdAt" DESC`;
|
|
120
|
-
}
|
|
121
|
-
processStringField(field, condition) {
|
|
122
|
-
const fieldRef = client_1.Prisma.raw(`r."${field}"`);
|
|
123
|
-
if (typeof condition === 'string') {
|
|
124
|
-
return client_1.Prisma.sql `${fieldRef} = ${condition}`;
|
|
125
|
-
}
|
|
126
|
-
const filter = condition;
|
|
127
|
-
const mode = filter.mode || 'default';
|
|
128
|
-
const isInsensitive = mode === 'insensitive';
|
|
129
|
-
if (filter.equals !== undefined) {
|
|
130
|
-
if (isInsensitive) {
|
|
131
|
-
return client_1.Prisma.sql `${fieldRef} ILIKE ${filter.equals}`;
|
|
132
|
-
}
|
|
133
|
-
return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
|
|
134
|
-
}
|
|
135
|
-
if (filter.contains !== undefined) {
|
|
136
|
-
const pattern = `%${filter.contains}%`;
|
|
137
|
-
if (isInsensitive) {
|
|
138
|
-
return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
|
|
139
|
-
}
|
|
140
|
-
return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
|
|
141
|
-
}
|
|
142
|
-
if (filter.startsWith !== undefined) {
|
|
143
|
-
const pattern = `${filter.startsWith}%`;
|
|
144
|
-
if (isInsensitive) {
|
|
145
|
-
return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
|
|
146
|
-
}
|
|
147
|
-
return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
|
|
148
|
-
}
|
|
149
|
-
if (filter.endsWith !== undefined) {
|
|
150
|
-
const pattern = `%${filter.endsWith}`;
|
|
151
|
-
if (isInsensitive) {
|
|
152
|
-
return client_1.Prisma.sql `${fieldRef} ILIKE ${pattern}`;
|
|
153
|
-
}
|
|
154
|
-
return client_1.Prisma.sql `${fieldRef} LIKE ${pattern}`;
|
|
155
|
-
}
|
|
156
|
-
if (filter.in !== undefined) {
|
|
157
|
-
if (Array.isArray(filter.in) && filter.in.length === 0) {
|
|
158
|
-
return client_1.Prisma.sql `FALSE`;
|
|
159
|
-
}
|
|
160
|
-
return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(filter.in)})`;
|
|
161
|
-
}
|
|
162
|
-
if (filter.notIn !== undefined) {
|
|
163
|
-
if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
|
|
164
|
-
return client_1.Prisma.sql `TRUE`;
|
|
165
|
-
}
|
|
166
|
-
return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(filter.notIn)})`;
|
|
167
|
-
}
|
|
168
|
-
if (filter.gt !== undefined) {
|
|
169
|
-
return client_1.Prisma.sql `${fieldRef} > ${filter.gt}`;
|
|
170
|
-
}
|
|
171
|
-
if (filter.gte !== undefined) {
|
|
172
|
-
return client_1.Prisma.sql `${fieldRef} >= ${filter.gte}`;
|
|
173
|
-
}
|
|
174
|
-
if (filter.lt !== undefined) {
|
|
175
|
-
return client_1.Prisma.sql `${fieldRef} < ${filter.lt}`;
|
|
176
|
-
}
|
|
177
|
-
if (filter.lte !== undefined) {
|
|
178
|
-
return client_1.Prisma.sql `${fieldRef} <= ${filter.lte}`;
|
|
179
|
-
}
|
|
180
|
-
if (filter.not !== undefined) {
|
|
181
|
-
return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
|
|
182
|
-
}
|
|
183
|
-
if (filter.search !== undefined) {
|
|
184
|
-
if (typeof filter.search !== 'string') {
|
|
185
|
-
throw new Error('Full-text search term must be a string');
|
|
186
|
-
}
|
|
187
|
-
if (filter.search.length > 1000) {
|
|
188
|
-
throw new Error('Full-text search term too long (max 1000 characters)');
|
|
189
|
-
}
|
|
190
|
-
return client_1.Prisma.sql `to_tsvector('simple', ${fieldRef}) @@ plainto_tsquery('simple', ${filter.search})`;
|
|
191
|
-
}
|
|
192
|
-
throw new Error(`Unsupported StringFilter: ${JSON.stringify(filter)}`);
|
|
193
|
-
}
|
|
194
|
-
processBoolField(field, condition) {
|
|
195
|
-
const fieldRef = client_1.Prisma.raw(`r."${field}"`);
|
|
196
|
-
if (typeof condition === 'boolean') {
|
|
197
|
-
return client_1.Prisma.sql `${fieldRef} = ${condition}`;
|
|
198
|
-
}
|
|
199
|
-
const filter = condition;
|
|
200
|
-
if (filter.equals !== undefined) {
|
|
201
|
-
return client_1.Prisma.sql `${fieldRef} = ${filter.equals}`;
|
|
202
|
-
}
|
|
203
|
-
if (filter.not !== undefined) {
|
|
204
|
-
return client_1.Prisma.sql `${fieldRef} != ${filter.not}`;
|
|
205
|
-
}
|
|
206
|
-
throw new Error(`Unsupported BoolFilter: ${JSON.stringify(filter)}`);
|
|
207
|
-
}
|
|
208
|
-
processDateField(field, condition) {
|
|
209
|
-
const fieldRef = client_1.Prisma.raw(`r."${field}"`);
|
|
210
|
-
if (typeof condition === 'string' || condition instanceof Date) {
|
|
211
|
-
const dateStr = condition instanceof Date ? condition.toISOString() : condition;
|
|
212
|
-
return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
|
|
213
|
-
}
|
|
214
|
-
const filter = condition;
|
|
215
|
-
const clauses = [];
|
|
216
|
-
if (filter.equals !== undefined) {
|
|
217
|
-
const dateStr = filter.equals instanceof Date
|
|
218
|
-
? filter.equals.toISOString()
|
|
219
|
-
: filter.equals;
|
|
220
|
-
return client_1.Prisma.sql `${fieldRef} = ${dateStr}::timestamp`;
|
|
221
|
-
}
|
|
222
|
-
if (filter.gt !== undefined) {
|
|
223
|
-
const dateStr = filter.gt instanceof Date ? filter.gt.toISOString() : filter.gt;
|
|
224
|
-
clauses.push(client_1.Prisma.sql `${fieldRef} > ${dateStr}::timestamp`);
|
|
225
|
-
}
|
|
226
|
-
if (filter.gte !== undefined) {
|
|
227
|
-
const dateStr = filter.gte instanceof Date ? filter.gte.toISOString() : filter.gte;
|
|
228
|
-
clauses.push(client_1.Prisma.sql `${fieldRef} >= ${dateStr}::timestamp`);
|
|
229
|
-
}
|
|
230
|
-
if (filter.lt !== undefined) {
|
|
231
|
-
const dateStr = filter.lt instanceof Date ? filter.lt.toISOString() : filter.lt;
|
|
232
|
-
clauses.push(client_1.Prisma.sql `${fieldRef} < ${dateStr}::timestamp`);
|
|
233
|
-
}
|
|
234
|
-
if (filter.lte !== undefined) {
|
|
235
|
-
const dateStr = filter.lte instanceof Date ? filter.lte.toISOString() : filter.lte;
|
|
236
|
-
clauses.push(client_1.Prisma.sql `${fieldRef} <= ${dateStr}::timestamp`);
|
|
237
|
-
}
|
|
238
|
-
if (clauses.length > 0) {
|
|
239
|
-
return this.combineWithAnd(clauses);
|
|
240
|
-
}
|
|
241
|
-
if (filter.in !== undefined) {
|
|
242
|
-
if (Array.isArray(filter.in) && filter.in.length === 0) {
|
|
243
|
-
return client_1.Prisma.sql `FALSE`;
|
|
244
|
-
}
|
|
245
|
-
const dateStrs = filter.in.map((d) => d instanceof Date ? d.toISOString() : d);
|
|
246
|
-
const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
|
|
247
|
-
return client_1.Prisma.sql `${fieldRef} IN (${client_1.Prisma.join(castDates)})`;
|
|
248
|
-
}
|
|
249
|
-
if (filter.notIn !== undefined) {
|
|
250
|
-
if (Array.isArray(filter.notIn) && filter.notIn.length === 0) {
|
|
251
|
-
return client_1.Prisma.sql `TRUE`;
|
|
252
|
-
}
|
|
253
|
-
const dateStrs = filter.notIn.map((d) => d instanceof Date ? d.toISOString() : d);
|
|
254
|
-
const castDates = dateStrs.map((d) => client_1.Prisma.sql `${d}::timestamp`);
|
|
255
|
-
return client_1.Prisma.sql `${fieldRef} NOT IN (${client_1.Prisma.join(castDates)})`;
|
|
256
|
-
}
|
|
257
|
-
throw new Error(`Unsupported DateFilter: ${JSON.stringify(filter)}`);
|
|
258
|
-
}
|
|
259
|
-
processJsonField(field, condition) {
|
|
260
|
-
const fieldRef = client_1.Prisma.raw(`r."${field}"`);
|
|
261
|
-
const { path, mode = 'default' } = condition;
|
|
262
|
-
const isInsensitive = mode === 'insensitive';
|
|
263
|
-
const pathParam = path.length === 1 ? path[0] : `{${path.join(',')}}`;
|
|
264
|
-
const jsonTextPath = path.length === 1
|
|
265
|
-
? client_1.Prisma.sql `${fieldRef}->>${pathParam}`
|
|
266
|
-
: client_1.Prisma.sql `${fieldRef}#>>${pathParam}`;
|
|
267
|
-
if (condition.equals !== undefined) {
|
|
268
|
-
if (typeof condition.equals === 'string' && isInsensitive) {
|
|
269
|
-
return client_1.Prisma.sql `LOWER(${jsonTextPath}) = LOWER(${condition.equals})`;
|
|
270
|
-
}
|
|
271
|
-
if (typeof condition.equals === 'string') {
|
|
272
|
-
return client_1.Prisma.sql `${jsonTextPath} = ${condition.equals}`;
|
|
273
|
-
}
|
|
274
|
-
const jsonValue = JSON.stringify(condition.equals);
|
|
275
|
-
return client_1.Prisma.sql `${jsonTextPath} = ${jsonValue}`;
|
|
276
|
-
}
|
|
277
|
-
if (condition.string_contains !== undefined) {
|
|
278
|
-
const pattern = `%${condition.string_contains}%`;
|
|
279
|
-
if (isInsensitive) {
|
|
280
|
-
return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
|
|
281
|
-
}
|
|
282
|
-
return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
|
|
283
|
-
}
|
|
284
|
-
if (condition.string_starts_with !== undefined) {
|
|
285
|
-
const pattern = `${condition.string_starts_with}%`;
|
|
286
|
-
if (isInsensitive) {
|
|
287
|
-
return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
|
|
288
|
-
}
|
|
289
|
-
return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
|
|
290
|
-
}
|
|
291
|
-
if (condition.string_ends_with !== undefined) {
|
|
292
|
-
const pattern = `%${condition.string_ends_with}`;
|
|
293
|
-
if (isInsensitive) {
|
|
294
|
-
return client_1.Prisma.sql `${jsonTextPath} ILIKE ${pattern}`;
|
|
295
|
-
}
|
|
296
|
-
return client_1.Prisma.sql `${jsonTextPath} LIKE ${pattern}`;
|
|
297
|
-
}
|
|
298
|
-
if (condition.gt !== undefined) {
|
|
299
|
-
return client_1.Prisma.sql `(${jsonTextPath})::numeric > ${condition.gt}`;
|
|
300
|
-
}
|
|
301
|
-
if (condition.gte !== undefined) {
|
|
302
|
-
return client_1.Prisma.sql `(${jsonTextPath})::numeric >= ${condition.gte}`;
|
|
303
|
-
}
|
|
304
|
-
if (condition.lt !== undefined) {
|
|
305
|
-
return client_1.Prisma.sql `(${jsonTextPath})::numeric < ${condition.lt}`;
|
|
306
|
-
}
|
|
307
|
-
if (condition.lte !== undefined) {
|
|
308
|
-
return client_1.Prisma.sql `(${jsonTextPath})::numeric <= ${condition.lte}`;
|
|
309
|
-
}
|
|
310
|
-
if (condition.array_contains !== undefined) {
|
|
311
|
-
const jsonValue = JSON.stringify(condition.array_contains);
|
|
312
|
-
return client_1.Prisma.sql `${fieldRef} @> ${jsonValue}::jsonb`;
|
|
313
|
-
}
|
|
314
|
-
if (condition.in !== undefined) {
|
|
315
|
-
if (Array.isArray(condition.in) && condition.in.length === 0) {
|
|
316
|
-
return client_1.Prisma.sql `FALSE`;
|
|
317
|
-
}
|
|
318
|
-
const values = condition.in.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
|
|
319
|
-
return client_1.Prisma.sql `${jsonTextPath} IN (${client_1.Prisma.join(values)})`;
|
|
320
|
-
}
|
|
321
|
-
if (condition.notIn !== undefined) {
|
|
322
|
-
if (Array.isArray(condition.notIn) && condition.notIn.length === 0) {
|
|
323
|
-
return client_1.Prisma.sql `TRUE`;
|
|
324
|
-
}
|
|
325
|
-
const values = condition.notIn.map((val) => typeof val === 'string' ? val : JSON.stringify(val));
|
|
326
|
-
return client_1.Prisma.sql `${jsonTextPath} NOT IN (${client_1.Prisma.join(values)})`;
|
|
327
|
-
}
|
|
328
|
-
if (condition.not !== undefined) {
|
|
329
|
-
if (typeof condition.not === 'string') {
|
|
330
|
-
return client_1.Prisma.sql `${jsonTextPath} != ${condition.not}`;
|
|
331
|
-
}
|
|
332
|
-
const jsonValue = JSON.stringify(condition.not);
|
|
333
|
-
return client_1.Prisma.sql `${jsonTextPath} != ${jsonValue}`;
|
|
334
|
-
}
|
|
335
|
-
throw new Error(`Unsupported JsonFilter: ${JSON.stringify(condition)}`);
|
|
336
|
-
}
|
|
337
|
-
getFieldReference(fieldName) {
|
|
338
|
-
if (!WhereGeneratorPrisma.VALID_ORDER_FIELDS.has(fieldName)) {
|
|
339
|
-
throw new Error(`Invalid ORDER BY field: ${fieldName}. Allowed fields: ${Array.from(WhereGeneratorPrisma.VALID_ORDER_FIELDS).join(', ')}`);
|
|
340
|
-
}
|
|
341
|
-
return client_1.Prisma.raw(`r."${fieldName}"`);
|
|
342
|
-
}
|
|
343
|
-
combineOrderBy(clauses) {
|
|
344
|
-
if (clauses.length === 0) {
|
|
345
|
-
return client_1.Prisma.sql `r."createdAt" DESC`;
|
|
346
|
-
}
|
|
347
|
-
if (clauses.length === 1) {
|
|
348
|
-
return clauses[0];
|
|
349
|
-
}
|
|
350
|
-
let result = clauses[0];
|
|
351
|
-
for (let i = 1; i < clauses.length; i++) {
|
|
352
|
-
result = client_1.Prisma.sql `${result}, ${clauses[i]}`;
|
|
353
|
-
}
|
|
354
|
-
return result;
|
|
355
|
-
}
|
|
356
|
-
generateJsonOrderBy(field, jsonOrder) {
|
|
357
|
-
const { path, direction = 'asc', type = 'text', aggregation = 'first', } = jsonOrder;
|
|
358
|
-
const fieldRef = client_1.Prisma.raw(`r."${field}"`);
|
|
359
|
-
const sortOrder = client_1.Prisma.raw(direction.toUpperCase());
|
|
360
|
-
const pgPath = typeof path === 'string' ? (0, json_path_1.parseJsonPath)(path) : path;
|
|
361
|
-
(0, json_path_1.validateJsonPath)(pgPath);
|
|
362
|
-
if ((0, json_path_1.hasArrayWildcard)(path) || aggregation !== 'first') {
|
|
363
|
-
return this.generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder);
|
|
364
|
-
}
|
|
365
|
-
const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(pgPath)}'`);
|
|
366
|
-
const sqlType = (0, json_path_1.getSqlType)(type);
|
|
367
|
-
return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
|
|
368
|
-
}
|
|
369
|
-
generateArrayAggregationOrder(fieldRef, pgPath, type, aggregation, sortOrder) {
|
|
370
|
-
const sqlType = (0, json_path_1.getSqlType)(type);
|
|
371
|
-
const { beforeStar, afterStar, starIndex } = (0, json_path_1.splitPathAtWildcard)(pgPath);
|
|
372
|
-
if (starIndex === -1) {
|
|
373
|
-
const modifiedPath = (0, json_path_1.handleArrayAggregation)(pgPath, aggregation);
|
|
374
|
-
const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(modifiedPath)}'`);
|
|
375
|
-
return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
|
|
376
|
-
}
|
|
377
|
-
const arrayPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(beforeStar)}'`);
|
|
378
|
-
switch (aggregation) {
|
|
379
|
-
case 'min':
|
|
380
|
-
if (afterStar.length > 0) {
|
|
381
|
-
const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
|
|
382
|
-
return client_1.Prisma.sql `(SELECT MIN((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
383
|
-
}
|
|
384
|
-
else {
|
|
385
|
-
return client_1.Prisma.sql `(SELECT MIN(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
386
|
-
}
|
|
387
|
-
case 'max':
|
|
388
|
-
if (afterStar.length > 0) {
|
|
389
|
-
const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
|
|
390
|
-
return client_1.Prisma.sql `(SELECT MAX((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
391
|
-
}
|
|
392
|
-
else {
|
|
393
|
-
return client_1.Prisma.sql `(SELECT MAX(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
394
|
-
}
|
|
395
|
-
case 'avg':
|
|
396
|
-
if (afterStar.length > 0) {
|
|
397
|
-
const subPath = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(afterStar)}'`);
|
|
398
|
-
return client_1.Prisma.sql `(SELECT AVG((value#>>${subPath})::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
399
|
-
}
|
|
400
|
-
else {
|
|
401
|
-
return client_1.Prisma.sql `(SELECT AVG(value::${client_1.Prisma.raw(sqlType)}) FROM jsonb_array_elements_text(${fieldRef}#>${arrayPath}) AS value) ${sortOrder}`;
|
|
402
|
-
}
|
|
403
|
-
case 'last': {
|
|
404
|
-
const lastPath = [...beforeStar, '-1', ...afterStar];
|
|
405
|
-
const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(lastPath)}'`);
|
|
406
|
-
return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
|
|
407
|
-
}
|
|
408
|
-
case 'first':
|
|
409
|
-
default: {
|
|
410
|
-
const firstPath = [...beforeStar, '0', ...afterStar];
|
|
411
|
-
const pathParam = client_1.Prisma.raw(`'${(0, json_path_1.buildJsonPathParam)(firstPath)}'`);
|
|
412
|
-
return client_1.Prisma.sql `(${fieldRef}#>>${pathParam})::${client_1.Prisma.raw(sqlType)} ${sortOrder}`;
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
}
|
|
416
|
-
generateGetRowsQueryPrisma(tableId, options = {}) {
|
|
417
|
-
const takeNum = Number(options.take ?? 50);
|
|
418
|
-
const take = Math.max(1, Math.min(500, isNaN(takeNum) ? 50 : takeNum));
|
|
419
|
-
const skipNum = Number(options.skip ?? 0);
|
|
420
|
-
const skip = Math.max(0, isNaN(skipNum) ? 0 : skipNum);
|
|
421
|
-
const orderByArray = Array.isArray(options.orderBy)
|
|
422
|
-
? options.orderBy
|
|
423
|
-
: options.orderBy
|
|
424
|
-
? [options.orderBy]
|
|
425
|
-
: [];
|
|
426
|
-
const whereSql = this.generateWhere(options.where || {});
|
|
427
|
-
const orderSql = this.generateOrderBy(orderByArray);
|
|
428
|
-
return client_1.Prisma.sql `
|
|
429
|
-
SELECT
|
|
430
|
-
r."versionId",
|
|
431
|
-
r."createdId",
|
|
432
|
-
r."id",
|
|
433
|
-
r."readonly",
|
|
434
|
-
r."createdAt",
|
|
435
|
-
r."updatedAt",
|
|
436
|
-
r."publishedAt",
|
|
437
|
-
r."data",
|
|
438
|
-
r."meta",
|
|
439
|
-
r."hash",
|
|
440
|
-
r."schemaHash"
|
|
441
|
-
FROM "Row" r
|
|
442
|
-
INNER JOIN "_RowToTable" rt ON rt."A" = r."versionId"
|
|
443
|
-
WHERE rt."B" = ${tableId}
|
|
444
|
-
AND ${whereSql}
|
|
445
|
-
ORDER BY ${orderSql}
|
|
446
|
-
LIMIT ${take}
|
|
447
|
-
OFFSET ${skip}
|
|
448
|
-
`;
|
|
449
|
-
}
|
|
450
|
-
generateGetRowsQuery(tableId, take, skip, whereConditions, orderBy) {
|
|
451
|
-
return this.generateGetRowsQueryPrisma(tableId, {
|
|
452
|
-
take,
|
|
453
|
-
skip,
|
|
454
|
-
where: whereConditions,
|
|
455
|
-
orderBy,
|
|
456
|
-
});
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
exports.WhereGeneratorPrisma = WhereGeneratorPrisma;
|
|
460
|
-
WhereGeneratorPrisma.VALID_ORDER_FIELDS = new Set([
|
|
461
|
-
'versionId',
|
|
462
|
-
'createdId',
|
|
463
|
-
'id',
|
|
464
|
-
'hash',
|
|
465
|
-
'schemaHash',
|
|
466
|
-
'readonly',
|
|
467
|
-
'createdAt',
|
|
468
|
-
'updatedAt',
|
|
469
|
-
'publishedAt',
|
|
470
|
-
'data',
|
|
471
|
-
'meta',
|
|
472
|
-
]);
|
|
473
|
-
function generateGetRowsQueryPrisma(tableId, take, skip, whereConditions, orderBy) {
|
|
474
|
-
const generator = new WhereGeneratorPrisma();
|
|
475
|
-
const whereClause = generator.generateWhere(whereConditions || {});
|
|
476
|
-
const orderByClause = generator.generateOrderBy(orderBy || []);
|
|
477
|
-
return client_1.Prisma.sql `
|
|
478
|
-
SELECT
|
|
479
|
-
r."versionId",
|
|
480
|
-
r."createdId",
|
|
481
|
-
r."id",
|
|
482
|
-
r."readonly",
|
|
483
|
-
r."createdAt",
|
|
484
|
-
r."updatedAt",
|
|
485
|
-
r."publishedAt",
|
|
486
|
-
r."data",
|
|
487
|
-
r."meta",
|
|
488
|
-
r."hash",
|
|
489
|
-
r."schemaHash"
|
|
490
|
-
FROM "Row" r
|
|
491
|
-
INNER JOIN "_RowToTable" rt ON r."versionId" = rt."A"
|
|
492
|
-
WHERE rt."B" = ${tableId}
|
|
493
|
-
AND (${whereClause})
|
|
494
|
-
ORDER BY ${orderByClause}
|
|
495
|
-
LIMIT ${take}
|
|
496
|
-
OFFSET ${skip}
|
|
497
|
-
`;
|
|
498
|
-
}
|
|
499
|
-
//# sourceMappingURL=where-generator.prisma.js.map
|