@slopware/sloppy-darwin-x64 0.1.0-alpha.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/LICENSE +201 -0
- package/README.md +5 -0
- package/bin/sloppy +0 -0
- package/bin/sloppyc +0 -0
- package/docs/KNOWN_LIMITATIONS.md +16 -0
- package/docs/LICENSES.md +6 -0
- package/docs/NOTICE.md +8 -0
- package/examples/README.md +140 -0
- package/examples/auth-api/README.md +20 -0
- package/examples/auth-api/app.js +61 -0
- package/examples/auth-api/appsettings.json +7 -0
- package/examples/auth-api/sloppy.json +5 -0
- package/examples/cache-basic/README.md +9 -0
- package/examples/cache-basic/app.js +32 -0
- package/examples/cache-hybrid-postgres/README.md +10 -0
- package/examples/cache-hybrid-postgres/app.js +27 -0
- package/examples/cache-output-api/README.md +10 -0
- package/examples/cache-output-api/app.js +35 -0
- package/examples/codec-base64-hex/README.md +14 -0
- package/examples/codec-base64-hex/app.js +15 -0
- package/examples/codec-checksums/README.md +15 -0
- package/examples/codec-checksums/app.js +8 -0
- package/examples/codec-compression/README.md +13 -0
- package/examples/codec-compression/app.js +9 -0
- package/examples/codec-streaming-compression/README.md +19 -0
- package/examples/codec-streaming-compression/app.js +16 -0
- package/examples/codec-text-binary/README.md +16 -0
- package/examples/codec-text-binary/app.js +17 -0
- package/examples/compiler-hello/README.md +71 -0
- package/examples/compiler-hello/app.js +7 -0
- package/examples/compiler-hello/expected/app.js +8 -0
- package/examples/compiler-hello/expected/app.js.map +53 -0
- package/examples/compiler-hello/expected/app.plan.json +229 -0
- package/examples/compiler-hello/expected/routes.slrt +0 -0
- package/examples/config-basic/README.md +13 -0
- package/examples/config-basic/app.js +13 -0
- package/examples/config-basic/appsettings.json +7 -0
- package/examples/config-secrets-redaction/README.md +9 -0
- package/examples/config-secrets-redaction/app.js +9 -0
- package/examples/config-secrets-redaction/appsettings.json +5 -0
- package/examples/config-strict-mode/README.md +7 -0
- package/examples/config-strict-mode/app.js +10 -0
- package/examples/config-strict-mode/appsettings.json +7 -0
- package/examples/configured-api/README.md +38 -0
- package/examples/configured-api/app.js +12 -0
- package/examples/configured-api/appsettings.Development.json +5 -0
- package/examples/configured-api/appsettings.json +6 -0
- package/examples/configured-api/sloppy.json +5 -0
- package/examples/core-config-secrets/README.md +10 -0
- package/examples/core-config-secrets/app.js +15 -0
- package/examples/core-fs-time-codec/README.md +9 -0
- package/examples/core-fs-time-codec/app.js +8 -0
- package/examples/core-network-time-codec/README.md +11 -0
- package/examples/core-network-time-codec/app.js +20 -0
- package/examples/core-policy-audit/README.md +7 -0
- package/examples/core-policy-audit/app.js +22 -0
- package/examples/core-process-time-codec/README.md +8 -0
- package/examples/core-process-time-codec/app.js +28 -0
- package/examples/core-worker-time/README.md +8 -0
- package/examples/core-worker-time/app.js +17 -0
- package/examples/crypto-hash-hmac/README.md +17 -0
- package/examples/crypto-hash-hmac/app.js +29 -0
- package/examples/crypto-password/README.md +21 -0
- package/examples/crypto-password/app.js +12 -0
- package/examples/crypto-random-token/README.md +16 -0
- package/examples/crypto-random-token/app.js +12 -0
- package/examples/crypto-secret-constant-time/README.md +21 -0
- package/examples/crypto-secret-constant-time/app.js +15 -0
- package/examples/data-foundation/README.md +39 -0
- package/examples/data-foundation/app.js +63 -0
- package/examples/dependency-graph/README.md +19 -0
- package/examples/dependency-graph/fixtures/graph-helper/index.js +3 -0
- package/examples/dependency-graph/fixtures/graph-helper/package.json +6 -0
- package/examples/dependency-graph/package.json +7 -0
- package/examples/dependency-graph/public/message.txt +1 -0
- package/examples/dependency-graph/sloppy.json +9 -0
- package/examples/dependency-graph/src/main.ts +8 -0
- package/examples/dogfood/README.md +23 -0
- package/examples/dogfood/dogfood.json +136 -0
- package/examples/dynamic-module-include/README.md +20 -0
- package/examples/dynamic-module-include/public/readme.txt +1 -0
- package/examples/dynamic-module-include/sloppy.json +12 -0
- package/examples/dynamic-module-include/src/main.ts +6 -0
- package/examples/dynamic-module-include/src/plugins/alpha.js +3 -0
- package/examples/dynamic-module-include/src/plugins/beta.js +3 -0
- package/examples/ergonomics/README.md +42 -0
- package/examples/ergonomics/app.js +38 -0
- package/examples/framework-controller/README.md +12 -0
- package/examples/framework-controller/app.js +31 -0
- package/examples/framework-di-services/README.md +17 -0
- package/examples/framework-di-services/app.ts +40 -0
- package/examples/framework-explicit-binding/README.md +12 -0
- package/examples/framework-explicit-binding/app.ts +34 -0
- package/examples/framework-hello/README.md +16 -0
- package/examples/framework-hello/app.ts +16 -0
- package/examples/framework-postgres-crud/README.md +73 -0
- package/examples/framework-postgres-crud/app.ts +64 -0
- package/examples/framework-sqlite-crud/README.md +52 -0
- package/examples/framework-sqlite-crud/app.ts +90 -0
- package/examples/framework-sqlite-crud/appsettings.json +11 -0
- package/examples/framework-sqlserver-crud/README.md +73 -0
- package/examples/framework-sqlserver-crud/app.ts +64 -0
- package/examples/framework-validation-errors/README.md +12 -0
- package/examples/framework-validation-errors/app.ts +16 -0
- package/examples/fs-basic/README.md +24 -0
- package/examples/fs-basic/app.js +12 -0
- package/examples/fs-roots-policy/README.md +14 -0
- package/examples/fs-roots-policy/app.js +4 -0
- package/examples/fs-streams/README.md +18 -0
- package/examples/fs-streams/app.js +11 -0
- package/examples/fs-watch/README.md +19 -0
- package/examples/fs-watch/app.js +11 -0
- package/examples/hello/README.md +63 -0
- package/examples/hello/app.js +19 -0
- package/examples/hello-minimal/README.md +51 -0
- package/examples/hello-minimal/sloppy.json +5 -0
- package/examples/hello-minimal/src/main.ts +9 -0
- package/examples/http-client-basic/README.md +11 -0
- package/examples/http-client-basic/app.js +46 -0
- package/examples/http-client-generated/README.md +22 -0
- package/examples/http-client-generated/openapi.json +45 -0
- package/examples/http-client-resilience/README.md +4 -0
- package/examples/http-client-resilience/app.js +38 -0
- package/examples/http-client-runtime-loopback/README.md +24 -0
- package/examples/http-client-testhost/README.md +4 -0
- package/examples/http-client-testhost/app.js +27 -0
- package/examples/http-client-testhost-package-mock/README.md +26 -0
- package/examples/http-client-typed/README.md +5 -0
- package/examples/http-client-typed/app.js +33 -0
- package/examples/modules-api/README.md +30 -0
- package/examples/modules-api/app.js +9 -0
- package/examples/modules-api/modules/routes.js +16 -0
- package/examples/modules-api/sloppy.json +5 -0
- package/examples/modules-basic/README.md +32 -0
- package/examples/modules-basic/app.js +41 -0
- package/examples/net-deadline-cancel/README.md +13 -0
- package/examples/net-deadline-cancel/app.js +34 -0
- package/examples/net-local-ipc/README.md +12 -0
- package/examples/net-local-ipc/app.js +46 -0
- package/examples/net-policy-strict/README.md +12 -0
- package/examples/net-policy-strict/app.js +34 -0
- package/examples/net-tcp-client/README.md +10 -0
- package/examples/net-tcp-client/app.js +23 -0
- package/examples/net-tcp-echo/README.md +11 -0
- package/examples/net-tcp-echo/app.js +45 -0
- package/examples/net-tcp-server/README.md +10 -0
- package/examples/net-tcp-server/app.js +28 -0
- package/examples/node-compat-path-events/README.md +15 -0
- package/examples/node-compat-path-events/sloppy.json +6 -0
- package/examples/node-compat-path-events/src/main.ts +15 -0
- package/examples/ops-compiler/README.md +9 -0
- package/examples/ops-compiler/app.js +26 -0
- package/examples/ops-health-metrics-management/README.md +14 -0
- package/examples/ops-health-metrics-management/app.js +24 -0
- package/examples/orm-basic/README.md +17 -0
- package/examples/orm-basic/app.js +82 -0
- package/examples/orm-cursor-export/README.md +16 -0
- package/examples/orm-cursor-export/app.js +28 -0
- package/examples/orm-migrations/README.md +14 -0
- package/examples/orm-migrations/migrations/.gitkeep +1 -0
- package/examples/orm-migrations/sloppy.json +9 -0
- package/examples/orm-migrations/src/app.ts +34 -0
- package/examples/orm-relations-includes/README.md +10 -0
- package/examples/orm-relations-includes/app.js +47 -0
- package/examples/orm-testservices/README.md +37 -0
- package/examples/orm-testservices/test.mjs +32 -0
- package/examples/os-runtime-api/README.md +11 -0
- package/examples/os-runtime-api/app.js +44 -0
- package/examples/package-zod-like/README.md +28 -0
- package/examples/package-zod-like/fixtures/zod-like/index.js +48 -0
- package/examples/package-zod-like/fixtures/zod-like/package.json +12 -0
- package/examples/package-zod-like/package.json +7 -0
- package/examples/package-zod-like/sloppy.json +6 -0
- package/examples/package-zod-like/src/main.ts +16 -0
- package/examples/postgres-basic/README.md +31 -0
- package/examples/postgres-basic/app.js +50 -0
- package/examples/prealpha-control-plane/README.md +50 -0
- package/examples/prealpha-control-plane/appsettings.Development.json +11 -0
- package/examples/prealpha-control-plane/appsettings.json +15 -0
- package/examples/prealpha-control-plane/sloppy.json +5 -0
- package/examples/prealpha-control-plane/src/db/schema.js +7 -0
- package/examples/prealpha-control-plane/src/db/seed.js +6 -0
- package/examples/prealpha-control-plane/src/main.js +21 -0
- package/examples/prealpha-control-plane/src/routes/apps.js +34 -0
- package/examples/prealpha-control-plane/src/routes/builds.js +25 -0
- package/examples/prealpha-control-plane/src/routes/deployments.js +19 -0
- package/examples/prealpha-control-plane/src/routes/diagnostics.js +11 -0
- package/examples/prealpha-control-plane/src/routes/health.js +27 -0
- package/examples/prealpha-control-plane/src/routes/projects.js +38 -0
- package/examples/prealpha-control-plane/src/services/diagnosticsSink.js +11 -0
- package/examples/prealpha-control-plane/src/services/repositories.js +9 -0
- package/examples/prealpha-control-plane/src/validation/schemas.js +6 -0
- package/examples/program-fs-process/README.md +31 -0
- package/examples/program-fs-process/sloppy.json +9 -0
- package/examples/program-fs-process/src/main.ts +27 -0
- package/examples/program-hello/README.md +32 -0
- package/examples/program-hello/main.ts +8 -0
- package/examples/program-hello/message.ts +1 -0
- package/examples/program-hello/sloppy.json +5 -0
- package/examples/rate-limit-auth/README.md +3 -0
- package/examples/rate-limit-auth/app.js +14 -0
- package/examples/rate-limit-basic/README.md +3 -0
- package/examples/rate-limit-basic/app.js +13 -0
- package/examples/rate-limit-redis/README.md +5 -0
- package/examples/rate-limit-redis/app.js +20 -0
- package/examples/rate-limit-testhost/README.md +4 -0
- package/examples/rate-limit-testhost/app.js +13 -0
- package/examples/rate-limit-websocket/README.md +3 -0
- package/examples/rate-limit-websocket/app.js +16 -0
- package/examples/realtime-auth/README.md +8 -0
- package/examples/realtime-auth/app.js +25 -0
- package/examples/realtime-auth/test.mjs +43 -0
- package/examples/realtime-chat/README.md +8 -0
- package/examples/realtime-chat/app.js +32 -0
- package/examples/realtime-chat/test.mjs +52 -0
- package/examples/realtime-dashboard/README.md +20 -0
- package/examples/realtime-dashboard/app.js +37 -0
- package/examples/realtime-presence/README.md +8 -0
- package/examples/realtime-presence/app.js +32 -0
- package/examples/realtime-presence/test.mjs +50 -0
- package/examples/realtime-testhost/README.md +8 -0
- package/examples/realtime-testhost/test.mjs +31 -0
- package/examples/redis-basic/README.md +17 -0
- package/examples/redis-basic/app.js +39 -0
- package/examples/redis-cache/README.md +14 -0
- package/examples/redis-cache/app.js +36 -0
- package/examples/redis-locks/README.md +13 -0
- package/examples/redis-locks/app.js +49 -0
- package/examples/request-context/README.md +32 -0
- package/examples/request-context/app.js +15 -0
- package/examples/sqlite-basic/README.md +52 -0
- package/examples/sqlite-basic/app.js +56 -0
- package/examples/sqlserver-basic/README.md +36 -0
- package/examples/sqlserver-basic/app.js +59 -0
- package/examples/static-files-basic/README.md +11 -0
- package/examples/static-files-basic/app.js +12 -0
- package/examples/static-files-basic/public/app.js +1 -0
- package/examples/static-files-basic/public/site.css +3 -0
- package/examples/static-files-package/README.md +12 -0
- package/examples/static-files-package/app.js +10 -0
- package/examples/static-files-package/public/index.html +2 -0
- package/examples/static-files-precompressed/README.md +12 -0
- package/examples/static-files-precompressed/app.js +11 -0
- package/examples/static-files-precompressed/public/app.js +1 -0
- package/examples/static-files-precompressed/public/app.js.br +0 -0
- package/examples/static-files-precompressed/public/app.js.gz +0 -0
- package/examples/static-files-spa/README.md +12 -0
- package/examples/static-files-spa/app.js +16 -0
- package/examples/static-files-spa/dist/assets/app.js +1 -0
- package/examples/static-files-spa/dist/index.html +4 -0
- package/examples/static-files-testhost/README.md +8 -0
- package/examples/static-files-testhost/app.js +13 -0
- package/examples/static-files-testhost/public/app.js +1 -0
- package/examples/static-files-testhost/public/app.js.gz +0 -0
- package/examples/static-files-testhost/test.mjs +38 -0
- package/examples/testhost-basic/README.md +26 -0
- package/examples/testhost-db/README.md +31 -0
- package/examples/testservices-postgres/README.md +68 -0
- package/examples/testservices-redis/README.md +71 -0
- package/examples/testservices-sqlserver/README.md +75 -0
- package/examples/time-basic/README.md +18 -0
- package/examples/time-basic/app.js +12 -0
- package/examples/time-deadline-cancellation/README.md +11 -0
- package/examples/time-deadline-cancellation/app.js +27 -0
- package/examples/time-fake-clock/README.md +14 -0
- package/examples/time-fake-clock/app.js +25 -0
- package/examples/time-interval-schedule/README.md +13 -0
- package/examples/time-interval-schedule/app.js +60 -0
- package/examples/users-api-sqlite/README.md +74 -0
- package/examples/users-api-sqlite/app.js +11 -0
- package/examples/users-api-sqlite/appsettings.Development.json +11 -0
- package/examples/users-api-sqlite/appsettings.json +11 -0
- package/examples/users-api-sqlite/modules/users.js +40 -0
- package/examples/users-api-sqlite/sloppy.json +5 -0
- package/examples/validation-errors/README.md +36 -0
- package/examples/validation-errors/app.js +14 -0
- package/examples/validation-errors/invalid-user.http +6 -0
- package/examples/validation-errors/sloppy.json +5 -0
- package/examples/web-dynamic-routes/README.md +17 -0
- package/examples/web-dynamic-routes/app.ts +27 -0
- package/examples/webhooks-basic/README.md +11 -0
- package/examples/webhooks-basic/app.js +48 -0
- package/examples/websocket-auth/README.md +8 -0
- package/examples/websocket-auth/app.js +16 -0
- package/examples/websocket-echo/README.md +9 -0
- package/examples/websocket-echo/app.js +36 -0
- package/examples/websocket-json-schema/README.md +5 -0
- package/examples/websocket-json-schema/app.js +25 -0
- package/examples/websocket-testhost/README.md +11 -0
- package/examples/websocket-testhost/test.mjs +49 -0
- package/examples/workers-background-service/README.md +7 -0
- package/examples/workers-background-service/app.js +16 -0
- package/examples/workers-js-isolate/README.md +8 -0
- package/examples/workers-js-isolate/app.js +19 -0
- package/examples/workers-js-isolate/workers/parser.ts +11 -0
- package/examples/workers-shutdown/README.md +6 -0
- package/examples/workers-shutdown/app.js +26 -0
- package/examples/workers-workerpool/README.md +6 -0
- package/examples/workers-workerpool/app.js +23 -0
- package/examples/workers-workqueue/README.md +8 -0
- package/examples/workers-workqueue/app.js +24 -0
- package/manifest.json +59 -0
- package/package.json +31 -0
- package/stdlib/sloppy/README.md +177 -0
- package/stdlib/sloppy/app.js +2142 -0
- package/stdlib/sloppy/auth.js +1813 -0
- package/stdlib/sloppy/bootstrap.manifest.json +83 -0
- package/stdlib/sloppy/cache.js +1542 -0
- package/stdlib/sloppy/codec.js +1153 -0
- package/stdlib/sloppy/config.js +61 -0
- package/stdlib/sloppy/crypto.js +312 -0
- package/stdlib/sloppy/data.js +2945 -0
- package/stdlib/sloppy/ffi.js +185 -0
- package/stdlib/sloppy/fs.js +795 -0
- package/stdlib/sloppy/health.js +603 -0
- package/stdlib/sloppy/http.js +1595 -0
- package/stdlib/sloppy/index.js +59 -0
- package/stdlib/sloppy/internal/bytes.js +31 -0
- package/stdlib/sloppy/internal/capabilities.js +155 -0
- package/stdlib/sloppy/internal/config.js +640 -0
- package/stdlib/sloppy/internal/disposable.js +31 -0
- package/stdlib/sloppy/internal/headers.js +63 -0
- package/stdlib/sloppy/internal/intrinsics.js +2 -0
- package/stdlib/sloppy/internal/json.js +20 -0
- package/stdlib/sloppy/internal/logging.js +278 -0
- package/stdlib/sloppy/internal/modules.js +405 -0
- package/stdlib/sloppy/internal/redaction.js +87 -0
- package/stdlib/sloppy/internal/routes.js +2279 -0
- package/stdlib/sloppy/internal/runtime-classic.js +19837 -0
- package/stdlib/sloppy/internal/services.js +690 -0
- package/stdlib/sloppy/internal/shared.js +32 -0
- package/stdlib/sloppy/internal/testhost-diagnostics.js +88 -0
- package/stdlib/sloppy/internal/testhost-http-server.js +238 -0
- package/stdlib/sloppy/internal/testhost-http.js +118 -0
- package/stdlib/sloppy/internal/testhost-loopback.js +50 -0
- package/stdlib/sloppy/internal/testservices-docker.js +154 -0
- package/stdlib/sloppy/internal/validation.js +117 -0
- package/stdlib/sloppy/metrics.js +427 -0
- package/stdlib/sloppy/net.js +5208 -0
- package/stdlib/sloppy/node/assert/strict.js +39 -0
- package/stdlib/sloppy/node/assert.js +228 -0
- package/stdlib/sloppy/node/buffer.js +247 -0
- package/stdlib/sloppy/node/console.js +33 -0
- package/stdlib/sloppy/node/constants.js +9 -0
- package/stdlib/sloppy/node/crypto.js +89 -0
- package/stdlib/sloppy/node/diagnostics_channel.js +41 -0
- package/stdlib/sloppy/node/events.js +113 -0
- package/stdlib/sloppy/node/fs/promises.js +27 -0
- package/stdlib/sloppy/node/fs.js +280 -0
- package/stdlib/sloppy/node/http.js +11 -0
- package/stdlib/sloppy/node/https.js +11 -0
- package/stdlib/sloppy/node/module.js +40 -0
- package/stdlib/sloppy/node/os.js +22 -0
- package/stdlib/sloppy/node/path.js +78 -0
- package/stdlib/sloppy/node/perf_hooks.js +12 -0
- package/stdlib/sloppy/node/process.js +129 -0
- package/stdlib/sloppy/node/querystring.js +21 -0
- package/stdlib/sloppy/node/stream/promises.js +3 -0
- package/stdlib/sloppy/node/stream.js +132 -0
- package/stdlib/sloppy/node/string_decoder.js +23 -0
- package/stdlib/sloppy/node/timers.js +26 -0
- package/stdlib/sloppy/node/tty.js +18 -0
- package/stdlib/sloppy/node/url.js +17 -0
- package/stdlib/sloppy/node/util.js +95 -0
- package/stdlib/sloppy/node/zlib.js +72 -0
- package/stdlib/sloppy/orm.js +2188 -0
- package/stdlib/sloppy/os.js +580 -0
- package/stdlib/sloppy/problem-details.js +29 -0
- package/stdlib/sloppy/providers/sqlite.js +26 -0
- package/stdlib/sloppy/rate-limit.js +856 -0
- package/stdlib/sloppy/realtime.js +1508 -0
- package/stdlib/sloppy/redis.js +1272 -0
- package/stdlib/sloppy/request-id.js +184 -0
- package/stdlib/sloppy/request-logging.js +101 -0
- package/stdlib/sloppy/results.js +933 -0
- package/stdlib/sloppy/schema.js +546 -0
- package/stdlib/sloppy/testing.js +4081 -0
- package/stdlib/sloppy/testservices.js +1041 -0
- package/stdlib/sloppy/time.js +894 -0
- package/stdlib/sloppy/webhooks.js +1330 -0
- package/stdlib/sloppy/workers.js +986 -0
- package/templates/api/README.md +82 -0
- package/templates/api/appsettings.Development.json +14 -0
- package/templates/api/appsettings.json +13 -0
- package/templates/api/data/.gitkeep +1 -0
- package/templates/api/gitignore +4 -0
- package/templates/api/migrations/0001_create_users.sql +1 -0
- package/templates/api/package.json +16 -0
- package/templates/api/public/hello.txt +1 -0
- package/templates/api/sloppy.json +14 -0
- package/templates/api/src/config.ts +1 -0
- package/templates/api/src/db/migrate.ts +14 -0
- package/templates/api/src/db/schema.ts +4 -0
- package/templates/api/src/db/usersRepository.ts +23 -0
- package/templates/api/src/main.ts +18 -0
- package/templates/api/src/models/user.ts +7 -0
- package/templates/api/src/routes/health.ts +20 -0
- package/templates/api/src/routes/users.ts +40 -0
- package/templates/api/src/services/usersService.ts +21 -0
- package/templates/api/tsconfig.json +15 -0
- package/templates/cli/README.md +16 -0
- package/templates/cli/gitignore +2 -0
- package/templates/cli/package.json +13 -0
- package/templates/cli/sloppy.json +6 -0
- package/templates/cli/src/commands/echo.ts +9 -0
- package/templates/cli/src/commands/inspect.ts +20 -0
- package/templates/cli/src/main.ts +50 -0
- package/templates/cli/tsconfig.json +15 -0
- package/templates/minimal-api/README.md +14 -0
- package/templates/minimal-api/gitignore +3 -0
- package/templates/minimal-api/package.json +14 -0
- package/templates/minimal-api/sloppy.json +5 -0
- package/templates/minimal-api/src/main.ts +9 -0
- package/templates/minimal-api/tsconfig.json +15 -0
- package/templates/node-compat/README.md +40 -0
- package/templates/node-compat/gitignore +2 -0
- package/templates/node-compat/package.json +11 -0
- package/templates/node-compat/sloppy.json +6 -0
- package/templates/node-compat/src/main.ts +40 -0
- package/templates/package-api/README.md +44 -0
- package/templates/package-api/fixtures/validator-lite/index.js +7 -0
- package/templates/package-api/fixtures/validator-lite/package.json +6 -0
- package/templates/package-api/gitignore +3 -0
- package/templates/package-api/package.json +17 -0
- package/templates/package-api/sloppy.json +5 -0
- package/templates/package-api/src/main.ts +10 -0
- package/templates/package-api/src/routes/health.ts +5 -0
- package/templates/package-api/src/routes/users.ts +12 -0
- package/templates/package-api/tsconfig.json +15 -0
- package/templates/program/README.md +12 -0
- package/templates/program/gitignore +1 -0
- package/templates/program/package.json +10 -0
- package/templates/program/sloppy.json +6 -0
- package/templates/program/src/main.ts +9 -0
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { isPlainObject } from "./validation.js";
|
|
2
|
+
|
|
3
|
+
const HTTP_TOKEN_PATTERN = /^[!#$%&'*+\-.^_`|~0-9A-Za-z]+$/u;
|
|
4
|
+
|
|
5
|
+
export function isHeaderToken(value) {
|
|
6
|
+
return typeof value === "string" && HTTP_TOKEN_PATTERN.test(value);
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export function assertHeaderToken(value, subject) {
|
|
10
|
+
if (!isHeaderToken(value)) {
|
|
11
|
+
throw new TypeError(`${subject} header names must be safe HTTP tokens.`);
|
|
12
|
+
}
|
|
13
|
+
return value;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export function assertHeaderValue(value, subject) {
|
|
17
|
+
if (typeof value !== "string" || /[\x00-\x08\x0A-\x1F\x7F]/u.test(value)) {
|
|
18
|
+
throw new TypeError(`${subject} header values must be safe strings.`);
|
|
19
|
+
}
|
|
20
|
+
return value;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export function createHeaderLookup(headers = {}) {
|
|
24
|
+
const values = new Map();
|
|
25
|
+
if (typeof headers?.entries === "function") {
|
|
26
|
+
for (const [name, value] of headers.entries()) {
|
|
27
|
+
values.set(String(name).toLowerCase(), value);
|
|
28
|
+
}
|
|
29
|
+
} else if (isPlainObject(headers)) {
|
|
30
|
+
for (const [name, value] of Object.entries(headers)) {
|
|
31
|
+
values.set(name.toLowerCase(), value);
|
|
32
|
+
}
|
|
33
|
+
} else {
|
|
34
|
+
throw new TypeError("Sloppy headers must be response headers or a plain object.");
|
|
35
|
+
}
|
|
36
|
+
return Object.freeze({
|
|
37
|
+
get(name) {
|
|
38
|
+
return values.get(String(name).toLowerCase());
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function headerValue(headers, name) {
|
|
44
|
+
if (headers === undefined || headers === null) {
|
|
45
|
+
return undefined;
|
|
46
|
+
}
|
|
47
|
+
if (typeof headers.get === "function") {
|
|
48
|
+
return headers.get(name) ?? headers.get(String(name).toLowerCase()) ?? undefined;
|
|
49
|
+
}
|
|
50
|
+
return createHeaderLookup(headers).get(name);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
export function appendVaryHeader(headers, value) {
|
|
54
|
+
const current = headerValue(headers, "vary");
|
|
55
|
+
if (current === undefined || String(current).trim().length === 0) {
|
|
56
|
+
headers.Vary = value;
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
const values = current.split(",").map((part) => part.trim().toLowerCase());
|
|
60
|
+
if (!values.includes(value.toLowerCase())) {
|
|
61
|
+
headers.Vary = `${current}, ${value}`;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export function deepFreeze(value, seen = new WeakSet()) {
|
|
2
|
+
if (value === null || typeof value !== "object" || Object.isFrozen(value)) {
|
|
3
|
+
return value;
|
|
4
|
+
}
|
|
5
|
+
if (seen.has(value)) {
|
|
6
|
+
return value;
|
|
7
|
+
}
|
|
8
|
+
seen.add(value);
|
|
9
|
+
for (const child of Object.values(value)) {
|
|
10
|
+
deepFreeze(child, seen);
|
|
11
|
+
}
|
|
12
|
+
return Object.freeze(value);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function snapshotJson(value) {
|
|
16
|
+
if (value === undefined) {
|
|
17
|
+
return undefined;
|
|
18
|
+
}
|
|
19
|
+
return deepFreeze(JSON.parse(JSON.stringify(value)));
|
|
20
|
+
}
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import { isPlainObject } from "./shared.js";
|
|
2
|
+
|
|
3
|
+
const LOG_LEVEL_RANK = Object.freeze({
|
|
4
|
+
trace: 0,
|
|
5
|
+
debug: 1,
|
|
6
|
+
info: 2,
|
|
7
|
+
warn: 3,
|
|
8
|
+
error: 4,
|
|
9
|
+
off: 5,
|
|
10
|
+
});
|
|
11
|
+
const MEMORY_SINK_STATE = new WeakMap();
|
|
12
|
+
const DEFAULT_REDACTION_KEYS = Object.freeze([
|
|
13
|
+
"password",
|
|
14
|
+
"passwd",
|
|
15
|
+
"pwd",
|
|
16
|
+
"secret",
|
|
17
|
+
"token",
|
|
18
|
+
"authorization",
|
|
19
|
+
"cookie",
|
|
20
|
+
"set-cookie",
|
|
21
|
+
"apiKey",
|
|
22
|
+
"clientSecret",
|
|
23
|
+
"privateKey",
|
|
24
|
+
"passphrase",
|
|
25
|
+
"connectionString",
|
|
26
|
+
]);
|
|
27
|
+
|
|
28
|
+
function validateLogLevel(level, options = {}) {
|
|
29
|
+
if (!Object.prototype.hasOwnProperty.call(LOG_LEVEL_RANK, level)) {
|
|
30
|
+
throw new TypeError("Sloppy log level must be one of trace, debug, info, warn, error, or off.");
|
|
31
|
+
}
|
|
32
|
+
if (level === "off" && options.allowOff !== true) {
|
|
33
|
+
throw new TypeError("Sloppy log write level must be one of trace, debug, info, warn, or error.");
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function normalizeRedactionKey(key) {
|
|
38
|
+
return String(key).toLowerCase().replace(/[_\-.:]/g, "");
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function isSensitiveKey(key, extraKeys) {
|
|
42
|
+
const normalized = normalizeRedactionKey(key);
|
|
43
|
+
|
|
44
|
+
for (const candidate of DEFAULT_REDACTION_KEYS) {
|
|
45
|
+
const normalizedCandidate = normalizeRedactionKey(candidate);
|
|
46
|
+
if (normalized === normalizedCandidate || normalized.endsWith(normalizedCandidate)) {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return extraKeys.has(normalized);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
function validateSinkFormat(format, allowed, subject) {
|
|
54
|
+
if (!allowed.includes(format)) {
|
|
55
|
+
throw new TypeError(`Sloppy ${subject} logging format is not supported.`);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
function validateCapacity(capacity, subject) {
|
|
60
|
+
if (!Number.isInteger(capacity) || capacity <= 0) {
|
|
61
|
+
throw new TypeError(`Sloppy ${subject} capacity must be a positive integer.`);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function copyLogFields(fields, redactionKeys) {
|
|
66
|
+
if (fields === undefined || fields === null) {
|
|
67
|
+
return undefined;
|
|
68
|
+
}
|
|
69
|
+
if (!isPlainObject(fields)) {
|
|
70
|
+
throw new TypeError("Sloppy log fields must be a shallow plain object.");
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const entries = Object.entries(fields);
|
|
74
|
+
if (entries.length > 8) {
|
|
75
|
+
throw new TypeError("Sloppy log fields support at most 8 fields per event.");
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const copied = {};
|
|
79
|
+
for (const [key, value] of entries) {
|
|
80
|
+
if (key.length === 0 || key.includes("\0")) {
|
|
81
|
+
throw new TypeError("Sloppy log field keys must be non-empty strings without NUL.");
|
|
82
|
+
}
|
|
83
|
+
if (isSensitiveKey(key, redactionKeys)) {
|
|
84
|
+
copied[key] = "[REDACTED]";
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
if (
|
|
88
|
+
value === null ||
|
|
89
|
+
typeof value === "string" ||
|
|
90
|
+
typeof value === "boolean" ||
|
|
91
|
+
(typeof value === "number" && Number.isFinite(value))
|
|
92
|
+
) {
|
|
93
|
+
copied[key] = value;
|
|
94
|
+
continue;
|
|
95
|
+
}
|
|
96
|
+
throw new TypeError(
|
|
97
|
+
"Sloppy log fields support null, boolean, finite number, and string values.",
|
|
98
|
+
);
|
|
99
|
+
}
|
|
100
|
+
return Object.freeze(copied);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
function snapshotLogEntry(entry) {
|
|
104
|
+
const snapshot = {
|
|
105
|
+
level: entry.level,
|
|
106
|
+
message: entry.message,
|
|
107
|
+
fields: entry.fields,
|
|
108
|
+
};
|
|
109
|
+
if (entry.category !== "app") {
|
|
110
|
+
snapshot.category = entry.category;
|
|
111
|
+
}
|
|
112
|
+
return Object.freeze(snapshot);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
function createLoggingBuilder(guard) {
|
|
116
|
+
const memorySinks = [];
|
|
117
|
+
const consoleSinks = [];
|
|
118
|
+
const fileSinks = [];
|
|
119
|
+
const redactionKeys = new Set(DEFAULT_REDACTION_KEYS.map(normalizeRedactionKey));
|
|
120
|
+
let minimumLevel = "info";
|
|
121
|
+
let queueCapacity = 16;
|
|
122
|
+
|
|
123
|
+
const logging = {
|
|
124
|
+
setMinimumLevel(level) {
|
|
125
|
+
guard.assertMutable();
|
|
126
|
+
validateLogLevel(level, { allowOff: true });
|
|
127
|
+
minimumLevel = level;
|
|
128
|
+
return logging;
|
|
129
|
+
},
|
|
130
|
+
|
|
131
|
+
setQueueCapacity(capacity) {
|
|
132
|
+
guard.assertMutable();
|
|
133
|
+
validateCapacity(capacity, "queue");
|
|
134
|
+
queueCapacity = capacity;
|
|
135
|
+
return logging;
|
|
136
|
+
},
|
|
137
|
+
|
|
138
|
+
addRedactionKey(key) {
|
|
139
|
+
guard.assertMutable();
|
|
140
|
+
if (typeof key !== "string" || key.length === 0 || key.includes("\0")) {
|
|
141
|
+
throw new TypeError("Sloppy log redaction key must be a non-empty string without NUL.");
|
|
142
|
+
}
|
|
143
|
+
redactionKeys.add(normalizeRedactionKey(key));
|
|
144
|
+
return logging;
|
|
145
|
+
},
|
|
146
|
+
|
|
147
|
+
addMemorySink(options = undefined) {
|
|
148
|
+
guard.assertMutable();
|
|
149
|
+
if (options !== undefined && !isPlainObject(options)) {
|
|
150
|
+
throw new TypeError("Sloppy memory log sink options must be a plain object.");
|
|
151
|
+
}
|
|
152
|
+
const capacity = options?.capacity ?? 32;
|
|
153
|
+
validateCapacity(capacity, "memory sink");
|
|
154
|
+
|
|
155
|
+
const state = {
|
|
156
|
+
entries: [],
|
|
157
|
+
capacity,
|
|
158
|
+
overwritten: 0,
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
const sink = Object.freeze({
|
|
162
|
+
entries() {
|
|
163
|
+
return Object.freeze(state.entries.map(snapshotLogEntry));
|
|
164
|
+
},
|
|
165
|
+
overwritten() {
|
|
166
|
+
return state.overwritten;
|
|
167
|
+
},
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
MEMORY_SINK_STATE.set(sink, state);
|
|
171
|
+
memorySinks.push(sink);
|
|
172
|
+
return sink;
|
|
173
|
+
},
|
|
174
|
+
|
|
175
|
+
writeTo: Object.freeze({
|
|
176
|
+
console(options = undefined) {
|
|
177
|
+
guard.assertMutable();
|
|
178
|
+
if (options !== undefined && !isPlainObject(options)) {
|
|
179
|
+
throw new TypeError("Sloppy console log sink options must be a plain object.");
|
|
180
|
+
}
|
|
181
|
+
const format = options?.format ?? "pretty";
|
|
182
|
+
validateSinkFormat(format, ["pretty", "jsonl"], "console");
|
|
183
|
+
consoleSinks.push(Object.freeze({ kind: "console", format }));
|
|
184
|
+
return logging;
|
|
185
|
+
},
|
|
186
|
+
|
|
187
|
+
file(options) {
|
|
188
|
+
guard.assertMutable();
|
|
189
|
+
if (!isPlainObject(options)) {
|
|
190
|
+
throw new TypeError("Sloppy file log sink options must be a plain object.");
|
|
191
|
+
}
|
|
192
|
+
if (typeof options.path !== "string" || options.path.length === 0 || options.path.includes("\0")) {
|
|
193
|
+
throw new TypeError("Sloppy file log sink path must be a non-empty string without NUL.");
|
|
194
|
+
}
|
|
195
|
+
const format = options.format ?? "jsonl";
|
|
196
|
+
validateSinkFormat(format, ["jsonl"], "file");
|
|
197
|
+
fileSinks.push(Object.freeze({ kind: "file", path: options.path, format }));
|
|
198
|
+
return logging;
|
|
199
|
+
},
|
|
200
|
+
}),
|
|
201
|
+
|
|
202
|
+
__snapshot() {
|
|
203
|
+
return Object.freeze({
|
|
204
|
+
minimumLevel,
|
|
205
|
+
queueCapacity,
|
|
206
|
+
memorySinks: Object.freeze([...memorySinks]),
|
|
207
|
+
consoleSinks: Object.freeze([...consoleSinks]),
|
|
208
|
+
fileSinks: Object.freeze([...fileSinks]),
|
|
209
|
+
redactionKeys: new Set(redactionKeys),
|
|
210
|
+
});
|
|
211
|
+
},
|
|
212
|
+
};
|
|
213
|
+
|
|
214
|
+
return Object.freeze(logging);
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
function createLogger(snapshot) {
|
|
218
|
+
function createCategoryLogger(category) {
|
|
219
|
+
function isEnabled(level) {
|
|
220
|
+
validateLogLevel(level, { allowOff: true });
|
|
221
|
+
return level !== "off" && LOG_LEVEL_RANK[level] >= LOG_LEVEL_RANK[snapshot.minimumLevel];
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
function write(level, message, fields) {
|
|
225
|
+
validateLogLevel(level);
|
|
226
|
+
|
|
227
|
+
if (!isEnabled(level)) {
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
const snapshotFields = copyLogFields(fields, snapshot.redactionKeys);
|
|
232
|
+
const entry = Object.freeze({
|
|
233
|
+
level,
|
|
234
|
+
category,
|
|
235
|
+
message: String(message),
|
|
236
|
+
fields: snapshotFields,
|
|
237
|
+
});
|
|
238
|
+
|
|
239
|
+
for (const sink of snapshot.memorySinks) {
|
|
240
|
+
const state = MEMORY_SINK_STATE.get(sink);
|
|
241
|
+
if (state.entries.length >= state.capacity) {
|
|
242
|
+
state.entries.shift();
|
|
243
|
+
state.overwritten += 1;
|
|
244
|
+
}
|
|
245
|
+
state.entries.push(entry);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
return Object.freeze({
|
|
250
|
+
isEnabled,
|
|
251
|
+
forCategory(nextCategory) {
|
|
252
|
+
if (typeof nextCategory !== "string" || nextCategory.length === 0 || nextCategory.includes("\0")) {
|
|
253
|
+
throw new TypeError("Sloppy log category must be a non-empty string without NUL.");
|
|
254
|
+
}
|
|
255
|
+
return createCategoryLogger(nextCategory);
|
|
256
|
+
},
|
|
257
|
+
trace(message, fields) {
|
|
258
|
+
write("trace", message, fields);
|
|
259
|
+
},
|
|
260
|
+
debug(message, fields) {
|
|
261
|
+
write("debug", message, fields);
|
|
262
|
+
},
|
|
263
|
+
info(message, fields) {
|
|
264
|
+
write("info", message, fields);
|
|
265
|
+
},
|
|
266
|
+
warn(message, fields) {
|
|
267
|
+
write("warn", message, fields);
|
|
268
|
+
},
|
|
269
|
+
error(message, fields) {
|
|
270
|
+
write("error", message, fields);
|
|
271
|
+
},
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
return createCategoryLogger("app");
|
|
276
|
+
}
|
|
277
|
+
|
|
278
|
+
export { createLogger, createLoggingBuilder };
|