@baseplate-dev/fastify-generators 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +390 -0
- package/dist/constants/fastify-packages.d.ts +56 -0
- package/dist/constants/fastify-packages.d.ts.map +1 -0
- package/dist/constants/fastify-packages.js +71 -0
- package/dist/constants/fastify-packages.js.map +1 -0
- package/dist/constants/index.d.ts +2 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +2 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/generators/auth/_providers/index.d.ts +2 -0
- package/dist/generators/auth/_providers/index.d.ts.map +1 -0
- package/dist/generators/auth/_providers/index.js +2 -0
- package/dist/generators/auth/_providers/index.js.map +1 -0
- package/dist/generators/auth/_providers/user-session.d.ts +9 -0
- package/dist/generators/auth/_providers/user-session.d.ts.map +1 -0
- package/dist/generators/auth/_providers/user-session.js +7 -0
- package/dist/generators/auth/_providers/user-session.js.map +1 -0
- package/dist/generators/auth/auth-context/auth-context.generator.d.ts +56 -0
- package/dist/generators/auth/auth-context/auth-context.generator.d.ts.map +1 -0
- package/dist/generators/auth/auth-context/auth-context.generator.js +77 -0
- package/dist/generators/auth/auth-context/auth-context.generator.js.map +1 -0
- package/dist/generators/auth/auth-context/generated/ts-import-maps.d.ts +31 -0
- package/dist/generators/auth/auth-context/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/auth/auth-context/generated/ts-import-maps.js +24 -0
- package/dist/generators/auth/auth-context/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/auth/auth-context/generated/ts-templates.d.ts +70 -0
- package/dist/generators/auth/auth-context/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/auth-context/generated/ts-templates.js +55 -0
- package/dist/generators/auth/auth-context/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/auth-context/templates/types/auth-context.types.ts +15 -0
- package/dist/generators/auth/auth-context/templates/types/auth-session.types.ts +31 -0
- package/dist/generators/auth/auth-context/templates/utils/auth-context.utils.ts +34 -0
- package/dist/generators/auth/auth-plugin/auth-plugin.generator.d.ts +32 -0
- package/dist/generators/auth/auth-plugin/auth-plugin.generator.d.ts.map +1 -0
- package/dist/generators/auth/auth-plugin/auth-plugin.generator.js +50 -0
- package/dist/generators/auth/auth-plugin/auth-plugin.generator.js.map +1 -0
- package/dist/generators/auth/auth-plugin/generated/ts-templates.d.ts +29 -0
- package/dist/generators/auth/auth-plugin/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/auth-plugin/generated/ts-templates.js +17 -0
- package/dist/generators/auth/auth-plugin/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/auth-plugin/templates/auth.plugin.ts +39 -0
- package/dist/generators/auth/auth-roles/auth-roles.generator.d.ts +25 -0
- package/dist/generators/auth/auth-roles/auth-roles.generator.d.ts.map +1 -0
- package/dist/generators/auth/auth-roles/auth-roles.generator.js +62 -0
- package/dist/generators/auth/auth-roles/auth-roles.generator.js.map +1 -0
- package/dist/generators/auth/auth-roles/generated/ts-import-maps.d.ts +25 -0
- package/dist/generators/auth/auth-roles/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/auth/auth-roles/generated/ts-import-maps.js +22 -0
- package/dist/generators/auth/auth-roles/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/auth/auth-roles/generated/ts-templates.d.ts +6 -0
- package/dist/generators/auth/auth-roles/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/auth-roles/generated/ts-templates.js +14 -0
- package/dist/generators/auth/auth-roles/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/auth-roles/templates/auth-roles.constants.ts +42 -0
- package/dist/generators/auth/auth-roles/templates/constants/auth-roles.constants.ts +42 -0
- package/dist/generators/auth/index.d.ts +9 -0
- package/dist/generators/auth/index.d.ts.map +1 -0
- package/dist/generators/auth/index.js +9 -0
- package/dist/generators/auth/index.js.map +1 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-import-maps.d.ts +13 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-import-maps.js +18 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-templates.d.ts +4 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-templates.js +11 -0
- package/dist/generators/auth/password-hasher-service/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/password-hasher-service/password-hasher-service.generator.d.ts +14 -0
- package/dist/generators/auth/password-hasher-service/password-hasher-service.generator.d.ts.map +1 -0
- package/dist/generators/auth/password-hasher-service/password-hasher-service.generator.js +45 -0
- package/dist/generators/auth/password-hasher-service/password-hasher-service.generator.js.map +1 -0
- package/dist/generators/auth/password-hasher-service/templates/password-hasher.service.ts +25 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-import-maps.d.ts +3 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-import-maps.js +12 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-templates.d.ts +13 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-templates.js +15 -0
- package/dist/generators/auth/placeholder-auth-service/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/placeholder-auth-service.generator.d.ts +24 -0
- package/dist/generators/auth/placeholder-auth-service/placeholder-auth-service.generator.d.ts.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/placeholder-auth-service.generator.js +50 -0
- package/dist/generators/auth/placeholder-auth-service/placeholder-auth-service.generator.js.map +1 -0
- package/dist/generators/auth/placeholder-auth-service/templates/user-session.service.ts +34 -0
- package/dist/generators/auth/prisma-password-transformer/prisma-password-transformer.generator.d.ts +12 -0
- package/dist/generators/auth/prisma-password-transformer/prisma-password-transformer.generator.d.ts.map +1 -0
- package/dist/generators/auth/prisma-password-transformer/prisma-password-transformer.generator.js +48 -0
- package/dist/generators/auth/prisma-password-transformer/prisma-password-transformer.generator.js.map +1 -0
- package/dist/generators/auth/user-session-types/generated/ts-import-maps.d.ts +21 -0
- package/dist/generators/auth/user-session-types/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/auth/user-session-types/generated/ts-import-maps.js +18 -0
- package/dist/generators/auth/user-session-types/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/auth/user-session-types/generated/ts-templates.d.ts +18 -0
- package/dist/generators/auth/user-session-types/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/auth/user-session-types/generated/ts-templates.js +14 -0
- package/dist/generators/auth/user-session-types/generated/ts-templates.js.map +1 -0
- package/dist/generators/auth/user-session-types/templates/user-session.types.ts +40 -0
- package/dist/generators/auth/user-session-types/user-session-types.generator.d.ts +30 -0
- package/dist/generators/auth/user-session-types/user-session-types.generator.d.ts.map +1 -0
- package/dist/generators/auth/user-session-types/user-session-types.generator.js +45 -0
- package/dist/generators/auth/user-session-types/user-session-types.generator.js.map +1 -0
- package/dist/generators/bull/bull-mq/bull-mq.generator.d.ts +40 -0
- package/dist/generators/bull/bull-mq/bull-mq.generator.d.ts.map +1 -0
- package/dist/generators/bull/bull-mq/bull-mq.generator.js +89 -0
- package/dist/generators/bull/bull-mq/bull-mq.generator.js.map +1 -0
- package/dist/generators/bull/bull-mq/generated/ts-import-maps.d.ts +27 -0
- package/dist/generators/bull/bull-mq/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/bull/bull-mq/generated/ts-import-maps.js +24 -0
- package/dist/generators/bull/bull-mq/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/bull/bull-mq/generated/ts-templates.d.ts +101 -0
- package/dist/generators/bull/bull-mq/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/bull/bull-mq/generated/ts-templates.js +97 -0
- package/dist/generators/bull/bull-mq/generated/ts-templates.js.map +1 -0
- package/dist/generators/bull/bull-mq/templates/scripts/run-workers.ts +48 -0
- package/dist/generators/bull/bull-mq/templates/scripts/synchronize-repeat-jobs.ts +15 -0
- package/dist/generators/bull/bull-mq/templates/service/index.ts +5 -0
- package/dist/generators/bull/bull-mq/templates/service/queue.ts +45 -0
- package/dist/generators/bull/bull-mq/templates/service/repeatable.ts +83 -0
- package/dist/generators/bull/bull-mq/templates/service/worker.ts +38 -0
- package/dist/generators/bull/fastify-bull-board/fastify-bull-board.generator.d.ts +44 -0
- package/dist/generators/bull/fastify-bull-board/fastify-bull-board.generator.d.ts.map +1 -0
- package/dist/generators/bull/fastify-bull-board/fastify-bull-board.generator.js +88 -0
- package/dist/generators/bull/fastify-bull-board/fastify-bull-board.generator.js.map +1 -0
- package/dist/generators/bull/fastify-bull-board/generated/ts-templates.d.ts +53 -0
- package/dist/generators/bull/fastify-bull-board/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/bull/fastify-bull-board/generated/ts-templates.js +59 -0
- package/dist/generators/bull/fastify-bull-board/generated/ts-templates.js.map +1 -0
- package/dist/generators/bull/fastify-bull-board/templates/index.ts +9 -0
- package/dist/generators/bull/fastify-bull-board/templates/plugins/bull-board.ts +91 -0
- package/dist/generators/bull/fastify-bull-board/templates/schema/authenticate.mutations.ts +18 -0
- package/dist/generators/bull/fastify-bull-board/templates/services/auth.service.ts +62 -0
- package/dist/generators/bull/index.d.ts +3 -0
- package/dist/generators/bull/index.d.ts.map +1 -0
- package/dist/generators/bull/index.js +3 -0
- package/dist/generators/bull/index.js.map +1 -0
- package/dist/generators/core/_composers/fastify-composer.d.ts +4 -0
- package/dist/generators/core/_composers/fastify-composer.d.ts.map +1 -0
- package/dist/generators/core/_composers/fastify-composer.js +42 -0
- package/dist/generators/core/_composers/fastify-composer.js.map +1 -0
- package/dist/generators/core/_composers/index.d.ts +2 -0
- package/dist/generators/core/_composers/index.d.ts.map +1 -0
- package/dist/generators/core/_composers/index.js +2 -0
- package/dist/generators/core/_composers/index.js.map +1 -0
- package/dist/generators/core/app-module/app-module.generator.d.ts +36 -0
- package/dist/generators/core/app-module/app-module.generator.d.ts.map +1 -0
- package/dist/generators/core/app-module/app-module.generator.js +101 -0
- package/dist/generators/core/app-module/app-module.generator.js.map +1 -0
- package/dist/generators/core/app-module/generated/ts-templates.d.ts +12 -0
- package/dist/generators/core/app-module/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/app-module/generated/ts-templates.js +11 -0
- package/dist/generators/core/app-module/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/app-module/templates/index.ts +7 -0
- package/dist/generators/core/app-module-setup/app-module-setup.generator.d.ts +25 -0
- package/dist/generators/core/app-module-setup/app-module-setup.generator.d.ts.map +1 -0
- package/dist/generators/core/app-module-setup/app-module-setup.generator.js +58 -0
- package/dist/generators/core/app-module-setup/app-module-setup.generator.js.map +1 -0
- package/dist/generators/core/app-module-setup/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/core/app-module-setup/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/app-module-setup/generated/ts-import-maps.js +16 -0
- package/dist/generators/core/app-module-setup/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/app-module-setup/generated/ts-templates.d.ts +8 -0
- package/dist/generators/core/app-module-setup/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/app-module-setup/generated/ts-templates.js +13 -0
- package/dist/generators/core/app-module-setup/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/app-module-setup/templates/app-modules.ts +23 -0
- package/dist/generators/core/axios/axios.generator.d.ts +20 -0
- package/dist/generators/core/axios/axios.generator.d.ts.map +1 -0
- package/dist/generators/core/axios/axios.generator.js +55 -0
- package/dist/generators/core/axios/axios.generator.js.map +1 -0
- package/dist/generators/core/axios/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/core/axios/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/axios/generated/ts-import-maps.js +14 -0
- package/dist/generators/core/axios/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/axios/generated/ts-templates.d.ts +4 -0
- package/dist/generators/core/axios/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/axios/generated/ts-templates.js +9 -0
- package/dist/generators/core/axios/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/axios/templates/axios.ts +44 -0
- package/dist/generators/core/config-service/config-service.generator.d.ts +60 -0
- package/dist/generators/core/config-service/config-service.generator.d.ts.map +1 -0
- package/dist/generators/core/config-service/config-service.generator.js +114 -0
- package/dist/generators/core/config-service/config-service.generator.js.map +1 -0
- package/dist/generators/core/config-service/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/core/config-service/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/config-service/generated/ts-import-maps.js +14 -0
- package/dist/generators/core/config-service/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/config-service/generated/ts-templates.d.ts +6 -0
- package/dist/generators/core/config-service/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/config-service/generated/ts-templates.js +9 -0
- package/dist/generators/core/config-service/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/config-service/templates/config.ts +5 -0
- package/dist/generators/core/error-handler-service/error-handler-service.generator.d.ts +60 -0
- package/dist/generators/core/error-handler-service/error-handler-service.generator.d.ts.map +1 -0
- package/dist/generators/core/error-handler-service/error-handler-service.generator.js +103 -0
- package/dist/generators/core/error-handler-service/error-handler-service.generator.js.map +1 -0
- package/dist/generators/core/error-handler-service/generated/ts-import-maps.d.ts +25 -0
- package/dist/generators/core/error-handler-service/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/error-handler-service/generated/ts-import-maps.js +30 -0
- package/dist/generators/core/error-handler-service/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/error-handler-service/generated/ts-templates.d.ts +26 -0
- package/dist/generators/core/error-handler-service/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/error-handler-service/generated/ts-templates.js +50 -0
- package/dist/generators/core/error-handler-service/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/error-handler-service/templates/plugins/error-handler.ts +52 -0
- package/dist/generators/core/error-handler-service/templates/services/error-logger.ts +28 -0
- package/dist/generators/core/error-handler-service/templates/utils/http-errors.ts +62 -0
- package/dist/generators/core/error-handler-service/templates/utils/zod.ts +30 -0
- package/dist/generators/core/fastify/fastify.generator.d.ts +90 -0
- package/dist/generators/core/fastify/fastify.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify/fastify.generator.js +123 -0
- package/dist/generators/core/fastify/fastify.generator.js.map +1 -0
- package/dist/generators/core/fastify/setup-fastify-typescript.d.ts +10 -0
- package/dist/generators/core/fastify/setup-fastify-typescript.d.ts.map +1 -0
- package/dist/generators/core/fastify/setup-fastify-typescript.js +28 -0
- package/dist/generators/core/fastify/setup-fastify-typescript.js.map +1 -0
- package/dist/generators/core/fastify-cookie-context/fastify-cookie-context.generator.d.ts +20 -0
- package/dist/generators/core/fastify-cookie-context/fastify-cookie-context.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-cookie-context/fastify-cookie-context.generator.js +56 -0
- package/dist/generators/core/fastify-cookie-context/fastify-cookie-context.generator.js.map +1 -0
- package/dist/generators/core/fastify-graceful-shutdown/fastify-graceful-shutdown.generator.d.ts +27 -0
- package/dist/generators/core/fastify-graceful-shutdown/fastify-graceful-shutdown.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-graceful-shutdown/fastify-graceful-shutdown.generator.js +44 -0
- package/dist/generators/core/fastify-graceful-shutdown/fastify-graceful-shutdown.generator.js.map +1 -0
- package/dist/generators/core/fastify-graceful-shutdown/generated/ts-templates.d.ts +18 -0
- package/dist/generators/core/fastify-graceful-shutdown/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-graceful-shutdown/generated/ts-templates.js +15 -0
- package/dist/generators/core/fastify-graceful-shutdown/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/fastify-graceful-shutdown/templates/graceful-shutdown.ts +33 -0
- package/dist/generators/core/fastify-health-check/fastify-health-check.generator.d.ts +23 -0
- package/dist/generators/core/fastify-health-check/fastify-health-check.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-health-check/fastify-health-check.generator.js +53 -0
- package/dist/generators/core/fastify-health-check/fastify-health-check.generator.js.map +1 -0
- package/dist/generators/core/fastify-health-check/generated/ts-templates.d.ts +6 -0
- package/dist/generators/core/fastify-health-check/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-health-check/generated/ts-templates.js +9 -0
- package/dist/generators/core/fastify-health-check/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/fastify-health-check/templates/health-check.ts +15 -0
- package/dist/generators/core/fastify-redis/fastify-redis.generator.d.ts +33 -0
- package/dist/generators/core/fastify-redis/fastify-redis.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-redis/fastify-redis.generator.js +79 -0
- package/dist/generators/core/fastify-redis/fastify-redis.generator.js.map +1 -0
- package/dist/generators/core/fastify-redis/generated/ts-import-maps.d.ts +13 -0
- package/dist/generators/core/fastify-redis/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/fastify-redis/generated/ts-import-maps.js +18 -0
- package/dist/generators/core/fastify-redis/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/fastify-redis/generated/ts-templates.d.ts +9 -0
- package/dist/generators/core/fastify-redis/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-redis/generated/ts-templates.js +17 -0
- package/dist/generators/core/fastify-redis/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/fastify-redis/templates/mock-redis.ts +41 -0
- package/dist/generators/core/fastify-redis/templates/redis.ts +17 -0
- package/dist/generators/core/fastify-scripts/fastify-scripts.generator.d.ts +13 -0
- package/dist/generators/core/fastify-scripts/fastify-scripts.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-scripts/fastify-scripts.generator.js +48 -0
- package/dist/generators/core/fastify-scripts/fastify-scripts.generator.js.map +1 -0
- package/dist/generators/core/fastify-scripts/generated/raw-templates.d.ts +4 -0
- package/dist/generators/core/fastify-scripts/generated/raw-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-scripts/generated/raw-templates.js +9 -0
- package/dist/generators/core/fastify-scripts/generated/raw-templates.js.map +1 -0
- package/dist/generators/core/fastify-scripts/templates/tsconfig.tpl.json +8 -0
- package/dist/generators/core/fastify-sentry/fastify-sentry.generator.d.ts +92 -0
- package/dist/generators/core/fastify-sentry/fastify-sentry.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-sentry/fastify-sentry.generator.js +162 -0
- package/dist/generators/core/fastify-sentry/fastify-sentry.generator.js.map +1 -0
- package/dist/generators/core/fastify-sentry/generated/ts-import-maps.d.ts +17 -0
- package/dist/generators/core/fastify-sentry/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/fastify-sentry/generated/ts-import-maps.js +22 -0
- package/dist/generators/core/fastify-sentry/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/fastify-sentry/generated/ts-templates.d.ts +28 -0
- package/dist/generators/core/fastify-sentry/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-sentry/generated/ts-templates.js +27 -0
- package/dist/generators/core/fastify-sentry/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/fastify-sentry/templates/instrument.ts +41 -0
- package/dist/generators/core/fastify-sentry/templates/services/sentry.ts +72 -0
- package/dist/generators/core/fastify-server/fastify-server.generator.d.ts +70 -0
- package/dist/generators/core/fastify-server/fastify-server.generator.d.ts.map +1 -0
- package/dist/generators/core/fastify-server/fastify-server.generator.js +127 -0
- package/dist/generators/core/fastify-server/fastify-server.generator.js.map +1 -0
- package/dist/generators/core/fastify-server/generated/ts-templates.d.ts +18 -0
- package/dist/generators/core/fastify-server/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/fastify-server/generated/ts-templates.js +25 -0
- package/dist/generators/core/fastify-server/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/fastify-server/templates/index.ts +19 -0
- package/dist/generators/core/fastify-server/templates/server.ts +31 -0
- package/dist/generators/core/index.d.ts +21 -0
- package/dist/generators/core/index.d.ts.map +1 -0
- package/dist/generators/core/index.js +21 -0
- package/dist/generators/core/index.js.map +1 -0
- package/dist/generators/core/logger-service/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/core/logger-service/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/logger-service/generated/ts-import-maps.js +14 -0
- package/dist/generators/core/logger-service/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/logger-service/generated/ts-templates.d.ts +6 -0
- package/dist/generators/core/logger-service/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/logger-service/generated/ts-templates.js +9 -0
- package/dist/generators/core/logger-service/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/logger-service/logger-service.generator.d.ts +28 -0
- package/dist/generators/core/logger-service/logger-service.generator.d.ts.map +1 -0
- package/dist/generators/core/logger-service/logger-service.generator.js +75 -0
- package/dist/generators/core/logger-service/logger-service.generator.js.map +1 -0
- package/dist/generators/core/logger-service/templates/logger.ts +5 -0
- package/dist/generators/core/readme/generated/text-templates.d.ts +8 -0
- package/dist/generators/core/readme/generated/text-templates.d.ts.map +1 -0
- package/dist/generators/core/readme/generated/text-templates.js +10 -0
- package/dist/generators/core/readme/generated/text-templates.js.map +1 -0
- package/dist/generators/core/readme/readme.generator.d.ts +8 -0
- package/dist/generators/core/readme/readme.generator.d.ts.map +1 -0
- package/dist/generators/core/readme/readme.generator.js +37 -0
- package/dist/generators/core/readme/readme.generator.js.map +1 -0
- package/dist/generators/core/readme/templates/README.md +26 -0
- package/dist/generators/core/request-context/generated/ts-import-maps.d.ts +15 -0
- package/dist/generators/core/request-context/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/request-context/generated/ts-import-maps.js +16 -0
- package/dist/generators/core/request-context/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/request-context/generated/ts-templates.d.ts +4 -0
- package/dist/generators/core/request-context/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/request-context/generated/ts-templates.js +9 -0
- package/dist/generators/core/request-context/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/request-context/request-context.generator.d.ts +27 -0
- package/dist/generators/core/request-context/request-context.generator.d.ts.map +1 -0
- package/dist/generators/core/request-context/request-context.generator.js +59 -0
- package/dist/generators/core/request-context/request-context.generator.js.map +1 -0
- package/dist/generators/core/request-context/templates/request-context.ts +50 -0
- package/dist/generators/core/request-service-context/generated/ts-import-maps.d.ts +17 -0
- package/dist/generators/core/request-service-context/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/request-service-context/generated/ts-import-maps.js +18 -0
- package/dist/generators/core/request-service-context/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/request-service-context/generated/ts-templates.d.ts +16 -0
- package/dist/generators/core/request-service-context/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/request-service-context/generated/ts-templates.js +20 -0
- package/dist/generators/core/request-service-context/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/request-service-context/request-service-context.generator.d.ts +46 -0
- package/dist/generators/core/request-service-context/request-service-context.generator.d.ts.map +1 -0
- package/dist/generators/core/request-service-context/request-service-context.generator.js +73 -0
- package/dist/generators/core/request-service-context/request-service-context.generator.js.map +1 -0
- package/dist/generators/core/request-service-context/templates/request-service-context.ts +17 -0
- package/dist/generators/core/service-context/generated/ts-import-maps.d.ts +19 -0
- package/dist/generators/core/service-context/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/core/service-context/generated/ts-import-maps.js +20 -0
- package/dist/generators/core/service-context/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/core/service-context/generated/ts-templates.d.ts +12 -0
- package/dist/generators/core/service-context/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/core/service-context/generated/ts-templates.js +22 -0
- package/dist/generators/core/service-context/generated/ts-templates.js.map +1 -0
- package/dist/generators/core/service-context/service-context.generator.d.ts +53 -0
- package/dist/generators/core/service-context/service-context.generator.d.ts.map +1 -0
- package/dist/generators/core/service-context/service-context.generator.js +87 -0
- package/dist/generators/core/service-context/service-context.generator.js.map +1 -0
- package/dist/generators/core/service-context/templates/service-context.test-helper.ts +9 -0
- package/dist/generators/core/service-context/templates/service-context.ts +9 -0
- package/dist/generators/core/service-file/service-file.generator.d.ts +58 -0
- package/dist/generators/core/service-file/service-file.generator.d.ts.map +1 -0
- package/dist/generators/core/service-file/service-file.generator.js +85 -0
- package/dist/generators/core/service-file/service-file.generator.js.map +1 -0
- package/dist/generators/email/fastify-postmark/fastify-postmark.generator.d.ts +19 -0
- package/dist/generators/email/fastify-postmark/fastify-postmark.generator.d.ts.map +1 -0
- package/dist/generators/email/fastify-postmark/fastify-postmark.generator.js +65 -0
- package/dist/generators/email/fastify-postmark/fastify-postmark.generator.js.map +1 -0
- package/dist/generators/email/fastify-postmark/generated/ts-templates.d.ts +11 -0
- package/dist/generators/email/fastify-postmark/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/email/fastify-postmark/generated/ts-templates.js +11 -0
- package/dist/generators/email/fastify-postmark/generated/ts-templates.js.map +1 -0
- package/dist/generators/email/fastify-postmark/templates/postmark.ts +60 -0
- package/dist/generators/email/index.d.ts +2 -0
- package/dist/generators/email/index.d.ts.map +1 -0
- package/dist/generators/email/index.js +2 -0
- package/dist/generators/email/index.js.map +1 -0
- package/dist/generators/index.d.ts +10 -0
- package/dist/generators/index.d.ts.map +1 -0
- package/dist/generators/index.js +10 -0
- package/dist/generators/index.js.map +1 -0
- package/dist/generators/pothos/_providers/index.d.ts +4 -0
- package/dist/generators/pothos/_providers/index.d.ts.map +1 -0
- package/dist/generators/pothos/_providers/index.js +4 -0
- package/dist/generators/pothos/_providers/index.js.map +1 -0
- package/dist/generators/pothos/_providers/pothos-field.d.ts +10 -0
- package/dist/generators/pothos/_providers/pothos-field.d.ts.map +1 -0
- package/dist/generators/pothos/_providers/pothos-field.js +3 -0
- package/dist/generators/pothos/_providers/pothos-field.js.map +1 -0
- package/dist/generators/pothos/_providers/pothos-type-output.d.ts +15 -0
- package/dist/generators/pothos/_providers/pothos-type-output.d.ts.map +1 -0
- package/dist/generators/pothos/_providers/pothos-type-output.js +6 -0
- package/dist/generators/pothos/_providers/pothos-type-output.js.map +1 -0
- package/dist/generators/pothos/_providers/scopes.d.ts +2 -0
- package/dist/generators/pothos/_providers/scopes.d.ts.map +1 -0
- package/dist/generators/pothos/_providers/scopes.js +3 -0
- package/dist/generators/pothos/_providers/scopes.js.map +1 -0
- package/dist/generators/pothos/index.d.ts +16 -0
- package/dist/generators/pothos/index.d.ts.map +1 -0
- package/dist/generators/pothos/index.js +16 -0
- package/dist/generators/pothos/index.js.map +1 -0
- package/dist/generators/pothos/pothos/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/pothos/pothos/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/pothos/pothos/generated/ts-import-maps.js +14 -0
- package/dist/generators/pothos/pothos/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/pothos/pothos/generated/ts-templates.d.ts +36 -0
- package/dist/generators/pothos/pothos/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/pothos/pothos/generated/ts-templates.js +63 -0
- package/dist/generators/pothos/pothos/generated/ts-templates.js.map +1 -0
- package/dist/generators/pothos/pothos/pothos.generator.d.ts +93 -0
- package/dist/generators/pothos/pothos/pothos.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos/pothos.generator.js +238 -0
- package/dist/generators/pothos/pothos/pothos.generator.js.map +1 -0
- package/dist/generators/pothos/pothos/templates/FieldWithInputPayloadPlugin/global-types.ts +92 -0
- package/dist/generators/pothos/pothos/templates/FieldWithInputPayloadPlugin/index.ts +21 -0
- package/dist/generators/pothos/pothos/templates/FieldWithInputPayloadPlugin/schema-builder.ts +103 -0
- package/dist/generators/pothos/pothos/templates/FieldWithInputPayloadPlugin/types.ts +49 -0
- package/dist/generators/pothos/pothos/templates/builder.ts +11 -0
- package/dist/generators/pothos/pothos/templates/strip-query-mutation-plugin.ts +60 -0
- package/dist/generators/pothos/pothos-auth/generated/ts-templates.d.ts +28 -0
- package/dist/generators/pothos/pothos-auth/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-auth/generated/ts-templates.js +35 -0
- package/dist/generators/pothos/pothos-auth/generated/ts-templates.js.map +1 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.d.ts +59 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.js +74 -0
- package/dist/generators/pothos/pothos-auth/pothos-auth.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-auth/templates/FieldAuthorizePlugin/global-types.ts +56 -0
- package/dist/generators/pothos/pothos-auth/templates/FieldAuthorizePlugin/index.ts +130 -0
- package/dist/generators/pothos/pothos-auth/templates/FieldAuthorizePlugin/types.ts +32 -0
- package/dist/generators/pothos/pothos-authorize-field/pothos-authorize-field.generator.d.ts +9 -0
- package/dist/generators/pothos/pothos-authorize-field/pothos-authorize-field.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-authorize-field/pothos-authorize-field.generator.js +25 -0
- package/dist/generators/pothos/pothos-authorize-field/pothos-authorize-field.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-enums-file/pothos-enums-file.generator.d.ts +32 -0
- package/dist/generators/pothos/pothos-enums-file/pothos-enums-file.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-enums-file/pothos-enums-file.generator.js +60 -0
- package/dist/generators/pothos/pothos-enums-file/pothos-enums-file.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma/pothos-prisma.generator.d.ts +25 -0
- package/dist/generators/pothos/pothos-prisma/pothos-prisma.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma/pothos-prisma.generator.js +62 -0
- package/dist/generators/pothos/pothos-prisma/pothos-prisma.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.d.ts +26 -0
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.js +164 -0
- package/dist/generators/pothos/pothos-prisma-crud-mutation/pothos-prisma-crud-mutation.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-enum/pothos-prisma-enum.generator.d.ts +12 -0
- package/dist/generators/pothos/pothos-prisma-enum/pothos-prisma-enum.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-enum/pothos-prisma-enum.generator.js +44 -0
- package/dist/generators/pothos/pothos-prisma-enum/pothos-prisma-enum.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.d.ts +15 -0
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.js +110 -0
- package/dist/generators/pothos/pothos-prisma-find-query/pothos-prisma-find-query.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.d.ts +12 -0
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.js +74 -0
- package/dist/generators/pothos/pothos-prisma-list-query/pothos-prisma-list-query.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.d.ts +21 -0
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.js +109 -0
- package/dist/generators/pothos/pothos-prisma-object/pothos-prisma-object.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-prisma-primary-key/pothos-prisma-primary-key.generator.d.ts +14 -0
- package/dist/generators/pothos/pothos-prisma-primary-key/pothos-prisma-primary-key.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-prisma-primary-key/pothos-prisma-primary-key.generator.js +76 -0
- package/dist/generators/pothos/pothos-prisma-primary-key/pothos-prisma-primary-key.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-scalar/generated/ts-templates.d.ts +48 -0
- package/dist/generators/pothos/pothos-scalar/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-scalar/generated/ts-templates.js +35 -0
- package/dist/generators/pothos/pothos-scalar/generated/ts-templates.js.map +1 -0
- package/dist/generators/pothos/pothos-scalar/pothos-scalar.generator.d.ts +34 -0
- package/dist/generators/pothos/pothos-scalar/pothos-scalar.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-scalar/pothos-scalar.generator.js +103 -0
- package/dist/generators/pothos/pothos-scalar/pothos-scalar.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-scalar/templates/date-time.ts +32 -0
- package/dist/generators/pothos/pothos-scalar/templates/date.ts +49 -0
- package/dist/generators/pothos/pothos-scalar/templates/uuid.ts +35 -0
- package/dist/generators/pothos/pothos-sentry/generated/ts-templates.d.ts +4 -0
- package/dist/generators/pothos/pothos-sentry/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-sentry/generated/ts-templates.js +9 -0
- package/dist/generators/pothos/pothos-sentry/generated/ts-templates.js.map +1 -0
- package/dist/generators/pothos/pothos-sentry/pothos-sentry.generator.d.ts +26 -0
- package/dist/generators/pothos/pothos-sentry/pothos-sentry.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-sentry/pothos-sentry.generator.js +80 -0
- package/dist/generators/pothos/pothos-sentry/pothos-sentry.generator.js.map +1 -0
- package/dist/generators/pothos/pothos-sentry/templates/use-sentry.ts +66 -0
- package/dist/generators/pothos/pothos-types-file/pothos-types-file.generator.d.ts +39 -0
- package/dist/generators/pothos/pothos-types-file/pothos-types-file.generator.d.ts.map +1 -0
- package/dist/generators/pothos/pothos-types-file/pothos-types-file.generator.js +63 -0
- package/dist/generators/pothos/pothos-types-file/pothos-types-file.generator.js.map +1 -0
- package/dist/generators/prisma/_shared/crud-method/data-method.d.ts +31 -0
- package/dist/generators/prisma/_shared/crud-method/data-method.d.ts.map +1 -0
- package/dist/generators/prisma/_shared/crud-method/data-method.js +195 -0
- package/dist/generators/prisma/_shared/crud-method/data-method.js.map +1 -0
- package/dist/generators/prisma/_shared/crud-method/primary-key-input.d.ts +14 -0
- package/dist/generators/prisma/_shared/crud-method/primary-key-input.d.ts.map +1 -0
- package/dist/generators/prisma/_shared/crud-method/primary-key-input.js +84 -0
- package/dist/generators/prisma/_shared/crud-method/primary-key-input.js.map +1 -0
- package/dist/generators/prisma/embedded-relation-transformer/embedded-relation-transformer.generator.d.ts +49 -0
- package/dist/generators/prisma/embedded-relation-transformer/embedded-relation-transformer.generator.d.ts.map +1 -0
- package/dist/generators/prisma/embedded-relation-transformer/embedded-relation-transformer.generator.js +371 -0
- package/dist/generators/prisma/embedded-relation-transformer/embedded-relation-transformer.generator.js.map +1 -0
- package/dist/generators/prisma/index.d.ts +15 -0
- package/dist/generators/prisma/index.d.ts.map +1 -0
- package/dist/generators/prisma/index.js +15 -0
- package/dist/generators/prisma/index.js.map +1 -0
- package/dist/generators/prisma/prisma/generated/ts-import-maps.d.ts +11 -0
- package/dist/generators/prisma/prisma/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/prisma/prisma/generated/ts-import-maps.js +14 -0
- package/dist/generators/prisma/prisma/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/prisma/prisma/generated/ts-templates.d.ts +5 -0
- package/dist/generators/prisma/prisma/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/prisma/prisma/generated/ts-templates.js +15 -0
- package/dist/generators/prisma/prisma/generated/ts-templates.js.map +1 -0
- package/dist/generators/prisma/prisma/prisma.generator.d.ts +60 -0
- package/dist/generators/prisma/prisma/prisma.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma/prisma.generator.js +179 -0
- package/dist/generators/prisma/prisma/prisma.generator.js.map +1 -0
- package/dist/generators/prisma/prisma/templates/prisma/seed.ts +18 -0
- package/dist/generators/prisma/prisma/templates/services/prisma.ts +5 -0
- package/dist/generators/prisma/prisma-crud-create/prisma-crud-create.generator.d.ts +47 -0
- package/dist/generators/prisma/prisma-crud-create/prisma-crud-create.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-crud-create/prisma-crud-create.generator.js +130 -0
- package/dist/generators/prisma/prisma-crud-create/prisma-crud-create.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-crud-delete/prisma-crud-delete.generator.d.ts +38 -0
- package/dist/generators/prisma/prisma-crud-delete/prisma-crud-delete.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-crud-delete/prisma-crud-delete.generator.js +94 -0
- package/dist/generators/prisma/prisma-crud-delete/prisma-crud-delete.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-crud-service/prisma-crud-service.generator.d.ts +20 -0
- package/dist/generators/prisma/prisma-crud-service/prisma-crud-service.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-crud-service/prisma-crud-service.generator.js +53 -0
- package/dist/generators/prisma/prisma-crud-service/prisma-crud-service.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-crud-update/prisma-crud-update.generator.d.ts +47 -0
- package/dist/generators/prisma/prisma-crud-update/prisma-crud-update.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-crud-update/prisma-crud-update.generator.js +145 -0
- package/dist/generators/prisma/prisma-crud-update/prisma-crud-update.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-enum/prisma-enum.generator.d.ts +11 -0
- package/dist/generators/prisma/prisma-enum/prisma-enum.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-enum/prisma-enum.generator.js +28 -0
- package/dist/generators/prisma/prisma-enum/prisma-enum.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-field/prisma-field.generator.d.ts +70 -0
- package/dist/generators/prisma/prisma-field/prisma-field.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-field/prisma-field.generator.js +62 -0
- package/dist/generators/prisma/prisma-field/prisma-field.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-model/prisma-model.generator.d.ts +21 -0
- package/dist/generators/prisma/prisma-model/prisma-model.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model/prisma-model.generator.js +47 -0
- package/dist/generators/prisma/prisma-model/prisma-model.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-model-id/prisma-model-id.generator.d.ts +8 -0
- package/dist/generators/prisma/prisma-model-id/prisma-model-id.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model-id/prisma-model-id.generator.js +26 -0
- package/dist/generators/prisma/prisma-model-id/prisma-model-id.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-model-index/prisma-model-index.generator.d.ts +8 -0
- package/dist/generators/prisma/prisma-model-index/prisma-model-index.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model-index/prisma-model-index.generator.js +26 -0
- package/dist/generators/prisma/prisma-model-index/prisma-model-index.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-model-unique/prisma-model-unique.generator.d.ts +10 -0
- package/dist/generators/prisma/prisma-model-unique/prisma-model-unique.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-model-unique/prisma-model-unique.generator.js +29 -0
- package/dist/generators/prisma/prisma-model-unique/prisma-model-unique.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-relation-field/prisma-relation-field.generator.d.ts +19 -0
- package/dist/generators/prisma/prisma-relation-field/prisma-relation-field.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-relation-field/prisma-relation-field.generator.js +81 -0
- package/dist/generators/prisma/prisma-relation-field/prisma-relation-field.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-import-maps.d.ts +57 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-import-maps.js +42 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-templates.d.ts +73 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-templates.js +98 -0
- package/dist/generators/prisma/prisma-utils/generated/ts-templates.js.map +1 -0
- package/dist/generators/prisma/prisma-utils/prisma-utils.generator.d.ts +54 -0
- package/dist/generators/prisma/prisma-utils/prisma-utils.generator.d.ts.map +1 -0
- package/dist/generators/prisma/prisma-utils/prisma-utils.generator.js +53 -0
- package/dist/generators/prisma/prisma-utils/prisma-utils.generator.js.map +1 -0
- package/dist/generators/prisma/prisma-utils/templates/crud-service-types.ts +35 -0
- package/dist/generators/prisma/prisma-utils/templates/data-pipes.ts +86 -0
- package/dist/generators/prisma/prisma-utils/templates/embedded-pipes/embedded-one-to-many.ts +247 -0
- package/dist/generators/prisma/prisma-utils/templates/embedded-pipes/embedded-one-to-one.ts +148 -0
- package/dist/generators/prisma/prisma-utils/templates/embedded-pipes/embedded-types.ts +6 -0
- package/dist/generators/prisma/prisma-utils/templates/prisma-relations.ts +24 -0
- package/dist/generators/stripe/fastify-stripe/fastify-stripe.generator.d.ts +46 -0
- package/dist/generators/stripe/fastify-stripe/fastify-stripe.generator.d.ts.map +1 -0
- package/dist/generators/stripe/fastify-stripe/fastify-stripe.generator.js +83 -0
- package/dist/generators/stripe/fastify-stripe/fastify-stripe.generator.js.map +1 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-import-maps.d.ts +19 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-import-maps.js +20 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-templates.d.ts +45 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-templates.js +64 -0
- package/dist/generators/stripe/fastify-stripe/generated/ts-templates.js.map +1 -0
- package/dist/generators/stripe/fastify-stripe/templates/plugins/stripe-webhook.int.test.ts +70 -0
- package/dist/generators/stripe/fastify-stripe/templates/plugins/stripe-webhook.ts +49 -0
- package/dist/generators/stripe/fastify-stripe/templates/services/stripe-events.ts +30 -0
- package/dist/generators/stripe/fastify-stripe/templates/services/stripe.ts +8 -0
- package/dist/generators/stripe/index.d.ts +2 -0
- package/dist/generators/stripe/index.d.ts.map +1 -0
- package/dist/generators/stripe/index.js +2 -0
- package/dist/generators/stripe/index.js.map +1 -0
- package/dist/generators/vitest/fastify-vitest/fastify-vitest.generator.d.ts +10 -0
- package/dist/generators/vitest/fastify-vitest/fastify-vitest.generator.d.ts.map +1 -0
- package/dist/generators/vitest/fastify-vitest/fastify-vitest.generator.js +27 -0
- package/dist/generators/vitest/fastify-vitest/fastify-vitest.generator.js.map +1 -0
- package/dist/generators/vitest/index.d.ts +3 -0
- package/dist/generators/vitest/index.d.ts.map +1 -0
- package/dist/generators/vitest/index.js +3 -0
- package/dist/generators/vitest/index.js.map +1 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-import-maps.d.ts +21 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-import-maps.d.ts.map +1 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-import-maps.js +26 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-import-maps.js.map +1 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-templates.d.ts +13 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-templates.js +26 -0
- package/dist/generators/vitest/prisma-vitest/generated/ts-templates.js.map +1 -0
- package/dist/generators/vitest/prisma-vitest/prisma-vitest.generator.d.ts +35 -0
- package/dist/generators/vitest/prisma-vitest/prisma-vitest.generator.d.ts.map +1 -0
- package/dist/generators/vitest/prisma-vitest/prisma-vitest.generator.js +94 -0
- package/dist/generators/vitest/prisma-vitest/prisma-vitest.generator.js.map +1 -0
- package/dist/generators/vitest/prisma-vitest/templates/db.test-helper.ts +83 -0
- package/dist/generators/vitest/prisma-vitest/templates/prisma.test-helper.ts +26 -0
- package/dist/generators/yoga/index.d.ts +2 -0
- package/dist/generators/yoga/index.d.ts.map +1 -0
- package/dist/generators/yoga/index.js +2 -0
- package/dist/generators/yoga/index.js.map +1 -0
- package/dist/generators/yoga/yoga-plugin/generated/ts-templates.d.ts +87 -0
- package/dist/generators/yoga/yoga-plugin/generated/ts-templates.d.ts.map +1 -0
- package/dist/generators/yoga/yoga-plugin/generated/ts-templates.js +66 -0
- package/dist/generators/yoga/yoga-plugin/generated/ts-templates.js.map +1 -0
- package/dist/generators/yoga/yoga-plugin/templates/graphql-plugin.ts +119 -0
- package/dist/generators/yoga/yoga-plugin/templates/plugins/graphql/index.ts +111 -0
- package/dist/generators/yoga/yoga-plugin/templates/plugins/graphql/pubsub.ts +22 -0
- package/dist/generators/yoga/yoga-plugin/templates/plugins/graphql/useGraphLogger.ts +109 -0
- package/dist/generators/yoga/yoga-plugin/templates/plugins/graphql/websocket.ts +256 -0
- package/dist/generators/yoga/yoga-plugin/templates/pubsub.ts +24 -0
- package/dist/generators/yoga/yoga-plugin/templates/use-graph-logger.ts +112 -0
- package/dist/generators/yoga/yoga-plugin/templates/websocket-fragments.ts +49 -0
- package/dist/generators/yoga/yoga-plugin/templates/websocket.ts +281 -0
- package/dist/generators/yoga/yoga-plugin/yoga-plugin.generator.d.ts +174 -0
- package/dist/generators/yoga/yoga-plugin/yoga-plugin.generator.d.ts.map +1 -0
- package/dist/generators/yoga/yoga-plugin/yoga-plugin.generator.js +239 -0
- package/dist/generators/yoga/yoga-plugin/yoga-plugin.generator.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/providers/prisma/prisma-data-transformable.d.ts +27 -0
- package/dist/providers/prisma/prisma-data-transformable.d.ts.map +1 -0
- package/dist/providers/prisma/prisma-data-transformable.js +2 -0
- package/dist/providers/prisma/prisma-data-transformable.js.map +1 -0
- package/dist/types/field-types.d.ts +8 -0
- package/dist/types/field-types.d.ts.map +1 -0
- package/dist/types/field-types.js +31 -0
- package/dist/types/field-types.js.map +1 -0
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/prisma-output.d.ts +37 -0
- package/dist/types/prisma-output.d.ts.map +1 -0
- package/dist/types/prisma-output.js +2 -0
- package/dist/types/prisma-output.js.map +1 -0
- package/dist/types/service-output.d.ts +59 -0
- package/dist/types/service-output.d.ts.map +1 -0
- package/dist/types/service-output.js +38 -0
- package/dist/types/service-output.js.map +1 -0
- package/dist/utils/case.d.ts +3 -0
- package/dist/utils/case.d.ts.map +1 -0
- package/dist/utils/case.js +13 -0
- package/dist/utils/case.js.map +1 -0
- package/dist/utils/string.d.ts +8 -0
- package/dist/utils/string.d.ts.map +1 -0
- package/dist/utils/string.js +13 -0
- package/dist/utils/string.js.map +1 -0
- package/dist/writers/index.d.ts +2 -0
- package/dist/writers/index.d.ts.map +1 -0
- package/dist/writers/index.js +2 -0
- package/dist/writers/index.js.map +1 -0
- package/dist/writers/pothos/args.d.ts +5 -0
- package/dist/writers/pothos/args.d.ts.map +1 -0
- package/dist/writers/pothos/args.js +31 -0
- package/dist/writers/pothos/args.js.map +1 -0
- package/dist/writers/pothos/definitions.d.ts +19 -0
- package/dist/writers/pothos/definitions.d.ts.map +1 -0
- package/dist/writers/pothos/definitions.js +2 -0
- package/dist/writers/pothos/definitions.js.map +1 -0
- package/dist/writers/pothos/helpers.d.ts +41 -0
- package/dist/writers/pothos/helpers.d.ts.map +1 -0
- package/dist/writers/pothos/helpers.js +73 -0
- package/dist/writers/pothos/helpers.js.map +1 -0
- package/dist/writers/pothos/index.d.ts +7 -0
- package/dist/writers/pothos/index.d.ts.map +1 -0
- package/dist/writers/pothos/index.js +7 -0
- package/dist/writers/pothos/index.js.map +1 -0
- package/dist/writers/pothos/input-types.d.ts +8 -0
- package/dist/writers/pothos/input-types.d.ts.map +1 -0
- package/dist/writers/pothos/input-types.js +62 -0
- package/dist/writers/pothos/input-types.js.map +1 -0
- package/dist/writers/pothos/object-types.d.ts +5 -0
- package/dist/writers/pothos/object-types.d.ts.map +1 -0
- package/dist/writers/pothos/object-types.js +63 -0
- package/dist/writers/pothos/object-types.js.map +1 -0
- package/dist/writers/pothos/options.d.ts +46 -0
- package/dist/writers/pothos/options.d.ts.map +1 -0
- package/dist/writers/pothos/options.js +11 -0
- package/dist/writers/pothos/options.js.map +1 -0
- package/dist/writers/pothos/resolvers.d.ts +4 -0
- package/dist/writers/pothos/resolvers.d.ts.map +1 -0
- package/dist/writers/pothos/resolvers.js +67 -0
- package/dist/writers/pothos/resolvers.js.map +1 -0
- package/dist/writers/pothos/scalar-fields.d.ts +37 -0
- package/dist/writers/pothos/scalar-fields.d.ts.map +1 -0
- package/dist/writers/pothos/scalar-fields.js +70 -0
- package/dist/writers/pothos/scalar-fields.js.map +1 -0
- package/dist/writers/pothos/scalars.d.ts +12 -0
- package/dist/writers/pothos/scalars.d.ts.map +1 -0
- package/dist/writers/pothos/scalars.js +53 -0
- package/dist/writers/pothos/scalars.js.map +1 -0
- package/dist/writers/prisma-schema/fields.d.ts +113 -0
- package/dist/writers/prisma-schema/fields.d.ts.map +1 -0
- package/dist/writers/prisma-schema/fields.js +173 -0
- package/dist/writers/prisma-schema/fields.js.map +1 -0
- package/dist/writers/prisma-schema/index.d.ts +3 -0
- package/dist/writers/prisma-schema/index.d.ts.map +1 -0
- package/dist/writers/prisma-schema/index.js +3 -0
- package/dist/writers/prisma-schema/index.js.map +1 -0
- package/dist/writers/prisma-schema/model-writer.d.ts +70 -0
- package/dist/writers/prisma-schema/model-writer.d.ts.map +1 -0
- package/dist/writers/prisma-schema/model-writer.js +158 -0
- package/dist/writers/prisma-schema/model-writer.js.map +1 -0
- package/dist/writers/prisma-schema/schema.d.ts +30 -0
- package/dist/writers/prisma-schema/schema.d.ts.map +1 -0
- package/dist/writers/prisma-schema/schema.js +87 -0
- package/dist/writers/prisma-schema/schema.js.map +1 -0
- package/dist/writers/prisma-schema/types.d.ts +20 -0
- package/dist/writers/prisma-schema/types.d.ts.map +1 -0
- package/dist/writers/prisma-schema/types.js +2 -0
- package/dist/writers/prisma-schema/types.js.map +1 -0
- package/package.json +69 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { projectScope, tsCodeFragment, TsCodeUtils, tsImportBuilder, typescriptFileProvider, } from '@baseplate-dev/core-generators';
|
|
2
|
+
import { createConfigProviderTask, createGenerator, createGeneratorTask, } from '@baseplate-dev/sync';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
import { configServiceImportsProvider } from '../config-service/config-service.generator.js';
|
|
5
|
+
import { fastifyServerConfigProvider } from '../fastify-server/fastify-server.generator.js';
|
|
6
|
+
import { loggerServiceImportsProvider } from '../logger-service/logger-service.generator.js';
|
|
7
|
+
import { createErrorHandlerServiceImports, errorHandlerServiceImportsProvider, } from './generated/ts-import-maps.js';
|
|
8
|
+
import { CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES } from './generated/ts-templates.js';
|
|
9
|
+
const descriptorSchema = z.object({});
|
|
10
|
+
export const [configTask, errorHandlerServiceConfigProvider, errorHandlerServiceConfigValuesProvider,] = createConfigProviderTask((t) => ({
|
|
11
|
+
contextActions: t.map(),
|
|
12
|
+
loggerActions: t.map(),
|
|
13
|
+
}), {
|
|
14
|
+
prefix: 'error-handler-service',
|
|
15
|
+
configScope: projectScope,
|
|
16
|
+
});
|
|
17
|
+
export const errorHandlerServiceGenerator = createGenerator({
|
|
18
|
+
name: 'core/error-handler-service',
|
|
19
|
+
generatorFileUrl: import.meta.url,
|
|
20
|
+
descriptorSchema,
|
|
21
|
+
buildTasks: () => ({
|
|
22
|
+
imports: createGeneratorTask({
|
|
23
|
+
exports: {
|
|
24
|
+
errorHandlerServiceImports: errorHandlerServiceImportsProvider.export(projectScope),
|
|
25
|
+
},
|
|
26
|
+
run() {
|
|
27
|
+
return {
|
|
28
|
+
providers: {
|
|
29
|
+
errorHandlerServiceImports: createErrorHandlerServiceImports('@/src'),
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
},
|
|
33
|
+
}),
|
|
34
|
+
fastifyPlugin: createGeneratorTask({
|
|
35
|
+
dependencies: {
|
|
36
|
+
fastifyServerConfig: fastifyServerConfigProvider,
|
|
37
|
+
typescriptFile: typescriptFileProvider,
|
|
38
|
+
configServiceImports: configServiceImportsProvider,
|
|
39
|
+
errorHandlerServiceImports: errorHandlerServiceImportsProvider,
|
|
40
|
+
},
|
|
41
|
+
run({ fastifyServerConfig, typescriptFile, configServiceImports, errorHandlerServiceImports, }) {
|
|
42
|
+
const errorPluginPath = '@/src/plugins/error-handler.ts';
|
|
43
|
+
fastifyServerConfig.plugins.set('errorHandlerPlugin', {
|
|
44
|
+
plugin: tsCodeFragment('errorHandlerPlugin', tsImportBuilder(['errorHandlerPlugin']).from(errorPluginPath)),
|
|
45
|
+
orderPriority: 'EARLY',
|
|
46
|
+
});
|
|
47
|
+
fastifyServerConfig.errorHandlerFunction.set(errorHandlerServiceImports.logError.fragment());
|
|
48
|
+
return {
|
|
49
|
+
build: async (builder) => {
|
|
50
|
+
await builder.apply(typescriptFile.renderTemplateFile({
|
|
51
|
+
template: CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES.errorHandlerPlugin,
|
|
52
|
+
destination: errorPluginPath,
|
|
53
|
+
variables: {},
|
|
54
|
+
importMapProviders: {
|
|
55
|
+
configServiceImports,
|
|
56
|
+
},
|
|
57
|
+
}));
|
|
58
|
+
},
|
|
59
|
+
};
|
|
60
|
+
},
|
|
61
|
+
}),
|
|
62
|
+
configTask,
|
|
63
|
+
errorLogger: createGeneratorTask({
|
|
64
|
+
dependencies: {
|
|
65
|
+
loggerServiceImports: loggerServiceImportsProvider,
|
|
66
|
+
typescriptFile: typescriptFileProvider,
|
|
67
|
+
errorHandlerServiceConfigValues: errorHandlerServiceConfigValuesProvider,
|
|
68
|
+
},
|
|
69
|
+
run({ loggerServiceImports, typescriptFile, errorHandlerServiceConfigValues: { contextActions, loggerActions }, }) {
|
|
70
|
+
return {
|
|
71
|
+
build: async (builder) => {
|
|
72
|
+
await builder.apply(typescriptFile.renderTemplateFile({
|
|
73
|
+
template: CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES.errorLogger,
|
|
74
|
+
destination: '@/src/services/error-logger.ts',
|
|
75
|
+
importMapProviders: { loggerServiceImports },
|
|
76
|
+
variables: {
|
|
77
|
+
TPL_CONTEXT_ACTIONS: TsCodeUtils.mergeFragments(contextActions, '\n\n'),
|
|
78
|
+
TPL_LOGGER_ACTIONS: TsCodeUtils.mergeFragments(loggerActions, '\n\n'),
|
|
79
|
+
},
|
|
80
|
+
}));
|
|
81
|
+
},
|
|
82
|
+
};
|
|
83
|
+
},
|
|
84
|
+
}),
|
|
85
|
+
utils: createGeneratorTask({
|
|
86
|
+
dependencies: {
|
|
87
|
+
typescriptFile: typescriptFileProvider,
|
|
88
|
+
},
|
|
89
|
+
run({ typescriptFile }) {
|
|
90
|
+
return {
|
|
91
|
+
build: async (builder) => {
|
|
92
|
+
await builder.apply(typescriptFile.renderTemplateGroup({
|
|
93
|
+
group: CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES.utilsGroup,
|
|
94
|
+
baseDirectory: '@/src/utils',
|
|
95
|
+
}));
|
|
96
|
+
},
|
|
97
|
+
};
|
|
98
|
+
},
|
|
99
|
+
}),
|
|
100
|
+
}),
|
|
101
|
+
});
|
|
102
|
+
export { errorHandlerServiceImportsProvider } from './generated/ts-import-maps.js';
|
|
103
|
+
//# sourceMappingURL=error-handler-service.generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"error-handler-service.generator.js","sourceRoot":"","sources":["../../../../src/generators/core/error-handler-service/error-handler-service.generator.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,YAAY,EACZ,cAAc,EACd,WAAW,EACX,eAAe,EACf,sBAAsB,GACvB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,wBAAwB,EACxB,eAAe,EACf,mBAAmB,GACpB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,EAAE,4BAA4B,EAAE,MAAM,+CAA+C,CAAC;AAC7F,OAAO,EAAE,2BAA2B,EAAE,MAAM,+CAA+C,CAAC;AAC5F,OAAO,EAAE,4BAA4B,EAAE,MAAM,+CAA+C,CAAC;AAC7F,OAAO,EACL,gCAAgC,EAChC,kCAAkC,GACnC,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,uCAAuC,EAAE,MAAM,6BAA6B,CAAC;AAEtF,MAAM,gBAAgB,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;AAEtC,MAAM,CAAC,MAAM,CACX,UAAU,EACV,iCAAiC,EACjC,uCAAuC,EACxC,GAAG,wBAAwB,CAC1B,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACN,cAAc,EAAE,CAAC,CAAC,GAAG,EAA0B;IAC/C,aAAa,EAAE,CAAC,CAAC,GAAG,EAA0B;CAC/C,CAAC,EACF;IACE,MAAM,EAAE,uBAAuB;IAC/B,WAAW,EAAE,YAAY;CAC1B,CACF,CAAC;AAEF,MAAM,CAAC,MAAM,4BAA4B,GAAG,eAAe,CAAC;IAC1D,IAAI,EAAE,4BAA4B;IAClC,gBAAgB,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG;IACjC,gBAAgB;IAEhB,UAAU,EAAE,GAAG,EAAE,CAAC,CAAC;QACjB,OAAO,EAAE,mBAAmB,CAAC;YAC3B,OAAO,EAAE;gBACP,0BAA0B,EACxB,kCAAkC,CAAC,MAAM,CAAC,YAAY,CAAC;aAC1D;YACD,GAAG;gBACD,OAAO;oBACL,SAAS,EAAE;wBACT,0BAA0B,EACxB,gCAAgC,CAAC,OAAO,CAAC;qBAC5C;iBACF,CAAC;YACJ,CAAC;SACF,CAAC;QACF,aAAa,EAAE,mBAAmB,CAAC;YACjC,YAAY,EAAE;gBACZ,mBAAmB,EAAE,2BAA2B;gBAChD,cAAc,EAAE,sBAAsB;gBACtC,oBAAoB,EAAE,4BAA4B;gBAClD,0BAA0B,EAAE,kCAAkC;aAC/D;YACD,GAAG,CAAC,EACF,mBAAmB,EACnB,cAAc,EACd,oBAAoB,EACpB,0BAA0B,GAC3B;gBACC,MAAM,eAAe,GAAG,gCAAgC,CAAC;gBACzD,mBAAmB,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE;oBACpD,MAAM,EAAE,cAAc,CACpB,oBAAoB,EACpB,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAC9D;oBACD,aAAa,EAAE,OAAO;iBACvB,CAAC,CAAC;gBAEH,mBAAmB,CAAC,oBAAoB,CAAC,GAAG,CAC1C,0BAA0B,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAC/C,CAAC;gBAEF,OAAO;oBACL,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;wBACvB,MAAM,OAAO,CAAC,KAAK,CACjB,cAAc,CAAC,kBAAkB,CAAC;4BAChC,QAAQ,EACN,uCAAuC,CAAC,kBAAkB;4BAC5D,WAAW,EAAE,eAAe;4BAC5B,SAAS,EAAE,EAAE;4BACb,kBAAkB,EAAE;gCAClB,oBAAoB;6BACrB;yBACF,CAAC,CACH,CAAC;oBACJ,CAAC;iBACF,CAAC;YACJ,CAAC;SACF,CAAC;QACF,UAAU;QACV,WAAW,EAAE,mBAAmB,CAAC;YAC/B,YAAY,EAAE;gBACZ,oBAAoB,EAAE,4BAA4B;gBAClD,cAAc,EAAE,sBAAsB;gBACtC,+BAA+B,EAC7B,uCAAuC;aAC1C;YACD,GAAG,CAAC,EACF,oBAAoB,EACpB,cAAc,EACd,+BAA+B,EAAE,EAAE,cAAc,EAAE,aAAa,EAAE,GACnE;gBACC,OAAO;oBACL,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;wBACvB,MAAM,OAAO,CAAC,KAAK,CACjB,cAAc,CAAC,kBAAkB,CAAC;4BAChC,QAAQ,EAAE,uCAAuC,CAAC,WAAW;4BAC7D,WAAW,EAAE,gCAAgC;4BAC7C,kBAAkB,EAAE,EAAE,oBAAoB,EAAE;4BAC5C,SAAS,EAAE;gCACT,mBAAmB,EAAE,WAAW,CAAC,cAAc,CAC7C,cAAc,EACd,MAAM,CACP;gCACD,kBAAkB,EAAE,WAAW,CAAC,cAAc,CAC5C,aAAa,EACb,MAAM,CACP;6BACF;yBACF,CAAC,CACH,CAAC;oBACJ,CAAC;iBACF,CAAC;YACJ,CAAC;SACF,CAAC;QACF,KAAK,EAAE,mBAAmB,CAAC;YACzB,YAAY,EAAE;gBACZ,cAAc,EAAE,sBAAsB;aACvC;YACD,GAAG,CAAC,EAAE,cAAc,EAAE;gBACpB,OAAO;oBACL,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;wBACvB,MAAM,OAAO,CAAC,KAAK,CACjB,cAAc,CAAC,mBAAmB,CAAC;4BACjC,KAAK,EAAE,uCAAuC,CAAC,UAAU;4BACzD,aAAa,EAAE,aAAa;yBAC7B,CAAC,CACH,CAAC;oBACJ,CAAC;iBACF,CAAC;YACJ,CAAC;SACF,CAAC;KACH,CAAC;CACH,CAAC,CAAC;AAEH,OAAO,EAAE,kCAAkC,EAAE,MAAM,+BAA+B,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { TsImportMapProviderFromSchema } from '@baseplate-dev/core-generators';
|
|
2
|
+
declare const errorHandlerServiceImportsSchema: {
|
|
3
|
+
BadRequestError: {};
|
|
4
|
+
ForbiddenError: {};
|
|
5
|
+
handleZodRequestValidationError: {};
|
|
6
|
+
HttpError: {};
|
|
7
|
+
InternalServerError: {};
|
|
8
|
+
logError: {};
|
|
9
|
+
NotFoundError: {};
|
|
10
|
+
UnauthorizedError: {};
|
|
11
|
+
};
|
|
12
|
+
type ErrorHandlerServiceImportsProvider = TsImportMapProviderFromSchema<typeof errorHandlerServiceImportsSchema>;
|
|
13
|
+
export declare const errorHandlerServiceImportsProvider: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
14
|
+
BadRequestError: {};
|
|
15
|
+
ForbiddenError: {};
|
|
16
|
+
handleZodRequestValidationError: {};
|
|
17
|
+
HttpError: {};
|
|
18
|
+
InternalServerError: {};
|
|
19
|
+
logError: {};
|
|
20
|
+
NotFoundError: {};
|
|
21
|
+
UnauthorizedError: {};
|
|
22
|
+
}>>;
|
|
23
|
+
export declare function createErrorHandlerServiceImports(importBase: string): ErrorHandlerServiceImportsProvider;
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=ts-import-maps.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ts-import-maps.d.ts","sourceRoot":"","sources":["../../../../../src/generators/core/error-handler-service/generated/ts-import-maps.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,gCAAgC,CAAC;AASpF,QAAA,MAAM,gCAAgC;;;;;;;;;CASpC,CAAC;AAEH,KAAK,kCAAkC,GAAG,6BAA6B,CACrE,OAAO,gCAAgC,CACxC,CAAC;AAEF,eAAO,MAAM,kCAAkC;;;;;;;;;GAG5C,CAAC;AAEJ,wBAAgB,gCAAgC,CAC9C,UAAU,EAAE,MAAM,GACjB,kCAAkC,CAepC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { createTsImportMap, createTsImportMapSchema, } from '@baseplate-dev/core-generators';
|
|
2
|
+
import { createReadOnlyProviderType } from '@baseplate-dev/sync';
|
|
3
|
+
import path from 'node:path/posix';
|
|
4
|
+
const errorHandlerServiceImportsSchema = createTsImportMapSchema({
|
|
5
|
+
BadRequestError: {},
|
|
6
|
+
ForbiddenError: {},
|
|
7
|
+
handleZodRequestValidationError: {},
|
|
8
|
+
HttpError: {},
|
|
9
|
+
InternalServerError: {},
|
|
10
|
+
logError: {},
|
|
11
|
+
NotFoundError: {},
|
|
12
|
+
UnauthorizedError: {},
|
|
13
|
+
});
|
|
14
|
+
export const errorHandlerServiceImportsProvider = createReadOnlyProviderType('error-handler-service-imports');
|
|
15
|
+
export function createErrorHandlerServiceImports(importBase) {
|
|
16
|
+
if (!importBase.startsWith('@/')) {
|
|
17
|
+
throw new Error('importBase must start with @/');
|
|
18
|
+
}
|
|
19
|
+
return createTsImportMap(errorHandlerServiceImportsSchema, {
|
|
20
|
+
BadRequestError: path.join(importBase, 'utils/http-errors.js'),
|
|
21
|
+
ForbiddenError: path.join(importBase, 'utils/http-errors.js'),
|
|
22
|
+
handleZodRequestValidationError: path.join(importBase, 'utils/zod.js'),
|
|
23
|
+
HttpError: path.join(importBase, 'utils/http-errors.js'),
|
|
24
|
+
InternalServerError: path.join(importBase, 'utils/http-errors.js'),
|
|
25
|
+
logError: path.join(importBase, 'services/error-logger.js'),
|
|
26
|
+
NotFoundError: path.join(importBase, 'utils/http-errors.js'),
|
|
27
|
+
UnauthorizedError: path.join(importBase, 'utils/http-errors.js'),
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=ts-import-maps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ts-import-maps.js","sourceRoot":"","sources":["../../../../../src/generators/core/error-handler-service/generated/ts-import-maps.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,iBAAiB,EACjB,uBAAuB,GACxB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,0BAA0B,EAAE,MAAM,qBAAqB,CAAC;AACjE,OAAO,IAAI,MAAM,iBAAiB,CAAC;AAEnC,MAAM,gCAAgC,GAAG,uBAAuB,CAAC;IAC/D,eAAe,EAAE,EAAE;IACnB,cAAc,EAAE,EAAE;IAClB,+BAA+B,EAAE,EAAE;IACnC,SAAS,EAAE,EAAE;IACb,mBAAmB,EAAE,EAAE;IACvB,QAAQ,EAAE,EAAE;IACZ,aAAa,EAAE,EAAE;IACjB,iBAAiB,EAAE,EAAE;CACtB,CAAC,CAAC;AAMH,MAAM,CAAC,MAAM,kCAAkC,GAC7C,0BAA0B,CACxB,+BAA+B,CAChC,CAAC;AAEJ,MAAM,UAAU,gCAAgC,CAC9C,UAAkB;IAElB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;IACnD,CAAC;IAED,OAAO,iBAAiB,CAAC,gCAAgC,EAAE;QACzD,eAAe,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;QAC9D,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;QAC7D,+BAA+B,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,cAAc,CAAC;QACtE,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;QACxD,mBAAmB,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;QAClE,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,0BAA0B,CAAC;QAC3D,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;QAC5D,iBAAiB,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,sBAAsB,CAAC;KACjE,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export declare const CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES: {
|
|
2
|
+
errorHandlerPlugin: import("@baseplate-dev/core-generators").TsTemplateFile<{}, {
|
|
3
|
+
configServiceImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
4
|
+
config: {};
|
|
5
|
+
}>>;
|
|
6
|
+
}>;
|
|
7
|
+
errorLogger: import("@baseplate-dev/core-generators").TsTemplateFile<{
|
|
8
|
+
TPL_CONTEXT_ACTIONS: {};
|
|
9
|
+
TPL_LOGGER_ACTIONS: {};
|
|
10
|
+
}, {
|
|
11
|
+
loggerServiceImports: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").InferTsImportMapFromSchema<{
|
|
12
|
+
logger: {};
|
|
13
|
+
}>>;
|
|
14
|
+
}>;
|
|
15
|
+
utilsGroup: import("@baseplate-dev/core-generators").TsTemplateGroup<{
|
|
16
|
+
httpErrors: {
|
|
17
|
+
destination: string;
|
|
18
|
+
template: import("@baseplate-dev/core-generators").TsTemplateFile<{}, Record<never, import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/sync").Provider>>>;
|
|
19
|
+
};
|
|
20
|
+
zod: {
|
|
21
|
+
destination: string;
|
|
22
|
+
template: import("@baseplate-dev/core-generators").TsTemplateFile<{}, Record<never, import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/sync").Provider>>>;
|
|
23
|
+
};
|
|
24
|
+
}>;
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=ts-templates.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ts-templates.d.ts","sourceRoot":"","sources":["../../../../../src/generators/core/error-handler-service/generated/ts-templates.ts"],"names":[],"mappings":"AAsDA,eAAO,MAAM,uCAAuC;;;;;;;;;;;;;;;;;;;;;;;;CAInD,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { createTsTemplateFile, createTsTemplateGroup, } from '@baseplate-dev/core-generators';
|
|
2
|
+
import { configServiceImportsProvider } from '../../config-service/generated/ts-import-maps.js';
|
|
3
|
+
import { loggerServiceImportsProvider } from '../../logger-service/generated/ts-import-maps.js';
|
|
4
|
+
const errorHandlerPlugin = createTsTemplateFile({
|
|
5
|
+
importMapProviders: { configServiceImports: configServiceImportsProvider },
|
|
6
|
+
name: 'error-handler-plugin',
|
|
7
|
+
projectExports: {},
|
|
8
|
+
source: { path: 'plugins/error-handler.ts' },
|
|
9
|
+
variables: {},
|
|
10
|
+
});
|
|
11
|
+
const errorLogger = createTsTemplateFile({
|
|
12
|
+
importMapProviders: { loggerServiceImports: loggerServiceImportsProvider },
|
|
13
|
+
name: 'error-logger',
|
|
14
|
+
projectExports: { logError: {} },
|
|
15
|
+
source: { path: 'services/error-logger.ts' },
|
|
16
|
+
variables: { TPL_CONTEXT_ACTIONS: {}, TPL_LOGGER_ACTIONS: {} },
|
|
17
|
+
});
|
|
18
|
+
const httpErrors = createTsTemplateFile({
|
|
19
|
+
group: 'utils',
|
|
20
|
+
name: 'http-errors',
|
|
21
|
+
projectExports: {
|
|
22
|
+
BadRequestError: {},
|
|
23
|
+
ForbiddenError: {},
|
|
24
|
+
HttpError: {},
|
|
25
|
+
InternalServerError: {},
|
|
26
|
+
NotFoundError: {},
|
|
27
|
+
UnauthorizedError: {},
|
|
28
|
+
},
|
|
29
|
+
source: { path: 'utils/http-errors.ts' },
|
|
30
|
+
variables: {},
|
|
31
|
+
});
|
|
32
|
+
const zod = createTsTemplateFile({
|
|
33
|
+
group: 'utils',
|
|
34
|
+
name: 'zod',
|
|
35
|
+
projectExports: { handleZodRequestValidationError: {} },
|
|
36
|
+
source: { path: 'utils/zod.ts' },
|
|
37
|
+
variables: {},
|
|
38
|
+
});
|
|
39
|
+
const utilsGroup = createTsTemplateGroup({
|
|
40
|
+
templates: {
|
|
41
|
+
httpErrors: { destination: 'http-errors.ts', template: httpErrors },
|
|
42
|
+
zod: { destination: 'zod.ts', template: zod },
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
export const CORE_ERROR_HANDLER_SERVICE_TS_TEMPLATES = {
|
|
46
|
+
errorHandlerPlugin,
|
|
47
|
+
errorLogger,
|
|
48
|
+
utilsGroup,
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=ts-templates.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ts-templates.js","sourceRoot":"","sources":["../../../../../src/generators/core/error-handler-service/generated/ts-templates.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,oBAAoB,EACpB,qBAAqB,GACtB,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,4BAA4B,EAAE,MAAM,kDAAkD,CAAC;AAChG,OAAO,EAAE,4BAA4B,EAAE,MAAM,kDAAkD,CAAC;AAEhG,MAAM,kBAAkB,GAAG,oBAAoB,CAAC;IAC9C,kBAAkB,EAAE,EAAE,oBAAoB,EAAE,4BAA4B,EAAE;IAC1E,IAAI,EAAE,sBAAsB;IAC5B,cAAc,EAAE,EAAE;IAClB,MAAM,EAAE,EAAE,IAAI,EAAE,0BAA0B,EAAE;IAC5C,SAAS,EAAE,EAAE;CACd,CAAC,CAAC;AAEH,MAAM,WAAW,GAAG,oBAAoB,CAAC;IACvC,kBAAkB,EAAE,EAAE,oBAAoB,EAAE,4BAA4B,EAAE;IAC1E,IAAI,EAAE,cAAc;IACpB,cAAc,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IAChC,MAAM,EAAE,EAAE,IAAI,EAAE,0BAA0B,EAAE;IAC5C,SAAS,EAAE,EAAE,mBAAmB,EAAE,EAAE,EAAE,kBAAkB,EAAE,EAAE,EAAE;CAC/D,CAAC,CAAC;AAEH,MAAM,UAAU,GAAG,oBAAoB,CAAC;IACtC,KAAK,EAAE,OAAO;IACd,IAAI,EAAE,aAAa;IACnB,cAAc,EAAE;QACd,eAAe,EAAE,EAAE;QACnB,cAAc,EAAE,EAAE;QAClB,SAAS,EAAE,EAAE;QACb,mBAAmB,EAAE,EAAE;QACvB,aAAa,EAAE,EAAE;QACjB,iBAAiB,EAAE,EAAE;KACtB;IACD,MAAM,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE;IACxC,SAAS,EAAE,EAAE;CACd,CAAC,CAAC;AAEH,MAAM,GAAG,GAAG,oBAAoB,CAAC;IAC/B,KAAK,EAAE,OAAO;IACd,IAAI,EAAE,KAAK;IACX,cAAc,EAAE,EAAE,+BAA+B,EAAE,EAAE,EAAE;IACvD,MAAM,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE;IAChC,SAAS,EAAE,EAAE;CACd,CAAC,CAAC;AAEH,MAAM,UAAU,GAAG,qBAAqB,CAAC;IACvC,SAAS,EAAE;QACT,UAAU,EAAE,EAAE,WAAW,EAAE,gBAAgB,EAAE,QAAQ,EAAE,UAAU,EAAE;QACnE,GAAG,EAAE,EAAE,WAAW,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE;KAC9C;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,uCAAuC,GAAG;IACrD,kBAAkB;IAClB,WAAW;IACX,UAAU;CACX,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
|
|
3
|
+
import { config } from '%configServiceImports';
|
|
4
|
+
import fp from 'fastify-plugin';
|
|
5
|
+
|
|
6
|
+
import { logError } from '../services/error-logger.js';
|
|
7
|
+
import { HttpError, NotFoundError } from '../utils/http-errors.js';
|
|
8
|
+
|
|
9
|
+
const IS_DEVELOPMENT = config.APP_ENVIRONMENT === 'development';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Handles errors from Fastify route handlers, sending the correct code
|
|
13
|
+
* if an HttpError was thrown.
|
|
14
|
+
*/
|
|
15
|
+
export const errorHandlerPlugin = fp((fastify, opts, done) => {
|
|
16
|
+
fastify.setNotFoundHandler((req) => {
|
|
17
|
+
throw new NotFoundError(`${req.method} ${req.url} not found`);
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
fastify.setErrorHandler(async (error, request, reply) => {
|
|
21
|
+
logError(error);
|
|
22
|
+
|
|
23
|
+
if (error instanceof HttpError) {
|
|
24
|
+
await reply.code(error.statusCode).send({
|
|
25
|
+
...error.extraData,
|
|
26
|
+
message: error.message,
|
|
27
|
+
code: error.code,
|
|
28
|
+
statusCode: error.statusCode,
|
|
29
|
+
reqId: request.id,
|
|
30
|
+
});
|
|
31
|
+
} else if (error.statusCode && error.statusCode < 500) {
|
|
32
|
+
await reply.code(error.statusCode).send({
|
|
33
|
+
message: error.message,
|
|
34
|
+
code: error.code,
|
|
35
|
+
statusCode: error.statusCode,
|
|
36
|
+
reqId: request.id,
|
|
37
|
+
});
|
|
38
|
+
} else {
|
|
39
|
+
await reply.code(500).send({
|
|
40
|
+
message: 'Internal server error',
|
|
41
|
+
code: 'INTERNAL_SERVER_ERROR',
|
|
42
|
+
statusCode: error.statusCode,
|
|
43
|
+
reqId: request.id,
|
|
44
|
+
originalError: IS_DEVELOPMENT
|
|
45
|
+
? { message: error.message, stack: error.stack }
|
|
46
|
+
: undefined,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
done();
|
|
52
|
+
});
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
|
|
3
|
+
import { logger } from '%loggerServiceImports';
|
|
4
|
+
|
|
5
|
+
interface ErrorContext extends Record<string, unknown> {
|
|
6
|
+
errorId?: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Logs error to the appropriate receivers.
|
|
11
|
+
*
|
|
12
|
+
* @param err Error object
|
|
13
|
+
* @param additionalContext Additional context to be logged
|
|
14
|
+
*/
|
|
15
|
+
export function logError(
|
|
16
|
+
error: unknown,
|
|
17
|
+
additionalContext?: Record<string, unknown>,
|
|
18
|
+
): string | undefined {
|
|
19
|
+
const context: ErrorContext = { ...additionalContext };
|
|
20
|
+
|
|
21
|
+
TPL_CONTEXT_ACTIONS;
|
|
22
|
+
|
|
23
|
+
TPL_LOGGER_ACTIONS;
|
|
24
|
+
|
|
25
|
+
logger.error({ err: error, ...context });
|
|
26
|
+
|
|
27
|
+
return context.errorId;
|
|
28
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
|
|
3
|
+
export class HttpError extends Error {
|
|
4
|
+
constructor(
|
|
5
|
+
message: string,
|
|
6
|
+
public code?: string,
|
|
7
|
+
public extraData?: Record<string, unknown>,
|
|
8
|
+
public statusCode = 500,
|
|
9
|
+
) {
|
|
10
|
+
super(message);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export class BadRequestError extends HttpError {
|
|
15
|
+
constructor(
|
|
16
|
+
message: string,
|
|
17
|
+
code = 'BAD_REQUEST',
|
|
18
|
+
extraData?: Record<string, unknown>,
|
|
19
|
+
) {
|
|
20
|
+
super(message, code, extraData, 400);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export class UnauthorizedError extends HttpError {
|
|
25
|
+
constructor(
|
|
26
|
+
message: string,
|
|
27
|
+
code = 'UNAUTHORIZED',
|
|
28
|
+
extraData?: Record<string, unknown>,
|
|
29
|
+
) {
|
|
30
|
+
super(message, code, extraData, 401);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export class ForbiddenError extends HttpError {
|
|
35
|
+
constructor(
|
|
36
|
+
message: string,
|
|
37
|
+
code = 'FORBIDDEN',
|
|
38
|
+
extraData?: Record<string, unknown>,
|
|
39
|
+
) {
|
|
40
|
+
super(message, code, extraData, 403);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export class NotFoundError extends HttpError {
|
|
45
|
+
constructor(
|
|
46
|
+
message: string,
|
|
47
|
+
code = 'NOT_FOUND',
|
|
48
|
+
extraData?: Record<string, unknown>,
|
|
49
|
+
) {
|
|
50
|
+
super(message, code, extraData, 404);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export class InternalServerError extends HttpError {
|
|
55
|
+
constructor(
|
|
56
|
+
message: string,
|
|
57
|
+
code = 'INTERNAL_SERVER_ERROR',
|
|
58
|
+
extraData?: Record<string, unknown>,
|
|
59
|
+
) {
|
|
60
|
+
super(message, code, extraData, 500);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
|
|
3
|
+
import { ZodError } from 'zod';
|
|
4
|
+
|
|
5
|
+
import { BadRequestError } from './http-errors.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Handles errors that occur during Zod request validation.
|
|
9
|
+
*
|
|
10
|
+
* If the provided error is an instance of `ZodError`, it formats the error details
|
|
11
|
+
* and throws a `BadRequestError` with a `ZOD_VALIDATION_ERROR` code and the formatted errors.
|
|
12
|
+
* If the error is not a `ZodError`, it is re-thrown as-is.
|
|
13
|
+
*
|
|
14
|
+
* @param {unknown} error - The error to handle. Can be any type, but typically expected
|
|
15
|
+
* to be a `ZodError` when triggered by Zod validation failures.
|
|
16
|
+
* @throws {BadRequestError} If the error is a `ZodError`, this throws a `BadRequestError`
|
|
17
|
+
* with the formatted validation errors.
|
|
18
|
+
* @throws {unknown} If the error is not a `ZodError`, it is re-thrown as-is.
|
|
19
|
+
* @returns {never} This function does not return as it always throws an error.
|
|
20
|
+
*/
|
|
21
|
+
export const handleZodRequestValidationError = (error: unknown): never => {
|
|
22
|
+
if (error instanceof ZodError) {
|
|
23
|
+
throw new BadRequestError('Validation failed', 'ZOD_VALIDATION_ERROR', {
|
|
24
|
+
errors: error.errors,
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// Re-throw non-Zod errors
|
|
29
|
+
throw error;
|
|
30
|
+
};
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import type { InferFieldMapSchemaFromBuilder } from '@baseplate-dev/utils';
|
|
2
|
+
export type FastifyNodeFlagUseCase = 'dev-env' | 'instrument';
|
|
3
|
+
export interface FastifyNodeFlag {
|
|
4
|
+
flag: string;
|
|
5
|
+
/**
|
|
6
|
+
* The type of flag that is used
|
|
7
|
+
*
|
|
8
|
+
* 'dev-env': For setting up environment variables in dev
|
|
9
|
+
* 'instrument': For instrumenting the code
|
|
10
|
+
*/
|
|
11
|
+
useCase: FastifyNodeFlagUseCase;
|
|
12
|
+
targetEnvironment: 'dev' | 'prod';
|
|
13
|
+
}
|
|
14
|
+
export interface FastifyGeneratorConfig {
|
|
15
|
+
/**
|
|
16
|
+
* Command to pipe the dev output into, e.g. pino-pretty
|
|
17
|
+
*/
|
|
18
|
+
devOutputFormatter?: string;
|
|
19
|
+
nodeFlags: FastifyNodeFlag[];
|
|
20
|
+
}
|
|
21
|
+
declare const fastifyConfigSchema: (t: import("@baseplate-dev/utils").FieldMapSchemaBuilder) => {
|
|
22
|
+
/**
|
|
23
|
+
* Command to pipe the dev output into, e.g. pino-pretty
|
|
24
|
+
*/
|
|
25
|
+
devOutputFormatter: import("@baseplate-dev/utils").ScalarContainer<string | undefined>;
|
|
26
|
+
/**
|
|
27
|
+
* Flags to pass to the node command when running
|
|
28
|
+
*/
|
|
29
|
+
nodeFlags: import("@baseplate-dev/utils").MapContainer<string, FastifyNodeFlag>;
|
|
30
|
+
};
|
|
31
|
+
export type FastifyProvider = InferFieldMapSchemaFromBuilder<typeof fastifyConfigSchema>;
|
|
32
|
+
export declare const fastifyProvider: import("@baseplate-dev/sync").ProviderType<{
|
|
33
|
+
/**
|
|
34
|
+
* Command to pipe the dev output into, e.g. pino-pretty
|
|
35
|
+
*/
|
|
36
|
+
devOutputFormatter: import("@baseplate-dev/utils").ScalarContainer<string | undefined>;
|
|
37
|
+
/**
|
|
38
|
+
* Flags to pass to the node command when running
|
|
39
|
+
*/
|
|
40
|
+
nodeFlags: import("@baseplate-dev/utils").MapContainer<string, FastifyNodeFlag>;
|
|
41
|
+
}>;
|
|
42
|
+
export interface FastifyOutputProvider {
|
|
43
|
+
getNodeFlags(): FastifyNodeFlag[];
|
|
44
|
+
getNodeFlagsDev(useCase?: FastifyNodeFlagUseCase): string[];
|
|
45
|
+
getNodeFlagsProd(useCase?: FastifyNodeFlagUseCase): string[];
|
|
46
|
+
getDevOutputFormatter(): string | undefined;
|
|
47
|
+
}
|
|
48
|
+
export declare const fastifyOutputProvider: import("@baseplate-dev/sync").ProviderType<FastifyOutputProvider>;
|
|
49
|
+
export declare const fastifyGenerator: import("@baseplate-dev/sync").GeneratorBundleCreator<{
|
|
50
|
+
placeholder?: string | undefined;
|
|
51
|
+
}, {
|
|
52
|
+
nodeSetup: import("@baseplate-dev/sync").GeneratorTask<any, {
|
|
53
|
+
nodeConfig: import("@baseplate-dev/sync").ProviderType<Omit<import("@baseplate-dev/utils").FieldMap<{
|
|
54
|
+
isEsm: import("@baseplate-dev/utils").ScalarContainer<boolean>;
|
|
55
|
+
}>, "getValues">>;
|
|
56
|
+
}, any>;
|
|
57
|
+
fastifyTypescript: import("@baseplate-dev/sync").GeneratorTask<undefined, {
|
|
58
|
+
typescriptSetup: import("@baseplate-dev/sync").ProviderType<Omit<import("@baseplate-dev/utils").FieldMap<{
|
|
59
|
+
compilerOptions: import("@baseplate-dev/utils").ScalarContainer<import("@baseplate-dev/core-generators").TypescriptCompilerOptions>;
|
|
60
|
+
include: import("@baseplate-dev/utils").ArrayContainer<string>;
|
|
61
|
+
exclude: import("@baseplate-dev/utils").ArrayContainer<string>;
|
|
62
|
+
references: import("@baseplate-dev/utils").ArrayContainer<import("@baseplate-dev/core-generators").TypescriptConfigReference>;
|
|
63
|
+
extraSections: import("@baseplate-dev/utils").ArrayContainer<Record<string, unknown>>;
|
|
64
|
+
}>, "getValues">>;
|
|
65
|
+
}, undefined>;
|
|
66
|
+
node: import("@baseplate-dev/sync").AnyGeneratorTask;
|
|
67
|
+
gitIgnore: import("@baseplate-dev/sync").GeneratorTask<undefined, {
|
|
68
|
+
provider: import("@baseplate-dev/sync").ProviderType<Omit<import("@baseplate-dev/utils").FieldMap<{
|
|
69
|
+
exclusions: import("@baseplate-dev/utils").MapContainer<string, string[]>;
|
|
70
|
+
}>, "getValues">>;
|
|
71
|
+
}, undefined>;
|
|
72
|
+
main: import("@baseplate-dev/sync").GeneratorTask<{
|
|
73
|
+
fastify: import("@baseplate-dev/sync").ProviderExport<{
|
|
74
|
+
/**
|
|
75
|
+
* Command to pipe the dev output into, e.g. pino-pretty
|
|
76
|
+
*/
|
|
77
|
+
devOutputFormatter: import("@baseplate-dev/utils").ScalarContainer<string | undefined>;
|
|
78
|
+
/**
|
|
79
|
+
* Flags to pass to the node command when running
|
|
80
|
+
*/
|
|
81
|
+
nodeFlags: import("@baseplate-dev/utils").MapContainer<string, FastifyNodeFlag>;
|
|
82
|
+
}>;
|
|
83
|
+
}, {
|
|
84
|
+
node: import("@baseplate-dev/sync").ProviderType<import("@baseplate-dev/core-generators").NodeProvider>;
|
|
85
|
+
}, {
|
|
86
|
+
fastifyOutput: import("@baseplate-dev/sync").ProviderExport<FastifyOutputProvider>;
|
|
87
|
+
}>;
|
|
88
|
+
}>;
|
|
89
|
+
export {};
|
|
90
|
+
//# sourceMappingURL=fastify.generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fastify.generator.d.ts","sourceRoot":"","sources":["../../../../src/generators/core/fastify/fastify.generator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,sBAAsB,CAAC;AA8B3E,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG,YAAY,CAAC;AAE9D,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb;;;;;OAKG;IACH,OAAO,EAAE,sBAAsB,CAAC;IAChC,iBAAiB,EAAE,KAAK,GAAG,MAAM,CAAC;CACnC;AAED,MAAM,WAAW,sBAAsB;IACrC;;OAEG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,EAAE,eAAe,EAAE,CAAC;CAC9B;AAED,QAAA,MAAM,mBAAmB;IACvB;;OAEG;;IAEH;;OAEG;;CAEF,CAAC;AAEJ,MAAM,MAAM,eAAe,GAAG,8BAA8B,CAC1D,OAAO,mBAAmB,CAC3B,CAAC;AAEF,eAAO,MAAM,eAAe;IAd1B;;OAEG;;IAEH;;OAEG;;EAQwE,CAAC;AAE9E,MAAM,WAAW,qBAAqB;IACpC,YAAY,IAAI,eAAe,EAAE,CAAC;IAClC,eAAe,CAAC,OAAO,CAAC,EAAE,sBAAsB,GAAG,MAAM,EAAE,CAAC;IAC5D,gBAAgB,CAAC,OAAO,CAAC,EAAE,sBAAsB,GAAG,MAAM,EAAE,CAAC;IAC7D,qBAAqB,IAAI,MAAM,GAAG,SAAS,CAAC;CAC7C;AAED,eAAO,MAAM,qBAAqB,mEACmC,CAAC;AAEtE,eAAO,MAAM,gBAAgB;;;;;0BAP6B,sBAC1C;;;;;oCAgDQ,sBAAsB;4BAGzB,sBACD;4BAEF,sBACC;+BACsB,sBAAsB;kCAEX,sBAAsB;;;;;;+BA9HtD,sBACA;;;;;YA+ClB;;eAEG;;YAEH;;eAEG;;;;;;;;EAyIH,CAAC"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { createNodeTask, extractPackageVersions, nodeConfigProvider, nodeGitIgnoreProvider, nodeProvider, projectScope, } from '@baseplate-dev/core-generators';
|
|
2
|
+
import { createConfigFieldMap, createGenerator, createGeneratorTask, createProviderTask, createProviderType, createReadOnlyProviderType, } from '@baseplate-dev/sync';
|
|
3
|
+
import { createFieldMapSchemaBuilder } from '@baseplate-dev/utils';
|
|
4
|
+
import { sortBy } from 'es-toolkit';
|
|
5
|
+
import { z } from 'zod';
|
|
6
|
+
import { FASTIFY_PACKAGES } from '#src/constants/fastify-packages.js';
|
|
7
|
+
import { fastifyTypescriptTask } from './setup-fastify-typescript.js';
|
|
8
|
+
const descriptorSchema = z.object({
|
|
9
|
+
placeholder: z.string().optional(),
|
|
10
|
+
});
|
|
11
|
+
const fastifyConfigSchema = createFieldMapSchemaBuilder((t) => ({
|
|
12
|
+
/**
|
|
13
|
+
* Command to pipe the dev output into, e.g. pino-pretty
|
|
14
|
+
*/
|
|
15
|
+
devOutputFormatter: t.scalar(),
|
|
16
|
+
/**
|
|
17
|
+
* Flags to pass to the node command when running
|
|
18
|
+
*/
|
|
19
|
+
nodeFlags: t.map(),
|
|
20
|
+
}));
|
|
21
|
+
export const fastifyProvider = createProviderType('fastify');
|
|
22
|
+
export const fastifyOutputProvider = createReadOnlyProviderType('fastify-output');
|
|
23
|
+
export const fastifyGenerator = createGenerator({
|
|
24
|
+
name: 'core/fastify',
|
|
25
|
+
generatorFileUrl: import.meta.url,
|
|
26
|
+
descriptorSchema,
|
|
27
|
+
buildTasks: () => ({
|
|
28
|
+
nodeSetup: createGeneratorTask({
|
|
29
|
+
dependencies: {
|
|
30
|
+
nodeConfig: nodeConfigProvider,
|
|
31
|
+
},
|
|
32
|
+
run({ nodeConfig }) {
|
|
33
|
+
nodeConfig.isEsm.set(false);
|
|
34
|
+
return {};
|
|
35
|
+
},
|
|
36
|
+
}),
|
|
37
|
+
fastifyTypescript: fastifyTypescriptTask,
|
|
38
|
+
node: createNodeTask((node) => {
|
|
39
|
+
node.packages.addDevPackages(extractPackageVersions(FASTIFY_PACKAGES, [
|
|
40
|
+
'tsc-alias',
|
|
41
|
+
'tsx',
|
|
42
|
+
'@types/node',
|
|
43
|
+
]));
|
|
44
|
+
node.extraProperties.merge({
|
|
45
|
+
main: 'dist/index.js',
|
|
46
|
+
files: ['dist/**/*', 'package.json', 'README.md'],
|
|
47
|
+
});
|
|
48
|
+
}),
|
|
49
|
+
gitIgnore: createProviderTask(nodeGitIgnoreProvider, (nodeGitIgnore) => {
|
|
50
|
+
nodeGitIgnore.exclusions.set('fastify', ['/dist']);
|
|
51
|
+
}),
|
|
52
|
+
main: createGeneratorTask({
|
|
53
|
+
dependencies: {
|
|
54
|
+
node: nodeProvider,
|
|
55
|
+
},
|
|
56
|
+
exports: {
|
|
57
|
+
fastify: fastifyProvider.export(projectScope),
|
|
58
|
+
},
|
|
59
|
+
outputs: {
|
|
60
|
+
fastifyOutput: fastifyOutputProvider.export(projectScope),
|
|
61
|
+
},
|
|
62
|
+
run({ node }) {
|
|
63
|
+
const fastifyConfig = createConfigFieldMap(fastifyConfigSchema);
|
|
64
|
+
return {
|
|
65
|
+
providers: {
|
|
66
|
+
fastify: fastifyConfig,
|
|
67
|
+
},
|
|
68
|
+
build() {
|
|
69
|
+
// add scripts
|
|
70
|
+
const { devOutputFormatter, nodeFlags } = fastifyConfig.getValues();
|
|
71
|
+
const USE_CASE_ORDER = {
|
|
72
|
+
'dev-env': 0,
|
|
73
|
+
instrument: 1,
|
|
74
|
+
};
|
|
75
|
+
const sortedNodeFlags = sortBy([...nodeFlags.entries()],
|
|
76
|
+
// Sort by use case, then by name
|
|
77
|
+
[([, flag]) => USE_CASE_ORDER[flag.useCase], ([name]) => name]).map(([, flag]) => flag);
|
|
78
|
+
const outputFormatter = devOutputFormatter
|
|
79
|
+
? `| ${devOutputFormatter}`
|
|
80
|
+
: '';
|
|
81
|
+
const devCommand = [
|
|
82
|
+
'tsx watch --clear-screen=false',
|
|
83
|
+
...sortedNodeFlags
|
|
84
|
+
.filter((f) => f.targetEnvironment === 'dev')
|
|
85
|
+
.map((f) => f.flag),
|
|
86
|
+
'src/index.ts',
|
|
87
|
+
outputFormatter,
|
|
88
|
+
]
|
|
89
|
+
.filter(Boolean)
|
|
90
|
+
.join(' ');
|
|
91
|
+
const startCommand = [
|
|
92
|
+
'node',
|
|
93
|
+
...sortedNodeFlags
|
|
94
|
+
.filter((f) => f.targetEnvironment === 'prod')
|
|
95
|
+
.map((f) => f.flag),
|
|
96
|
+
'dist/index.js',
|
|
97
|
+
].join(' ');
|
|
98
|
+
node.scripts.mergeObj({
|
|
99
|
+
build: 'tsc && tsc-alias',
|
|
100
|
+
start: startCommand,
|
|
101
|
+
dev: devCommand,
|
|
102
|
+
});
|
|
103
|
+
return {
|
|
104
|
+
fastifyOutput: {
|
|
105
|
+
getNodeFlags: () => sortedNodeFlags,
|
|
106
|
+
getNodeFlagsDev: (useCase) => sortedNodeFlags
|
|
107
|
+
.filter((f) => f.targetEnvironment === 'dev' &&
|
|
108
|
+
(!useCase || f.useCase === useCase))
|
|
109
|
+
.map((f) => f.flag),
|
|
110
|
+
getNodeFlagsProd: (useCase) => sortedNodeFlags
|
|
111
|
+
.filter((f) => f.targetEnvironment === 'prod' &&
|
|
112
|
+
(!useCase || f.useCase === useCase))
|
|
113
|
+
.map((f) => f.flag),
|
|
114
|
+
getDevOutputFormatter: () => devOutputFormatter,
|
|
115
|
+
},
|
|
116
|
+
};
|
|
117
|
+
},
|
|
118
|
+
};
|
|
119
|
+
},
|
|
120
|
+
}),
|
|
121
|
+
}),
|
|
122
|
+
});
|
|
123
|
+
//# sourceMappingURL=fastify.generator.js.map
|