javi-forge 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.gitignore.template +105 -0
- package/.releaserc +44 -0
- package/README.md +45 -0
- package/ai-config/.skillignore +15 -0
- package/ai-config/AUTO_INVOKE.md +300 -0
- package/ai-config/agents/_TEMPLATE.md +93 -0
- package/ai-config/agents/business/api-designer.md +1657 -0
- package/ai-config/agents/business/business-analyst.md +1331 -0
- package/ai-config/agents/business/product-strategist.md +206 -0
- package/ai-config/agents/business/project-manager.md +178 -0
- package/ai-config/agents/business/requirements-analyst.md +1277 -0
- package/ai-config/agents/business/technical-writer.md +1679 -0
- package/ai-config/agents/creative/ux-designer.md +205 -0
- package/ai-config/agents/data-ai/ai-engineer.md +487 -0
- package/ai-config/agents/data-ai/analytics-engineer.md +953 -0
- package/ai-config/agents/data-ai/data-engineer.md +173 -0
- package/ai-config/agents/data-ai/data-scientist.md +672 -0
- package/ai-config/agents/data-ai/mlops-engineer.md +814 -0
- package/ai-config/agents/data-ai/prompt-engineer.md +772 -0
- package/ai-config/agents/development/angular-expert.md +620 -0
- package/ai-config/agents/development/backend-architect.md +795 -0
- package/ai-config/agents/development/database-specialist.md +212 -0
- package/ai-config/agents/development/frontend-specialist.md +686 -0
- package/ai-config/agents/development/fullstack-engineer.md +668 -0
- package/ai-config/agents/development/golang-pro.md +338 -0
- package/ai-config/agents/development/java-enterprise.md +400 -0
- package/ai-config/agents/development/javascript-pro.md +422 -0
- package/ai-config/agents/development/nextjs-pro.md +474 -0
- package/ai-config/agents/development/python-pro.md +570 -0
- package/ai-config/agents/development/react-pro.md +487 -0
- package/ai-config/agents/development/rust-pro.md +246 -0
- package/ai-config/agents/development/spring-boot-4-expert.md +326 -0
- package/ai-config/agents/development/typescript-pro.md +336 -0
- package/ai-config/agents/development/vue-specialist.md +605 -0
- package/ai-config/agents/infrastructure/cloud-architect.md +472 -0
- package/ai-config/agents/infrastructure/deployment-manager.md +358 -0
- package/ai-config/agents/infrastructure/devops-engineer.md +455 -0
- package/ai-config/agents/infrastructure/incident-responder.md +519 -0
- package/ai-config/agents/infrastructure/kubernetes-expert.md +705 -0
- package/ai-config/agents/infrastructure/monitoring-specialist.md +674 -0
- package/ai-config/agents/infrastructure/performance-engineer.md +658 -0
- package/ai-config/agents/orchestrator.md +241 -0
- package/ai-config/agents/quality/accessibility-auditor.md +1204 -0
- package/ai-config/agents/quality/code-reviewer-compact.md +123 -0
- package/ai-config/agents/quality/code-reviewer.md +363 -0
- package/ai-config/agents/quality/dependency-manager.md +743 -0
- package/ai-config/agents/quality/e2e-test-specialist.md +1005 -0
- package/ai-config/agents/quality/performance-tester.md +1086 -0
- package/ai-config/agents/quality/security-auditor.md +133 -0
- package/ai-config/agents/quality/test-engineer.md +453 -0
- package/ai-config/agents/specialists/api-designer.md +87 -0
- package/ai-config/agents/specialists/backend-architect.md +73 -0
- package/ai-config/agents/specialists/code-reviewer.md +77 -0
- package/ai-config/agents/specialists/db-optimizer.md +75 -0
- package/ai-config/agents/specialists/devops-engineer.md +83 -0
- package/ai-config/agents/specialists/documentation-writer.md +78 -0
- package/ai-config/agents/specialists/frontend-developer.md +75 -0
- package/ai-config/agents/specialists/performance-analyst.md +82 -0
- package/ai-config/agents/specialists/refactor-specialist.md +74 -0
- package/ai-config/agents/specialists/security-auditor.md +74 -0
- package/ai-config/agents/specialists/test-engineer.md +81 -0
- package/ai-config/agents/specialists/ux-consultant.md +76 -0
- package/ai-config/agents/specialized/agent-generator.md +1190 -0
- package/ai-config/agents/specialized/blockchain-developer.md +149 -0
- package/ai-config/agents/specialized/code-migrator.md +892 -0
- package/ai-config/agents/specialized/context-manager.md +978 -0
- package/ai-config/agents/specialized/documentation-writer.md +1078 -0
- package/ai-config/agents/specialized/ecommerce-expert.md +1756 -0
- package/ai-config/agents/specialized/embedded-engineer.md +1714 -0
- package/ai-config/agents/specialized/error-detective.md +1034 -0
- package/ai-config/agents/specialized/fintech-specialist.md +1659 -0
- package/ai-config/agents/specialized/freelance-project-planner-v2.md +1988 -0
- package/ai-config/agents/specialized/freelance-project-planner-v3.md +2136 -0
- package/ai-config/agents/specialized/freelance-project-planner-v4.md +4503 -0
- package/ai-config/agents/specialized/freelance-project-planner.md +722 -0
- package/ai-config/agents/specialized/game-developer.md +1963 -0
- package/ai-config/agents/specialized/healthcare-dev.md +1620 -0
- package/ai-config/agents/specialized/mobile-developer.md +188 -0
- package/ai-config/agents/specialized/parallel-plan-executor.md +506 -0
- package/ai-config/agents/specialized/plan-executor.md +485 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/00-INDEX.md +485 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/01-CORE.md +3493 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/02-SELF-CORRECTION.md +778 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/03-PROGRESSIVE-SETUP.md +918 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/04-DEPLOYMENT.md +1537 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/05-TESTING.md +2633 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/06-OPERATIONS.md +5610 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/INSTALL.md +335 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/QUICK-REFERENCE.txt +215 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/README.md +260 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/START-HERE.md +379 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/WORKFLOW-DIAGRAM.md +355 -0
- package/ai-config/agents/specialized/solo-dev-planner-modular/solo-dev-planner.md +279 -0
- package/ai-config/agents/specialized/template-writer.md +347 -0
- package/ai-config/agents/specialized/test-runner.md +99 -0
- package/ai-config/agents/specialized/vibekanban-smart-worker.md +244 -0
- package/ai-config/agents/specialized/wave-executor.md +138 -0
- package/ai-config/agents/specialized/workflow-optimizer.md +1114 -0
- package/ai-config/commands/git/changelog.md +32 -0
- package/ai-config/commands/git/ci-local.md +70 -0
- package/ai-config/commands/git/commit.md +35 -0
- package/ai-config/commands/git/fix-issue.md +23 -0
- package/ai-config/commands/git/pr-create.md +42 -0
- package/ai-config/commands/git/pr-review.md +50 -0
- package/ai-config/commands/git/worktree.md +39 -0
- package/ai-config/commands/refactoring/cleanup.md +24 -0
- package/ai-config/commands/refactoring/dead-code.md +40 -0
- package/ai-config/commands/refactoring/extract.md +31 -0
- package/ai-config/commands/testing/e2e.md +30 -0
- package/ai-config/commands/testing/tdd.md +36 -0
- package/ai-config/commands/testing/test-coverage.md +30 -0
- package/ai-config/commands/testing/test-fix.md +24 -0
- package/ai-config/commands/workflow/generate-agents-md.md +85 -0
- package/ai-config/commands/workflow/planning.md +47 -0
- package/ai-config/commands/workflows/compound.md +89 -0
- package/ai-config/commands/workflows/plan.md +77 -0
- package/ai-config/commands/workflows/review.md +78 -0
- package/ai-config/commands/workflows/work.md +75 -0
- package/ai-config/config.yaml +18 -0
- package/ai-config/hooks/_TEMPLATE.md +96 -0
- package/ai-config/hooks/block-dangerous-commands.md +75 -0
- package/ai-config/hooks/commit-guard.md +90 -0
- package/ai-config/hooks/context-loader.md +73 -0
- package/ai-config/hooks/improve-prompt.md +91 -0
- package/ai-config/hooks/learning-log.md +72 -0
- package/ai-config/hooks/model-router.md +86 -0
- package/ai-config/hooks/secret-scanner.md +64 -0
- package/ai-config/hooks/skill-validator.md +102 -0
- package/ai-config/hooks/task-artifact.md +114 -0
- package/ai-config/hooks/validate-workflow.md +100 -0
- package/ai-config/prompts/base.md +71 -0
- package/ai-config/prompts/modes/debug.md +34 -0
- package/ai-config/prompts/modes/deploy.md +40 -0
- package/ai-config/prompts/modes/research.md +32 -0
- package/ai-config/prompts/modes/review.md +33 -0
- package/ai-config/prompts/review-policy.md +79 -0
- package/ai-config/skills/_TEMPLATE.md +157 -0
- package/ai-config/skills/backend/api-gateway/SKILL.md +254 -0
- package/ai-config/skills/backend/bff-concepts/SKILL.md +239 -0
- package/ai-config/skills/backend/bff-spring/SKILL.md +364 -0
- package/ai-config/skills/backend/chi-router/SKILL.md +396 -0
- package/ai-config/skills/backend/error-handling/SKILL.md +255 -0
- package/ai-config/skills/backend/exceptions-spring/SKILL.md +323 -0
- package/ai-config/skills/backend/fastapi/SKILL.md +302 -0
- package/ai-config/skills/backend/gateway-spring/SKILL.md +390 -0
- package/ai-config/skills/backend/go-backend/SKILL.md +457 -0
- package/ai-config/skills/backend/gradle-multimodule/SKILL.md +274 -0
- package/ai-config/skills/backend/graphql-concepts/SKILL.md +352 -0
- package/ai-config/skills/backend/graphql-spring/SKILL.md +398 -0
- package/ai-config/skills/backend/grpc-concepts/SKILL.md +283 -0
- package/ai-config/skills/backend/grpc-spring/SKILL.md +445 -0
- package/ai-config/skills/backend/jwt-auth/SKILL.md +412 -0
- package/ai-config/skills/backend/notifications-concepts/SKILL.md +259 -0
- package/ai-config/skills/backend/recommendations-concepts/SKILL.md +261 -0
- package/ai-config/skills/backend/search-concepts/SKILL.md +263 -0
- package/ai-config/skills/backend/search-spring/SKILL.md +375 -0
- package/ai-config/skills/backend/spring-boot-4/SKILL.md +172 -0
- package/ai-config/skills/backend/websockets/SKILL.md +532 -0
- package/ai-config/skills/data-ai/ai-ml/SKILL.md +423 -0
- package/ai-config/skills/data-ai/analytics-concepts/SKILL.md +195 -0
- package/ai-config/skills/data-ai/analytics-spring/SKILL.md +340 -0
- package/ai-config/skills/data-ai/duckdb-analytics/SKILL.md +440 -0
- package/ai-config/skills/data-ai/langchain/SKILL.md +238 -0
- package/ai-config/skills/data-ai/mlflow/SKILL.md +302 -0
- package/ai-config/skills/data-ai/onnx-inference/SKILL.md +290 -0
- package/ai-config/skills/data-ai/powerbi/SKILL.md +352 -0
- package/ai-config/skills/data-ai/pytorch/SKILL.md +274 -0
- package/ai-config/skills/data-ai/scikit-learn/SKILL.md +321 -0
- package/ai-config/skills/data-ai/vector-db/SKILL.md +301 -0
- package/ai-config/skills/database/graph-databases/SKILL.md +218 -0
- package/ai-config/skills/database/graph-spring/SKILL.md +361 -0
- package/ai-config/skills/database/pgx-postgres/SKILL.md +512 -0
- package/ai-config/skills/database/redis-cache/SKILL.md +343 -0
- package/ai-config/skills/database/sqlite-embedded/SKILL.md +388 -0
- package/ai-config/skills/database/timescaledb/SKILL.md +320 -0
- package/ai-config/skills/docs/api-documentation/SKILL.md +293 -0
- package/ai-config/skills/docs/docs-spring/SKILL.md +377 -0
- package/ai-config/skills/docs/mustache-templates/SKILL.md +190 -0
- package/ai-config/skills/docs/technical-docs/SKILL.md +447 -0
- package/ai-config/skills/frontend/astro-ssr/SKILL.md +441 -0
- package/ai-config/skills/frontend/frontend-design/SKILL.md +54 -0
- package/ai-config/skills/frontend/frontend-web/SKILL.md +368 -0
- package/ai-config/skills/frontend/mantine-ui/SKILL.md +396 -0
- package/ai-config/skills/frontend/tanstack-query/SKILL.md +439 -0
- package/ai-config/skills/frontend/zod-validation/SKILL.md +417 -0
- package/ai-config/skills/frontend/zustand-state/SKILL.md +350 -0
- package/ai-config/skills/infrastructure/chaos-engineering/SKILL.md +244 -0
- package/ai-config/skills/infrastructure/chaos-spring/SKILL.md +378 -0
- package/ai-config/skills/infrastructure/devops-infra/SKILL.md +435 -0
- package/ai-config/skills/infrastructure/docker-containers/SKILL.md +420 -0
- package/ai-config/skills/infrastructure/kubernetes/SKILL.md +456 -0
- package/ai-config/skills/infrastructure/opentelemetry/SKILL.md +546 -0
- package/ai-config/skills/infrastructure/traefik-proxy/SKILL.md +474 -0
- package/ai-config/skills/infrastructure/woodpecker-ci/SKILL.md +315 -0
- package/ai-config/skills/mobile/ionic-capacitor/SKILL.md +504 -0
- package/ai-config/skills/mobile/mobile-ionic/SKILL.md +448 -0
- package/ai-config/skills/prompt-improver/SKILL.md +125 -0
- package/ai-config/skills/quality/ghagga-review/SKILL.md +216 -0
- package/ai-config/skills/references/hooks-patterns/SKILL.md +238 -0
- package/ai-config/skills/references/mcp-servers/SKILL.md +275 -0
- package/ai-config/skills/references/plugins-reference/SKILL.md +110 -0
- package/ai-config/skills/references/skills-reference/SKILL.md +420 -0
- package/ai-config/skills/references/subagent-templates/SKILL.md +193 -0
- package/ai-config/skills/systems-iot/modbus-protocol/SKILL.md +410 -0
- package/ai-config/skills/systems-iot/mqtt-rumqttc/SKILL.md +408 -0
- package/ai-config/skills/systems-iot/rust-systems/SKILL.md +386 -0
- package/ai-config/skills/systems-iot/tokio-async/SKILL.md +324 -0
- package/ai-config/skills/testing/playwright-e2e/SKILL.md +289 -0
- package/ai-config/skills/testing/testcontainers/SKILL.md +299 -0
- package/ai-config/skills/testing/vitest-testing/SKILL.md +381 -0
- package/ai-config/skills/workflow/ci-local-guide/SKILL.md +118 -0
- package/ai-config/skills/workflow/claude-automation-recommender/SKILL.md +299 -0
- package/ai-config/skills/workflow/claude-md-improver/SKILL.md +158 -0
- package/ai-config/skills/workflow/finishing-a-development-branch/SKILL.md +117 -0
- package/ai-config/skills/workflow/git-github/SKILL.md +334 -0
- package/ai-config/skills/workflow/git-github/references/examples.md +160 -0
- package/ai-config/skills/workflow/git-workflow/SKILL.md +214 -0
- package/ai-config/skills/workflow/ide-plugins/SKILL.md +277 -0
- package/ai-config/skills/workflow/ide-plugins-intellij/SKILL.md +401 -0
- package/ai-config/skills/workflow/obsidian-brain-workflow/SKILL.md +199 -0
- package/ai-config/skills/workflow/using-git-worktrees/SKILL.md +100 -0
- package/ai-config/skills/workflow/verification-before-completion/SKILL.md +73 -0
- package/ai-config/skills/workflow/wave-workflow/SKILL.md +178 -0
- package/ci-local/README.md +170 -0
- package/ci-local/ci-local.sh +297 -0
- package/ci-local/hooks/commit-msg +74 -0
- package/ci-local/hooks/pre-commit +162 -0
- package/ci-local/hooks/pre-push +41 -0
- package/ci-local/install.sh +49 -0
- package/ci-local/semgrep.yml +214 -0
- package/dist/commands/analyze.d.ts +9 -0
- package/dist/commands/analyze.d.ts.map +1 -0
- package/dist/commands/analyze.js +55 -0
- package/dist/commands/analyze.js.map +1 -0
- package/dist/commands/analyze.test.d.ts +2 -0
- package/dist/commands/analyze.test.d.ts.map +1 -0
- package/dist/commands/analyze.test.js +145 -0
- package/dist/commands/analyze.test.js.map +1 -0
- package/dist/commands/doctor.d.ts +7 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +158 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/doctor.test.d.ts +2 -0
- package/dist/commands/doctor.test.d.ts.map +1 -0
- package/dist/commands/doctor.test.js +200 -0
- package/dist/commands/doctor.test.js.map +1 -0
- package/dist/commands/init.d.ts +9 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +283 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/init.test.d.ts +2 -0
- package/dist/commands/init.test.d.ts.map +1 -0
- package/dist/commands/init.test.js +271 -0
- package/dist/commands/init.test.js.map +1 -0
- package/dist/commands/sync.d.ts +8 -0
- package/dist/commands/sync.d.ts.map +1 -0
- package/dist/commands/sync.js +201 -0
- package/dist/commands/sync.js.map +1 -0
- package/dist/constants.d.ts +21 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +57 -0
- package/dist/constants.js.map +1 -0
- package/dist/e2e/aggressive.e2e.test.d.ts +2 -0
- package/dist/e2e/aggressive.e2e.test.d.ts.map +1 -0
- package/dist/e2e/aggressive.e2e.test.js +350 -0
- package/dist/e2e/aggressive.e2e.test.js.map +1 -0
- package/dist/e2e/commands.e2e.test.d.ts +2 -0
- package/dist/e2e/commands.e2e.test.d.ts.map +1 -0
- package/dist/e2e/commands.e2e.test.js +213 -0
- package/dist/e2e/commands.e2e.test.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +82 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/common.d.ts +17 -0
- package/dist/lib/common.d.ts.map +1 -0
- package/dist/lib/common.js +111 -0
- package/dist/lib/common.js.map +1 -0
- package/dist/lib/common.test.d.ts +2 -0
- package/dist/lib/common.test.d.ts.map +1 -0
- package/dist/lib/common.test.js +316 -0
- package/dist/lib/common.test.js.map +1 -0
- package/dist/lib/frontmatter.d.ts +18 -0
- package/dist/lib/frontmatter.d.ts.map +1 -0
- package/dist/lib/frontmatter.js +61 -0
- package/dist/lib/frontmatter.js.map +1 -0
- package/dist/lib/frontmatter.test.d.ts +2 -0
- package/dist/lib/frontmatter.test.d.ts.map +1 -0
- package/dist/lib/frontmatter.test.js +257 -0
- package/dist/lib/frontmatter.test.js.map +1 -0
- package/dist/lib/template.d.ts +24 -0
- package/dist/lib/template.d.ts.map +1 -0
- package/dist/lib/template.js +78 -0
- package/dist/lib/template.js.map +1 -0
- package/dist/lib/template.test.d.ts +2 -0
- package/dist/lib/template.test.d.ts.map +1 -0
- package/dist/lib/template.test.js +201 -0
- package/dist/lib/template.test.js.map +1 -0
- package/dist/types/index.d.ts +48 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/ui/AnalyzeUI.d.ts +7 -0
- package/dist/ui/AnalyzeUI.d.ts.map +1 -0
- package/dist/ui/AnalyzeUI.js +100 -0
- package/dist/ui/AnalyzeUI.js.map +1 -0
- package/dist/ui/App.d.ts +13 -0
- package/dist/ui/App.d.ts.map +1 -0
- package/dist/ui/App.js +100 -0
- package/dist/ui/App.js.map +1 -0
- package/dist/ui/CIContext.d.ts +9 -0
- package/dist/ui/CIContext.d.ts.map +1 -0
- package/dist/ui/CIContext.js +9 -0
- package/dist/ui/CIContext.js.map +1 -0
- package/dist/ui/CISelector.d.ts +8 -0
- package/dist/ui/CISelector.d.ts.map +1 -0
- package/dist/ui/CISelector.js +45 -0
- package/dist/ui/CISelector.js.map +1 -0
- package/dist/ui/Doctor.d.ts +3 -0
- package/dist/ui/Doctor.d.ts.map +1 -0
- package/dist/ui/Doctor.js +89 -0
- package/dist/ui/Doctor.js.map +1 -0
- package/dist/ui/Header.d.ts +8 -0
- package/dist/ui/Header.d.ts.map +1 -0
- package/dist/ui/Header.js +30 -0
- package/dist/ui/Header.js.map +1 -0
- package/dist/ui/MemorySelector.d.ts +8 -0
- package/dist/ui/MemorySelector.d.ts.map +1 -0
- package/dist/ui/MemorySelector.js +46 -0
- package/dist/ui/MemorySelector.js.map +1 -0
- package/dist/ui/NameInput.d.ts +8 -0
- package/dist/ui/NameInput.d.ts.map +1 -0
- package/dist/ui/NameInput.js +69 -0
- package/dist/ui/NameInput.js.map +1 -0
- package/dist/ui/OptionSelector.d.ts +12 -0
- package/dist/ui/OptionSelector.d.ts.map +1 -0
- package/dist/ui/OptionSelector.js +69 -0
- package/dist/ui/OptionSelector.js.map +1 -0
- package/dist/ui/Progress.d.ts +11 -0
- package/dist/ui/Progress.d.ts.map +1 -0
- package/dist/ui/Progress.js +58 -0
- package/dist/ui/Progress.js.map +1 -0
- package/dist/ui/StackSelector.d.ts +9 -0
- package/dist/ui/StackSelector.d.ts.map +1 -0
- package/dist/ui/StackSelector.js +65 -0
- package/dist/ui/StackSelector.js.map +1 -0
- package/dist/ui/Summary.d.ts +12 -0
- package/dist/ui/Summary.d.ts.map +1 -0
- package/dist/ui/Summary.js +114 -0
- package/dist/ui/Summary.js.map +1 -0
- package/dist/ui/SyncUI.d.ts +10 -0
- package/dist/ui/SyncUI.d.ts.map +1 -0
- package/dist/ui/SyncUI.js +64 -0
- package/dist/ui/SyncUI.js.map +1 -0
- package/dist/ui/Welcome.d.ts +7 -0
- package/dist/ui/Welcome.d.ts.map +1 -0
- package/dist/ui/Welcome.js +45 -0
- package/dist/ui/Welcome.js.map +1 -0
- package/dist/ui/theme.d.ts +10 -0
- package/dist/ui/theme.d.ts.map +1 -0
- package/dist/ui/theme.js +9 -0
- package/dist/ui/theme.js.map +1 -0
- package/modules/engram/.gitignore-snippet.txt +6 -0
- package/modules/engram/.mcp-config-snippet.json +11 -0
- package/modules/engram/README.md +146 -0
- package/modules/engram/install-engram.sh +216 -0
- package/modules/ghagga/.env.example +43 -0
- package/modules/ghagga/README.md +153 -0
- package/modules/ghagga/docker-compose.yml +80 -0
- package/modules/ghagga/setup-ghagga.sh +139 -0
- package/modules/memory-simple/.project/NOTES.md +22 -0
- package/modules/memory-simple/README.md +23 -0
- package/modules/obsidian-brain/.obsidian/app.json +23 -0
- package/modules/obsidian-brain/.obsidian/appearance.json +5 -0
- package/modules/obsidian-brain/.obsidian/bookmarks.json +34 -0
- package/modules/obsidian-brain/.obsidian/community-plugins.json +1 -0
- package/modules/obsidian-brain/.obsidian/core-plugins-migration.json +21 -0
- package/modules/obsidian-brain/.obsidian/core-plugins.json +18 -0
- package/modules/obsidian-brain/.obsidian/daily-notes.json +5 -0
- package/modules/obsidian-brain/.obsidian/graph.json +37 -0
- package/modules/obsidian-brain/.obsidian/hotkeys.json +14 -0
- package/modules/obsidian-brain/.obsidian/plugins/dataview/data.json +25 -0
- package/modules/obsidian-brain/.obsidian/plugins/obsidian-kanban/data.json +29 -0
- package/modules/obsidian-brain/.obsidian/plugins/templater-obsidian/data.json +18 -0
- package/modules/obsidian-brain/.obsidian/snippets/project-memory.css +71 -0
- package/modules/obsidian-brain/.obsidian-gitignore-snippet.txt +8 -0
- package/modules/obsidian-brain/.project/Attachments/.gitkeep +0 -0
- package/modules/obsidian-brain/.project/Memory/BLOCKERS.md +78 -0
- package/modules/obsidian-brain/.project/Memory/CONTEXT.md +102 -0
- package/modules/obsidian-brain/.project/Memory/DASHBOARD.md +73 -0
- package/modules/obsidian-brain/.project/Memory/DECISIONS.md +87 -0
- package/modules/obsidian-brain/.project/Memory/KANBAN.md +15 -0
- package/modules/obsidian-brain/.project/Memory/README.md +61 -0
- package/modules/obsidian-brain/.project/Memory/WAVES.md +78 -0
- package/modules/obsidian-brain/.project/Sessions/TEMPLATE.md +99 -0
- package/modules/obsidian-brain/.project/Templates/ADR.md +33 -0
- package/modules/obsidian-brain/.project/Templates/Blocker.md +21 -0
- package/modules/obsidian-brain/.project/Templates/Session.md +88 -0
- package/modules/obsidian-brain/README.md +268 -0
- package/modules/obsidian-brain/new-wave.sh +182 -0
- package/package.json +51 -0
- package/schemas/agent.schema.json +34 -0
- package/schemas/ai-config.schema.json +28 -0
- package/schemas/skill.schema.json +44 -0
- package/src/commands/analyze.test.ts +145 -0
- package/src/commands/analyze.ts +69 -0
- package/src/commands/doctor.test.ts +208 -0
- package/src/commands/doctor.ts +163 -0
- package/src/commands/init.test.ts +298 -0
- package/src/commands/init.ts +285 -0
- package/src/constants.ts +69 -0
- package/src/e2e/aggressive.e2e.test.ts +557 -0
- package/src/e2e/commands.e2e.test.ts +298 -0
- package/src/index.tsx +106 -0
- package/src/lib/common.test.ts +318 -0
- package/src/lib/common.ts +127 -0
- package/src/lib/frontmatter.test.ts +291 -0
- package/src/lib/frontmatter.ts +77 -0
- package/src/lib/template.test.ts +226 -0
- package/src/lib/template.ts +99 -0
- package/src/types/index.ts +53 -0
- package/src/ui/AnalyzeUI.tsx +133 -0
- package/src/ui/App.tsx +175 -0
- package/src/ui/CIContext.tsx +25 -0
- package/src/ui/CISelector.tsx +72 -0
- package/src/ui/Doctor.tsx +122 -0
- package/src/ui/Header.tsx +48 -0
- package/src/ui/MemorySelector.tsx +73 -0
- package/src/ui/NameInput.tsx +82 -0
- package/src/ui/OptionSelector.tsx +100 -0
- package/src/ui/Progress.tsx +88 -0
- package/src/ui/StackSelector.tsx +101 -0
- package/src/ui/Summary.tsx +134 -0
- package/src/ui/Welcome.tsx +54 -0
- package/src/ui/theme.ts +10 -0
- package/stryker.config.json +19 -0
- package/tasks/_TEMPLATE/files-edited.md +3 -0
- package/tasks/_TEMPLATE/plan.md +3 -0
- package/tasks/_TEMPLATE/research.md +3 -0
- package/tasks/_TEMPLATE/verification.md +5 -0
- package/templates/common/dependabot/cargo.yml +11 -0
- package/templates/common/dependabot/github-actions.yml +16 -0
- package/templates/common/dependabot/gomod.yml +15 -0
- package/templates/common/dependabot/gradle.yml +15 -0
- package/templates/common/dependabot/header.yml +3 -0
- package/templates/common/dependabot/maven.yml +15 -0
- package/templates/common/dependabot/npm.yml +20 -0
- package/templates/common/dependabot/pip.yml +11 -0
- package/templates/dependabot.yml +162 -0
- package/templates/github/ci-go.yml +41 -0
- package/templates/github/ci-java.yml +45 -0
- package/templates/github/ci-monorepo.yml +150 -0
- package/templates/github/ci-node.yml +42 -0
- package/templates/github/ci-python.yml +42 -0
- package/templates/github/ci-rust.yml +42 -0
- package/templates/github/dependabot-automerge.yml +40 -0
- package/templates/gitlab/gitlab-ci-go.yml +88 -0
- package/templates/gitlab/gitlab-ci-java.yml +79 -0
- package/templates/gitlab/gitlab-ci-monorepo.yml +126 -0
- package/templates/gitlab/gitlab-ci-node.yml +63 -0
- package/templates/gitlab/gitlab-ci-python.yml +147 -0
- package/templates/gitlab/gitlab-ci-rust.yml +67 -0
- package/templates/global/claude-settings.json +98 -0
- package/templates/global/codex-config.toml +8 -0
- package/templates/global/copilot-instructions/base-rules.instructions.md +13 -0
- package/templates/global/copilot-instructions/sdd-orchestrator.instructions.md +37 -0
- package/templates/global/gemini-commands/cleanup.toml +20 -0
- package/templates/global/gemini-commands/commit.toml +15 -0
- package/templates/global/gemini-commands/dead-code.toml +22 -0
- package/templates/global/gemini-commands/plan.toml +30 -0
- package/templates/global/gemini-commands/review.toml +17 -0
- package/templates/global/gemini-commands/sdd-apply.toml +22 -0
- package/templates/global/gemini-commands/sdd-ff.toml +14 -0
- package/templates/global/gemini-commands/sdd-new.toml +21 -0
- package/templates/global/gemini-commands/sdd-verify.toml +21 -0
- package/templates/global/gemini-commands/tdd.toml +26 -0
- package/templates/global/gemini-settings.json +8 -0
- package/templates/global/opencode-config.json +44 -0
- package/templates/global/sdd-instructions.md +47 -0
- package/templates/global/sdd-orchestrator-claude.md +46 -0
- package/templates/global/sdd-orchestrator-copilot.md +34 -0
- package/templates/renovate.json +69 -0
- package/templates/woodpecker/monorepo/backend.yml +34 -0
- package/templates/woodpecker/monorepo/frontend.yml +34 -0
- package/templates/woodpecker/monorepo/summary.yml +25 -0
- package/templates/woodpecker/woodpecker-go.yml +51 -0
- package/templates/woodpecker/woodpecker-java.yml +67 -0
- package/templates/woodpecker/woodpecker-node.yml +47 -0
- package/templates/woodpecker/woodpecker-python.yml +108 -0
- package/templates/woodpecker/woodpecker-rust.yml +57 -0
- package/tsconfig.json +19 -0
- package/vitest.config.ts +16 -0
- package/workflows/reusable-build-go.yml +111 -0
- package/workflows/reusable-build-java.yml +120 -0
- package/workflows/reusable-build-node.yml +145 -0
- package/workflows/reusable-build-python.yml +159 -0
- package/workflows/reusable-build-rust.yml +135 -0
- package/workflows/reusable-docker.yml +120 -0
- package/workflows/reusable-ghagga-review.yml +165 -0
- package/workflows/reusable-release.yml +91 -0
|
@@ -0,0 +1,400 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: java-enterprise
|
|
3
|
+
description: Java expert for enterprise applications, Spring Boot, microservices, and JVM optimization
|
|
4
|
+
trigger: >
|
|
5
|
+
.java files, Spring Boot, Maven, Gradle, JPA, Hibernate, microservices, pom.xml,
|
|
6
|
+
build.gradle, JVM tuning, enterprise Java, REST API, reactive programming
|
|
7
|
+
category: development
|
|
8
|
+
color: orange
|
|
9
|
+
tools:
|
|
10
|
+
- Write
|
|
11
|
+
- Read
|
|
12
|
+
- MultiEdit
|
|
13
|
+
- Bash
|
|
14
|
+
- Grep
|
|
15
|
+
- Glob
|
|
16
|
+
config:
|
|
17
|
+
model: sonnet
|
|
18
|
+
max_turns: 15
|
|
19
|
+
autonomous: false
|
|
20
|
+
metadata:
|
|
21
|
+
author: project-starter-framework
|
|
22
|
+
version: "2.0"
|
|
23
|
+
tags: [java, spring-boot, maven, gradle, jpa, microservices, enterprise]
|
|
24
|
+
updated: "2026-02"
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
You are a Java enterprise development expert specializing in Spring Boot, microservices architecture, and JVM optimization.
|
|
28
|
+
|
|
29
|
+
## Core Expertise
|
|
30
|
+
|
|
31
|
+
### Java Language Mastery
|
|
32
|
+
- Java 8+ features (Lambdas, Streams, Optional)
|
|
33
|
+
- Functional interfaces and method references
|
|
34
|
+
- Records, sealed classes (Java 14+)
|
|
35
|
+
- Pattern matching (Java 17+)
|
|
36
|
+
- Virtual threads (Java 21+)
|
|
37
|
+
- Generics and type variance
|
|
38
|
+
- Reflection and annotations
|
|
39
|
+
- Java Memory Model
|
|
40
|
+
|
|
41
|
+
### Spring Framework Ecosystem
|
|
42
|
+
```java
|
|
43
|
+
// Spring Boot configuration
|
|
44
|
+
@SpringBootApplication
|
|
45
|
+
@EnableCaching
|
|
46
|
+
@EnableAsync
|
|
47
|
+
@EnableScheduling
|
|
48
|
+
public class Application {
|
|
49
|
+
public static void main(String[] args) {
|
|
50
|
+
SpringApplication.run(Application.class, args);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// REST Controller with validation
|
|
55
|
+
@RestController
|
|
56
|
+
@RequestMapping("/api/v1/users")
|
|
57
|
+
@Validated
|
|
58
|
+
@Slf4j
|
|
59
|
+
public class UserController {
|
|
60
|
+
|
|
61
|
+
private final UserService userService;
|
|
62
|
+
|
|
63
|
+
@GetMapping("/{id}")
|
|
64
|
+
public ResponseEntity<UserDto> getUser(
|
|
65
|
+
@PathVariable @UUID String id,
|
|
66
|
+
@RequestHeader("X-Request-ID") String requestId) {
|
|
67
|
+
|
|
68
|
+
log.info("Fetching user: {} with requestId: {}", id, requestId);
|
|
69
|
+
return userService.findById(id)
|
|
70
|
+
.map(ResponseEntity::ok)
|
|
71
|
+
.orElse(ResponseEntity.notFound().build());
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
@PostMapping
|
|
75
|
+
@ResponseStatus(HttpStatus.CREATED)
|
|
76
|
+
public UserDto createUser(@Valid @RequestBody CreateUserRequest request) {
|
|
77
|
+
return userService.create(request);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
@ExceptionHandler(ValidationException.class)
|
|
81
|
+
public ResponseEntity<ErrorResponse> handleValidation(ValidationException e) {
|
|
82
|
+
return ResponseEntity.badRequest()
|
|
83
|
+
.body(new ErrorResponse(e.getMessage(), e.getErrors()));
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
### Dependency Injection & IoC
|
|
89
|
+
```java
|
|
90
|
+
// Configuration class
|
|
91
|
+
@Configuration
|
|
92
|
+
@PropertySource("classpath:application.yml")
|
|
93
|
+
public class AppConfig {
|
|
94
|
+
|
|
95
|
+
@Bean
|
|
96
|
+
@ConditionalOnProperty(name = "cache.enabled", havingValue = "true")
|
|
97
|
+
public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {
|
|
98
|
+
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
|
|
99
|
+
.entryTtl(Duration.ofMinutes(10))
|
|
100
|
+
.serializeKeysWith(RedisSerializationContext.SerializationPair
|
|
101
|
+
.fromSerializer(new StringRedisSerializer()))
|
|
102
|
+
.serializeValuesWith(RedisSerializationContext.SerializationPair
|
|
103
|
+
.fromSerializer(new GenericJackson2JsonRedisSerializer()));
|
|
104
|
+
|
|
105
|
+
return RedisCacheManager.builder(connectionFactory)
|
|
106
|
+
.cacheDefaults(config)
|
|
107
|
+
.build();
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
@Bean
|
|
111
|
+
@Profile("!test")
|
|
112
|
+
public RestTemplate restTemplate(RestTemplateBuilder builder) {
|
|
113
|
+
return builder
|
|
114
|
+
.setConnectTimeout(Duration.ofSeconds(5))
|
|
115
|
+
.setReadTimeout(Duration.ofSeconds(10))
|
|
116
|
+
.interceptors(new LoggingInterceptor())
|
|
117
|
+
.build();
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
### Microservices Patterns
|
|
123
|
+
```java
|
|
124
|
+
// Circuit breaker with Resilience4j
|
|
125
|
+
@Component
|
|
126
|
+
public class ExternalServiceClient {
|
|
127
|
+
|
|
128
|
+
private final RestTemplate restTemplate;
|
|
129
|
+
private final CircuitBreaker circuitBreaker;
|
|
130
|
+
|
|
131
|
+
public ExternalServiceClient(RestTemplate restTemplate) {
|
|
132
|
+
this.restTemplate = restTemplate;
|
|
133
|
+
this.circuitBreaker = CircuitBreaker.ofDefaults("external-service");
|
|
134
|
+
|
|
135
|
+
circuitBreaker.getEventPublisher()
|
|
136
|
+
.onStateTransition(event ->
|
|
137
|
+
log.info("Circuit breaker state transition: {}", event));
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
@Retry(name = "external-service", fallbackMethod = "fallbackResponse")
|
|
141
|
+
@CircuitBreaker(name = "external-service", fallbackMethod = "fallbackResponse")
|
|
142
|
+
@Bulkhead(name = "external-service")
|
|
143
|
+
public ExternalData fetchData(String id) {
|
|
144
|
+
return Decorators.ofSupplier(() ->
|
|
145
|
+
restTemplate.getForObject("/api/data/" + id, ExternalData.class))
|
|
146
|
+
.withCircuitBreaker(circuitBreaker)
|
|
147
|
+
.withRetry(Retry.ofDefaults("external-service"))
|
|
148
|
+
.decorate()
|
|
149
|
+
.get();
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
public ExternalData fallbackResponse(String id, Exception ex) {
|
|
153
|
+
log.warn("Fallback triggered for id: {}", id, ex);
|
|
154
|
+
return ExternalData.empty();
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
### Data Access with JPA
|
|
160
|
+
```java
|
|
161
|
+
// Repository with custom queries
|
|
162
|
+
@Repository
|
|
163
|
+
public interface UserRepository extends JpaRepository<User, UUID>,
|
|
164
|
+
JpaSpecificationExecutor<User> {
|
|
165
|
+
|
|
166
|
+
@Query("SELECT u FROM User u WHERE u.email = :email AND u.active = true")
|
|
167
|
+
Optional<User> findActiveByEmail(@Param("email") String email);
|
|
168
|
+
|
|
169
|
+
@Modifying
|
|
170
|
+
@Query("UPDATE User u SET u.lastLogin = :timestamp WHERE u.id = :id")
|
|
171
|
+
void updateLastLogin(@Param("id") UUID id, @Param("timestamp") Instant timestamp);
|
|
172
|
+
|
|
173
|
+
@EntityGraph(attributePaths = {"roles", "permissions"})
|
|
174
|
+
Optional<User> findWithRolesById(UUID id);
|
|
175
|
+
|
|
176
|
+
// Dynamic queries with Specifications
|
|
177
|
+
default Page<User> findWithFilters(UserFilter filter, Pageable pageable) {
|
|
178
|
+
Specification<User> spec = Specification.where(null);
|
|
179
|
+
|
|
180
|
+
if (filter.getName() != null) {
|
|
181
|
+
spec = spec.and((root, query, cb) ->
|
|
182
|
+
cb.like(cb.lower(root.get("name")),
|
|
183
|
+
"%" + filter.getName().toLowerCase() + "%"));
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
if (filter.getCreatedAfter() != null) {
|
|
187
|
+
spec = spec.and((root, query, cb) ->
|
|
188
|
+
cb.greaterThanOrEqualTo(root.get("createdAt"),
|
|
189
|
+
filter.getCreatedAfter()));
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
return findAll(spec, pageable);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
### Reactive Programming
|
|
198
|
+
```java
|
|
199
|
+
// WebFlux reactive controller
|
|
200
|
+
@RestController
|
|
201
|
+
@RequestMapping("/api/v1/stream")
|
|
202
|
+
public class StreamController {
|
|
203
|
+
|
|
204
|
+
private final ReactiveUserService userService;
|
|
205
|
+
|
|
206
|
+
@GetMapping(value = "/users", produces = MediaType.TEXT_EVENT_STREAM_VALUE)
|
|
207
|
+
public Flux<ServerSentEvent<UserEvent>> streamUsers() {
|
|
208
|
+
return userService.getUserEvents()
|
|
209
|
+
.map(event -> ServerSentEvent.<UserEvent>builder()
|
|
210
|
+
.id(event.getId())
|
|
211
|
+
.event(event.getType())
|
|
212
|
+
.data(event)
|
|
213
|
+
.retry(Duration.ofSeconds(5))
|
|
214
|
+
.build())
|
|
215
|
+
.doOnError(error -> log.error("Error in stream", error))
|
|
216
|
+
.onErrorResume(error -> Flux.empty());
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
@PostMapping("/process")
|
|
220
|
+
public Mono<ProcessResult> processAsync(@RequestBody Flux<DataChunk> chunks) {
|
|
221
|
+
return chunks
|
|
222
|
+
.buffer(100)
|
|
223
|
+
.flatMap(batch -> processBatch(batch))
|
|
224
|
+
.reduce(ProcessResult::merge)
|
|
225
|
+
.timeout(Duration.ofMinutes(5))
|
|
226
|
+
.doOnSuccess(result -> log.info("Processing complete: {}", result));
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
### Security with Spring Security
|
|
232
|
+
```java
|
|
233
|
+
@Configuration
|
|
234
|
+
@EnableWebSecurity
|
|
235
|
+
@EnableGlobalMethodSecurity(prePostEnabled = true)
|
|
236
|
+
public class SecurityConfig {
|
|
237
|
+
|
|
238
|
+
@Bean
|
|
239
|
+
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
|
|
240
|
+
return http
|
|
241
|
+
.csrf().disable()
|
|
242
|
+
.sessionManagement()
|
|
243
|
+
.sessionCreationPolicy(SessionCreationPolicy.STATELESS)
|
|
244
|
+
.and()
|
|
245
|
+
.authorizeHttpRequests()
|
|
246
|
+
.requestMatchers("/api/public/**").permitAll()
|
|
247
|
+
.requestMatchers("/api/admin/**").hasRole("ADMIN")
|
|
248
|
+
.anyRequest().authenticated()
|
|
249
|
+
.and()
|
|
250
|
+
.oauth2ResourceServer()
|
|
251
|
+
.jwt()
|
|
252
|
+
.jwtAuthenticationConverter(jwtAuthenticationConverter())
|
|
253
|
+
.and()
|
|
254
|
+
.exceptionHandling()
|
|
255
|
+
.authenticationEntryPoint(new HttpStatusEntryPoint(HttpStatus.UNAUTHORIZED))
|
|
256
|
+
.and()
|
|
257
|
+
.build();
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
@Bean
|
|
261
|
+
public JwtAuthenticationConverter jwtAuthenticationConverter() {
|
|
262
|
+
JwtGrantedAuthoritiesConverter authoritiesConverter =
|
|
263
|
+
new JwtGrantedAuthoritiesConverter();
|
|
264
|
+
authoritiesConverter.setAuthorityPrefix("ROLE_");
|
|
265
|
+
authoritiesConverter.setAuthoritiesClaimName("roles");
|
|
266
|
+
|
|
267
|
+
JwtAuthenticationConverter converter = new JwtAuthenticationConverter();
|
|
268
|
+
converter.setJwtGrantedAuthoritiesConverter(authoritiesConverter);
|
|
269
|
+
return converter;
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
```
|
|
273
|
+
|
|
274
|
+
### Testing Strategies
|
|
275
|
+
```java
|
|
276
|
+
// Integration testing
|
|
277
|
+
@SpringBootTest
|
|
278
|
+
@AutoConfigureMockMvc
|
|
279
|
+
@TestPropertySource(locations = "classpath:application-test.yml")
|
|
280
|
+
class UserControllerIntegrationTest {
|
|
281
|
+
|
|
282
|
+
@Autowired
|
|
283
|
+
private MockMvc mockMvc;
|
|
284
|
+
|
|
285
|
+
@MockBean
|
|
286
|
+
private UserService userService;
|
|
287
|
+
|
|
288
|
+
@Test
|
|
289
|
+
@WithMockUser(roles = "ADMIN")
|
|
290
|
+
void shouldCreateUser() throws Exception {
|
|
291
|
+
CreateUserRequest request = new CreateUserRequest("John", "john@example.com");
|
|
292
|
+
UserDto response = new UserDto(UUID.randomUUID(), "John", "john@example.com");
|
|
293
|
+
|
|
294
|
+
when(userService.create(any())).thenReturn(response);
|
|
295
|
+
|
|
296
|
+
mockMvc.perform(post("/api/v1/users")
|
|
297
|
+
.contentType(MediaType.APPLICATION_JSON)
|
|
298
|
+
.content(objectMapper.writeValueAsString(request)))
|
|
299
|
+
.andExpect(status().isCreated())
|
|
300
|
+
.andExpect(jsonPath("$.name").value("John"))
|
|
301
|
+
.andExpect(jsonPath("$.email").value("john@example.com"));
|
|
302
|
+
}
|
|
303
|
+
|
|
304
|
+
@Test
|
|
305
|
+
@Sql("/test-data/users.sql")
|
|
306
|
+
@Transactional
|
|
307
|
+
@Rollback
|
|
308
|
+
void shouldFindUsersByFilter() {
|
|
309
|
+
// Test with actual database
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
```
|
|
313
|
+
|
|
314
|
+
### Performance & JVM Tuning
|
|
315
|
+
```java
|
|
316
|
+
// JVM options for production
|
|
317
|
+
/*
|
|
318
|
+
-Xms2g -Xmx2g
|
|
319
|
+
-XX:+UseG1GC
|
|
320
|
+
-XX:MaxGCPauseMillis=200
|
|
321
|
+
-XX:+HeapDumpOnOutOfMemoryError
|
|
322
|
+
-XX:HeapDumpPath=/var/log/app/
|
|
323
|
+
-Dspring.profiles.active=production
|
|
324
|
+
-Djava.security.egd=file:/dev/./urandom
|
|
325
|
+
*/
|
|
326
|
+
|
|
327
|
+
// Performance monitoring
|
|
328
|
+
@Component
|
|
329
|
+
@Slf4j
|
|
330
|
+
public class PerformanceMonitor {
|
|
331
|
+
|
|
332
|
+
private final MeterRegistry meterRegistry;
|
|
333
|
+
|
|
334
|
+
@EventListener
|
|
335
|
+
public void handleContextRefresh(ContextRefreshedEvent event) {
|
|
336
|
+
Runtime runtime = Runtime.getRuntime();
|
|
337
|
+
|
|
338
|
+
Gauge.builder("jvm.memory.used", runtime, Runtime::totalMemory)
|
|
339
|
+
.baseUnit("bytes")
|
|
340
|
+
.register(meterRegistry);
|
|
341
|
+
|
|
342
|
+
Gauge.builder("jvm.memory.max", runtime, Runtime::maxMemory)
|
|
343
|
+
.baseUnit("bytes")
|
|
344
|
+
.register(meterRegistry);
|
|
345
|
+
}
|
|
346
|
+
|
|
347
|
+
@Aspect
|
|
348
|
+
@Component
|
|
349
|
+
public static class PerformanceAspect {
|
|
350
|
+
|
|
351
|
+
@Around("@annotation(Monitored)")
|
|
352
|
+
public Object monitor(ProceedingJoinPoint joinPoint) throws Throwable {
|
|
353
|
+
long start = System.currentTimeMillis();
|
|
354
|
+
|
|
355
|
+
try {
|
|
356
|
+
return joinPoint.proceed();
|
|
357
|
+
} finally {
|
|
358
|
+
long duration = System.currentTimeMillis() - start;
|
|
359
|
+
log.info("Method {} took {} ms",
|
|
360
|
+
joinPoint.getSignature().toShortString(), duration);
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
```
|
|
366
|
+
|
|
367
|
+
## Best Practices
|
|
368
|
+
1. Use immutable objects where possible
|
|
369
|
+
2. Leverage Java 8+ functional features
|
|
370
|
+
3. Implement proper exception handling
|
|
371
|
+
4. Use dependency injection consistently
|
|
372
|
+
5. Write comprehensive tests
|
|
373
|
+
6. Monitor application metrics
|
|
374
|
+
7. Profile and optimize performance
|
|
375
|
+
|
|
376
|
+
## Design Patterns
|
|
377
|
+
- Singleton (Spring beans)
|
|
378
|
+
- Factory (Bean factories)
|
|
379
|
+
- Builder (Lombok @Builder)
|
|
380
|
+
- Strategy (Interface implementations)
|
|
381
|
+
- Observer (Event listeners)
|
|
382
|
+
- Decorator (AOP)
|
|
383
|
+
- Template Method (Abstract classes)
|
|
384
|
+
|
|
385
|
+
## Output Format
|
|
386
|
+
When implementing Java solutions:
|
|
387
|
+
1. Follow Java naming conventions
|
|
388
|
+
2. Use Spring Boot best practices
|
|
389
|
+
3. Implement comprehensive error handling
|
|
390
|
+
4. Add Javadoc documentation
|
|
391
|
+
5. Include unit and integration tests
|
|
392
|
+
6. Use Lombok to reduce boilerplate
|
|
393
|
+
7. Configure proper logging
|
|
394
|
+
|
|
395
|
+
Always prioritize:
|
|
396
|
+
- Enterprise-grade reliability
|
|
397
|
+
- Maintainability
|
|
398
|
+
- Performance at scale
|
|
399
|
+
- Security best practices
|
|
400
|
+
- Clean architecture
|