webapp-factory 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +145 -0
- package/dist/access-control/adapters/in-memory-relations.d.ts +7 -0
- package/dist/access-control/adapters/in-memory-relations.d.ts.map +1 -0
- package/dist/access-control/adapters/in-memory-relations.js +6 -0
- package/dist/access-control/adapters/in-memory-relations.js.map +1 -0
- package/dist/access-control/core/enforcement.d.ts +13 -0
- package/dist/access-control/core/enforcement.d.ts.map +1 -0
- package/dist/access-control/core/enforcement.js +38 -0
- package/dist/access-control/core/enforcement.js.map +1 -0
- package/dist/access-control/core/errors.d.ts +30 -0
- package/dist/access-control/core/errors.d.ts.map +1 -0
- package/dist/access-control/core/errors.js +46 -0
- package/dist/access-control/core/errors.js.map +1 -0
- package/dist/access-control/core/pdp.d.ts +14 -0
- package/dist/access-control/core/pdp.d.ts.map +1 -0
- package/dist/access-control/core/pdp.js +79 -0
- package/dist/access-control/core/pdp.js.map +1 -0
- package/dist/access-control/core/ports.d.ts +68 -0
- package/dist/access-control/core/ports.d.ts.map +1 -0
- package/dist/access-control/core/ports.js +6 -0
- package/dist/access-control/core/ports.js.map +1 -0
- package/dist/access-control/core/rbac.d.ts +10 -0
- package/dist/access-control/core/rbac.d.ts.map +1 -0
- package/dist/access-control/core/rbac.js +78 -0
- package/dist/access-control/core/rbac.js.map +1 -0
- package/dist/access-control/core/rebac.d.ts +15 -0
- package/dist/access-control/core/rebac.d.ts.map +1 -0
- package/dist/access-control/core/rebac.js +48 -0
- package/dist/access-control/core/rebac.js.map +1 -0
- package/dist/access-control/index.d.ts +15 -0
- package/dist/access-control/index.d.ts.map +1 -0
- package/dist/access-control/index.js +20 -0
- package/dist/access-control/index.js.map +1 -0
- package/dist/access-control/nestjs/access-control.module.d.ts +34 -0
- package/dist/access-control/nestjs/access-control.module.d.ts.map +1 -0
- package/dist/access-control/nestjs/access-control.module.js +80 -0
- package/dist/access-control/nestjs/access-control.module.js.map +1 -0
- package/dist/audit/adapters/in-memory-store.d.ts +3 -0
- package/dist/audit/adapters/in-memory-store.d.ts.map +1 -0
- package/dist/audit/adapters/in-memory-store.js +66 -0
- package/dist/audit/adapters/in-memory-store.js.map +1 -0
- package/dist/audit/adapters/pg-store.d.ts +22 -0
- package/dist/audit/adapters/pg-store.d.ts.map +1 -0
- package/dist/audit/adapters/pg-store.js +119 -0
- package/dist/audit/adapters/pg-store.js.map +1 -0
- package/dist/audit/core/audit-log.d.ts +41 -0
- package/dist/audit/core/audit-log.d.ts.map +1 -0
- package/dist/audit/core/audit-log.js +78 -0
- package/dist/audit/core/audit-log.js.map +1 -0
- package/dist/audit/core/errors.d.ts +22 -0
- package/dist/audit/core/errors.d.ts.map +1 -0
- package/dist/audit/core/errors.js +35 -0
- package/dist/audit/core/errors.js.map +1 -0
- package/dist/audit/core/hash.d.ts +9 -0
- package/dist/audit/core/hash.d.ts.map +1 -0
- package/dist/audit/core/hash.js +45 -0
- package/dist/audit/core/hash.js.map +1 -0
- package/dist/audit/core/ports.d.ts +68 -0
- package/dist/audit/core/ports.d.ts.map +1 -0
- package/dist/audit/core/ports.js +6 -0
- package/dist/audit/core/ports.js.map +1 -0
- package/dist/audit/index.d.ts +13 -0
- package/dist/audit/index.d.ts.map +1 -0
- package/dist/audit/index.js +16 -0
- package/dist/audit/index.js.map +1 -0
- package/dist/auth/adapters/argon2id-hasher.d.ts +15 -0
- package/dist/auth/adapters/argon2id-hasher.d.ts.map +1 -0
- package/dist/auth/adapters/argon2id-hasher.js +61 -0
- package/dist/auth/adapters/argon2id-hasher.js.map +1 -0
- package/dist/auth/adapters/in-memory-stores.d.ts +14 -0
- package/dist/auth/adapters/in-memory-stores.d.ts.map +1 -0
- package/dist/auth/adapters/in-memory-stores.js +78 -0
- package/dist/auth/adapters/in-memory-stores.js.map +1 -0
- package/dist/auth/core/auth-service.d.ts +40 -0
- package/dist/auth/core/auth-service.d.ts.map +1 -0
- package/dist/auth/core/auth-service.js +106 -0
- package/dist/auth/core/auth-service.js.map +1 -0
- package/dist/auth/core/credentials.d.ts +15 -0
- package/dist/auth/core/credentials.d.ts.map +1 -0
- package/dist/auth/core/credentials.js +15 -0
- package/dist/auth/core/credentials.js.map +1 -0
- package/dist/auth/core/crypto-util.d.ts +7 -0
- package/dist/auth/core/crypto-util.d.ts.map +1 -0
- package/dist/auth/core/crypto-util.js +15 -0
- package/dist/auth/core/crypto-util.js.map +1 -0
- package/dist/auth/core/errors.d.ts +33 -0
- package/dist/auth/core/errors.d.ts.map +1 -0
- package/dist/auth/core/errors.js +48 -0
- package/dist/auth/core/errors.js.map +1 -0
- package/dist/auth/core/jwt.d.ts +5 -0
- package/dist/auth/core/jwt.d.ts.map +1 -0
- package/dist/auth/core/jwt.js +40 -0
- package/dist/auth/core/jwt.js.map +1 -0
- package/dist/auth/core/ports.d.ts +95 -0
- package/dist/auth/core/ports.d.ts.map +1 -0
- package/dist/auth/core/ports.js +7 -0
- package/dist/auth/core/ports.js.map +1 -0
- package/dist/auth/core/single-use.d.ts +10 -0
- package/dist/auth/core/single-use.d.ts.map +1 -0
- package/dist/auth/core/single-use.js +47 -0
- package/dist/auth/core/single-use.js.map +1 -0
- package/dist/auth/core/tokens.d.ts +14 -0
- package/dist/auth/core/tokens.d.ts.map +1 -0
- package/dist/auth/core/tokens.js +85 -0
- package/dist/auth/core/tokens.js.map +1 -0
- package/dist/auth/index.d.ts +18 -0
- package/dist/auth/index.d.ts.map +1 -0
- package/dist/auth/index.js +22 -0
- package/dist/auth/index.js.map +1 -0
- package/dist/auth/nestjs/auth.module.d.ts +17 -0
- package/dist/auth/nestjs/auth.module.d.ts.map +1 -0
- package/dist/auth/nestjs/auth.module.js +18 -0
- package/dist/auth/nestjs/auth.module.js.map +1 -0
- package/dist/cache/adapters/in-memory-store.d.ts +6 -0
- package/dist/cache/adapters/in-memory-store.d.ts.map +1 -0
- package/dist/cache/adapters/in-memory-store.js +65 -0
- package/dist/cache/adapters/in-memory-store.js.map +1 -0
- package/dist/cache/adapters/redis-store.d.ts +32 -0
- package/dist/cache/adapters/redis-store.d.ts.map +1 -0
- package/dist/cache/adapters/redis-store.js +59 -0
- package/dist/cache/adapters/redis-store.js.map +1 -0
- package/dist/cache/core/cache.d.ts +31 -0
- package/dist/cache/core/cache.d.ts.map +1 -0
- package/dist/cache/core/cache.js +89 -0
- package/dist/cache/core/cache.js.map +1 -0
- package/dist/cache/core/errors.d.ts +17 -0
- package/dist/cache/core/errors.d.ts.map +1 -0
- package/dist/cache/core/errors.js +27 -0
- package/dist/cache/core/errors.js.map +1 -0
- package/dist/cache/core/lock.d.ts +21 -0
- package/dist/cache/core/lock.d.ts.map +1 -0
- package/dist/cache/core/lock.js +47 -0
- package/dist/cache/core/lock.js.map +1 -0
- package/dist/cache/core/ports.d.ts +33 -0
- package/dist/cache/core/ports.d.ts.map +1 -0
- package/dist/cache/core/ports.js +6 -0
- package/dist/cache/core/ports.js.map +1 -0
- package/dist/cache/core/pubsub.d.ts +14 -0
- package/dist/cache/core/pubsub.d.ts.map +1 -0
- package/dist/cache/core/pubsub.js +13 -0
- package/dist/cache/core/pubsub.js.map +1 -0
- package/dist/cache/core/serializer.d.ts +4 -0
- package/dist/cache/core/serializer.d.ts.map +1 -0
- package/dist/cache/core/serializer.js +6 -0
- package/dist/cache/core/serializer.js.map +1 -0
- package/dist/cache/index.d.ts +14 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +19 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/config/adapters/reporters.d.ts +17 -0
- package/dist/config/adapters/reporters.d.ts.map +1 -0
- package/dist/config/adapters/reporters.js +35 -0
- package/dist/config/adapters/reporters.js.map +1 -0
- package/dist/config/adapters/secret-resolvers.d.ts +21 -0
- package/dist/config/adapters/secret-resolvers.d.ts.map +1 -0
- package/dist/config/adapters/secret-resolvers.js +60 -0
- package/dist/config/adapters/secret-resolvers.js.map +1 -0
- package/dist/config/adapters/zod-schema.d.ts +20 -0
- package/dist/config/adapters/zod-schema.d.ts.map +1 -0
- package/dist/config/adapters/zod-schema.js +35 -0
- package/dist/config/adapters/zod-schema.js.map +1 -0
- package/dist/config/core/env-loader.d.ts +47 -0
- package/dist/config/core/env-loader.d.ts.map +1 -0
- package/dist/config/core/env-loader.js +155 -0
- package/dist/config/core/env-loader.js.map +1 -0
- package/dist/config/core/errors.d.ts +34 -0
- package/dist/config/core/errors.d.ts.map +1 -0
- package/dist/config/core/errors.js +49 -0
- package/dist/config/core/errors.js.map +1 -0
- package/dist/config/core/freeze.d.ts +7 -0
- package/dist/config/core/freeze.d.ts.map +1 -0
- package/dist/config/core/freeze.js +20 -0
- package/dist/config/core/freeze.js.map +1 -0
- package/dist/config/core/load-config.d.ts +43 -0
- package/dist/config/core/load-config.d.ts.map +1 -0
- package/dist/config/core/load-config.js +74 -0
- package/dist/config/core/load-config.js.map +1 -0
- package/dist/config/core/merge.d.ts +19 -0
- package/dist/config/core/merge.d.ts.map +1 -0
- package/dist/config/core/merge.js +31 -0
- package/dist/config/core/merge.js.map +1 -0
- package/dist/config/core/ports.d.ts +58 -0
- package/dist/config/core/ports.d.ts.map +1 -0
- package/dist/config/core/ports.js +2 -0
- package/dist/config/core/ports.js.map +1 -0
- package/dist/config/core/secret-resolver.d.ts +16 -0
- package/dist/config/core/secret-resolver.d.ts.map +1 -0
- package/dist/config/core/secret-resolver.js +73 -0
- package/dist/config/core/secret-resolver.js.map +1 -0
- package/dist/config/core/secret.d.ts +21 -0
- package/dist/config/core/secret.d.ts.map +1 -0
- package/dist/config/core/secret.js +40 -0
- package/dist/config/core/secret.js.map +1 -0
- package/dist/config/index.d.ts +16 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +23 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/nestjs/config-kit.module.d.ts +37 -0
- package/dist/config/nestjs/config-kit.module.d.ts.map +1 -0
- package/dist/config/nestjs/config-kit.module.js +24 -0
- package/dist/config/nestjs/config-kit.module.js.map +1 -0
- package/dist/http/adapters/zod-schema.d.ts +11 -0
- package/dist/http/adapters/zod-schema.d.ts.map +1 -0
- package/dist/http/adapters/zod-schema.js +74 -0
- package/dist/http/adapters/zod-schema.js.map +1 -0
- package/dist/http/core/context.d.ts +25 -0
- package/dist/http/core/context.d.ts.map +1 -0
- package/dist/http/core/context.js +60 -0
- package/dist/http/core/context.js.map +1 -0
- package/dist/http/core/errors.d.ts +41 -0
- package/dist/http/core/errors.d.ts.map +1 -0
- package/dist/http/core/errors.js +99 -0
- package/dist/http/core/errors.js.map +1 -0
- package/dist/http/core/kernel.d.ts +54 -0
- package/dist/http/core/kernel.d.ts.map +1 -0
- package/dist/http/core/kernel.js +122 -0
- package/dist/http/core/kernel.js.map +1 -0
- package/dist/http/core/openapi.d.ts +37 -0
- package/dist/http/core/openapi.d.ts.map +1 -0
- package/dist/http/core/openapi.js +99 -0
- package/dist/http/core/openapi.js.map +1 -0
- package/dist/http/core/pagination.d.ts +17 -0
- package/dist/http/core/pagination.d.ts.map +1 -0
- package/dist/http/core/pagination.js +108 -0
- package/dist/http/core/pagination.js.map +1 -0
- package/dist/http/core/ports.d.ts +106 -0
- package/dist/http/core/ports.d.ts.map +1 -0
- package/dist/http/core/ports.js +6 -0
- package/dist/http/core/ports.js.map +1 -0
- package/dist/http/core/redaction.d.ts +8 -0
- package/dist/http/core/redaction.d.ts.map +1 -0
- package/dist/http/core/redaction.js +45 -0
- package/dist/http/core/redaction.js.map +1 -0
- package/dist/http/core/router.d.ts +37 -0
- package/dist/http/core/router.d.ts.map +1 -0
- package/dist/http/core/router.js +120 -0
- package/dist/http/core/router.js.map +1 -0
- package/dist/http/core/security.d.ts +43 -0
- package/dist/http/core/security.d.ts.map +1 -0
- package/dist/http/core/security.js +66 -0
- package/dist/http/core/security.js.map +1 -0
- package/dist/http/core/validation.d.ts +9 -0
- package/dist/http/core/validation.d.ts.map +1 -0
- package/dist/http/core/validation.js +36 -0
- package/dist/http/core/validation.js.map +1 -0
- package/dist/http/index.d.ts +20 -0
- package/dist/http/index.d.ts.map +1 -0
- package/dist/http/index.js +29 -0
- package/dist/http/index.js.map +1 -0
- package/dist/http/nestjs/http-kernel.module.d.ts +37 -0
- package/dist/http/nestjs/http-kernel.module.d.ts.map +1 -0
- package/dist/http/nestjs/http-kernel.module.js +77 -0
- package/dist/http/nestjs/http-kernel.module.js.map +1 -0
- package/dist/http/nodejs/http-adapter.d.ts +11 -0
- package/dist/http/nodejs/http-adapter.d.ts.map +1 -0
- package/dist/http/nodejs/http-adapter.js +60 -0
- package/dist/http/nodejs/http-adapter.js.map +1 -0
- package/dist/i18n/core/catalog.d.ts +23 -0
- package/dist/i18n/core/catalog.d.ts.map +1 -0
- package/dist/i18n/core/catalog.js +31 -0
- package/dist/i18n/core/catalog.js.map +1 -0
- package/dist/i18n/core/errors.d.ts +14 -0
- package/dist/i18n/core/errors.d.ts.map +1 -0
- package/dist/i18n/core/errors.js +22 -0
- package/dist/i18n/core/errors.js.map +1 -0
- package/dist/i18n/core/i18n.d.ts +20 -0
- package/dist/i18n/core/i18n.d.ts.map +1 -0
- package/dist/i18n/core/i18n.js +48 -0
- package/dist/i18n/core/i18n.js.map +1 -0
- package/dist/i18n/core/message.d.ts +8 -0
- package/dist/i18n/core/message.d.ts.map +1 -0
- package/dist/i18n/core/message.js +38 -0
- package/dist/i18n/core/message.js.map +1 -0
- package/dist/i18n/core/negotiate.d.ts +13 -0
- package/dist/i18n/core/negotiate.d.ts.map +1 -0
- package/dist/i18n/core/negotiate.js +46 -0
- package/dist/i18n/core/negotiate.js.map +1 -0
- package/dist/i18n/core/ports.d.ts +35 -0
- package/dist/i18n/core/ports.d.ts.map +1 -0
- package/dist/i18n/core/ports.js +6 -0
- package/dist/i18n/core/ports.js.map +1 -0
- package/dist/i18n/index.d.ts +14 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js +18 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/i18n/nestjs/i18n.module.d.ts +16 -0
- package/dist/i18n/nestjs/i18n.module.d.ts.map +1 -0
- package/dist/i18n/nestjs/i18n.module.js +17 -0
- package/dist/i18n/nestjs/i18n.module.js.map +1 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +31 -0
- package/dist/index.js.map +1 -0
- package/dist/jobs/adapters/in-memory-idempotency.d.ts +9 -0
- package/dist/jobs/adapters/in-memory-idempotency.d.ts.map +1 -0
- package/dist/jobs/adapters/in-memory-idempotency.js +34 -0
- package/dist/jobs/adapters/in-memory-idempotency.js.map +1 -0
- package/dist/jobs/adapters/in-memory-queue-store.d.ts +7 -0
- package/dist/jobs/adapters/in-memory-queue-store.d.ts.map +1 -0
- package/dist/jobs/adapters/in-memory-queue-store.js +70 -0
- package/dist/jobs/adapters/in-memory-queue-store.js.map +1 -0
- package/dist/jobs/adapters/redis-queue-store.d.ts +28 -0
- package/dist/jobs/adapters/redis-queue-store.d.ts.map +1 -0
- package/dist/jobs/adapters/redis-queue-store.js +86 -0
- package/dist/jobs/adapters/redis-queue-store.js.map +1 -0
- package/dist/jobs/core/backoff.d.ts +15 -0
- package/dist/jobs/core/backoff.d.ts.map +1 -0
- package/dist/jobs/core/backoff.js +20 -0
- package/dist/jobs/core/backoff.js.map +1 -0
- package/dist/jobs/core/cron.d.ts +13 -0
- package/dist/jobs/core/cron.d.ts.map +1 -0
- package/dist/jobs/core/cron.js +101 -0
- package/dist/jobs/core/cron.js.map +1 -0
- package/dist/jobs/core/errors.d.ts +18 -0
- package/dist/jobs/core/errors.d.ts.map +1 -0
- package/dist/jobs/core/errors.js +30 -0
- package/dist/jobs/core/errors.js.map +1 -0
- package/dist/jobs/core/ports.d.ts +80 -0
- package/dist/jobs/core/ports.d.ts.map +1 -0
- package/dist/jobs/core/ports.js +6 -0
- package/dist/jobs/core/ports.js.map +1 -0
- package/dist/jobs/core/queue.d.ts +16 -0
- package/dist/jobs/core/queue.d.ts.map +1 -0
- package/dist/jobs/core/queue.js +29 -0
- package/dist/jobs/core/queue.js.map +1 -0
- package/dist/jobs/core/registry.d.ts +4 -0
- package/dist/jobs/core/registry.d.ts.map +1 -0
- package/dist/jobs/core/registry.js +11 -0
- package/dist/jobs/core/registry.js.map +1 -0
- package/dist/jobs/core/scheduler.d.ts +30 -0
- package/dist/jobs/core/scheduler.d.ts.map +1 -0
- package/dist/jobs/core/scheduler.js +53 -0
- package/dist/jobs/core/scheduler.js.map +1 -0
- package/dist/jobs/core/serializer.d.ts +3 -0
- package/dist/jobs/core/serializer.d.ts.map +1 -0
- package/dist/jobs/core/serializer.js +5 -0
- package/dist/jobs/core/serializer.js.map +1 -0
- package/dist/jobs/core/worker.d.ts +28 -0
- package/dist/jobs/core/worker.d.ts.map +1 -0
- package/dist/jobs/core/worker.js +118 -0
- package/dist/jobs/core/worker.js.map +1 -0
- package/dist/jobs/index.d.ts +18 -0
- package/dist/jobs/index.d.ts.map +1 -0
- package/dist/jobs/index.js +23 -0
- package/dist/jobs/index.js.map +1 -0
- package/dist/mailer/adapters/dev-inbox.d.ts +17 -0
- package/dist/mailer/adapters/dev-inbox.d.ts.map +1 -0
- package/dist/mailer/adapters/dev-inbox.js +29 -0
- package/dist/mailer/adapters/dev-inbox.js.map +1 -0
- package/dist/mailer/adapters/i18n-renderer.d.ts +13 -0
- package/dist/mailer/adapters/i18n-renderer.d.ts.map +1 -0
- package/dist/mailer/adapters/i18n-renderer.js +27 -0
- package/dist/mailer/adapters/i18n-renderer.js.map +1 -0
- package/dist/mailer/adapters/in-memory-templates.d.ts +6 -0
- package/dist/mailer/adapters/in-memory-templates.d.ts.map +1 -0
- package/dist/mailer/adapters/in-memory-templates.js +6 -0
- package/dist/mailer/adapters/in-memory-templates.js.map +1 -0
- package/dist/mailer/adapters/transports.d.ts +19 -0
- package/dist/mailer/adapters/transports.d.ts.map +1 -0
- package/dist/mailer/adapters/transports.js +38 -0
- package/dist/mailer/adapters/transports.js.map +1 -0
- package/dist/mailer/core/errors.d.ts +23 -0
- package/dist/mailer/core/errors.d.ts.map +1 -0
- package/dist/mailer/core/errors.js +40 -0
- package/dist/mailer/core/errors.js.map +1 -0
- package/dist/mailer/core/failover.d.ts +3 -0
- package/dist/mailer/core/failover.d.ts.map +1 -0
- package/dist/mailer/core/failover.js +30 -0
- package/dist/mailer/core/failover.js.map +1 -0
- package/dist/mailer/core/mailer.d.ts +25 -0
- package/dist/mailer/core/mailer.d.ts.map +1 -0
- package/dist/mailer/core/mailer.js +61 -0
- package/dist/mailer/core/mailer.js.map +1 -0
- package/dist/mailer/core/ports.d.ts +54 -0
- package/dist/mailer/core/ports.d.ts.map +1 -0
- package/dist/mailer/core/ports.js +6 -0
- package/dist/mailer/core/ports.js.map +1 -0
- package/dist/mailer/core/render.d.ts +4 -0
- package/dist/mailer/core/render.d.ts.map +1 -0
- package/dist/mailer/core/render.js +29 -0
- package/dist/mailer/core/render.js.map +1 -0
- package/dist/mailer/index.d.ts +17 -0
- package/dist/mailer/index.d.ts.map +1 -0
- package/dist/mailer/index.js +21 -0
- package/dist/mailer/index.js.map +1 -0
- package/dist/mailer/nestjs/mailer.module.d.ts +17 -0
- package/dist/mailer/nestjs/mailer.module.d.ts.map +1 -0
- package/dist/mailer/nestjs/mailer.module.js +15 -0
- package/dist/mailer/nestjs/mailer.module.js.map +1 -0
- package/dist/observability/core/context.d.ts +9 -0
- package/dist/observability/core/context.d.ts.map +1 -0
- package/dist/observability/core/context.js +15 -0
- package/dist/observability/core/context.js.map +1 -0
- package/dist/observability/core/health.d.ts +40 -0
- package/dist/observability/core/health.d.ts.map +1 -0
- package/dist/observability/core/health.js +51 -0
- package/dist/observability/core/health.js.map +1 -0
- package/dist/observability/core/logger.d.ts +22 -0
- package/dist/observability/core/logger.d.ts.map +1 -0
- package/dist/observability/core/logger.js +45 -0
- package/dist/observability/core/logger.js.map +1 -0
- package/dist/observability/core/metrics.d.ts +63 -0
- package/dist/observability/core/metrics.d.ts.map +1 -0
- package/dist/observability/core/metrics.js +172 -0
- package/dist/observability/core/metrics.js.map +1 -0
- package/dist/observability/core/redaction.d.ts +10 -0
- package/dist/observability/core/redaction.d.ts.map +1 -0
- package/dist/observability/core/redaction.js +48 -0
- package/dist/observability/core/redaction.js.map +1 -0
- package/dist/observability/core/tracing.d.ts +52 -0
- package/dist/observability/core/tracing.d.ts.map +1 -0
- package/dist/observability/core/tracing.js +88 -0
- package/dist/observability/core/tracing.js.map +1 -0
- package/dist/observability/index.d.ts +14 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js +19 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/nestjs/observability.module.d.ts +35 -0
- package/dist/observability/nestjs/observability.module.d.ts.map +1 -0
- package/dist/observability/nestjs/observability.module.js +87 -0
- package/dist/observability/nestjs/observability.module.js.map +1 -0
- package/dist/persistence/adapters/in-memory-driver.d.ts +18 -0
- package/dist/persistence/adapters/in-memory-driver.d.ts.map +1 -0
- package/dist/persistence/adapters/in-memory-driver.js +229 -0
- package/dist/persistence/adapters/in-memory-driver.js.map +1 -0
- package/dist/persistence/adapters/pg-driver.d.ts +21 -0
- package/dist/persistence/adapters/pg-driver.d.ts.map +1 -0
- package/dist/persistence/adapters/pg-driver.js +42 -0
- package/dist/persistence/adapters/pg-driver.js.map +1 -0
- package/dist/persistence/adapters/testcontainer-harness.d.ts +37 -0
- package/dist/persistence/adapters/testcontainer-harness.d.ts.map +1 -0
- package/dist/persistence/adapters/testcontainer-harness.js +79 -0
- package/dist/persistence/adapters/testcontainer-harness.js.map +1 -0
- package/dist/persistence/core/errors.d.ts +36 -0
- package/dist/persistence/core/errors.d.ts.map +1 -0
- package/dist/persistence/core/errors.js +58 -0
- package/dist/persistence/core/errors.js.map +1 -0
- package/dist/persistence/core/migrations.d.ts +16 -0
- package/dist/persistence/core/migrations.d.ts.map +1 -0
- package/dist/persistence/core/migrations.js +95 -0
- package/dist/persistence/core/migrations.js.map +1 -0
- package/dist/persistence/core/pool.d.ts +4 -0
- package/dist/persistence/core/pool.d.ts.map +1 -0
- package/dist/persistence/core/pool.js +180 -0
- package/dist/persistence/core/pool.js.map +1 -0
- package/dist/persistence/core/ports.d.ts +91 -0
- package/dist/persistence/core/ports.d.ts.map +1 -0
- package/dist/persistence/core/ports.js +6 -0
- package/dist/persistence/core/ports.js.map +1 -0
- package/dist/persistence/core/repository.d.ts +18 -0
- package/dist/persistence/core/repository.d.ts.map +1 -0
- package/dist/persistence/core/repository.js +113 -0
- package/dist/persistence/core/repository.js.map +1 -0
- package/dist/persistence/core/sql.d.ts +13 -0
- package/dist/persistence/core/sql.d.ts.map +1 -0
- package/dist/persistence/core/sql.js +35 -0
- package/dist/persistence/core/sql.js.map +1 -0
- package/dist/persistence/index.d.ts +14 -0
- package/dist/persistence/index.d.ts.map +1 -0
- package/dist/persistence/index.js +22 -0
- package/dist/persistence/index.js.map +1 -0
- package/dist/persistence/pg.d.ts +7 -0
- package/dist/persistence/pg.d.ts.map +1 -0
- package/dist/persistence/pg.js +7 -0
- package/dist/persistence/pg.js.map +1 -0
- package/dist/privacy/adapters/audit-sink.d.ts +19 -0
- package/dist/privacy/adapters/audit-sink.d.ts.map +1 -0
- package/dist/privacy/adapters/audit-sink.js +13 -0
- package/dist/privacy/adapters/audit-sink.js.map +1 -0
- package/dist/privacy/adapters/in-memory-consent-store.d.ts +7 -0
- package/dist/privacy/adapters/in-memory-consent-store.d.ts.map +1 -0
- package/dist/privacy/adapters/in-memory-consent-store.js +18 -0
- package/dist/privacy/adapters/in-memory-consent-store.js.map +1 -0
- package/dist/privacy/adapters/pg-consent-store.d.ts +26 -0
- package/dist/privacy/adapters/pg-consent-store.d.ts.map +1 -0
- package/dist/privacy/adapters/pg-consent-store.js +43 -0
- package/dist/privacy/adapters/pg-consent-store.js.map +1 -0
- package/dist/privacy/core/consent.d.ts +35 -0
- package/dist/privacy/core/consent.d.ts.map +1 -0
- package/dist/privacy/core/consent.js +49 -0
- package/dist/privacy/core/consent.js.map +1 -0
- package/dist/privacy/core/erasure.d.ts +22 -0
- package/dist/privacy/core/erasure.d.ts.map +1 -0
- package/dist/privacy/core/erasure.js +35 -0
- package/dist/privacy/core/erasure.js.map +1 -0
- package/dist/privacy/core/errors.d.ts +18 -0
- package/dist/privacy/core/errors.d.ts.map +1 -0
- package/dist/privacy/core/errors.js +30 -0
- package/dist/privacy/core/errors.js.map +1 -0
- package/dist/privacy/core/export.d.ts +20 -0
- package/dist/privacy/core/export.d.ts.map +1 -0
- package/dist/privacy/core/export.js +30 -0
- package/dist/privacy/core/export.js.map +1 -0
- package/dist/privacy/core/ports.d.ts +48 -0
- package/dist/privacy/core/ports.d.ts.map +1 -0
- package/dist/privacy/core/ports.js +6 -0
- package/dist/privacy/core/ports.js.map +1 -0
- package/dist/privacy/core/registry.d.ts +17 -0
- package/dist/privacy/core/registry.d.ts.map +1 -0
- package/dist/privacy/core/registry.js +31 -0
- package/dist/privacy/core/registry.js.map +1 -0
- package/dist/privacy/index.d.ts +16 -0
- package/dist/privacy/index.d.ts.map +1 -0
- package/dist/privacy/index.js +21 -0
- package/dist/privacy/index.js.map +1 -0
- package/dist/rate-limit/adapters/in-memory-store.d.ts +7 -0
- package/dist/rate-limit/adapters/in-memory-store.d.ts.map +1 -0
- package/dist/rate-limit/adapters/in-memory-store.js +50 -0
- package/dist/rate-limit/adapters/in-memory-store.js.map +1 -0
- package/dist/rate-limit/adapters/redis-store.d.ts +11 -0
- package/dist/rate-limit/adapters/redis-store.d.ts.map +1 -0
- package/dist/rate-limit/adapters/redis-store.js +93 -0
- package/dist/rate-limit/adapters/redis-store.js.map +1 -0
- package/dist/rate-limit/core/enforcer.d.ts +23 -0
- package/dist/rate-limit/core/enforcer.d.ts.map +1 -0
- package/dist/rate-limit/core/enforcer.js +27 -0
- package/dist/rate-limit/core/enforcer.js.map +1 -0
- package/dist/rate-limit/core/errors.d.ts +19 -0
- package/dist/rate-limit/core/errors.d.ts.map +1 -0
- package/dist/rate-limit/core/errors.js +32 -0
- package/dist/rate-limit/core/errors.js.map +1 -0
- package/dist/rate-limit/core/ports.d.ts +50 -0
- package/dist/rate-limit/core/ports.d.ts.map +1 -0
- package/dist/rate-limit/core/ports.js +6 -0
- package/dist/rate-limit/core/ports.js.map +1 -0
- package/dist/rate-limit/core/sliding-window.d.ts +9 -0
- package/dist/rate-limit/core/sliding-window.d.ts.map +1 -0
- package/dist/rate-limit/core/sliding-window.js +24 -0
- package/dist/rate-limit/core/sliding-window.js.map +1 -0
- package/dist/rate-limit/core/token-bucket.d.ts +9 -0
- package/dist/rate-limit/core/token-bucket.d.ts.map +1 -0
- package/dist/rate-limit/core/token-bucket.js +24 -0
- package/dist/rate-limit/core/token-bucket.js.map +1 -0
- package/dist/rate-limit/index.d.ts +15 -0
- package/dist/rate-limit/index.d.ts.map +1 -0
- package/dist/rate-limit/index.js +19 -0
- package/dist/rate-limit/index.js.map +1 -0
- package/dist/rate-limit/nestjs/rate-limit.module.d.ts +25 -0
- package/dist/rate-limit/nestjs/rate-limit.module.d.ts.map +1 -0
- package/dist/rate-limit/nestjs/rate-limit.module.js +63 -0
- package/dist/rate-limit/nestjs/rate-limit.module.js.map +1 -0
- package/dist/rate-limit/nodejs/middleware.d.ts +16 -0
- package/dist/rate-limit/nodejs/middleware.d.ts.map +1 -0
- package/dist/rate-limit/nodejs/middleware.js +26 -0
- package/dist/rate-limit/nodejs/middleware.js.map +1 -0
- package/dist/test-kit/adapters/infra-bootstrap.d.ts +40 -0
- package/dist/test-kit/adapters/infra-bootstrap.d.ts.map +1 -0
- package/dist/test-kit/adapters/infra-bootstrap.js +64 -0
- package/dist/test-kit/adapters/infra-bootstrap.js.map +1 -0
- package/dist/test-kit/core/contract.d.ts +49 -0
- package/dist/test-kit/core/contract.d.ts.map +1 -0
- package/dist/test-kit/core/contract.js +52 -0
- package/dist/test-kit/core/contract.js.map +1 -0
- package/dist/test-kit/core/errors.d.ts +12 -0
- package/dist/test-kit/core/errors.d.ts.map +1 -0
- package/dist/test-kit/core/errors.js +19 -0
- package/dist/test-kit/core/errors.js.map +1 -0
- package/dist/test-kit/core/factories.d.ts +24 -0
- package/dist/test-kit/core/factories.d.ts.map +1 -0
- package/dist/test-kit/core/factories.js +57 -0
- package/dist/test-kit/core/factories.js.map +1 -0
- package/dist/test-kit/core/http-client.d.ts +46 -0
- package/dist/test-kit/core/http-client.d.ts.map +1 -0
- package/dist/test-kit/core/http-client.js +63 -0
- package/dist/test-kit/core/http-client.js.map +1 -0
- package/dist/test-kit/index.d.ts +10 -0
- package/dist/test-kit/index.d.ts.map +1 -0
- package/dist/test-kit/index.js +14 -0
- package/dist/test-kit/index.js.map +1 -0
- package/dist/test-kit/infra.d.ts +6 -0
- package/dist/test-kit/infra.d.ts.map +1 -0
- package/dist/test-kit/infra.js +6 -0
- package/dist/test-kit/infra.js.map +1 -0
- package/package.json +170 -0
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Poorten & types voor de persistence-kit. Het consumerende project injecteert een driver-adapter,
|
|
3
|
+
* connectie-config, migraties en entity-mappings; de kit bevat geen domeinkennis of tabelnamen.
|
|
4
|
+
*/
|
|
5
|
+
export type Row = Record<string, unknown>;
|
|
6
|
+
export interface QueryResult<R extends Row = Row> {
|
|
7
|
+
rows: R[];
|
|
8
|
+
rowCount: number;
|
|
9
|
+
}
|
|
10
|
+
/** Een fysieke databaseverbinding zoals een driver-adapter die levert. */
|
|
11
|
+
export interface DriverConnection {
|
|
12
|
+
execute<R extends Row = Row>(sql: string, params?: readonly unknown[]): Promise<QueryResult<R>>;
|
|
13
|
+
close(): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Driver-poort (US-0301 AC4). De pool leent hier fysieke verbindingen. Adapters: `pgDriver` (echte
|
|
17
|
+
* Postgres) en `inMemoryDriver` (dep-vrij, voor tests en consumer-tests).
|
|
18
|
+
*/
|
|
19
|
+
export interface Driver {
|
|
20
|
+
/** Maak een nieuwe fysieke verbinding. Gooit bij een onbereikbare database. */
|
|
21
|
+
create(): Promise<DriverConnection>;
|
|
22
|
+
}
|
|
23
|
+
export interface PoolConfig {
|
|
24
|
+
/** Maximum aantal verbindingen. Default 10. */
|
|
25
|
+
max?: number;
|
|
26
|
+
/** Timeout (ms) voor het lenen van een verbinding bij verzadiging. Default 5000. */
|
|
27
|
+
acquireTimeoutMs?: number;
|
|
28
|
+
/** Timeout (ms) voor de health-probe bij verzadiging. Default 1000. */
|
|
29
|
+
healthTimeoutMs?: number;
|
|
30
|
+
}
|
|
31
|
+
export type HealthState = 'healthy' | 'degraded' | 'down';
|
|
32
|
+
export interface HealthResult {
|
|
33
|
+
status: HealthState;
|
|
34
|
+
latencyMs: number;
|
|
35
|
+
/** Geredigeerde reden bij `down` (nooit een wachtwoord). */
|
|
36
|
+
error?: string;
|
|
37
|
+
}
|
|
38
|
+
/** Uitvoerder van SQL binnen de actieve context (pool-verbinding of transactie). */
|
|
39
|
+
export interface Executor {
|
|
40
|
+
execute<R extends Row = Row>(sql: string, params?: readonly unknown[]): Promise<QueryResult<R>>;
|
|
41
|
+
}
|
|
42
|
+
/** Beheerde connectie-pool (US-0301/US-0302). */
|
|
43
|
+
export interface Pool extends Executor {
|
|
44
|
+
/** Valideer de verbinding fail-fast bij opstart. */
|
|
45
|
+
init(): Promise<void>;
|
|
46
|
+
checkHealth(): Promise<HealthResult>;
|
|
47
|
+
/** Voer `fn` uit met een geleende verbinding (auto-released). */
|
|
48
|
+
withConnection<T>(fn: (executor: Executor) => Promise<T>): Promise<T>;
|
|
49
|
+
/** Voer `fn` atomair uit in een transactie; nesting gebruikt savepoints (US-0302). */
|
|
50
|
+
withTransaction<T>(fn: (executor: Executor) => Promise<T>): Promise<T>;
|
|
51
|
+
close(): Promise<void>;
|
|
52
|
+
readonly stats: PoolStats;
|
|
53
|
+
}
|
|
54
|
+
export interface PoolStats {
|
|
55
|
+
total: number;
|
|
56
|
+
idle: number;
|
|
57
|
+
inUse: number;
|
|
58
|
+
}
|
|
59
|
+
export interface MigrationContext {
|
|
60
|
+
execute<R extends Row = Row>(sql: string, params?: readonly unknown[]): Promise<QueryResult<R>>;
|
|
61
|
+
}
|
|
62
|
+
export interface Migration {
|
|
63
|
+
/** Stabiele volgorde-sleutel, bv. `0001_init`. */
|
|
64
|
+
id: string;
|
|
65
|
+
up(ctx: MigrationContext): Promise<void>;
|
|
66
|
+
down(ctx: MigrationContext): Promise<void>;
|
|
67
|
+
}
|
|
68
|
+
export interface MigrationStatus {
|
|
69
|
+
applied: string[];
|
|
70
|
+
pending: string[];
|
|
71
|
+
}
|
|
72
|
+
export interface EntityMapping<T extends Row> {
|
|
73
|
+
/** Tabelnaam (geïnjecteerd; geen tabelnaam in de kit zelf). */
|
|
74
|
+
table: string;
|
|
75
|
+
/** Naam van de identifier-kolom. Default `id`. */
|
|
76
|
+
idColumn?: string;
|
|
77
|
+
/** Persisteerbare kolommen. */
|
|
78
|
+
columns: (keyof T & string)[];
|
|
79
|
+
/** Id-generator wanneer een insert geen identifier meelevert. */
|
|
80
|
+
generateId?: () => unknown;
|
|
81
|
+
}
|
|
82
|
+
export interface FindOptions<T extends Row> {
|
|
83
|
+
filter?: Partial<Record<keyof T & string, unknown>>;
|
|
84
|
+
limit?: number;
|
|
85
|
+
offset?: number;
|
|
86
|
+
sort?: {
|
|
87
|
+
field: keyof T & string;
|
|
88
|
+
direction: 'asc' | 'desc';
|
|
89
|
+
}[];
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=ports.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ports.d.ts","sourceRoot":"","sources":["../../../src/persistence/core/ports.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ports.js","sourceRoot":"","sources":["../../../src/persistence/core/ports.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { EntityMapping, FindOptions, Pool, Row } from './ports.js';
|
|
2
|
+
export declare class BaseRepository<T extends Row, ID = unknown> {
|
|
3
|
+
#private;
|
|
4
|
+
constructor(pool: Pool, mapping: EntityMapping<T>);
|
|
5
|
+
insert(entity: Partial<T>): Promise<T>;
|
|
6
|
+
findById(id: ID): Promise<T | null>;
|
|
7
|
+
findOne(filter: FindOptions<T>['filter']): Promise<T | null>;
|
|
8
|
+
find(options?: FindOptions<T>): Promise<T[]>;
|
|
9
|
+
count(filter?: FindOptions<T>['filter']): Promise<number>;
|
|
10
|
+
/** Combineert `find` + `count` voor een pagina met totaalaantal (US-0304 AC2). */
|
|
11
|
+
page(options?: FindOptions<T>): Promise<{
|
|
12
|
+
data: T[];
|
|
13
|
+
total: number;
|
|
14
|
+
}>;
|
|
15
|
+
update(id: ID, patch: Partial<T>): Promise<T | null>;
|
|
16
|
+
delete(id: ID): Promise<boolean>;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository.d.ts","sourceRoot":"","sources":["../../../src/persistence/core/repository.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,aAAa,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,YAAY,CAAC;AAGxE,qBAAa,cAAc,CAAC,CAAC,SAAS,GAAG,EAAE,EAAE,GAAG,OAAO;;gBAKzC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IAM3C,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IAetC,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAMnC,OAAO,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAK5D,IAAI,CAAC,OAAO,GAAE,WAAW,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAgBhD,KAAK,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;IAO/D,kFAAkF;IAC5E,IAAI,CAAC,OAAO,GAAE,WAAW,CAAC,CAAC,CAAM,GAAG,OAAO,CAAC;QAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAMzE,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAepD,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC;CAuBvC"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* US-0304 — Generieke, getypte base-repository met CRUD- en query-primitives.
|
|
3
|
+
*
|
|
4
|
+
* Generiek over een geïnjecteerd entity-type + mapping (tabelnaam/kolommen); geen hardgecodeerde
|
|
5
|
+
* tabellen of domeinkennis. Operaties lopen via {@link Pool.execute}, dus ze sluiten automatisch aan
|
|
6
|
+
* op een actieve transactie-context (US-0302). Fouten lekken geen ruwe SQL of secrets (US-0304 AC3).
|
|
7
|
+
*/
|
|
8
|
+
import { QueryError, UniqueConstraintError } from './errors.js';
|
|
9
|
+
import { buildOrderBy, buildWhere, quoteIdent } from './sql.js';
|
|
10
|
+
export class BaseRepository {
|
|
11
|
+
#pool;
|
|
12
|
+
#mapping;
|
|
13
|
+
#idColumn;
|
|
14
|
+
constructor(pool, mapping) {
|
|
15
|
+
this.#pool = pool;
|
|
16
|
+
this.#mapping = mapping;
|
|
17
|
+
this.#idColumn = mapping.idColumn ?? 'id';
|
|
18
|
+
}
|
|
19
|
+
async insert(entity) {
|
|
20
|
+
const row = { ...entity };
|
|
21
|
+
if (row[this.#idColumn] === undefined && this.#mapping.generateId) {
|
|
22
|
+
row[this.#idColumn] = this.#mapping.generateId();
|
|
23
|
+
}
|
|
24
|
+
const columns = this.#persistableColumns().filter((c) => row[c] !== undefined);
|
|
25
|
+
const values = columns.map((c) => row[c]);
|
|
26
|
+
const placeholders = columns.map((_, i) => `$${i + 1}`);
|
|
27
|
+
const sql = `INSERT INTO ${this.#table()} (${columns.map(quoteIdent).join(', ')}) ` +
|
|
28
|
+
`VALUES (${placeholders.join(', ')}) RETURNING *`;
|
|
29
|
+
const result = await this.#run(sql, values);
|
|
30
|
+
return result.rows[0];
|
|
31
|
+
}
|
|
32
|
+
async findById(id) {
|
|
33
|
+
const sql = `SELECT * FROM ${this.#table()} WHERE ${quoteIdent(this.#idColumn)} = $1 LIMIT 1`;
|
|
34
|
+
const result = await this.#run(sql, [id]);
|
|
35
|
+
return result.rows[0] ?? null;
|
|
36
|
+
}
|
|
37
|
+
async findOne(filter) {
|
|
38
|
+
const rows = await this.find({ ...(filter ? { filter } : {}), limit: 1 });
|
|
39
|
+
return rows[0] ?? null;
|
|
40
|
+
}
|
|
41
|
+
async find(options = {}) {
|
|
42
|
+
const where = buildWhere(options.filter);
|
|
43
|
+
const params = [...where.params];
|
|
44
|
+
let sql = `SELECT * FROM ${this.#table()}${where.text}${buildOrderBy(options.sort)}`;
|
|
45
|
+
if (options.limit !== undefined) {
|
|
46
|
+
params.push(options.limit);
|
|
47
|
+
sql += ` LIMIT $${params.length}`;
|
|
48
|
+
}
|
|
49
|
+
if (options.offset !== undefined) {
|
|
50
|
+
params.push(options.offset);
|
|
51
|
+
sql += ` OFFSET $${params.length}`;
|
|
52
|
+
}
|
|
53
|
+
const result = await this.#run(sql, params);
|
|
54
|
+
return result.rows;
|
|
55
|
+
}
|
|
56
|
+
async count(filter) {
|
|
57
|
+
const where = buildWhere(filter);
|
|
58
|
+
const sql = `SELECT COUNT(*)::int AS "count" FROM ${this.#table()}${where.text}`;
|
|
59
|
+
const result = await this.#run(sql, where.params);
|
|
60
|
+
return Number(result.rows[0]?.count ?? 0);
|
|
61
|
+
}
|
|
62
|
+
/** Combineert `find` + `count` voor een pagina met totaalaantal (US-0304 AC2). */
|
|
63
|
+
async page(options = {}) {
|
|
64
|
+
const data = await this.find(options);
|
|
65
|
+
const total = await this.count(options.filter);
|
|
66
|
+
return { data, total };
|
|
67
|
+
}
|
|
68
|
+
async update(id, patch) {
|
|
69
|
+
const columns = this.#persistableColumns().filter((c) => c !== this.#idColumn && patch[c] !== undefined);
|
|
70
|
+
if (columns.length === 0)
|
|
71
|
+
return this.findById(id);
|
|
72
|
+
const assignments = columns.map((c, i) => `${quoteIdent(c)} = $${i + 1}`);
|
|
73
|
+
const params = columns.map((c) => patch[c]);
|
|
74
|
+
params.push(id);
|
|
75
|
+
const sql = `UPDATE ${this.#table()} SET ${assignments.join(', ')} ` +
|
|
76
|
+
`WHERE ${quoteIdent(this.#idColumn)} = $${params.length} RETURNING *`;
|
|
77
|
+
const result = await this.#run(sql, params);
|
|
78
|
+
return result.rows[0] ?? null;
|
|
79
|
+
}
|
|
80
|
+
async delete(id) {
|
|
81
|
+
const sql = `DELETE FROM ${this.#table()} WHERE ${quoteIdent(this.#idColumn)} = $1`;
|
|
82
|
+
const result = await this.#run(sql, [id]);
|
|
83
|
+
return result.rowCount > 0;
|
|
84
|
+
}
|
|
85
|
+
#table() {
|
|
86
|
+
return quoteIdent(this.#mapping.table);
|
|
87
|
+
}
|
|
88
|
+
#persistableColumns() {
|
|
89
|
+
const set = new Set(this.#mapping.columns);
|
|
90
|
+
set.add(this.#idColumn);
|
|
91
|
+
return [...set];
|
|
92
|
+
}
|
|
93
|
+
async #run(sql, params) {
|
|
94
|
+
try {
|
|
95
|
+
return await this.#pool.execute(sql, params);
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
throw mapDbError(error);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
function mapDbError(error) {
|
|
103
|
+
if (error instanceof UniqueConstraintError)
|
|
104
|
+
return error;
|
|
105
|
+
const code = error?.code;
|
|
106
|
+
if (code === '23505') {
|
|
107
|
+
const constraint = error.constraint;
|
|
108
|
+
return new UniqueConstraintError(constraint);
|
|
109
|
+
}
|
|
110
|
+
// Geen ruwe SQL of driver-details doorgeven.
|
|
111
|
+
return new QueryError();
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository.js","sourceRoot":"","sources":["../../../src/persistence/core/repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/** Valideert en quote't een identifier; gooit bij een ongeldige naam (injectiebescherming). */
|
|
2
|
+
export declare function quoteIdent(name: string): string;
|
|
3
|
+
export interface WhereClause {
|
|
4
|
+
text: string;
|
|
5
|
+
params: unknown[];
|
|
6
|
+
}
|
|
7
|
+
/** Bouwt een `WHERE a = $1 AND b = $2`-clausule uit een gelijkheids-filter. */
|
|
8
|
+
export declare function buildWhere(filter: Record<string, unknown> | undefined, startIndex?: number): WhereClause;
|
|
9
|
+
export declare function buildOrderBy(sort: {
|
|
10
|
+
field: string;
|
|
11
|
+
direction: 'asc' | 'desc';
|
|
12
|
+
}[] | undefined): string;
|
|
13
|
+
//# sourceMappingURL=sql.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql.d.ts","sourceRoot":"","sources":["../../../src/persistence/core/sql.ts"],"names":[],"mappings":"AAQA,+FAA+F;AAC/F,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAK/C;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,EAAE,CAAC;CACnB;AAED,+EAA+E;AAC/E,wBAAgB,UAAU,CACxB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,EAC3C,UAAU,SAAI,GACb,WAAW,CAWb;AAED,wBAAgB,YAAY,CAC1B,IAAI,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,KAAK,GAAG,MAAM,CAAA;CAAE,EAAE,GAAG,SAAS,GAC/D,MAAM,CAIR"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Kleine, veilige SQL-builder voor de base-repository. Identifiers worden gevalideerd en gequote
|
|
3
|
+
* (geen interpolatie van waarden — alles gaat via parameters `$n`).
|
|
4
|
+
*/
|
|
5
|
+
import { PersistenceError } from './errors.js';
|
|
6
|
+
const IDENT = /^[A-Za-z_][A-Za-z0-9_]*$/;
|
|
7
|
+
/** Valideert en quote't een identifier; gooit bij een ongeldige naam (injectiebescherming). */
|
|
8
|
+
export function quoteIdent(name) {
|
|
9
|
+
if (!IDENT.test(name)) {
|
|
10
|
+
throw new PersistenceError(`Ongeldige identifier: ${JSON.stringify(name)}`);
|
|
11
|
+
}
|
|
12
|
+
return `"${name}"`;
|
|
13
|
+
}
|
|
14
|
+
/** Bouwt een `WHERE a = $1 AND b = $2`-clausule uit een gelijkheids-filter. */
|
|
15
|
+
export function buildWhere(filter, startIndex = 1) {
|
|
16
|
+
if (!filter)
|
|
17
|
+
return { text: '', params: [] };
|
|
18
|
+
const entries = Object.entries(filter).filter(([, v]) => v !== undefined);
|
|
19
|
+
if (entries.length === 0)
|
|
20
|
+
return { text: '', params: [] };
|
|
21
|
+
const parts = [];
|
|
22
|
+
const params = [];
|
|
23
|
+
entries.forEach(([col, value], i) => {
|
|
24
|
+
parts.push(`${quoteIdent(col)} = $${startIndex + i}`);
|
|
25
|
+
params.push(value);
|
|
26
|
+
});
|
|
27
|
+
return { text: ` WHERE ${parts.join(' AND ')}`, params };
|
|
28
|
+
}
|
|
29
|
+
export function buildOrderBy(sort) {
|
|
30
|
+
if (!sort || sort.length === 0)
|
|
31
|
+
return '';
|
|
32
|
+
const parts = sort.map((s) => `${quoteIdent(s.field)} ${s.direction === 'desc' ? 'DESC' : 'ASC'}`);
|
|
33
|
+
return ` ORDER BY ${parts.join(', ')}`;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=sql.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql.js","sourceRoot":"","sources":["../../../src/persistence/core/sql.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAE/C,MAAM,KAAK,GAAG,0BAA0B,CAAC;AAEzC,+FAA+F;AAC/F,MAAM,UAAU,UAAU,CAAC,IAAY;IACrC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACtB,MAAM,IAAI,gBAAgB,CAAC,yBAAyB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC9E,CAAC;IACD,OAAO,IAAI,IAAI,GAAG,CAAC;AACrB,CAAC;AAOD,+EAA+E;AAC/E,MAAM,UAAU,UAAU,CACxB,MAA2C,EAC3C,UAAU,GAAG,CAAC;IAEd,IAAI,CAAC,MAAM;QAAE,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IAC7C,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC;IAC1E,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IAC1D,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,MAAM,MAAM,GAAc,EAAE,CAAC;IAC7B,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,CAAC,EAAE,EAAE;QAClC,KAAK,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,OAAO,UAAU,GAAG,CAAC,EAAE,CAAC,CAAC;QACtD,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC,CAAC;IACH,OAAO,EAAE,IAAI,EAAE,UAAU,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,EAAE,MAAM,EAAE,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,YAAY,CAC1B,IAAgE;IAEhE,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;IACnG,OAAO,aAAa,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;AACzC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `persistence` kit — domein-loos DB-fundament: connectie-pool + health, transactie-scope
|
|
3
|
+
* (unit-of-work met savepoints), migratie-runner, generieke base-repository en een testcontainer-
|
|
4
|
+
* harness. Framework-/ORM-neutraal via de {@link Driver}-poort; entities en migraties worden
|
|
5
|
+
* geïnjecteerd.
|
|
6
|
+
*/
|
|
7
|
+
export type { Driver, DriverConnection, Executor, Pool, PoolConfig, PoolStats, QueryResult, Row, HealthResult, HealthState, Migration, MigrationContext, MigrationStatus, EntityMapping, FindOptions, } from './core/ports.js';
|
|
8
|
+
export { createPool } from './core/pool.js';
|
|
9
|
+
export { MigrationRunner, type MigrationRunnerOptions } from './core/migrations.js';
|
|
10
|
+
export { BaseRepository } from './core/repository.js';
|
|
11
|
+
export { PersistenceError, ConnectionError, PoolTimeoutError, QueryError, UniqueConstraintError, MigrationError, redactReason, } from './core/errors.js';
|
|
12
|
+
export { quoteIdent } from './core/sql.js';
|
|
13
|
+
export { inMemoryDriver } from './adapters/in-memory-driver.js';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/persistence/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,YAAY,EACV,MAAM,EACN,gBAAgB,EAChB,QAAQ,EACR,IAAI,EACJ,UAAU,EACV,SAAS,EACT,WAAW,EACX,GAAG,EACH,YAAY,EACZ,WAAW,EACX,SAAS,EACT,gBAAgB,EAChB,eAAe,EACf,aAAa,EACb,WAAW,GACZ,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5C,OAAO,EAAE,eAAe,EAAE,KAAK,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAGpF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGtD,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,gBAAgB,EAChB,UAAU,EACV,qBAAqB,EACrB,cAAc,EACd,YAAY,GACb,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAG3C,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `persistence` kit — domein-loos DB-fundament: connectie-pool + health, transactie-scope
|
|
3
|
+
* (unit-of-work met savepoints), migratie-runner, generieke base-repository en een testcontainer-
|
|
4
|
+
* harness. Framework-/ORM-neutraal via de {@link Driver}-poort; entities en migraties worden
|
|
5
|
+
* geïnjecteerd.
|
|
6
|
+
*/
|
|
7
|
+
// Pool + transacties (US-0301/US-0302)
|
|
8
|
+
export { createPool } from './core/pool.js';
|
|
9
|
+
// Migraties (US-0303)
|
|
10
|
+
export { MigrationRunner } from './core/migrations.js';
|
|
11
|
+
// Base-repository (US-0304)
|
|
12
|
+
export { BaseRepository } from './core/repository.js';
|
|
13
|
+
// Fouten
|
|
14
|
+
export { PersistenceError, ConnectionError, PoolTimeoutError, QueryError, UniqueConstraintError, MigrationError, redactReason, } from './core/errors.js';
|
|
15
|
+
// SQL-helpers
|
|
16
|
+
export { quoteIdent } from './core/sql.js';
|
|
17
|
+
// Dep-vrije adapter (voor tests en consumer-tests zonder Docker)
|
|
18
|
+
export { inMemoryDriver } from './adapters/in-memory-driver.js';
|
|
19
|
+
// De echte Postgres-driver + testcontainer-harness zitten achter de subpath
|
|
20
|
+
// `webapp-factory/backend-foundation/persistence/pg` (harde `pg`/`testcontainers`-import), zodat de
|
|
21
|
+
// core-kit zonder die deps bruikbaar blijft.
|
|
22
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/persistence/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAqBH,uCAAuC;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,sBAAsB;AACtB,OAAO,EAAE,eAAe,EAA+B,MAAM,sBAAsB,CAAC;AAEpF,4BAA4B;AAC5B,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,SAAS;AACT,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,gBAAgB,EAChB,UAAU,EACV,qBAAqB,EACrB,cAAc,EACd,YAAY,GACb,MAAM,kBAAkB,CAAC;AAE1B,cAAc;AACd,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,iEAAiE;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAEhE,4EAA4E;AAC5E,oGAAoG;AACpG,6CAA6C"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Subpath `webapp-factory/backend-foundation/persistence/pg` — de echte Postgres-driver en de testcontainer-
|
|
3
|
+
* harness. Vereist de optionele peer-dependencies `pg` en (voor de harness) `testcontainers`.
|
|
4
|
+
*/
|
|
5
|
+
export { pgDriver, type PgConnectionConfig } from './adapters/pg-driver.js';
|
|
6
|
+
export { startTestDatabase, postgresContainerFactory, type TestDatabase, type TestDatabaseOptions, type ContainerFactory, type StartedDatabase, type PostgresContainerOptions, } from './adapters/testcontainer-harness.js';
|
|
7
|
+
//# sourceMappingURL=pg.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pg.d.ts","sourceRoot":"","sources":["../../src/persistence/pg.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,EAAE,QAAQ,EAAE,KAAK,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EACL,iBAAiB,EACjB,wBAAwB,EACxB,KAAK,YAAY,EACjB,KAAK,mBAAmB,EACxB,KAAK,gBAAgB,EACrB,KAAK,eAAe,EACpB,KAAK,wBAAwB,GAC9B,MAAM,qCAAqC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Subpath `webapp-factory/backend-foundation/persistence/pg` — de echte Postgres-driver en de testcontainer-
|
|
3
|
+
* harness. Vereist de optionele peer-dependencies `pg` en (voor de harness) `testcontainers`.
|
|
4
|
+
*/
|
|
5
|
+
export { pgDriver } from './adapters/pg-driver.js';
|
|
6
|
+
export { startTestDatabase, postgresContainerFactory, } from './adapters/testcontainer-harness.js';
|
|
7
|
+
//# sourceMappingURL=pg.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pg.js","sourceRoot":"","sources":["../../src/persistence/pg.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,EAAE,QAAQ,EAA2B,MAAM,yBAAyB,CAAC;AAC5E,OAAO,EACL,iBAAiB,EACjB,wBAAwB,GAMzB,MAAM,qCAAqC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* US-1202/US-1203/US-1204 — {@link AuditSink}-adapter op de audit-log-kit. Mapt privacy-events naar een
|
|
3
|
+
* append op de geïnjecteerde audit-log. De consumer registreert de gebruikte `action`-namen als
|
|
4
|
+
* event-types in de audit-log (bv. `privacy.export`, `privacy.erasure`, `privacy.consent.granted`).
|
|
5
|
+
*/
|
|
6
|
+
import type { AuditSink } from '../core/ports.js';
|
|
7
|
+
/** Minimaal contract dat we van de audit-log nodig hebben (structureel, geen harde import). */
|
|
8
|
+
export interface AuditLogLike {
|
|
9
|
+
append(input: {
|
|
10
|
+
actor: string;
|
|
11
|
+
action: string;
|
|
12
|
+
target: string;
|
|
13
|
+
meta?: Record<string, unknown>;
|
|
14
|
+
}): Promise<unknown>;
|
|
15
|
+
}
|
|
16
|
+
export declare function auditLogSink(auditLog: AuditLogLike, options: {
|
|
17
|
+
actor: string;
|
|
18
|
+
}): AuditSink;
|
|
19
|
+
//# sourceMappingURL=audit-sink.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-sink.d.ts","sourceRoot":"","sources":["../../../src/privacy/adapters/audit-sink.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,EAAE,SAAS,EAAqB,MAAM,kBAAkB,CAAC;AAErE,+FAA+F;AAC/F,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACpH;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAE;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,GAAG,SAAS,CAW1F"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export function auditLogSink(auditLog, options) {
|
|
2
|
+
return {
|
|
3
|
+
async record(event) {
|
|
4
|
+
await auditLog.append({
|
|
5
|
+
actor: options.actor,
|
|
6
|
+
action: event.action,
|
|
7
|
+
target: event.subjectId,
|
|
8
|
+
meta: { complete: event.complete, ...(event.meta ?? {}) },
|
|
9
|
+
});
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=audit-sink.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-sink.js","sourceRoot":"","sources":["../../../src/privacy/adapters/audit-sink.ts"],"names":[],"mappings":"AAYA,MAAM,UAAU,YAAY,CAAC,QAAsB,EAAE,OAA0B;IAC7E,OAAO;QACL,KAAK,CAAC,MAAM,CAAC,KAAwB;YACnC,MAAM,QAAQ,CAAC,MAAM,CAAC;gBACpB,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,MAAM,EAAE,KAAK,CAAC,SAAS;gBACvB,IAAI,EAAE,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,EAAE;aAC1D,CAAC,CAAC;QACL,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* US-1204 — In-memory {@link ConsentStore} (tests/dev). Append-only: geen update/delete, alleen toevoegen
|
|
3
|
+
* en lezen; `latest` geeft het laatst toegevoegde record voor (subject, purpose).
|
|
4
|
+
*/
|
|
5
|
+
import type { ConsentStore } from '../core/ports.js';
|
|
6
|
+
export declare function inMemoryConsentStore(): ConsentStore;
|
|
7
|
+
//# sourceMappingURL=in-memory-consent-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"in-memory-consent-store.d.ts","sourceRoot":"","sources":["../../../src/privacy/adapters/in-memory-consent-store.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,EAAiB,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEpE,wBAAgB,oBAAoB,IAAI,YAAY,CAkBnD"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export function inMemoryConsentStore() {
|
|
2
|
+
const records = [];
|
|
3
|
+
const matching = (subjectId, purpose) => records.filter((r) => r.subjectId === subjectId && r.purpose === purpose);
|
|
4
|
+
return {
|
|
5
|
+
async append(record) {
|
|
6
|
+
records.push({ ...record });
|
|
7
|
+
},
|
|
8
|
+
async history(subjectId, purpose) {
|
|
9
|
+
return matching(subjectId, purpose).map((r) => ({ ...r }));
|
|
10
|
+
},
|
|
11
|
+
async latest(subjectId, purpose) {
|
|
12
|
+
const found = matching(subjectId, purpose);
|
|
13
|
+
const last = found[found.length - 1];
|
|
14
|
+
return last ? { ...last } : null;
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=in-memory-consent-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"in-memory-consent-store.js","sourceRoot":"","sources":["../../../src/privacy/adapters/in-memory-consent-store.ts"],"names":[],"mappings":"AAMA,MAAM,UAAU,oBAAoB;IAClC,MAAM,OAAO,GAAoB,EAAE,CAAC;IACpC,MAAM,QAAQ,GAAG,CAAC,SAAiB,EAAE,OAAe,EAAE,EAAE,CACtD,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;IAE5E,OAAO;QACL,KAAK,CAAC,MAAM,CAAC,MAAM;YACjB,OAAO,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC;QAC9B,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO;YAC9B,OAAO,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7D,CAAC;QACD,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO;YAC7B,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;YAC3C,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QACnC,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* US-1204 — Postgres {@link ConsentStore} (productie). Append-only tabel; records worden alleen
|
|
3
|
+
* toegevoegd en gelezen (`latest` = hoogste id per subject/purpose). Werkt tegen een structurele
|
|
4
|
+
* `SqlExec` (compatibel met de persistence-kit `Pool`) — geen harde `pg`-dep.
|
|
5
|
+
*/
|
|
6
|
+
import type { ConsentStore } from '../core/ports.js';
|
|
7
|
+
export interface SqlResult<R = Record<string, unknown>> {
|
|
8
|
+
rows: R[];
|
|
9
|
+
rowCount: number;
|
|
10
|
+
}
|
|
11
|
+
export interface SqlExec {
|
|
12
|
+
execute<R = Record<string, unknown>>(sql: string, params?: readonly unknown[]): Promise<SqlResult<R>>;
|
|
13
|
+
}
|
|
14
|
+
export interface PgConsentStoreOptions {
|
|
15
|
+
table?: string;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Migratie voor de consent-tabel (append-only door conventie: de adapter kent geen update/delete-pad).
|
|
19
|
+
* Vorm compatibel met de persistence-kit `Migration` (id + up).
|
|
20
|
+
*/
|
|
21
|
+
export declare function consentMigration(table?: string): {
|
|
22
|
+
id: string;
|
|
23
|
+
up(ctx: SqlExec): Promise<void>;
|
|
24
|
+
};
|
|
25
|
+
export declare function pgConsentStore(executor: SqlExec, options?: PgConsentStoreOptions): ConsentStore;
|
|
26
|
+
//# sourceMappingURL=pg-consent-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pg-consent-store.d.ts","sourceRoot":"","sources":["../../../src/privacy/adapters/pg-consent-store.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,EAAiB,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAEpE,MAAM,WAAW,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACpD,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,QAAQ,EAAE,MAAM,CAAC;CAClB;AACD,MAAM,WAAW,OAAO;IACtB,OAAO,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,SAAS,OAAO,EAAE,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;CACvG;AAED,MAAM,WAAW,qBAAqB;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,SAAoB;;YAIxC,OAAO;EAYxB;AAED,wBAAgB,cAAc,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,GAAE,qBAA0B,GAAG,YAAY,CAmCnG"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Migratie voor de consent-tabel (append-only door conventie: de adapter kent geen update/delete-pad).
|
|
3
|
+
* Vorm compatibel met de persistence-kit `Migration` (id + up).
|
|
4
|
+
*/
|
|
5
|
+
export function consentMigration(table = 'consent_records') {
|
|
6
|
+
const q = `"${table}"`;
|
|
7
|
+
return {
|
|
8
|
+
id: '0001_consent_records',
|
|
9
|
+
async up(ctx) {
|
|
10
|
+
await ctx.execute(`CREATE TABLE IF NOT EXISTS ${q} (` +
|
|
11
|
+
`id bigserial PRIMARY KEY, subject_id text NOT NULL, purpose text NOT NULL, ` +
|
|
12
|
+
`status text NOT NULL CHECK (status IN ('granted', 'withdrawn')), ` +
|
|
13
|
+
`policy_version text, "timestamp" bigint NOT NULL)`);
|
|
14
|
+
await ctx.execute(`CREATE INDEX IF NOT EXISTS "${table}_subject_purpose_idx" ON ${q} (subject_id, purpose, id)`);
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export function pgConsentStore(executor, options = {}) {
|
|
19
|
+
const table = options.table ?? 'consent_records';
|
|
20
|
+
const q = `"${table}"`;
|
|
21
|
+
const mapRow = (row) => ({
|
|
22
|
+
subjectId: String(row['subject_id']),
|
|
23
|
+
purpose: String(row['purpose']),
|
|
24
|
+
status: row['status'],
|
|
25
|
+
...(row['policy_version'] != null ? { policyVersion: String(row['policy_version']) } : {}),
|
|
26
|
+
timestamp: Number(row['timestamp']),
|
|
27
|
+
});
|
|
28
|
+
return {
|
|
29
|
+
async append(record) {
|
|
30
|
+
await executor.execute(`INSERT INTO ${q} (subject_id, purpose, status, policy_version, "timestamp") VALUES ($1, $2, $3, $4, $5)`, [record.subjectId, record.purpose, record.status, record.policyVersion ?? null, record.timestamp]);
|
|
31
|
+
},
|
|
32
|
+
async history(subjectId, purpose) {
|
|
33
|
+
const result = await executor.execute(`SELECT * FROM ${q} WHERE subject_id = $1 AND purpose = $2 ORDER BY id ASC`, [subjectId, purpose]);
|
|
34
|
+
return result.rows.map(mapRow);
|
|
35
|
+
},
|
|
36
|
+
async latest(subjectId, purpose) {
|
|
37
|
+
const result = await executor.execute(`SELECT * FROM ${q} WHERE subject_id = $1 AND purpose = $2 ORDER BY id DESC LIMIT 1`, [subjectId, purpose]);
|
|
38
|
+
const row = result.rows[0];
|
|
39
|
+
return row ? mapRow(row) : null;
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=pg-consent-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pg-consent-store.js","sourceRoot":"","sources":["../../../src/privacy/adapters/pg-consent-store.ts"],"names":[],"mappings":"AAmBA;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAK,GAAG,iBAAiB;IACxD,MAAM,CAAC,GAAG,IAAI,KAAK,GAAG,CAAC;IACvB,OAAO;QACL,EAAE,EAAE,sBAAsB;QAC1B,KAAK,CAAC,EAAE,CAAC,GAAY;YACnB,MAAM,GAAG,CAAC,OAAO,CACf,8BAA8B,CAAC,IAAI;gBACjC,6EAA6E;gBAC7E,mEAAmE;gBACnE,mDAAmD,CACtD,CAAC;YACF,MAAM,GAAG,CAAC,OAAO,CACf,+BAA+B,KAAK,4BAA4B,CAAC,4BAA4B,CAC9F,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,QAAiB,EAAE,UAAiC,EAAE;IACnF,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,iBAAiB,CAAC;IACjD,MAAM,CAAC,GAAG,IAAI,KAAK,GAAG,CAAC;IAEvB,MAAM,MAAM,GAAG,CAAC,GAA4B,EAAiB,EAAE,CAAC,CAAC;QAC/D,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACpC,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,MAAM,EAAE,GAAG,CAAC,QAAQ,CAA4B;QAChD,GAAG,CAAC,GAAG,CAAC,gBAAgB,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,MAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC1F,SAAS,EAAE,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;KACpC,CAAC,CAAC;IAEH,OAAO;QACL,KAAK,CAAC,MAAM,CAAC,MAAM;YACjB,MAAM,QAAQ,CAAC,OAAO,CACpB,eAAe,CAAC,yFAAyF,EACzG,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,aAAa,IAAI,IAAI,EAAE,MAAM,CAAC,SAAS,CAAC,CAClG,CAAC;QACJ,CAAC;QACD,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO;YAC9B,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,OAAO,CACnC,iBAAiB,CAAC,yDAAyD,EAC3E,CAAC,SAAS,EAAE,OAAO,CAAC,CACrB,CAAC;YACF,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACjC,CAAC;QACD,KAAK,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO;YAC7B,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,OAAO,CACnC,iBAAiB,CAAC,kEAAkE,EACpF,CAAC,SAAS,EAAE,OAAO,CAAC,CACrB,CAAC;YACF,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC3B,OAAO,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAClC,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* US-1204 — Consent-registry (AVG art. 7). Legt per (subject, purpose) append-only records vast met
|
|
3
|
+
* status/policyversie/tijdstempel; een intrekking overschrijft niet maar voegt toe. US-1205 — een
|
|
4
|
+
* afgeleide analytics-opt-out-flag met veilige default (opt-out bij ontbrekende toestemming).
|
|
5
|
+
*/
|
|
6
|
+
import type { AuditSink, Clock, ConsentRecord, ConsentStatus, ConsentStore } from './ports.js';
|
|
7
|
+
export interface ConsentStatusResult {
|
|
8
|
+
status: ConsentStatus | 'none';
|
|
9
|
+
policyVersion?: string;
|
|
10
|
+
timestamp?: number;
|
|
11
|
+
}
|
|
12
|
+
export interface ConsentRegistry {
|
|
13
|
+
grant(subjectId: string, purpose: string, options?: {
|
|
14
|
+
policyVersion?: string;
|
|
15
|
+
}): Promise<ConsentRecord>;
|
|
16
|
+
withdraw(subjectId: string, purpose: string): Promise<ConsentRecord>;
|
|
17
|
+
status(subjectId: string, purpose: string): Promise<ConsentStatusResult>;
|
|
18
|
+
history(subjectId: string, purpose: string): Promise<ConsentRecord[]>;
|
|
19
|
+
}
|
|
20
|
+
export interface ConsentOptions {
|
|
21
|
+
clock?: Clock;
|
|
22
|
+
audit?: AuditSink;
|
|
23
|
+
}
|
|
24
|
+
export declare function createConsentRegistry(store: ConsentStore, options?: ConsentOptions): ConsentRegistry;
|
|
25
|
+
export interface AnalyticsOptOut {
|
|
26
|
+
isAnalyticsAllowed(subjectId: string): Promise<boolean>;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Leidt een boolean opt-out-flag af uit de consent-status voor het doel "analytics". Leest live uit de
|
|
30
|
+
* consent-registry (geen cache), zodat een intrekking direct doorwerkt; default is opt-out.
|
|
31
|
+
*/
|
|
32
|
+
export declare function analyticsOptOut(consent: ConsentRegistry, options?: {
|
|
33
|
+
purpose?: string;
|
|
34
|
+
}): AnalyticsOptOut;
|
|
35
|
+
//# sourceMappingURL=consent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consent.d.ts","sourceRoot":"","sources":["../../../src/privacy/core/consent.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE/F,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,aAAa,GAAG,MAAM,CAAC;IAC/B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IACxG,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IACrE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAC;IACzE,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;CACvE;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,KAAK,CAAC,EAAE,SAAS,CAAC;CACnB;AAED,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,GAAE,cAAmB,GAAG,eAAe,CAwCxG;AAID,MAAM,WAAW,eAAe;IAC9B,kBAAkB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACzD;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,eAAe,EAAE,OAAO,GAAE;IAAE,OAAO,CAAC,EAAE,MAAM,CAAA;CAAO,GAAG,eAAe,CAQ7G"}
|