@mytechtoday/augment-extensions 0.1.2 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +614 -39
- package/augment-extensions/coding-standards/bash/README.md +196 -0
- package/augment-extensions/coding-standards/bash/module.json +163 -0
- package/augment-extensions/coding-standards/bash/rules/naming-conventions.md +336 -0
- package/augment-extensions/coding-standards/bash/rules/universal-standards.md +289 -0
- package/augment-extensions/coding-standards/css/README.md +40 -0
- package/augment-extensions/coding-standards/css/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/css/module.json +44 -0
- package/augment-extensions/coding-standards/css/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/css/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html/README.md +40 -0
- package/augment-extensions/coding-standards/html/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html/module.json +44 -0
- package/augment-extensions/coding-standards/html/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/README.md +194 -0
- package/augment-extensions/coding-standards/html-css-js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/html-css-js/examples/css-examples.css +550 -0
- package/augment-extensions/coding-standards/html-css-js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/html-css-js/examples/html-examples.html +267 -0
- package/augment-extensions/coding-standards/html-css-js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/html-css-js/examples/responsive-layout.html +505 -0
- package/augment-extensions/coding-standards/html-css-js/module.json +48 -0
- package/augment-extensions/coding-standards/html-css-js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-modern-features.md +448 -0
- package/augment-extensions/coding-standards/html-css-js/rules/css-standards.md +492 -0
- package/augment-extensions/coding-standards/html-css-js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/html-css-js/rules/html-standards.md +349 -0
- package/augment-extensions/coding-standards/html-css-js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/html-css-js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/html-css-js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/js/README.md +46 -0
- package/augment-extensions/coding-standards/js/examples/async-examples.js +487 -0
- package/augment-extensions/coding-standards/js/examples/dom-examples.js +667 -0
- package/augment-extensions/coding-standards/js/examples/javascript-examples.js +612 -0
- package/augment-extensions/coding-standards/js/module.json +49 -0
- package/augment-extensions/coding-standards/js/rules/async-patterns.md +515 -0
- package/augment-extensions/coding-standards/js/rules/dom-manipulation.md +439 -0
- package/augment-extensions/coding-standards/js/rules/javascript-standards.md +486 -0
- package/augment-extensions/coding-standards/js/rules/performance.md +463 -0
- package/augment-extensions/coding-standards/js/rules/tooling.md +543 -0
- package/augment-extensions/coding-standards/php/README.md +248 -0
- package/augment-extensions/coding-standards/php/examples/api-endpoint-example.php +204 -0
- package/augment-extensions/coding-standards/php/examples/cli-command-example.php +206 -0
- package/augment-extensions/coding-standards/php/examples/legacy-refactoring-example.php +234 -0
- package/augment-extensions/coding-standards/php/examples/web-application-example.php +211 -0
- package/augment-extensions/coding-standards/php/examples/woocommerce-extension-example.php +215 -0
- package/augment-extensions/coding-standards/php/examples/wordpress-plugin-example.php +189 -0
- package/augment-extensions/coding-standards/php/module.json +166 -0
- package/augment-extensions/coding-standards/php/rules/api-development.md +480 -0
- package/augment-extensions/coding-standards/php/rules/category-configuration.md +332 -0
- package/augment-extensions/coding-standards/php/rules/cli-tools.md +472 -0
- package/augment-extensions/coding-standards/php/rules/cms-integration.md +561 -0
- package/augment-extensions/coding-standards/php/rules/code-quality.md +402 -0
- package/augment-extensions/coding-standards/php/rules/documentation.md +425 -0
- package/augment-extensions/coding-standards/php/rules/ecommerce.md +627 -0
- package/augment-extensions/coding-standards/php/rules/error-handling.md +336 -0
- package/augment-extensions/coding-standards/php/rules/legacy-migration.md +677 -0
- package/augment-extensions/coding-standards/php/rules/naming-conventions.md +279 -0
- package/augment-extensions/coding-standards/php/rules/performance.md +392 -0
- package/augment-extensions/coding-standards/php/rules/psr-standards.md +186 -0
- package/augment-extensions/coding-standards/php/rules/security.md +358 -0
- package/augment-extensions/coding-standards/php/rules/testing.md +403 -0
- package/augment-extensions/coding-standards/php/rules/type-declarations.md +331 -0
- package/augment-extensions/coding-standards/php/rules/web-applications.md +426 -0
- package/augment-extensions/coding-standards/powershell/README.md +154 -0
- package/augment-extensions/coding-standards/powershell/examples/admin-example.ps1 +272 -0
- package/augment-extensions/coding-standards/powershell/examples/automation-example.ps1 +173 -0
- package/augment-extensions/coding-standards/powershell/examples/cloud-example.ps1 +243 -0
- package/augment-extensions/coding-standards/powershell/examples/cross-platform-example.ps1 +297 -0
- package/augment-extensions/coding-standards/powershell/examples/dsc-example.ps1 +224 -0
- package/augment-extensions/coding-standards/powershell/examples/legacy-migration-example.ps1 +340 -0
- package/augment-extensions/coding-standards/powershell/examples/module-example.psm1 +255 -0
- package/augment-extensions/coding-standards/powershell/module.json +165 -0
- package/augment-extensions/coding-standards/powershell/rules/administrative-tools.md +439 -0
- package/augment-extensions/coding-standards/powershell/rules/automation-scripts.md +240 -0
- package/augment-extensions/coding-standards/powershell/rules/cloud-orchestration.md +384 -0
- package/augment-extensions/coding-standards/powershell/rules/configuration-schema.md +383 -0
- package/augment-extensions/coding-standards/powershell/rules/cross-platform-scripts.md +482 -0
- package/augment-extensions/coding-standards/powershell/rules/dsc-configurations.md +296 -0
- package/augment-extensions/coding-standards/powershell/rules/error-handling.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/legacy-migrations.md +466 -0
- package/augment-extensions/coding-standards/powershell/rules/modules-functions.md +244 -0
- package/augment-extensions/coding-standards/powershell/rules/naming-conventions.md +266 -0
- package/augment-extensions/coding-standards/powershell/rules/performance-optimization.md +209 -0
- package/augment-extensions/coding-standards/powershell/rules/security-practices.md +314 -0
- package/augment-extensions/coding-standards/powershell/rules/testing-guidelines.md +268 -0
- package/augment-extensions/coding-standards/powershell/rules/universal-standards.md +197 -0
- package/augment-extensions/coding-standards/python/README.md +12 -8
- package/augment-extensions/coding-standards/python/examples/best-practices.py +373 -0
- package/augment-extensions/coding-standards/python/module.json +8 -4
- package/augment-extensions/coding-standards/python/rules/async-patterns.md +884 -0
- package/augment-extensions/coding-standards/python/rules/documentation.md +831 -0
- package/augment-extensions/coding-standards/python/rules/error-handling.md +855 -68
- package/augment-extensions/coding-standards/python/rules/testing.md +409 -0
- package/augment-extensions/coding-standards/python/rules/tooling.md +446 -0
- package/augment-extensions/coding-standards/python/rules/type-hints.md +115 -50
- package/augment-extensions/collections/html-css-js/README.md +82 -0
- package/augment-extensions/collections/html-css-js/collection.json +41 -0
- package/augment-extensions/domain-rules/database/README.md +161 -0
- package/augment-extensions/domain-rules/database/examples/flat-database-example.md +793 -0
- package/augment-extensions/domain-rules/database/examples/hybrid-database-example.md +1132 -0
- package/augment-extensions/domain-rules/database/examples/nosql-document-example.md +868 -0
- package/augment-extensions/domain-rules/database/examples/nosql-graph-example.md +805 -0
- package/augment-extensions/domain-rules/database/examples/relational-schema-example.md +621 -0
- package/augment-extensions/domain-rules/database/examples/vector-database-example.md +965 -0
- package/augment-extensions/domain-rules/database/module.json +28 -0
- package/augment-extensions/domain-rules/database/rules/flat-databases.md +624 -0
- package/augment-extensions/domain-rules/database/rules/nosql-databases.md +588 -0
- package/augment-extensions/domain-rules/database/rules/nosql-document-stores.md +856 -0
- package/augment-extensions/domain-rules/database/rules/nosql-graph-databases.md +778 -0
- package/augment-extensions/domain-rules/database/rules/nosql-key-value-stores.md +963 -0
- package/augment-extensions/domain-rules/database/rules/performance-optimization.md +1076 -0
- package/augment-extensions/domain-rules/database/rules/relational-databases.md +697 -0
- package/augment-extensions/domain-rules/database/rules/relational-indexing.md +671 -0
- package/augment-extensions/domain-rules/database/rules/relational-query-optimization.md +607 -0
- package/augment-extensions/domain-rules/database/rules/relational-schema-design.md +907 -0
- package/augment-extensions/domain-rules/database/rules/relational-transactions.md +783 -0
- package/augment-extensions/domain-rules/database/rules/security-standards.md +980 -0
- package/augment-extensions/domain-rules/database/rules/universal-best-practices.md +485 -0
- package/augment-extensions/domain-rules/database/rules/vector-databases.md +521 -0
- package/augment-extensions/domain-rules/database/rules/vector-embeddings.md +858 -0
- package/augment-extensions/domain-rules/database/rules/vector-indexing.md +934 -0
- package/augment-extensions/domain-rules/mcp/README.md +150 -0
- package/augment-extensions/domain-rules/mcp/examples/compressed-example.md +522 -0
- package/augment-extensions/domain-rules/mcp/examples/graph-augmented-example.md +520 -0
- package/augment-extensions/domain-rules/mcp/examples/hybrid-example.md +570 -0
- package/augment-extensions/domain-rules/mcp/examples/state-based-example.md +427 -0
- package/augment-extensions/domain-rules/mcp/examples/token-based-example.md +435 -0
- package/augment-extensions/domain-rules/mcp/examples/vector-based-example.md +502 -0
- package/augment-extensions/domain-rules/mcp/module.json +49 -0
- package/augment-extensions/domain-rules/mcp/rules/compressed-mcp.md +595 -0
- package/augment-extensions/domain-rules/mcp/rules/configuration.md +345 -0
- package/augment-extensions/domain-rules/mcp/rules/graph-augmented-mcp.md +687 -0
- package/augment-extensions/domain-rules/mcp/rules/hybrid-mcp.md +636 -0
- package/augment-extensions/domain-rules/mcp/rules/state-based-mcp.md +484 -0
- package/augment-extensions/domain-rules/mcp/rules/testing-validation.md +360 -0
- package/augment-extensions/domain-rules/mcp/rules/token-based-mcp.md +393 -0
- package/augment-extensions/domain-rules/mcp/rules/universal-rules.md +194 -0
- package/augment-extensions/domain-rules/mcp/rules/vector-based-mcp.md +625 -0
- package/augment-extensions/domain-rules/wordpress/README.md +163 -0
- package/augment-extensions/domain-rules/wordpress/module.json +32 -0
- package/augment-extensions/domain-rules/wordpress/rules/coding-standards.md +617 -0
- package/augment-extensions/domain-rules/wordpress/rules/directory-structure.md +270 -0
- package/augment-extensions/domain-rules/wordpress/rules/file-patterns.md +423 -0
- package/augment-extensions/domain-rules/wordpress/rules/gutenberg-blocks.md +493 -0
- package/augment-extensions/domain-rules/wordpress/rules/performance.md +568 -0
- package/augment-extensions/domain-rules/wordpress/rules/plugin-development.md +510 -0
- package/augment-extensions/domain-rules/wordpress/rules/project-detection.md +251 -0
- package/augment-extensions/domain-rules/wordpress/rules/rest-api.md +501 -0
- package/augment-extensions/domain-rules/wordpress/rules/security.md +564 -0
- package/augment-extensions/domain-rules/wordpress/rules/theme-development.md +388 -0
- package/augment-extensions/domain-rules/wordpress/rules/woocommerce.md +441 -0
- package/augment-extensions/domain-rules/wordpress-plugin/README.md +139 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/ajax-plugin.md +1599 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/custom-post-type-plugin.md +1727 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/gutenberg-block-plugin.md +428 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/gutenberg-block.md +422 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/mvc-plugin.md +1623 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/object-oriented-plugin.md +1343 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/rest-endpoint.md +734 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/settings-page-plugin.md +1350 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/simple-procedural-plugin.md +503 -0
- package/augment-extensions/domain-rules/wordpress-plugin/examples/singleton-plugin.md +971 -0
- package/augment-extensions/domain-rules/wordpress-plugin/module.json +53 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/activation-hooks.md +770 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/admin-interface.md +874 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/ajax-handlers.md +629 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/asset-management.md +559 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/context-providers.md +709 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/cron-jobs.md +736 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/database-management.md +1057 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/documentation-standards.md +463 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/frontend-functionality.md +478 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/gutenberg-blocks.md +818 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/internationalization.md +416 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/migration.md +667 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/performance-optimization.md +878 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/plugin-architecture.md +693 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/plugin-structure.md +352 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/rest-api.md +818 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/scaffolding-workflow.md +624 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/security-best-practices.md +866 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/testing-patterns.md +1165 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/testing.md +414 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/vscode-integration.md +751 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/woocommerce-integration.md +949 -0
- package/augment-extensions/domain-rules/wordpress-plugin/rules/wordpress-org-submission.md +458 -0
- package/augment-extensions/examples/gutenberg-block-plugin/README.md +101 -0
- package/augment-extensions/examples/gutenberg-block-plugin/examples/testimonial-block.md +428 -0
- package/augment-extensions/examples/gutenberg-block-plugin/module.json +40 -0
- package/augment-extensions/examples/rest-api-plugin/README.md +98 -0
- package/augment-extensions/examples/rest-api-plugin/examples/task-manager-api.md +1299 -0
- package/augment-extensions/examples/rest-api-plugin/module.json +40 -0
- package/augment-extensions/examples/woocommerce-extension/README.md +98 -0
- package/augment-extensions/examples/woocommerce-extension/examples/product-customizer.md +763 -0
- package/augment-extensions/examples/woocommerce-extension/module.json +40 -0
- package/augment-extensions/workflows/beads/module.json +4 -3
- package/augment-extensions/workflows/database/README.md +195 -0
- package/augment-extensions/workflows/database/ai-prompt-testing.md +295 -0
- package/augment-extensions/workflows/database/examples/migration-example.md +498 -0
- package/augment-extensions/workflows/database/examples/optimization-example.md +496 -0
- package/augment-extensions/workflows/database/examples/schema-design-example.md +444 -0
- package/augment-extensions/workflows/database/module.json +42 -0
- package/augment-extensions/workflows/database/rules/data-migration.md +249 -0
- package/augment-extensions/workflows/database/rules/documentation-standards.md +339 -0
- package/augment-extensions/workflows/database/rules/migration-workflow.md +352 -0
- package/augment-extensions/workflows/database/rules/optimization-workflow.md +435 -0
- package/augment-extensions/workflows/database/rules/schema-design-workflow.md +535 -0
- package/augment-extensions/workflows/database/rules/testing-patterns.md +305 -0
- package/augment-extensions/workflows/database/rules/workflow.md +458 -0
- package/augment-extensions/workflows/openspec/module.json +4 -3
- package/augment-extensions/workflows/wordpress-plugin/README.md +232 -0
- package/augment-extensions/workflows/wordpress-plugin/ai-prompts.md +839 -0
- package/augment-extensions/workflows/wordpress-plugin/bead-decomposition-patterns.md +854 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/complete-plugin-example.md +540 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/custom-post-type-example.md +1083 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/feature-addition-workflow.md +669 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/plugin-creation-workflow.md +597 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/secure-form-handler-example.md +925 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/security-audit-workflow.md +752 -0
- package/augment-extensions/workflows/wordpress-plugin/examples/wordpress-org-submission-workflow.md +773 -0
- package/augment-extensions/workflows/wordpress-plugin/module.json +49 -0
- package/augment-extensions/workflows/wordpress-plugin/rules/best-practices.md +942 -0
- package/augment-extensions/workflows/wordpress-plugin/rules/development-workflow.md +702 -0
- package/augment-extensions/workflows/wordpress-plugin/rules/submission-workflow.md +728 -0
- package/augment-extensions/workflows/wordpress-plugin/rules/testing-workflow.md +775 -0
- package/augment-extensions/writing-standards/screenplay/README.md +171 -0
- package/augment-extensions/writing-standards/screenplay/examples/aaa-hollywood-scene.fountain +164 -0
- package/augment-extensions/writing-standards/screenplay/module.json +124 -0
- package/augment-extensions/writing-standards/screenplay/rules/universal-formatting.md +339 -0
- package/cli/MODULES.md +302 -0
- package/cli/dist/cli.js +142 -9
- package/cli/dist/cli.js.map +1 -1
- package/cli/dist/commands/catalog.d.ts +13 -0
- package/cli/dist/commands/catalog.d.ts.map +1 -0
- package/cli/dist/commands/catalog.js +104 -0
- package/cli/dist/commands/catalog.js.map +1 -0
- package/cli/dist/commands/gui.d.ts +6 -0
- package/cli/dist/commands/gui.d.ts.map +1 -0
- package/cli/dist/commands/gui.js +211 -0
- package/cli/dist/commands/gui.js.map +1 -0
- package/cli/dist/commands/init.d.ts.map +1 -1
- package/cli/dist/commands/init.js +12 -0
- package/cli/dist/commands/init.js.map +1 -1
- package/cli/dist/commands/install-rules.d.ts +14 -0
- package/cli/dist/commands/install-rules.d.ts.map +1 -0
- package/cli/dist/commands/install-rules.js +127 -0
- package/cli/dist/commands/install-rules.js.map +1 -0
- package/cli/dist/commands/link.d.ts.map +1 -1
- package/cli/dist/commands/link.js +9 -11
- package/cli/dist/commands/link.js.map +1 -1
- package/cli/dist/commands/list.d.ts.map +1 -1
- package/cli/dist/commands/list.js +11 -28
- package/cli/dist/commands/list.js.map +1 -1
- package/cli/dist/commands/mcp.d.ts +48 -0
- package/cli/dist/commands/mcp.d.ts.map +1 -0
- package/cli/dist/commands/mcp.js +229 -0
- package/cli/dist/commands/mcp.js.map +1 -0
- package/cli/dist/commands/self-remove.d.ts +7 -0
- package/cli/dist/commands/self-remove.d.ts.map +1 -0
- package/cli/dist/commands/self-remove.js +179 -0
- package/cli/dist/commands/self-remove.js.map +1 -0
- package/cli/dist/commands/show.d.ts.map +1 -1
- package/cli/dist/commands/show.js +42 -71
- package/cli/dist/commands/show.js.map +1 -1
- package/cli/dist/commands/skill.d.ts +67 -0
- package/cli/dist/commands/skill.d.ts.map +1 -0
- package/cli/dist/commands/skill.js +513 -0
- package/cli/dist/commands/skill.js.map +1 -0
- package/cli/dist/commands/unlink.d.ts +6 -0
- package/cli/dist/commands/unlink.d.ts.map +1 -0
- package/cli/dist/commands/unlink.js +115 -0
- package/cli/dist/commands/unlink.js.map +1 -0
- package/cli/dist/commands/validate.d.ts +6 -0
- package/cli/dist/commands/validate.d.ts.map +1 -0
- package/cli/dist/commands/validate.js +159 -0
- package/cli/dist/commands/validate.js.map +1 -0
- package/cli/dist/utils/catalog-sync.d.ts +22 -0
- package/cli/dist/utils/catalog-sync.d.ts.map +1 -0
- package/cli/dist/utils/catalog-sync.js +157 -0
- package/cli/dist/utils/catalog-sync.js.map +1 -0
- package/cli/dist/utils/character-count.d.ts +56 -0
- package/cli/dist/utils/character-count.d.ts.map +1 -0
- package/cli/dist/utils/character-count.js +190 -0
- package/cli/dist/utils/character-count.js.map +1 -0
- package/cli/dist/utils/documentation-validator.d.ts +18 -0
- package/cli/dist/utils/documentation-validator.d.ts.map +1 -0
- package/cli/dist/utils/documentation-validator.js +233 -0
- package/cli/dist/utils/documentation-validator.js.map +1 -0
- package/cli/dist/utils/install-rules.d.ts +32 -0
- package/cli/dist/utils/install-rules.d.ts.map +1 -0
- package/cli/dist/utils/install-rules.js +375 -0
- package/cli/dist/utils/install-rules.js.map +1 -0
- package/cli/dist/utils/mcp-integration.d.ts +70 -0
- package/cli/dist/utils/mcp-integration.d.ts.map +1 -0
- package/cli/dist/utils/mcp-integration.js +292 -0
- package/cli/dist/utils/mcp-integration.js.map +1 -0
- package/cli/dist/utils/module-system.d.ts +153 -0
- package/cli/dist/utils/module-system.d.ts.map +1 -0
- package/cli/dist/utils/module-system.js +528 -0
- package/cli/dist/utils/module-system.js.map +1 -0
- package/cli/dist/utils/modules-catalog.d.ts +33 -0
- package/cli/dist/utils/modules-catalog.d.ts.map +1 -0
- package/cli/dist/utils/modules-catalog.js +163 -0
- package/cli/dist/utils/modules-catalog.js.map +1 -0
- package/cli/dist/utils/rule-install-hooks.d.ts +19 -0
- package/cli/dist/utils/rule-install-hooks.d.ts.map +1 -0
- package/cli/dist/utils/rule-install-hooks.js +224 -0
- package/cli/dist/utils/rule-install-hooks.js.map +1 -0
- package/cli/dist/utils/skill-system.d.ts +95 -0
- package/cli/dist/utils/skill-system.d.ts.map +1 -0
- package/cli/dist/utils/skill-system.js +313 -0
- package/cli/dist/utils/skill-system.js.map +1 -0
- package/modules.md +534 -70
- package/package.json +12 -3
|
@@ -0,0 +1,435 @@
|
|
|
1
|
+
# Optimization Workflow
|
|
2
|
+
|
|
3
|
+
## Purpose
|
|
4
|
+
|
|
5
|
+
Provide structured guidance for identifying, analyzing, and resolving database performance issues through systematic optimization.
|
|
6
|
+
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Core Principles
|
|
10
|
+
|
|
11
|
+
1. **Measure First**: Profile before optimizing - don't guess
|
|
12
|
+
2. **Focus on Impact**: Optimize high-impact queries first
|
|
13
|
+
3. **Understand Trade-offs**: Every optimization has costs
|
|
14
|
+
4. **Test Changes**: Benchmark before and after optimization
|
|
15
|
+
5. **Monitor Continuously**: Performance degrades over time
|
|
16
|
+
6. **Document Decisions**: Record why optimizations were made
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
## Optimization Workflow
|
|
21
|
+
|
|
22
|
+
### Step 1: Identify Performance Issues
|
|
23
|
+
|
|
24
|
+
**Purpose**: Find slow queries and performance bottlenecks
|
|
25
|
+
|
|
26
|
+
**Methods**:
|
|
27
|
+
- **Slow Query Logs**: Enable and analyze database slow query logs
|
|
28
|
+
- **Application Monitoring**: Track query execution times in application
|
|
29
|
+
- **Database Metrics**: Monitor CPU, memory, disk I/O, connection pool
|
|
30
|
+
- **User Reports**: Investigate user-reported slowness
|
|
31
|
+
|
|
32
|
+
**Tools by Database**:
|
|
33
|
+
- **PostgreSQL**: `pg_stat_statements`, `EXPLAIN ANALYZE`
|
|
34
|
+
- **MySQL**: Slow query log, `EXPLAIN`, Performance Schema
|
|
35
|
+
- **MongoDB**: Profiler, `explain()`, Database Profiler
|
|
36
|
+
- **SQLite**: `EXPLAIN QUERY PLAN`
|
|
37
|
+
|
|
38
|
+
**Output**: List of slow queries with execution times and frequency
|
|
39
|
+
|
|
40
|
+
**AI Prompt Template**:
|
|
41
|
+
```
|
|
42
|
+
Analyze these slow queries and identify optimization opportunities:
|
|
43
|
+
|
|
44
|
+
Database: [PostgreSQL/MySQL/MongoDB/etc.]
|
|
45
|
+
|
|
46
|
+
Slow Queries:
|
|
47
|
+
1. Query: [paste query]
|
|
48
|
+
Execution time: [time]
|
|
49
|
+
Frequency: [calls per minute]
|
|
50
|
+
|
|
51
|
+
2. Query: [paste query]
|
|
52
|
+
Execution time: [time]
|
|
53
|
+
Frequency: [calls per minute]
|
|
54
|
+
|
|
55
|
+
Please identify which queries to optimize first and why.
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
### Step 2: Analyze Query Execution Plans
|
|
59
|
+
|
|
60
|
+
**Purpose**: Understand how the database executes queries
|
|
61
|
+
|
|
62
|
+
**PostgreSQL Example**:
|
|
63
|
+
```sql
|
|
64
|
+
EXPLAIN ANALYZE
|
|
65
|
+
SELECT u.name, COUNT(o.id) as order_count
|
|
66
|
+
FROM users u
|
|
67
|
+
LEFT JOIN orders o ON u.id = o.user_id
|
|
68
|
+
WHERE u.created_at > '2024-01-01'
|
|
69
|
+
GROUP BY u.id, u.name
|
|
70
|
+
ORDER BY order_count DESC
|
|
71
|
+
LIMIT 10;
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
**What to Look For**:
|
|
75
|
+
- **Sequential Scans**: Full table scans (often slow)
|
|
76
|
+
- **Index Scans**: Using indexes (usually fast)
|
|
77
|
+
- **Nested Loops**: Can be slow with large datasets
|
|
78
|
+
- **Hash Joins**: Good for large joins
|
|
79
|
+
- **Sort Operations**: Can be expensive
|
|
80
|
+
- **Estimated vs Actual Rows**: Large differences indicate stale statistics
|
|
81
|
+
|
|
82
|
+
**Output**: Understanding of query execution and bottlenecks
|
|
83
|
+
|
|
84
|
+
**AI Prompt Template**:
|
|
85
|
+
```
|
|
86
|
+
Analyze this query execution plan:
|
|
87
|
+
|
|
88
|
+
Query:
|
|
89
|
+
[paste query]
|
|
90
|
+
|
|
91
|
+
Execution Plan:
|
|
92
|
+
[paste EXPLAIN ANALYZE output]
|
|
93
|
+
|
|
94
|
+
Schema:
|
|
95
|
+
[paste relevant table definitions and indexes]
|
|
96
|
+
|
|
97
|
+
Please identify:
|
|
98
|
+
1. Performance bottlenecks
|
|
99
|
+
2. Missing indexes
|
|
100
|
+
3. Query optimization opportunities
|
|
101
|
+
4. Estimated impact of each optimization
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### Step 3: Implement Optimizations
|
|
105
|
+
|
|
106
|
+
**Purpose**: Apply optimizations based on analysis
|
|
107
|
+
|
|
108
|
+
**Optimization Strategies**:
|
|
109
|
+
|
|
110
|
+
#### 3.1 Add Indexes
|
|
111
|
+
|
|
112
|
+
**When to Add**:
|
|
113
|
+
- Columns in WHERE clauses
|
|
114
|
+
- Columns in JOIN conditions
|
|
115
|
+
- Columns in ORDER BY clauses
|
|
116
|
+
- Foreign key columns
|
|
117
|
+
|
|
118
|
+
**Example**:
|
|
119
|
+
```sql
|
|
120
|
+
-- Before: Sequential scan on users table
|
|
121
|
+
-- After: Index scan
|
|
122
|
+
CREATE INDEX idx_users_created_at ON users(created_at);
|
|
123
|
+
|
|
124
|
+
-- Composite index for multiple columns
|
|
125
|
+
CREATE INDEX idx_orders_user_status ON orders(user_id, status);
|
|
126
|
+
|
|
127
|
+
-- Partial index for specific conditions
|
|
128
|
+
CREATE INDEX idx_users_active ON users(email) WHERE status = 'active';
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
#### 3.2 Optimize Queries
|
|
132
|
+
|
|
133
|
+
**Query Rewriting**:
|
|
134
|
+
```sql
|
|
135
|
+
-- ❌ Inefficient: Using OR
|
|
136
|
+
SELECT * FROM users WHERE status = 'active' OR status = 'pending';
|
|
137
|
+
|
|
138
|
+
-- ✅ Efficient: Using IN
|
|
139
|
+
SELECT * FROM users WHERE status IN ('active', 'pending');
|
|
140
|
+
|
|
141
|
+
-- ❌ Inefficient: Function on indexed column
|
|
142
|
+
SELECT * FROM users WHERE LOWER(email) = 'user@example.com';
|
|
143
|
+
|
|
144
|
+
-- ✅ Efficient: Use functional index or case-insensitive collation
|
|
145
|
+
CREATE INDEX idx_users_email_lower ON users(LOWER(email));
|
|
146
|
+
SELECT * FROM users WHERE LOWER(email) = 'user@example.com';
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
**Avoid N+1 Queries**:
|
|
150
|
+
```sql
|
|
151
|
+
-- ❌ N+1: One query per user
|
|
152
|
+
SELECT * FROM users;
|
|
153
|
+
-- Then for each user: SELECT * FROM orders WHERE user_id = ?
|
|
154
|
+
|
|
155
|
+
-- ✅ Single query with JOIN
|
|
156
|
+
SELECT u.*, o.*
|
|
157
|
+
FROM users u
|
|
158
|
+
LEFT JOIN orders o ON u.id = o.user_id;
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
#### 3.3 Denormalization
|
|
162
|
+
|
|
163
|
+
**When to Denormalize**:
|
|
164
|
+
- Read-heavy workloads
|
|
165
|
+
- Complex joins are slow
|
|
166
|
+
- Acceptable data redundancy
|
|
167
|
+
|
|
168
|
+
**Example**:
|
|
169
|
+
```sql
|
|
170
|
+
-- Add denormalized column to avoid JOIN
|
|
171
|
+
ALTER TABLE orders ADD COLUMN user_email VARCHAR(255);
|
|
172
|
+
|
|
173
|
+
-- Keep it updated with trigger or application logic
|
|
174
|
+
CREATE TRIGGER update_order_user_email
|
|
175
|
+
AFTER UPDATE ON users
|
|
176
|
+
FOR EACH ROW
|
|
177
|
+
BEGIN
|
|
178
|
+
UPDATE orders SET user_email = NEW.email WHERE user_id = NEW.id;
|
|
179
|
+
END;
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
#### 3.4 Caching
|
|
183
|
+
|
|
184
|
+
**Strategies**:
|
|
185
|
+
- **Query Result Caching**: Cache expensive query results
|
|
186
|
+
- **Materialized Views**: Pre-compute complex aggregations
|
|
187
|
+
- **Application-Level Caching**: Redis, Memcached
|
|
188
|
+
|
|
189
|
+
**PostgreSQL Materialized View**:
|
|
190
|
+
```sql
|
|
191
|
+
CREATE MATERIALIZED VIEW user_order_stats AS
|
|
192
|
+
SELECT
|
|
193
|
+
u.id,
|
|
194
|
+
u.name,
|
|
195
|
+
COUNT(o.id) as order_count,
|
|
196
|
+
SUM(o.total) as total_spent
|
|
197
|
+
FROM users u
|
|
198
|
+
LEFT JOIN orders o ON u.id = o.user_id
|
|
199
|
+
GROUP BY u.id, u.name;
|
|
200
|
+
|
|
201
|
+
-- Refresh periodically
|
|
202
|
+
REFRESH MATERIALIZED VIEW user_order_stats;
|
|
203
|
+
```
|
|
204
|
+
|
|
205
|
+
#### 3.5 Partitioning
|
|
206
|
+
|
|
207
|
+
**When to Partition**:
|
|
208
|
+
- Very large tables (millions of rows)
|
|
209
|
+
- Time-series data
|
|
210
|
+
- Queries filter on partition key
|
|
211
|
+
|
|
212
|
+
**Example** (PostgreSQL):
|
|
213
|
+
```sql
|
|
214
|
+
-- Partition by date range
|
|
215
|
+
CREATE TABLE orders (
|
|
216
|
+
id SERIAL,
|
|
217
|
+
user_id INTEGER,
|
|
218
|
+
created_at TIMESTAMP,
|
|
219
|
+
total DECIMAL(10,2)
|
|
220
|
+
) PARTITION BY RANGE (created_at);
|
|
221
|
+
|
|
222
|
+
CREATE TABLE orders_2024_q1 PARTITION OF orders
|
|
223
|
+
FOR VALUES FROM ('2024-01-01') TO ('2024-04-01');
|
|
224
|
+
|
|
225
|
+
CREATE TABLE orders_2024_q2 PARTITION OF orders
|
|
226
|
+
FOR VALUES FROM ('2024-04-01') TO ('2024-07-01');
|
|
227
|
+
```
|
|
228
|
+
|
|
229
|
+
**AI Prompt Template**:
|
|
230
|
+
```
|
|
231
|
+
Suggest optimizations for this slow query:
|
|
232
|
+
|
|
233
|
+
Query:
|
|
234
|
+
[paste query]
|
|
235
|
+
|
|
236
|
+
Execution Plan:
|
|
237
|
+
[paste EXPLAIN output]
|
|
238
|
+
|
|
239
|
+
Schema:
|
|
240
|
+
[paste table definitions and existing indexes]
|
|
241
|
+
|
|
242
|
+
Performance Issue:
|
|
243
|
+
- Current execution time: [time]
|
|
244
|
+
- Target execution time: [time]
|
|
245
|
+
- Data volume: [number of rows]
|
|
246
|
+
|
|
247
|
+
Please suggest:
|
|
248
|
+
1. Index additions or modifications
|
|
249
|
+
2. Query rewrites
|
|
250
|
+
3. Schema changes (denormalization, partitioning)
|
|
251
|
+
4. Caching strategies
|
|
252
|
+
5. Estimated impact of each optimization
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
### Step 4: Benchmark and Validate
|
|
256
|
+
|
|
257
|
+
**Purpose**: Measure improvement and ensure correctness
|
|
258
|
+
|
|
259
|
+
**Benchmarking Process**:
|
|
260
|
+
1. **Baseline**: Measure performance before optimization
|
|
261
|
+
2. **Apply**: Implement optimization
|
|
262
|
+
3. **Measure**: Measure performance after optimization
|
|
263
|
+
4. **Compare**: Calculate improvement percentage
|
|
264
|
+
5. **Validate**: Ensure results are still correct
|
|
265
|
+
|
|
266
|
+
**Example Benchmark**:
|
|
267
|
+
```sql
|
|
268
|
+
-- Baseline
|
|
269
|
+
EXPLAIN ANALYZE
|
|
270
|
+
SELECT * FROM users WHERE email = 'user@example.com';
|
|
271
|
+
-- Execution time: 245ms
|
|
272
|
+
|
|
273
|
+
-- Add index
|
|
274
|
+
CREATE INDEX idx_users_email ON users(email);
|
|
275
|
+
|
|
276
|
+
-- After optimization
|
|
277
|
+
EXPLAIN ANALYZE
|
|
278
|
+
SELECT * FROM users WHERE email = 'user@example.com';
|
|
279
|
+
-- Execution time: 2ms
|
|
280
|
+
-- Improvement: 99.2%
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
**Validation Checklist**:
|
|
284
|
+
- [ ] Query returns same results as before
|
|
285
|
+
- [ ] Execution time improved
|
|
286
|
+
- [ ] No negative impact on write performance
|
|
287
|
+
- [ ] Index size is acceptable
|
|
288
|
+
- [ ] Application behavior unchanged
|
|
289
|
+
|
|
290
|
+
**Output**: Validated optimization with measured improvement
|
|
291
|
+
|
|
292
|
+
### Step 5: Monitor Ongoing Performance
|
|
293
|
+
|
|
294
|
+
**Purpose**: Ensure optimizations remain effective over time
|
|
295
|
+
|
|
296
|
+
**Monitoring Metrics**:
|
|
297
|
+
- **Query Execution Time**: Track slow query trends
|
|
298
|
+
- **Index Usage**: Ensure indexes are being used
|
|
299
|
+
- **Cache Hit Ratio**: Monitor cache effectiveness
|
|
300
|
+
- **Database Size**: Track growth over time
|
|
301
|
+
- **Connection Pool**: Monitor connection usage
|
|
302
|
+
|
|
303
|
+
**Tools**:
|
|
304
|
+
- **PostgreSQL**: `pg_stat_statements`, `pg_stat_user_indexes`
|
|
305
|
+
- **MySQL**: Performance Schema, `sys` schema
|
|
306
|
+
- **MongoDB**: Database Profiler, Cloud Manager
|
|
307
|
+
- **Application**: APM tools (New Relic, Datadog, etc.)
|
|
308
|
+
|
|
309
|
+
**Alerts to Set**:
|
|
310
|
+
- Query execution time exceeds threshold
|
|
311
|
+
- Index not being used
|
|
312
|
+
- Cache hit ratio drops below threshold
|
|
313
|
+
- Database size grows unexpectedly
|
|
314
|
+
- Connection pool exhaustion
|
|
315
|
+
|
|
316
|
+
---
|
|
317
|
+
|
|
318
|
+
## Optimization Patterns by Database Type
|
|
319
|
+
|
|
320
|
+
### Relational Databases (PostgreSQL, MySQL)
|
|
321
|
+
|
|
322
|
+
**Common Optimizations**:
|
|
323
|
+
1. Add indexes on frequently queried columns
|
|
324
|
+
2. Use EXPLAIN to analyze query plans
|
|
325
|
+
3. Optimize JOIN order and types
|
|
326
|
+
4. Use connection pooling
|
|
327
|
+
5. Partition large tables
|
|
328
|
+
6. Update statistics regularly
|
|
329
|
+
|
|
330
|
+
**PostgreSQL-Specific**:
|
|
331
|
+
- Use `VACUUM` and `ANALYZE` regularly
|
|
332
|
+
- Create partial indexes for filtered queries
|
|
333
|
+
- Use `EXPLAIN (ANALYZE, BUFFERS)` for detailed analysis
|
|
334
|
+
- Consider table inheritance for partitioning
|
|
335
|
+
|
|
336
|
+
**MySQL-Specific**:
|
|
337
|
+
- Choose appropriate storage engine (InnoDB vs MyISAM)
|
|
338
|
+
- Optimize `innodb_buffer_pool_size`
|
|
339
|
+
- Use covering indexes
|
|
340
|
+
- Avoid `SELECT *` in queries
|
|
341
|
+
|
|
342
|
+
### NoSQL Databases (MongoDB)
|
|
343
|
+
|
|
344
|
+
**Common Optimizations**:
|
|
345
|
+
1. Create indexes on query fields
|
|
346
|
+
2. Use compound indexes for multiple fields
|
|
347
|
+
3. Avoid large documents (> 16MB limit)
|
|
348
|
+
4. Use projection to limit returned fields
|
|
349
|
+
5. Implement sharding for horizontal scaling
|
|
350
|
+
6. Use aggregation pipeline efficiently
|
|
351
|
+
|
|
352
|
+
**MongoDB-Specific**:
|
|
353
|
+
```javascript
|
|
354
|
+
// Create compound index
|
|
355
|
+
db.users.createIndex({ email: 1, status: 1 });
|
|
356
|
+
|
|
357
|
+
// Use projection to limit fields
|
|
358
|
+
db.users.find({ status: 'active' }, { name: 1, email: 1 });
|
|
359
|
+
|
|
360
|
+
// Optimize aggregation pipeline
|
|
361
|
+
db.orders.aggregate([
|
|
362
|
+
{ $match: { status: 'completed' } }, // Filter early
|
|
363
|
+
{ $group: { _id: '$user_id', total: { $sum: '$amount' } } },
|
|
364
|
+
{ $sort: { total: -1 } },
|
|
365
|
+
{ $limit: 10 }
|
|
366
|
+
]);
|
|
367
|
+
```
|
|
368
|
+
|
|
369
|
+
### Vector Databases (Pinecone, Milvus)
|
|
370
|
+
|
|
371
|
+
**Common Optimizations**:
|
|
372
|
+
1. Choose appropriate index type (HNSW, IVF, etc.)
|
|
373
|
+
2. Tune index parameters (ef_construction, M)
|
|
374
|
+
3. Use metadata filtering efficiently
|
|
375
|
+
4. Batch upsert operations
|
|
376
|
+
5. Monitor query latency and recall
|
|
377
|
+
|
|
378
|
+
---
|
|
379
|
+
|
|
380
|
+
## Common Pitfalls
|
|
381
|
+
|
|
382
|
+
❌ **Adding indexes without measuring**: Too many indexes slow down writes
|
|
383
|
+
✅ **Solution**: Profile queries first, add indexes strategically
|
|
384
|
+
|
|
385
|
+
❌ **Optimizing low-impact queries**: Wasting time on queries that run rarely
|
|
386
|
+
✅ **Solution**: Focus on high-frequency or high-impact queries
|
|
387
|
+
|
|
388
|
+
❌ **Not testing on production-like data**: Optimization works on small data but not at scale
|
|
389
|
+
✅ **Solution**: Test with production-like data volumes
|
|
390
|
+
|
|
391
|
+
❌ **Ignoring write performance**: Indexes speed up reads but slow down writes
|
|
392
|
+
✅ **Solution**: Balance read and write performance needs
|
|
393
|
+
|
|
394
|
+
❌ **Over-denormalizing**: Data inconsistency and update complexity
|
|
395
|
+
✅ **Solution**: Denormalize only when necessary and manageable
|
|
396
|
+
|
|
397
|
+
❌ **Not monitoring after optimization**: Performance degrades over time
|
|
398
|
+
✅ **Solution**: Set up continuous monitoring and alerts
|
|
399
|
+
|
|
400
|
+
---
|
|
401
|
+
|
|
402
|
+
## Best Practices
|
|
403
|
+
|
|
404
|
+
### DO
|
|
405
|
+
|
|
406
|
+
✅ Profile before optimizing (measure, don't guess)
|
|
407
|
+
✅ Focus on high-impact queries first
|
|
408
|
+
✅ Benchmark before and after changes
|
|
409
|
+
✅ Monitor index usage and effectiveness
|
|
410
|
+
✅ Update database statistics regularly
|
|
411
|
+
✅ Document optimization decisions
|
|
412
|
+
✅ Test on production-like data volumes
|
|
413
|
+
✅ Consider trade-offs (read vs write performance)
|
|
414
|
+
|
|
415
|
+
### DON'T
|
|
416
|
+
|
|
417
|
+
❌ Add indexes without profiling
|
|
418
|
+
❌ Optimize without measuring baseline
|
|
419
|
+
❌ Ignore write performance impact
|
|
420
|
+
❌ Over-denormalize data
|
|
421
|
+
❌ Skip testing optimizations
|
|
422
|
+
❌ Forget to monitor ongoing performance
|
|
423
|
+
❌ Optimize low-impact queries first
|
|
424
|
+
|
|
425
|
+
---
|
|
426
|
+
|
|
427
|
+
## Next Steps
|
|
428
|
+
|
|
429
|
+
- See `schema-design-workflow.md` for designing performant schemas
|
|
430
|
+
- See `migration-workflow.md` for applying schema optimizations
|
|
431
|
+
- See `testing-patterns.md` for performance testing strategies
|
|
432
|
+
- See `documentation-standards.md` for documenting optimizations
|
|
433
|
+
- See `../examples/optimization-example.md` for complete optimization example
|
|
434
|
+
|
|
435
|
+
|