create-fluxstack 1.0.2 → 1.0.4
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/.claude/settings.local.json +65 -0
- package/.dockerignore +50 -0
- package/.env.example +53 -0
- package/.gitattributes +2 -0
- package/.github/workflows/ci-build-tests.yml +480 -0
- package/.github/workflows/dependency-management.yml +324 -0
- package/.github/workflows/release-validation.yml +355 -0
- package/.kiro/specs/fluxstack-architecture-optimization/design.md +700 -0
- package/.kiro/specs/fluxstack-architecture-optimization/requirements.md +127 -0
- package/.kiro/specs/fluxstack-architecture-optimization/tasks.md +330 -0
- package/CLAUDE.md +200 -0
- package/Dockerfile +58 -0
- package/Dockerfile.backend +52 -0
- package/Dockerfile.frontend +54 -0
- package/ENV_TESTING_REPORT.md +292 -0
- package/FRAMEWORK_ROADMAP.md +183 -0
- package/FRONTEND_TESTS_README.md +287 -0
- package/LICENSE +21 -0
- package/README-Docker.md +85 -0
- package/TEST_RESULTS.md +130 -0
- package/ai-context/00-QUICK-START.md +86 -0
- package/ai-context/README.md +88 -0
- package/ai-context/development/eden-treaty-guide.md +362 -0
- package/ai-context/development/patterns.md +382 -0
- package/ai-context/examples/crud-complete.md +626 -0
- package/ai-context/project/architecture.md +399 -0
- package/ai-context/project/overview.md +213 -0
- package/ai-context/recent-changes/eden-treaty-refactor.md +281 -0
- package/ai-context/recent-changes/type-inference-fix.md +223 -0
- package/ai-context/reference/environment-vars.md +384 -0
- package/ai-context/reference/troubleshooting.md +407 -0
- package/app/client/README.md +69 -0
- package/app/client/frontend-only.ts +12 -0
- package/app/client/index.html +13 -0
- package/app/client/public/vite.svg +1 -0
- package/app/client/src/App.css +883 -0
- package/app/client/src/App.tsx +669 -0
- package/app/client/src/assets/react.svg +1 -0
- package/app/client/src/components/TestPage.tsx +453 -0
- package/app/client/src/index.css +51 -0
- package/app/client/src/lib/eden-api.ts +110 -0
- package/app/client/src/main.tsx +10 -0
- package/app/client/src/vite-env.d.ts +1 -0
- package/app/client/tsconfig.app.json +43 -0
- package/app/client/tsconfig.json +7 -0
- package/app/client/tsconfig.node.json +25 -0
- package/app/server/app.ts +10 -0
- package/app/server/backend-only.ts +15 -0
- package/app/server/controllers/users.controller.ts +69 -0
- package/app/server/index.ts +104 -0
- package/app/server/routes/index.ts +25 -0
- package/app/server/routes/users.routes.ts +121 -0
- package/app/server/types/index.ts +1 -0
- package/app/shared/types/index.ts +18 -0
- package/bun.lock +1063 -0
- package/bunfig.toml +16 -0
- package/config/fluxstack.config.ts +48 -0
- package/core/__tests__/integration.test.ts +227 -0
- package/core/build/index.ts +186 -0
- package/core/cli/command-registry.ts +334 -0
- package/core/cli/index.ts +394 -0
- package/core/cli/plugin-discovery.ts +200 -0
- package/core/client/standalone.ts +57 -0
- package/core/config/__tests__/config-loader.test.ts +591 -0
- package/core/config/__tests__/config-merger.test.ts +657 -0
- package/core/config/__tests__/env-converter.test.ts +372 -0
- package/core/config/__tests__/env-processor.test.ts +431 -0
- package/core/config/__tests__/env.test.ts +452 -0
- package/core/config/__tests__/integration.test.ts +418 -0
- package/core/config/__tests__/loader.test.ts +331 -0
- package/core/config/__tests__/schema.test.ts +129 -0
- package/core/config/__tests__/validator.test.ts +318 -0
- package/core/config/env-dynamic.ts +326 -0
- package/core/config/env.ts +597 -0
- package/core/config/index.ts +317 -0
- package/core/config/loader.ts +546 -0
- package/core/config/runtime-config.ts +322 -0
- package/core/config/schema.ts +694 -0
- package/core/config/validator.ts +540 -0
- package/core/framework/__tests__/server.test.ts +233 -0
- package/core/framework/client.ts +132 -0
- package/core/framework/index.ts +8 -0
- package/core/framework/server.ts +501 -0
- package/core/framework/types.ts +63 -0
- package/core/plugins/__tests__/built-in.test.ts.disabled +366 -0
- package/core/plugins/__tests__/manager.test.ts +398 -0
- package/core/plugins/__tests__/monitoring.test.ts +401 -0
- package/core/plugins/__tests__/registry.test.ts +335 -0
- package/core/plugins/built-in/index.ts +142 -0
- package/core/plugins/built-in/logger/index.ts +180 -0
- package/core/plugins/built-in/monitoring/README.md +193 -0
- package/core/plugins/built-in/monitoring/index.ts +912 -0
- package/core/plugins/built-in/static/index.ts +289 -0
- package/core/plugins/built-in/swagger/index.ts +229 -0
- package/core/plugins/built-in/vite/index.ts +316 -0
- package/core/plugins/config.ts +348 -0
- package/core/plugins/discovery.ts +350 -0
- package/core/plugins/executor.ts +351 -0
- package/core/plugins/index.ts +195 -0
- package/core/plugins/manager.ts +583 -0
- package/core/plugins/registry.ts +424 -0
- package/core/plugins/types.ts +254 -0
- package/core/server/framework.ts +123 -0
- package/core/server/index.ts +8 -0
- package/core/server/plugins/database.ts +182 -0
- package/core/server/plugins/logger.ts +47 -0
- package/core/server/plugins/swagger.ts +34 -0
- package/core/server/standalone.ts +91 -0
- package/core/templates/create-project.ts +455 -0
- package/core/types/api.ts +169 -0
- package/core/types/build.ts +174 -0
- package/core/types/config.ts +68 -0
- package/core/types/index.ts +127 -0
- package/core/types/plugin.ts +94 -0
- package/core/utils/__tests__/errors.test.ts +139 -0
- package/core/utils/__tests__/helpers.test.ts +297 -0
- package/core/utils/__tests__/logger.test.ts +141 -0
- package/core/utils/env-runtime-v2.ts +232 -0
- package/core/utils/env-runtime.ts +252 -0
- package/core/utils/errors/codes.ts +115 -0
- package/core/utils/errors/handlers.ts +63 -0
- package/core/utils/errors/index.ts +81 -0
- package/core/utils/helpers.ts +180 -0
- package/core/utils/index.ts +18 -0
- package/core/utils/logger/index.ts +161 -0
- package/core/utils/logger.ts +106 -0
- package/core/utils/monitoring/index.ts +212 -0
- package/create-fluxstack.ts +1 -1
- package/create-test-app.ts +156 -0
- package/docker-compose.microservices.yml +75 -0
- package/docker-compose.simple.yml +57 -0
- package/docker-compose.yml +71 -0
- package/docs/dynamic-environment-variables.md +380 -0
- package/eslint.config.js +23 -0
- package/examples/dynamic-env-usage.ts +283 -0
- package/examples/hybrid-env-strategy.ts +212 -0
- package/examples/simplified-env-usage.ts +251 -0
- package/flux-cli.ts +214 -0
- package/fluxstack.config.ts +318 -0
- package/meu-app-teste/README.md +44 -0
- package/meu-app-teste/app/client/README.md +69 -0
- package/meu-app-teste/app/client/frontend-only.ts +12 -0
- package/meu-app-teste/app/client/index.html +13 -0
- package/meu-app-teste/app/client/public/vite.svg +1 -0
- package/meu-app-teste/app/client/src/App.css +883 -0
- package/meu-app-teste/app/client/src/App.tsx +669 -0
- package/meu-app-teste/app/client/src/assets/react.svg +1 -0
- package/meu-app-teste/app/client/src/components/TestPage.tsx +453 -0
- package/meu-app-teste/app/client/src/index.css +51 -0
- package/meu-app-teste/app/client/src/lib/eden-api.ts +110 -0
- package/meu-app-teste/app/client/src/main.tsx +10 -0
- package/meu-app-teste/app/client/src/vite-env.d.ts +1 -0
- package/meu-app-teste/app/client/tsconfig.app.json +43 -0
- package/meu-app-teste/app/client/tsconfig.json +7 -0
- package/meu-app-teste/app/client/tsconfig.node.json +25 -0
- package/meu-app-teste/app/server/app.ts +10 -0
- package/meu-app-teste/app/server/backend-only.ts +15 -0
- package/meu-app-teste/app/server/controllers/users.controller.ts +69 -0
- package/meu-app-teste/app/server/index.ts +104 -0
- package/meu-app-teste/app/server/routes/index.ts +25 -0
- package/meu-app-teste/app/server/routes/users.routes.ts +121 -0
- package/meu-app-teste/app/server/types/index.ts +1 -0
- package/meu-app-teste/app/shared/types/index.ts +18 -0
- package/meu-app-teste/bun.lock +1053 -0
- package/meu-app-teste/core/__tests__/integration.test.ts +227 -0
- package/meu-app-teste/core/build/index.ts +186 -0
- package/meu-app-teste/core/cli/command-registry.ts +334 -0
- package/meu-app-teste/core/cli/index.ts +394 -0
- package/meu-app-teste/core/cli/plugin-discovery.ts +200 -0
- package/meu-app-teste/core/client/standalone.ts +57 -0
- package/meu-app-teste/core/config/__tests__/config-loader.test.ts +591 -0
- package/meu-app-teste/core/config/__tests__/config-merger.test.ts +657 -0
- package/meu-app-teste/core/config/__tests__/env-converter.test.ts +372 -0
- package/meu-app-teste/core/config/__tests__/env-processor.test.ts +431 -0
- package/meu-app-teste/core/config/__tests__/env.test.ts +452 -0
- package/meu-app-teste/core/config/__tests__/integration.test.ts +418 -0
- package/meu-app-teste/core/config/__tests__/loader.test.ts +331 -0
- package/meu-app-teste/core/config/__tests__/schema.test.ts +129 -0
- package/meu-app-teste/core/config/__tests__/validator.test.ts +318 -0
- package/meu-app-teste/core/config/env-dynamic.ts +326 -0
- package/meu-app-teste/core/config/env.ts +597 -0
- package/meu-app-teste/core/config/index.ts +317 -0
- package/meu-app-teste/core/config/loader.ts +546 -0
- package/meu-app-teste/core/config/runtime-config.ts +322 -0
- package/meu-app-teste/core/config/schema.ts +694 -0
- package/meu-app-teste/core/config/validator.ts +540 -0
- package/meu-app-teste/core/framework/__tests__/server.test.ts +233 -0
- package/meu-app-teste/core/framework/client.ts +132 -0
- package/meu-app-teste/core/framework/index.ts +8 -0
- package/meu-app-teste/core/framework/server.ts +501 -0
- package/meu-app-teste/core/framework/types.ts +63 -0
- package/meu-app-teste/core/plugins/__tests__/built-in.test.ts.disabled +366 -0
- package/meu-app-teste/core/plugins/__tests__/manager.test.ts +398 -0
- package/meu-app-teste/core/plugins/__tests__/monitoring.test.ts +401 -0
- package/meu-app-teste/core/plugins/__tests__/registry.test.ts +335 -0
- package/meu-app-teste/core/plugins/built-in/index.ts +142 -0
- package/meu-app-teste/core/plugins/built-in/logger/index.ts +180 -0
- package/meu-app-teste/core/plugins/built-in/monitoring/README.md +193 -0
- package/meu-app-teste/core/plugins/built-in/monitoring/index.ts +912 -0
- package/meu-app-teste/core/plugins/built-in/static/index.ts +289 -0
- package/meu-app-teste/core/plugins/built-in/swagger/index.ts +229 -0
- package/meu-app-teste/core/plugins/built-in/vite/index.ts +316 -0
- package/meu-app-teste/core/plugins/config.ts +348 -0
- package/meu-app-teste/core/plugins/discovery.ts +350 -0
- package/meu-app-teste/core/plugins/executor.ts +351 -0
- package/meu-app-teste/core/plugins/index.ts +195 -0
- package/meu-app-teste/core/plugins/manager.ts +583 -0
- package/meu-app-teste/core/plugins/registry.ts +424 -0
- package/meu-app-teste/core/plugins/types.ts +254 -0
- package/meu-app-teste/core/server/framework.ts +123 -0
- package/meu-app-teste/core/server/index.ts +8 -0
- package/meu-app-teste/core/server/plugins/database.ts +182 -0
- package/meu-app-teste/core/server/plugins/logger.ts +47 -0
- package/meu-app-teste/core/server/plugins/swagger.ts +34 -0
- package/meu-app-teste/core/server/standalone.ts +91 -0
- package/meu-app-teste/core/templates/create-project.ts +455 -0
- package/meu-app-teste/core/types/api.ts +169 -0
- package/meu-app-teste/core/types/build.ts +174 -0
- package/meu-app-teste/core/types/config.ts +68 -0
- package/meu-app-teste/core/types/index.ts +127 -0
- package/meu-app-teste/core/types/plugin.ts +94 -0
- package/meu-app-teste/core/utils/__tests__/errors.test.ts +139 -0
- package/meu-app-teste/core/utils/__tests__/helpers.test.ts +297 -0
- package/meu-app-teste/core/utils/__tests__/logger.test.ts +141 -0
- package/meu-app-teste/core/utils/env-runtime-v2.ts +232 -0
- package/meu-app-teste/core/utils/env-runtime.ts +252 -0
- package/meu-app-teste/core/utils/errors/codes.ts +115 -0
- package/meu-app-teste/core/utils/errors/handlers.ts +63 -0
- package/meu-app-teste/core/utils/errors/index.ts +81 -0
- package/meu-app-teste/core/utils/helpers.ts +180 -0
- package/meu-app-teste/core/utils/index.ts +18 -0
- package/meu-app-teste/core/utils/logger/index.ts +161 -0
- package/meu-app-teste/core/utils/logger.ts +106 -0
- package/meu-app-teste/core/utils/monitoring/index.ts +212 -0
- package/meu-app-teste/package.json +92 -0
- package/meu-app-teste/tsconfig.json +51 -0
- package/meu-app-teste/vite.config.ts +42 -0
- package/my-final-test/README.md +44 -0
- package/my-final-test/app/client/README.md +69 -0
- package/my-final-test/app/client/frontend-only.ts +12 -0
- package/my-final-test/app/client/index.html +13 -0
- package/my-final-test/app/client/public/vite.svg +1 -0
- package/my-final-test/app/client/src/App.css +883 -0
- package/my-final-test/app/client/src/App.tsx +669 -0
- package/my-final-test/app/client/src/assets/react.svg +1 -0
- package/my-final-test/app/client/src/components/TestPage.tsx +453 -0
- package/my-final-test/app/client/src/index.css +51 -0
- package/my-final-test/app/client/src/lib/eden-api.ts +110 -0
- package/my-final-test/app/client/src/main.tsx +10 -0
- package/my-final-test/app/client/src/vite-env.d.ts +1 -0
- package/my-final-test/app/client/tsconfig.app.json +43 -0
- package/my-final-test/app/client/tsconfig.json +7 -0
- package/my-final-test/app/client/tsconfig.node.json +25 -0
- package/my-final-test/app/server/app.ts +10 -0
- package/my-final-test/app/server/backend-only.ts +15 -0
- package/my-final-test/app/server/controllers/users.controller.ts +69 -0
- package/my-final-test/app/server/index.ts +104 -0
- package/my-final-test/app/server/routes/index.ts +25 -0
- package/my-final-test/app/server/routes/users.routes.ts +121 -0
- package/my-final-test/app/server/types/index.ts +1 -0
- package/my-final-test/app/shared/types/index.ts +18 -0
- package/my-final-test/bun.lock +993 -0
- package/my-final-test/core/__tests__/integration.test.ts +227 -0
- package/my-final-test/core/build/index.ts +186 -0
- package/my-final-test/core/cli/command-registry.ts +334 -0
- package/my-final-test/core/cli/index.ts +394 -0
- package/my-final-test/core/cli/plugin-discovery.ts +200 -0
- package/my-final-test/core/client/standalone.ts +57 -0
- package/my-final-test/core/config/__tests__/config-loader.test.ts +591 -0
- package/my-final-test/core/config/__tests__/config-merger.test.ts +657 -0
- package/my-final-test/core/config/__tests__/env-converter.test.ts +372 -0
- package/my-final-test/core/config/__tests__/env-processor.test.ts +431 -0
- package/my-final-test/core/config/__tests__/env.test.ts +452 -0
- package/my-final-test/core/config/__tests__/integration.test.ts +418 -0
- package/my-final-test/core/config/__tests__/loader.test.ts +331 -0
- package/my-final-test/core/config/__tests__/schema.test.ts +129 -0
- package/my-final-test/core/config/__tests__/validator.test.ts +318 -0
- package/my-final-test/core/config/env-dynamic.ts +326 -0
- package/my-final-test/core/config/env.ts +597 -0
- package/my-final-test/core/config/index.ts +317 -0
- package/my-final-test/core/config/loader.ts +546 -0
- package/my-final-test/core/config/runtime-config.ts +322 -0
- package/my-final-test/core/config/schema.ts +694 -0
- package/my-final-test/core/config/validator.ts +540 -0
- package/my-final-test/core/framework/__tests__/server.test.ts +233 -0
- package/my-final-test/core/framework/client.ts +132 -0
- package/my-final-test/core/framework/index.ts +8 -0
- package/my-final-test/core/framework/server.ts +501 -0
- package/my-final-test/core/framework/types.ts +63 -0
- package/my-final-test/core/plugins/__tests__/built-in.test.ts.disabled +366 -0
- package/my-final-test/core/plugins/__tests__/manager.test.ts +398 -0
- package/my-final-test/core/plugins/__tests__/monitoring.test.ts +401 -0
- package/my-final-test/core/plugins/__tests__/registry.test.ts +335 -0
- package/my-final-test/core/plugins/built-in/index.ts +142 -0
- package/my-final-test/core/plugins/built-in/logger/index.ts +180 -0
- package/my-final-test/core/plugins/built-in/monitoring/README.md +193 -0
- package/my-final-test/core/plugins/built-in/monitoring/index.ts +912 -0
- package/my-final-test/core/plugins/built-in/static/index.ts +289 -0
- package/my-final-test/core/plugins/built-in/swagger/index.ts +229 -0
- package/my-final-test/core/plugins/built-in/vite/index.ts +316 -0
- package/my-final-test/core/plugins/config.ts +348 -0
- package/my-final-test/core/plugins/discovery.ts +350 -0
- package/my-final-test/core/plugins/executor.ts +351 -0
- package/my-final-test/core/plugins/index.ts +195 -0
- package/my-final-test/core/plugins/manager.ts +583 -0
- package/my-final-test/core/plugins/registry.ts +424 -0
- package/my-final-test/core/plugins/types.ts +254 -0
- package/my-final-test/core/server/framework.ts +123 -0
- package/my-final-test/core/server/index.ts +8 -0
- package/my-final-test/core/server/plugins/database.ts +182 -0
- package/my-final-test/core/server/plugins/logger.ts +47 -0
- package/my-final-test/core/server/plugins/swagger.ts +34 -0
- package/my-final-test/core/server/standalone.ts +91 -0
- package/my-final-test/core/templates/create-project.ts +455 -0
- package/my-final-test/core/types/api.ts +169 -0
- package/my-final-test/core/types/build.ts +174 -0
- package/my-final-test/core/types/config.ts +68 -0
- package/my-final-test/core/types/index.ts +127 -0
- package/my-final-test/core/types/plugin.ts +94 -0
- package/my-final-test/core/utils/__tests__/errors.test.ts +139 -0
- package/my-final-test/core/utils/__tests__/helpers.test.ts +297 -0
- package/my-final-test/core/utils/__tests__/logger.test.ts +141 -0
- package/my-final-test/core/utils/env-runtime-v2.ts +232 -0
- package/my-final-test/core/utils/env-runtime.ts +252 -0
- package/my-final-test/core/utils/errors/codes.ts +115 -0
- package/my-final-test/core/utils/errors/handlers.ts +63 -0
- package/my-final-test/core/utils/errors/index.ts +81 -0
- package/my-final-test/core/utils/helpers.ts +180 -0
- package/my-final-test/core/utils/index.ts +18 -0
- package/my-final-test/core/utils/logger/index.ts +161 -0
- package/my-final-test/core/utils/logger.ts +106 -0
- package/my-final-test/core/utils/monitoring/index.ts +212 -0
- package/my-final-test/package.json +68 -0
- package/my-final-test/tsconfig.json +51 -0
- package/my-final-test/vite.config.ts +42 -0
- package/nginx-lb.conf +37 -0
- package/package-template.json +32 -15
- package/package.json +71 -30
- package/publish-setup.md +111 -0
- package/publish.sh +63 -0
- package/run-clean.ts +26 -0
- package/run-env-tests.ts +313 -0
- package/tailwind.config.js +34 -0
- package/teste-corrigido/README.md +44 -0
- package/teste-corrigido/app/client/README.md +69 -0
- package/teste-corrigido/app/client/frontend-only.ts +12 -0
- package/teste-corrigido/app/client/index.html +13 -0
- package/teste-corrigido/app/client/public/vite.svg +1 -0
- package/teste-corrigido/app/client/src/App.css +883 -0
- package/teste-corrigido/app/client/src/App.tsx +669 -0
- package/teste-corrigido/app/client/src/assets/react.svg +1 -0
- package/teste-corrigido/app/client/src/components/TestPage.tsx +453 -0
- package/teste-corrigido/app/client/src/index.css +51 -0
- package/teste-corrigido/app/client/src/lib/eden-api.ts +110 -0
- package/teste-corrigido/app/client/src/main.tsx +10 -0
- package/teste-corrigido/app/client/src/vite-env.d.ts +1 -0
- package/teste-corrigido/app/client/tsconfig.app.json +43 -0
- package/teste-corrigido/app/client/tsconfig.json +7 -0
- package/teste-corrigido/app/client/tsconfig.node.json +25 -0
- package/teste-corrigido/app/server/app.ts +10 -0
- package/teste-corrigido/app/server/backend-only.ts +15 -0
- package/teste-corrigido/app/server/controllers/users.controller.ts +69 -0
- package/teste-corrigido/app/server/index.ts +104 -0
- package/teste-corrigido/app/server/routes/index.ts +25 -0
- package/teste-corrigido/app/server/routes/users.routes.ts +121 -0
- package/teste-corrigido/app/server/types/index.ts +1 -0
- package/teste-corrigido/app/shared/types/index.ts +18 -0
- package/teste-corrigido/bun.lock +1053 -0
- package/teste-corrigido/core/__tests__/integration.test.ts +227 -0
- package/teste-corrigido/core/build/index.ts +186 -0
- package/teste-corrigido/core/cli/command-registry.ts +334 -0
- package/teste-corrigido/core/cli/index.ts +394 -0
- package/teste-corrigido/core/cli/plugin-discovery.ts +200 -0
- package/teste-corrigido/core/client/standalone.ts +57 -0
- package/teste-corrigido/core/config/__tests__/config-loader.test.ts +591 -0
- package/teste-corrigido/core/config/__tests__/config-merger.test.ts +657 -0
- package/teste-corrigido/core/config/__tests__/env-converter.test.ts +372 -0
- package/teste-corrigido/core/config/__tests__/env-processor.test.ts +431 -0
- package/teste-corrigido/core/config/__tests__/env.test.ts +452 -0
- package/teste-corrigido/core/config/__tests__/integration.test.ts +418 -0
- package/teste-corrigido/core/config/__tests__/loader.test.ts +331 -0
- package/teste-corrigido/core/config/__tests__/schema.test.ts +129 -0
- package/teste-corrigido/core/config/__tests__/validator.test.ts +318 -0
- package/teste-corrigido/core/config/env-dynamic.ts +326 -0
- package/teste-corrigido/core/config/env.ts +597 -0
- package/teste-corrigido/core/config/index.ts +317 -0
- package/teste-corrigido/core/config/loader.ts +546 -0
- package/teste-corrigido/core/config/runtime-config.ts +322 -0
- package/teste-corrigido/core/config/schema.ts +694 -0
- package/teste-corrigido/core/config/validator.ts +540 -0
- package/teste-corrigido/core/framework/__tests__/server.test.ts +233 -0
- package/teste-corrigido/core/framework/client.ts +132 -0
- package/teste-corrigido/core/framework/index.ts +8 -0
- package/teste-corrigido/core/framework/server.ts +501 -0
- package/teste-corrigido/core/framework/types.ts +63 -0
- package/teste-corrigido/core/plugins/__tests__/built-in.test.ts.disabled +366 -0
- package/teste-corrigido/core/plugins/__tests__/manager.test.ts +398 -0
- package/teste-corrigido/core/plugins/__tests__/monitoring.test.ts +401 -0
- package/teste-corrigido/core/plugins/__tests__/registry.test.ts +335 -0
- package/teste-corrigido/core/plugins/built-in/index.ts +142 -0
- package/teste-corrigido/core/plugins/built-in/logger/index.ts +180 -0
- package/teste-corrigido/core/plugins/built-in/monitoring/README.md +193 -0
- package/teste-corrigido/core/plugins/built-in/monitoring/index.ts +912 -0
- package/teste-corrigido/core/plugins/built-in/static/index.ts +289 -0
- package/teste-corrigido/core/plugins/built-in/swagger/index.ts +229 -0
- package/teste-corrigido/core/plugins/built-in/vite/index.ts +316 -0
- package/teste-corrigido/core/plugins/config.ts +348 -0
- package/teste-corrigido/core/plugins/discovery.ts +350 -0
- package/teste-corrigido/core/plugins/executor.ts +351 -0
- package/teste-corrigido/core/plugins/index.ts +195 -0
- package/teste-corrigido/core/plugins/manager.ts +583 -0
- package/teste-corrigido/core/plugins/registry.ts +424 -0
- package/teste-corrigido/core/plugins/types.ts +254 -0
- package/teste-corrigido/core/server/framework.ts +123 -0
- package/teste-corrigido/core/server/index.ts +8 -0
- package/teste-corrigido/core/server/plugins/database.ts +182 -0
- package/teste-corrigido/core/server/plugins/logger.ts +47 -0
- package/teste-corrigido/core/server/plugins/swagger.ts +34 -0
- package/teste-corrigido/core/server/standalone.ts +91 -0
- package/teste-corrigido/core/templates/create-project.ts +455 -0
- package/teste-corrigido/core/types/api.ts +169 -0
- package/teste-corrigido/core/types/build.ts +174 -0
- package/teste-corrigido/core/types/config.ts +68 -0
- package/teste-corrigido/core/types/index.ts +127 -0
- package/teste-corrigido/core/types/plugin.ts +94 -0
- package/teste-corrigido/core/utils/__tests__/errors.test.ts +139 -0
- package/teste-corrigido/core/utils/__tests__/helpers.test.ts +297 -0
- package/teste-corrigido/core/utils/__tests__/logger.test.ts +141 -0
- package/teste-corrigido/core/utils/env-runtime-v2.ts +232 -0
- package/teste-corrigido/core/utils/env-runtime.ts +252 -0
- package/teste-corrigido/core/utils/errors/codes.ts +115 -0
- package/teste-corrigido/core/utils/errors/handlers.ts +63 -0
- package/teste-corrigido/core/utils/errors/index.ts +81 -0
- package/teste-corrigido/core/utils/helpers.ts +180 -0
- package/teste-corrigido/core/utils/index.ts +18 -0
- package/teste-corrigido/core/utils/logger/index.ts +161 -0
- package/teste-corrigido/core/utils/logger.ts +106 -0
- package/teste-corrigido/core/utils/monitoring/index.ts +212 -0
- package/teste-corrigido/package-template.json +51 -0
- package/teste-corrigido/package.json +51 -0
- package/teste-corrigido/tsconfig.json +51 -0
- package/teste-corrigido/vite.config.ts +42 -0
- package/teste-final-npm/README.md +44 -0
- package/teste-final-npm/app/client/README.md +69 -0
- package/teste-final-npm/app/client/frontend-only.ts +12 -0
- package/teste-final-npm/app/client/index.html +13 -0
- package/teste-final-npm/app/client/public/vite.svg +1 -0
- package/teste-final-npm/app/client/src/App.css +883 -0
- package/teste-final-npm/app/client/src/App.tsx +669 -0
- package/teste-final-npm/app/client/src/assets/react.svg +1 -0
- package/teste-final-npm/app/client/src/components/TestPage.tsx +453 -0
- package/teste-final-npm/app/client/src/index.css +51 -0
- package/teste-final-npm/app/client/src/lib/eden-api.ts +110 -0
- package/teste-final-npm/app/client/src/main.tsx +10 -0
- package/teste-final-npm/app/client/src/vite-env.d.ts +1 -0
- package/teste-final-npm/app/client/tsconfig.app.json +43 -0
- package/teste-final-npm/app/client/tsconfig.json +7 -0
- package/teste-final-npm/app/client/tsconfig.node.json +25 -0
- package/teste-final-npm/app/server/app.ts +10 -0
- package/teste-final-npm/app/server/backend-only.ts +15 -0
- package/teste-final-npm/app/server/controllers/users.controller.ts +69 -0
- package/teste-final-npm/app/server/index.ts +104 -0
- package/teste-final-npm/app/server/routes/index.ts +25 -0
- package/teste-final-npm/app/server/routes/users.routes.ts +121 -0
- package/teste-final-npm/app/server/types/index.ts +1 -0
- package/teste-final-npm/app/shared/types/index.ts +18 -0
- package/teste-final-npm/bun.lock +1053 -0
- package/teste-final-npm/core/__tests__/integration.test.ts +227 -0
- package/teste-final-npm/core/build/index.ts +186 -0
- package/teste-final-npm/core/cli/command-registry.ts +334 -0
- package/teste-final-npm/core/cli/index.ts +394 -0
- package/teste-final-npm/core/cli/plugin-discovery.ts +200 -0
- package/teste-final-npm/core/client/standalone.ts +57 -0
- package/teste-final-npm/core/config/__tests__/config-loader.test.ts +591 -0
- package/teste-final-npm/core/config/__tests__/config-merger.test.ts +657 -0
- package/teste-final-npm/core/config/__tests__/env-converter.test.ts +372 -0
- package/teste-final-npm/core/config/__tests__/env-processor.test.ts +431 -0
- package/teste-final-npm/core/config/__tests__/env.test.ts +452 -0
- package/teste-final-npm/core/config/__tests__/integration.test.ts +418 -0
- package/teste-final-npm/core/config/__tests__/loader.test.ts +331 -0
- package/teste-final-npm/core/config/__tests__/schema.test.ts +129 -0
- package/teste-final-npm/core/config/__tests__/validator.test.ts +318 -0
- package/teste-final-npm/core/config/env-dynamic.ts +326 -0
- package/teste-final-npm/core/config/env.ts +597 -0
- package/teste-final-npm/core/config/index.ts +317 -0
- package/teste-final-npm/core/config/loader.ts +546 -0
- package/teste-final-npm/core/config/runtime-config.ts +322 -0
- package/teste-final-npm/core/config/schema.ts +694 -0
- package/teste-final-npm/core/config/validator.ts +540 -0
- package/teste-final-npm/core/framework/__tests__/server.test.ts +233 -0
- package/teste-final-npm/core/framework/client.ts +132 -0
- package/teste-final-npm/core/framework/index.ts +8 -0
- package/teste-final-npm/core/framework/server.ts +501 -0
- package/teste-final-npm/core/framework/types.ts +63 -0
- package/teste-final-npm/core/plugins/__tests__/built-in.test.ts.disabled +366 -0
- package/teste-final-npm/core/plugins/__tests__/manager.test.ts +398 -0
- package/teste-final-npm/core/plugins/__tests__/monitoring.test.ts +401 -0
- package/teste-final-npm/core/plugins/__tests__/registry.test.ts +335 -0
- package/teste-final-npm/core/plugins/built-in/index.ts +142 -0
- package/teste-final-npm/core/plugins/built-in/logger/index.ts +180 -0
- package/teste-final-npm/core/plugins/built-in/monitoring/README.md +193 -0
- package/teste-final-npm/core/plugins/built-in/monitoring/index.ts +912 -0
- package/teste-final-npm/core/plugins/built-in/static/index.ts +289 -0
- package/teste-final-npm/core/plugins/built-in/swagger/index.ts +229 -0
- package/teste-final-npm/core/plugins/built-in/vite/index.ts +316 -0
- package/teste-final-npm/core/plugins/config.ts +348 -0
- package/teste-final-npm/core/plugins/discovery.ts +350 -0
- package/teste-final-npm/core/plugins/executor.ts +351 -0
- package/teste-final-npm/core/plugins/index.ts +195 -0
- package/teste-final-npm/core/plugins/manager.ts +583 -0
- package/teste-final-npm/core/plugins/registry.ts +424 -0
- package/teste-final-npm/core/plugins/types.ts +254 -0
- package/teste-final-npm/core/server/framework.ts +123 -0
- package/teste-final-npm/core/server/index.ts +8 -0
- package/teste-final-npm/core/server/plugins/database.ts +182 -0
- package/teste-final-npm/core/server/plugins/logger.ts +47 -0
- package/teste-final-npm/core/server/plugins/swagger.ts +34 -0
- package/teste-final-npm/core/server/standalone.ts +91 -0
- package/teste-final-npm/core/templates/create-project.ts +455 -0
- package/teste-final-npm/core/types/api.ts +169 -0
- package/teste-final-npm/core/types/build.ts +174 -0
- package/teste-final-npm/core/types/config.ts +68 -0
- package/teste-final-npm/core/types/index.ts +127 -0
- package/teste-final-npm/core/types/plugin.ts +94 -0
- package/teste-final-npm/core/utils/__tests__/errors.test.ts +139 -0
- package/teste-final-npm/core/utils/__tests__/helpers.test.ts +297 -0
- package/teste-final-npm/core/utils/__tests__/logger.test.ts +141 -0
- package/teste-final-npm/core/utils/env-runtime-v2.ts +232 -0
- package/teste-final-npm/core/utils/env-runtime.ts +252 -0
- package/teste-final-npm/core/utils/errors/codes.ts +115 -0
- package/teste-final-npm/core/utils/errors/handlers.ts +63 -0
- package/teste-final-npm/core/utils/errors/index.ts +81 -0
- package/teste-final-npm/core/utils/helpers.ts +180 -0
- package/teste-final-npm/core/utils/index.ts +18 -0
- package/teste-final-npm/core/utils/logger/index.ts +161 -0
- package/teste-final-npm/core/utils/logger.ts +106 -0
- package/teste-final-npm/core/utils/monitoring/index.ts +212 -0
- package/teste-final-npm/package-template.json +51 -0
- package/teste-final-npm/package.json +51 -0
- package/teste-final-npm/tsconfig.json +51 -0
- package/teste-final-npm/vite.config.ts +42 -0
- package/tests/__mocks__/api.ts +56 -0
- package/tests/fixtures/users.ts +69 -0
- package/tests/integration/api/users.routes.test.ts +221 -0
- package/tests/setup.ts +29 -0
- package/tests/unit/app/client/App-simple.test.tsx +56 -0
- package/tests/unit/app/client/App.test.tsx.skip +237 -0
- package/tests/unit/app/client/eden-api.test.ts +186 -0
- package/tests/unit/app/client/simple.test.tsx +23 -0
- package/tests/unit/app/controllers/users.controller.test.ts +150 -0
- package/tests/unit/core/create-project.test.ts.skip +95 -0
- package/tests/unit/core/framework.test.ts +144 -0
- package/tests/unit/core/plugins/logger.test.ts.skip +268 -0
- package/tests/unit/core/plugins/vite.test.ts.disabled +188 -0
- package/tests/utils/test-helpers.ts +61 -0
- package/tsconfig.json +51 -0
- package/types/global.d.ts +30 -0
- package/types/vitest.d.ts +9 -0
- package/vite.config.ts +42 -0
- package/vitest.config.ts +50 -0
- package/workspace.json +6 -0
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* FluxStack Logger
|
|
3
|
+
* Environment-aware logging system
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
// Environment info is handled via process.env directly
|
|
7
|
+
|
|
8
|
+
type LogLevel = 'debug' | 'info' | 'warn' | 'error'
|
|
9
|
+
|
|
10
|
+
export interface Logger {
|
|
11
|
+
debug(message: string, meta?: any): void
|
|
12
|
+
info(message: string, meta?: any): void
|
|
13
|
+
warn(message: string, meta?: any): void
|
|
14
|
+
error(message: string, meta?: any): void
|
|
15
|
+
|
|
16
|
+
// Contextual logging
|
|
17
|
+
child(context: any): Logger
|
|
18
|
+
|
|
19
|
+
// Performance logging
|
|
20
|
+
time(label: string): void
|
|
21
|
+
timeEnd(label: string): void
|
|
22
|
+
|
|
23
|
+
// Request logging
|
|
24
|
+
request(method: string, path: string, status?: number, duration?: number): void
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
class FluxStackLogger implements Logger {
|
|
28
|
+
private static instance: FluxStackLogger | null = null
|
|
29
|
+
private logLevel: LogLevel
|
|
30
|
+
private context: any = {}
|
|
31
|
+
private timers: Map<string, number> = new Map()
|
|
32
|
+
|
|
33
|
+
private constructor(context?: any) {
|
|
34
|
+
// Default to 'info' level, can be overridden by config
|
|
35
|
+
this.logLevel = (process.env.LOG_LEVEL as LogLevel) || 'info'
|
|
36
|
+
this.context = context || {}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
static getInstance(): FluxStackLogger {
|
|
40
|
+
if (FluxStackLogger.instance === null) {
|
|
41
|
+
FluxStackLogger.instance = new FluxStackLogger()
|
|
42
|
+
}
|
|
43
|
+
return FluxStackLogger.instance
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
private shouldLog(level: LogLevel): boolean {
|
|
47
|
+
const levels: Record<LogLevel, number> = {
|
|
48
|
+
debug: 0,
|
|
49
|
+
info: 1,
|
|
50
|
+
warn: 2,
|
|
51
|
+
error: 3
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return levels[level] >= levels[this.logLevel]
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
private formatMessage(level: LogLevel, message: string, meta?: any): string {
|
|
58
|
+
const timestamp = new Date().toISOString()
|
|
59
|
+
const levelStr = level.toUpperCase().padEnd(5)
|
|
60
|
+
|
|
61
|
+
let formatted = `[${timestamp}] ${levelStr}`
|
|
62
|
+
|
|
63
|
+
// Add context if available
|
|
64
|
+
if (Object.keys(this.context).length > 0) {
|
|
65
|
+
const contextStr = Object.entries(this.context)
|
|
66
|
+
.map(([key, value]) => `${key}=${value}`)
|
|
67
|
+
.join(' ')
|
|
68
|
+
formatted += ` [${contextStr}]`
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
formatted += ` ${message}`
|
|
72
|
+
|
|
73
|
+
if (meta && typeof meta === 'object') {
|
|
74
|
+
formatted += ` ${JSON.stringify(meta)}`
|
|
75
|
+
} else if (meta !== undefined) {
|
|
76
|
+
formatted += ` ${meta}`
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return formatted
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
debug(message: string, meta?: any): void {
|
|
83
|
+
if (this.shouldLog('debug')) {
|
|
84
|
+
console.debug(this.formatMessage('debug', message, meta))
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
info(message: string, meta?: any): void {
|
|
89
|
+
if (this.shouldLog('info')) {
|
|
90
|
+
console.info(this.formatMessage('info', message, meta))
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
warn(message: string, meta?: any): void {
|
|
95
|
+
if (this.shouldLog('warn')) {
|
|
96
|
+
console.warn(this.formatMessage('warn', message, meta))
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
error(message: string, meta?: any): void {
|
|
101
|
+
if (this.shouldLog('error')) {
|
|
102
|
+
console.error(this.formatMessage('error', message, meta))
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
// Contextual logging
|
|
107
|
+
child(context: any): FluxStackLogger {
|
|
108
|
+
return new FluxStackLogger({ ...this.context, ...context })
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// Performance logging
|
|
112
|
+
time(label: string): void {
|
|
113
|
+
this.timers.set(label, Date.now())
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
timeEnd(label: string): void {
|
|
117
|
+
const startTime = this.timers.get(label)
|
|
118
|
+
if (startTime) {
|
|
119
|
+
const duration = Date.now() - startTime
|
|
120
|
+
this.info(`Timer ${label}: ${duration}ms`)
|
|
121
|
+
this.timers.delete(label)
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// HTTP request logging
|
|
126
|
+
request(method: string, path: string, status?: number, duration?: number): void {
|
|
127
|
+
const statusStr = status ? ` ${status}` : ''
|
|
128
|
+
const durationStr = duration ? ` (${duration}ms)` : ''
|
|
129
|
+
this.info(`${method} ${path}${statusStr}${durationStr}`)
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
// Plugin logging
|
|
133
|
+
plugin(pluginName: string, message: string, meta?: any): void {
|
|
134
|
+
this.debug(`[${pluginName}] ${message}`, meta)
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// Framework logging
|
|
138
|
+
framework(message: string, meta?: any): void {
|
|
139
|
+
this.info(`[FluxStack] ${message}`, meta)
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Export singleton instance
|
|
144
|
+
export const logger = FluxStackLogger.getInstance()
|
|
145
|
+
|
|
146
|
+
// Export convenience functions
|
|
147
|
+
export const log = {
|
|
148
|
+
debug: (message: string, meta?: any) => logger.debug(message, meta),
|
|
149
|
+
info: (message: string, meta?: any) => logger.info(message, meta),
|
|
150
|
+
warn: (message: string, meta?: any) => logger.warn(message, meta),
|
|
151
|
+
error: (message: string, meta?: any) => logger.error(message, meta),
|
|
152
|
+
request: (method: string, path: string, status?: number, duration?: number) =>
|
|
153
|
+
logger.request(method, path, status, duration),
|
|
154
|
+
plugin: (pluginName: string, message: string, meta?: any) =>
|
|
155
|
+
logger.plugin(pluginName, message, meta),
|
|
156
|
+
framework: (message: string, meta?: any) =>
|
|
157
|
+
logger.framework(message, meta),
|
|
158
|
+
child: (context: any) => logger.child(context),
|
|
159
|
+
time: (label: string) => logger.time(label),
|
|
160
|
+
timeEnd: (label: string) => logger.timeEnd(label)
|
|
161
|
+
}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* FluxStack Logger
|
|
3
|
+
* Environment-aware logging system
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
type LogLevel = 'debug' | 'info' | 'warn' | 'error'
|
|
7
|
+
|
|
8
|
+
class Logger {
|
|
9
|
+
private static instance: Logger | null = null
|
|
10
|
+
private logLevel: LogLevel
|
|
11
|
+
|
|
12
|
+
private constructor() {
|
|
13
|
+
this.logLevel = (process.env.LOG_LEVEL as LogLevel) || 'info'
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
static getInstance(): Logger {
|
|
17
|
+
if (Logger.instance === null) {
|
|
18
|
+
Logger.instance = new Logger()
|
|
19
|
+
}
|
|
20
|
+
return Logger.instance
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
private shouldLog(level: LogLevel): boolean {
|
|
24
|
+
const levels: Record<LogLevel, number> = {
|
|
25
|
+
debug: 0,
|
|
26
|
+
info: 1,
|
|
27
|
+
warn: 2,
|
|
28
|
+
error: 3
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
return levels[level] >= levels[this.logLevel]
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
private formatMessage(level: LogLevel, message: string, meta?: any): string {
|
|
35
|
+
const timestamp = new Date().toISOString()
|
|
36
|
+
const levelStr = level.toUpperCase().padEnd(5)
|
|
37
|
+
|
|
38
|
+
let formatted = `[${timestamp}] ${levelStr} ${message}`
|
|
39
|
+
|
|
40
|
+
if (meta && typeof meta === 'object') {
|
|
41
|
+
formatted += ` ${JSON.stringify(meta)}`
|
|
42
|
+
} else if (meta !== undefined) {
|
|
43
|
+
formatted += ` ${meta}`
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
return formatted
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
debug(message: string, meta?: any): void {
|
|
50
|
+
if (this.shouldLog('debug')) {
|
|
51
|
+
console.debug(this.formatMessage('debug', message, meta))
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
info(message: string, meta?: any): void {
|
|
56
|
+
if (this.shouldLog('info')) {
|
|
57
|
+
console.info(this.formatMessage('info', message, meta))
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
warn(message: string, meta?: any): void {
|
|
62
|
+
if (this.shouldLog('warn')) {
|
|
63
|
+
console.warn(this.formatMessage('warn', message, meta))
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
error(message: string, meta?: any): void {
|
|
68
|
+
if (this.shouldLog('error')) {
|
|
69
|
+
console.error(this.formatMessage('error', message, meta))
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// HTTP request logging
|
|
74
|
+
request(method: string, path: string, status?: number, duration?: number): void {
|
|
75
|
+
const statusStr = status ? ` ${status}` : ''
|
|
76
|
+
const durationStr = duration ? ` (${duration}ms)` : ''
|
|
77
|
+
this.info(`${method} ${path}${statusStr}${durationStr}`)
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
// Plugin logging
|
|
81
|
+
plugin(pluginName: string, message: string, meta?: any): void {
|
|
82
|
+
this.debug(`[${pluginName}] ${message}`, meta)
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Framework logging
|
|
86
|
+
framework(message: string, meta?: any): void {
|
|
87
|
+
this.info(`[FluxStack] ${message}`, meta)
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// Export singleton instance
|
|
92
|
+
export const logger = Logger.getInstance()
|
|
93
|
+
|
|
94
|
+
// Export convenience functions
|
|
95
|
+
export const log = {
|
|
96
|
+
debug: (message: string, meta?: any) => logger.debug(message, meta),
|
|
97
|
+
info: (message: string, meta?: any) => logger.info(message, meta),
|
|
98
|
+
warn: (message: string, meta?: any) => logger.warn(message, meta),
|
|
99
|
+
error: (message: string, meta?: any) => logger.error(message, meta),
|
|
100
|
+
request: (method: string, path: string, status?: number, duration?: number) =>
|
|
101
|
+
logger.request(method, path, status, duration),
|
|
102
|
+
plugin: (pluginName: string, message: string, meta?: any) =>
|
|
103
|
+
logger.plugin(pluginName, message, meta),
|
|
104
|
+
framework: (message: string, meta?: any) =>
|
|
105
|
+
logger.framework(message, meta)
|
|
106
|
+
}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
export interface Metric {
|
|
2
|
+
name: string
|
|
3
|
+
type: 'counter' | 'gauge' | 'histogram'
|
|
4
|
+
help: string
|
|
5
|
+
labels?: string[]
|
|
6
|
+
value?: number
|
|
7
|
+
values?: number[]
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export interface Counter extends Metric {
|
|
11
|
+
type: 'counter'
|
|
12
|
+
inc(value?: number, labels?: Record<string, string>): void
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export interface Gauge extends Metric {
|
|
16
|
+
type: 'gauge'
|
|
17
|
+
set(value: number, labels?: Record<string, string>): void
|
|
18
|
+
inc(value?: number, labels?: Record<string, string>): void
|
|
19
|
+
dec(value?: number, labels?: Record<string, string>): void
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export interface Histogram extends Metric {
|
|
23
|
+
type: 'histogram'
|
|
24
|
+
observe(value: number, labels?: Record<string, string>): void
|
|
25
|
+
buckets: number[]
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export interface SystemMetrics {
|
|
29
|
+
memoryUsage: {
|
|
30
|
+
rss: number
|
|
31
|
+
heapTotal: number
|
|
32
|
+
heapUsed: number
|
|
33
|
+
external: number
|
|
34
|
+
}
|
|
35
|
+
cpuUsage: {
|
|
36
|
+
user: number
|
|
37
|
+
system: number
|
|
38
|
+
}
|
|
39
|
+
eventLoopLag: number
|
|
40
|
+
uptime: number
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export interface HttpMetrics {
|
|
44
|
+
requestsTotal: number
|
|
45
|
+
requestDuration: number[]
|
|
46
|
+
requestSize: number[]
|
|
47
|
+
responseSize: number[]
|
|
48
|
+
errorRate: number
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export class MetricsCollector {
|
|
52
|
+
private metrics: Map<string, Metric> = new Map()
|
|
53
|
+
private httpMetrics: HttpMetrics = {
|
|
54
|
+
requestsTotal: 0,
|
|
55
|
+
requestDuration: [],
|
|
56
|
+
requestSize: [],
|
|
57
|
+
responseSize: [],
|
|
58
|
+
errorRate: 0
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// Create metrics
|
|
62
|
+
createCounter(name: string, help: string, labels?: string[]): Counter {
|
|
63
|
+
const counter: Counter = {
|
|
64
|
+
name,
|
|
65
|
+
type: 'counter',
|
|
66
|
+
help,
|
|
67
|
+
labels,
|
|
68
|
+
value: 0,
|
|
69
|
+
inc: (value = 1, _labels) => {
|
|
70
|
+
counter.value = (counter.value || 0) + value
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
this.metrics.set(name, counter)
|
|
75
|
+
return counter
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
createGauge(name: string, help: string, labels?: string[]): Gauge {
|
|
79
|
+
const gauge: Gauge = {
|
|
80
|
+
name,
|
|
81
|
+
type: 'gauge',
|
|
82
|
+
help,
|
|
83
|
+
labels,
|
|
84
|
+
value: 0,
|
|
85
|
+
set: (value, _labels) => {
|
|
86
|
+
gauge.value = value
|
|
87
|
+
},
|
|
88
|
+
inc: (value = 1, _labels) => {
|
|
89
|
+
gauge.value = (gauge.value || 0) + value
|
|
90
|
+
},
|
|
91
|
+
dec: (value = 1, _labels) => {
|
|
92
|
+
gauge.value = (gauge.value || 0) - value
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
this.metrics.set(name, gauge)
|
|
97
|
+
return gauge
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
createHistogram(name: string, help: string, buckets: number[] = [0.1, 0.5, 1, 2.5, 5, 10]): Histogram {
|
|
101
|
+
const histogram: Histogram = {
|
|
102
|
+
name,
|
|
103
|
+
type: 'histogram',
|
|
104
|
+
help,
|
|
105
|
+
buckets,
|
|
106
|
+
values: [],
|
|
107
|
+
observe: (value, _labels) => {
|
|
108
|
+
histogram.values = histogram.values || []
|
|
109
|
+
histogram.values.push(value)
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
this.metrics.set(name, histogram)
|
|
114
|
+
return histogram
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
// HTTP metrics
|
|
118
|
+
recordHttpRequest(_method: string, _path: string, statusCode: number, duration: number, requestSize?: number, responseSize?: number): void {
|
|
119
|
+
this.httpMetrics.requestsTotal++
|
|
120
|
+
this.httpMetrics.requestDuration.push(duration)
|
|
121
|
+
|
|
122
|
+
if (requestSize) {
|
|
123
|
+
this.httpMetrics.requestSize.push(requestSize)
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
if (responseSize) {
|
|
127
|
+
this.httpMetrics.responseSize.push(responseSize)
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
if (statusCode >= 400) {
|
|
131
|
+
this.httpMetrics.errorRate = this.calculateErrorRate()
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// System metrics
|
|
136
|
+
getSystemMetrics(): SystemMetrics {
|
|
137
|
+
const memUsage = process.memoryUsage()
|
|
138
|
+
const cpuUsage = process.cpuUsage()
|
|
139
|
+
|
|
140
|
+
return {
|
|
141
|
+
memoryUsage: {
|
|
142
|
+
rss: memUsage.rss,
|
|
143
|
+
heapTotal: memUsage.heapTotal,
|
|
144
|
+
heapUsed: memUsage.heapUsed,
|
|
145
|
+
external: memUsage.external
|
|
146
|
+
},
|
|
147
|
+
cpuUsage: {
|
|
148
|
+
user: cpuUsage.user,
|
|
149
|
+
system: cpuUsage.system
|
|
150
|
+
},
|
|
151
|
+
eventLoopLag: this.measureEventLoopLag(),
|
|
152
|
+
uptime: process.uptime()
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// Get all metrics
|
|
157
|
+
getAllMetrics(): Map<string, Metric> {
|
|
158
|
+
return new Map(this.metrics)
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
getHttpMetrics(): HttpMetrics {
|
|
162
|
+
return { ...this.httpMetrics }
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
// Export metrics in Prometheus format
|
|
166
|
+
exportPrometheus(): string {
|
|
167
|
+
let output = ''
|
|
168
|
+
|
|
169
|
+
for (const metric of this.metrics.values()) {
|
|
170
|
+
output += `# HELP ${metric.name} ${metric.help}\n`
|
|
171
|
+
output += `# TYPE ${metric.name} ${metric.type}\n`
|
|
172
|
+
|
|
173
|
+
if (metric.type === 'counter' || metric.type === 'gauge') {
|
|
174
|
+
output += `${metric.name} ${metric.value || 0}\n`
|
|
175
|
+
} else if (metric.type === 'histogram' && metric.values) {
|
|
176
|
+
const values = metric.values.sort((a, b) => a - b)
|
|
177
|
+
const buckets = (metric as Histogram).buckets
|
|
178
|
+
|
|
179
|
+
for (const bucket of buckets) {
|
|
180
|
+
const count = values.filter(v => v <= bucket).length
|
|
181
|
+
output += `${metric.name}_bucket{le="${bucket}"} ${count}\n`
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
output += `${metric.name}_bucket{le="+Inf"} ${values.length}\n`
|
|
185
|
+
output += `${metric.name}_count ${values.length}\n`
|
|
186
|
+
output += `${metric.name}_sum ${values.reduce((sum, v) => sum + v, 0)}\n`
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
output += '\n'
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
return output
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
private calculateErrorRate(): number {
|
|
196
|
+
const totalRequests = this.httpMetrics.requestsTotal
|
|
197
|
+
if (totalRequests === 0) return 0
|
|
198
|
+
|
|
199
|
+
// This is a simplified calculation - in a real implementation,
|
|
200
|
+
// you'd track error counts separately
|
|
201
|
+
return 0 // Placeholder
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
private measureEventLoopLag(): number {
|
|
205
|
+
const start = process.hrtime.bigint()
|
|
206
|
+
setImmediate(() => {
|
|
207
|
+
const lag = Number(process.hrtime.bigint() - start) / 1e6 // Convert to milliseconds
|
|
208
|
+
return lag
|
|
209
|
+
})
|
|
210
|
+
return 0 // Placeholder - actual implementation would be more complex
|
|
211
|
+
}
|
|
212
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "PROJECT_NAME",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "PROJECT_NAME - FluxStack application",
|
|
5
|
+
"keywords": ["fluxstack", "bun", "typescript", "full-stack", "elysia", "react", "vite"],
|
|
6
|
+
"author": "Your Name",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"scripts": {
|
|
10
|
+
"dev": "bun core/cli/index.ts dev",
|
|
11
|
+
"dev:clean": "bun run-clean.ts",
|
|
12
|
+
"dev:backend": "bun core/cli/index.ts dev:backend",
|
|
13
|
+
"dev:frontend": "bun core/cli/index.ts dev:frontend",
|
|
14
|
+
"build": "bun core/cli/index.ts build",
|
|
15
|
+
"build:backend": "bun core/cli/index.ts build:backend",
|
|
16
|
+
"build:frontend": "bun core/cli/index.ts build:frontend",
|
|
17
|
+
"start": "NODE_ENV=production bun app/server/index.ts",
|
|
18
|
+
"start:backend": "NODE_ENV=production bun app/server/backend-only.ts",
|
|
19
|
+
"start:frontend": "NODE_ENV=production bun app/client/frontend-only.ts",
|
|
20
|
+
"typecheck": "bunx tsc --noEmit",
|
|
21
|
+
"test": "vitest",
|
|
22
|
+
"test:ui": "vitest --ui",
|
|
23
|
+
"test:coverage": "vitest --coverage"
|
|
24
|
+
},
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@types/react": "^19.1.2",
|
|
27
|
+
"@types/react-dom": "^19.1.5",
|
|
28
|
+
"@vitejs/plugin-react": "^4.3.6",
|
|
29
|
+
"elysia": "^1.4.6",
|
|
30
|
+
"react": "^19.1.0",
|
|
31
|
+
"react-dom": "^19.1.0",
|
|
32
|
+
"tailwindcss": "^4.1.0",
|
|
33
|
+
"typescript": "^5.9.2",
|
|
34
|
+
"vite": "^7.0.4",
|
|
35
|
+
"vitest": "^2.2.0"
|
|
36
|
+
},
|
|
37
|
+
"devDependencies": {
|
|
38
|
+
"@eden-treaty/elysia": "^1.1.5",
|
|
39
|
+
"@swagger-ui/dist": "^5.19.2",
|
|
40
|
+
"@types/bun": "latest",
|
|
41
|
+
"@vitest/coverage-v8": "^2.2.0",
|
|
42
|
+
"@vitest/ui": "^2.2.0",
|
|
43
|
+
"happy-dom": "^16.7.0"
|
|
44
|
+
},
|
|
45
|
+
"engines": {
|
|
46
|
+
"bun": ">=1.2.0",
|
|
47
|
+
"node": ">=20.0.0"
|
|
48
|
+
},
|
|
49
|
+
"preferredPackageManager": "bun",
|
|
50
|
+
"trustedDependencies": ["esbuild"]
|
|
51
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "teste-corrigido",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "teste-corrigido - FluxStack application",
|
|
5
|
+
"keywords": ["fluxstack", "bun", "typescript", "full-stack", "elysia", "react", "vite"],
|
|
6
|
+
"author": "Your Name",
|
|
7
|
+
"license": "MIT",
|
|
8
|
+
"type": "module",
|
|
9
|
+
"scripts": {
|
|
10
|
+
"dev": "bun core/cli/index.ts dev",
|
|
11
|
+
"dev:clean": "bun run-clean.ts",
|
|
12
|
+
"dev:backend": "bun core/cli/index.ts dev:backend",
|
|
13
|
+
"dev:frontend": "bun core/cli/index.ts dev:frontend",
|
|
14
|
+
"build": "bun core/cli/index.ts build",
|
|
15
|
+
"build:backend": "bun core/cli/index.ts build:backend",
|
|
16
|
+
"build:frontend": "bun core/cli/index.ts build:frontend",
|
|
17
|
+
"start": "NODE_ENV=production bun app/server/index.ts",
|
|
18
|
+
"start:backend": "NODE_ENV=production bun app/server/backend-only.ts",
|
|
19
|
+
"start:frontend": "NODE_ENV=production bun app/client/frontend-only.ts",
|
|
20
|
+
"typecheck": "bunx tsc --noEmit",
|
|
21
|
+
"test": "vitest",
|
|
22
|
+
"test:ui": "vitest --ui",
|
|
23
|
+
"test:coverage": "vitest --coverage"
|
|
24
|
+
},
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@types/react": "^19.1.2",
|
|
27
|
+
"@types/react-dom": "^19.1.5",
|
|
28
|
+
"@vitejs/plugin-react": "^4.3.6",
|
|
29
|
+
"elysia": "^1.4.6",
|
|
30
|
+
"react": "^19.1.0",
|
|
31
|
+
"react-dom": "^19.1.0",
|
|
32
|
+
"tailwindcss": "^4.1.0",
|
|
33
|
+
"typescript": "^5.9.2",
|
|
34
|
+
"vite": "^7.0.4",
|
|
35
|
+
"vitest": "^2.2.0"
|
|
36
|
+
},
|
|
37
|
+
"devDependencies": {
|
|
38
|
+
"@eden-treaty/elysia": "^1.1.5",
|
|
39
|
+
"@swagger-ui/dist": "^5.19.2",
|
|
40
|
+
"@types/bun": "latest",
|
|
41
|
+
"@vitest/coverage-v8": "^2.2.0",
|
|
42
|
+
"@vitest/ui": "^2.2.0",
|
|
43
|
+
"happy-dom": "^16.7.0"
|
|
44
|
+
},
|
|
45
|
+
"engines": {
|
|
46
|
+
"bun": ">=1.2.0",
|
|
47
|
+
"node": ">=20.0.0"
|
|
48
|
+
},
|
|
49
|
+
"preferredPackageManager": "bun",
|
|
50
|
+
"trustedDependencies": ["esbuild"]
|
|
51
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
// Enable latest features
|
|
4
|
+
"lib": ["ESNext", "DOM", "DOM.Iterable"],
|
|
5
|
+
"target": "ES2022",
|
|
6
|
+
"module": "ES2022",
|
|
7
|
+
"moduleDetection": "force",
|
|
8
|
+
"jsx": "react-jsx",
|
|
9
|
+
"allowJs": true,
|
|
10
|
+
"types": ["node"],
|
|
11
|
+
"typeRoots": ["./types", "./node_modules/@types"],
|
|
12
|
+
|
|
13
|
+
// Bundler mode
|
|
14
|
+
"moduleResolution": "bundler",
|
|
15
|
+
"allowImportingTsExtensions": true,
|
|
16
|
+
"verbatimModuleSyntax": true,
|
|
17
|
+
"noEmit": true,
|
|
18
|
+
"downlevelIteration": true,
|
|
19
|
+
|
|
20
|
+
// Path mapping (alias support)
|
|
21
|
+
"baseUrl": ".",
|
|
22
|
+
"paths": {
|
|
23
|
+
"@/*": ["./*"],
|
|
24
|
+
"@/core/*": ["./core/*"],
|
|
25
|
+
"@/app/*": ["./app/*"],
|
|
26
|
+
"@/config/*": ["./config/*"],
|
|
27
|
+
"@/shared/*": ["./app/shared/*"]
|
|
28
|
+
},
|
|
29
|
+
|
|
30
|
+
// Best practices
|
|
31
|
+
"strict": false,
|
|
32
|
+
"skipLibCheck": true,
|
|
33
|
+
"noFallthroughCasesInSwitch": true,
|
|
34
|
+
"noImplicitAny": false,
|
|
35
|
+
"strictNullChecks": false,
|
|
36
|
+
"strictFunctionTypes": false,
|
|
37
|
+
"noImplicitReturns": false,
|
|
38
|
+
"noImplicitThis": false,
|
|
39
|
+
|
|
40
|
+
// Some stricter flags (disabled by default)
|
|
41
|
+
"noUnusedLocals": false,
|
|
42
|
+
"noUnusedParameters": false,
|
|
43
|
+
"noPropertyAccessFromIndexSignature": false
|
|
44
|
+
},
|
|
45
|
+
"exclude": [
|
|
46
|
+
"examples/**/*",
|
|
47
|
+
"**/*.test.ts",
|
|
48
|
+
"**/__tests__/**/*",
|
|
49
|
+
"run-env-tests.ts"
|
|
50
|
+
]
|
|
51
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { defineConfig } from 'vite'
|
|
2
|
+
import react from '@vitejs/plugin-react'
|
|
3
|
+
import tailwindcss from '@tailwindcss/vite'
|
|
4
|
+
import { resolve } from 'path'
|
|
5
|
+
import { fileURLToPath, URL } from 'node:url'
|
|
6
|
+
|
|
7
|
+
const __dirname = fileURLToPath(new URL('.', import.meta.url))
|
|
8
|
+
|
|
9
|
+
// https://vite.dev/config/
|
|
10
|
+
export default defineConfig({
|
|
11
|
+
plugins: [react(), tailwindcss()],
|
|
12
|
+
root: 'app/client',
|
|
13
|
+
server: {
|
|
14
|
+
port: 5173,
|
|
15
|
+
host: true,
|
|
16
|
+
proxy: {
|
|
17
|
+
'/api': {
|
|
18
|
+
target: 'http://localhost:3000',
|
|
19
|
+
changeOrigin: true,
|
|
20
|
+
secure: false,
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
build: {
|
|
25
|
+
outDir: '../../dist/client'
|
|
26
|
+
},
|
|
27
|
+
resolve: {
|
|
28
|
+
alias: {
|
|
29
|
+
'@': resolve(__dirname, './app/client/src'),
|
|
30
|
+
'@/core': resolve(__dirname, './core'),
|
|
31
|
+
'@/app': resolve(__dirname, './app'),
|
|
32
|
+
'@/config': resolve(__dirname, './config'),
|
|
33
|
+
'@/shared': resolve(__dirname, './app/shared'),
|
|
34
|
+
'@/components': resolve(__dirname, './app/client/src/components'),
|
|
35
|
+
'@/utils': resolve(__dirname, './app/client/src/utils'),
|
|
36
|
+
'@/hooks': resolve(__dirname, './app/client/src/hooks'),
|
|
37
|
+
'@/assets': resolve(__dirname, './app/client/src/assets'),
|
|
38
|
+
'@/lib': resolve(__dirname, './app/client/src/lib'),
|
|
39
|
+
'@/types': resolve(__dirname, './app/client/src/types')
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
})
|