code-ai-installer 1.2.0 → 1.3.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/.agents/a11y_baseline/SKILL.md +260 -41
- package/.agents/a11y_baseline/agents/claude.json +2 -2
- package/.agents/a11y_baseline/agents/copilot.json +2 -2
- package/.agents/a11y_baseline/agents/gemini.json +2 -2
- package/.agents/a11y_baseline/agents/openai.yaml +1 -1
- package/.agents/a11y_baseline/agents/qwen.json +2 -2
- package/.agents/a11y_baseline/agents/skill.yaml +2 -2
- package/.agents/adr_log/SKILL.md +369 -69
- package/.agents/adr_log/agents/claude.json +2 -2
- package/.agents/adr_log/agents/copilot.json +2 -2
- package/.agents/adr_log/agents/gemini.json +2 -2
- package/.agents/adr_log/agents/openai.yaml +1 -1
- package/.agents/adr_log/agents/qwen.json +2 -2
- package/.agents/adr_log/agents/skill.yaml +2 -2
- package/.agents/api_contract_compliance_review/SKILL.md +224 -18
- package/.agents/api_contract_compliance_review/agents/claude.json +2 -2
- package/.agents/api_contract_compliance_review/agents/copilot.json +2 -2
- package/.agents/api_contract_compliance_review/agents/gemini.json +2 -2
- package/.agents/api_contract_compliance_review/agents/openai.yaml +1 -1
- package/.agents/api_contract_compliance_review/agents/qwen.json +2 -2
- package/.agents/api_contract_compliance_review/agents/skill.yaml +2 -2
- package/.agents/api_contracts/SKILL.md +329 -42
- package/.agents/api_contracts/agents/claude.json +2 -2
- package/.agents/api_contracts/agents/copilot.json +2 -2
- package/.agents/api_contracts/agents/gemini.json +2 -2
- package/.agents/api_contracts/agents/openai.yaml +1 -1
- package/.agents/api_contracts/agents/qwen.json +2 -2
- package/.agents/api_contracts/agents/skill.yaml +2 -2
- package/.agents/architecture_compliance_review/SKILL.md +213 -17
- package/.agents/architecture_compliance_review/agents/claude.json +2 -2
- package/.agents/architecture_compliance_review/agents/copilot.json +2 -2
- package/.agents/architecture_compliance_review/agents/gemini.json +2 -2
- package/.agents/architecture_compliance_review/agents/openai.yaml +1 -1
- package/.agents/architecture_compliance_review/agents/qwen.json +2 -2
- package/.agents/architecture_compliance_review/agents/skill.yaml +2 -2
- package/.agents/architecture_doc/SKILL.md +384 -92
- package/.agents/architecture_doc/agents/claude.json +2 -2
- package/.agents/architecture_doc/agents/copilot.json +2 -2
- package/.agents/architecture_doc/agents/gemini.json +2 -2
- package/.agents/architecture_doc/agents/openai.yaml +1 -1
- package/.agents/architecture_doc/agents/qwen.json +2 -2
- package/.agents/architecture_doc/agents/skill.yaml +2 -2
- package/.agents/board/SKILL.md +232 -43
- package/.agents/board/agents/claude.json +2 -2
- package/.agents/board/agents/copilot.json +2 -2
- package/.agents/board/agents/gemini.json +2 -2
- package/.agents/board/agents/openai.yaml +1 -1
- package/.agents/board/agents/qwen.json +2 -2
- package/.agents/board/agents/skill.yaml +2 -2
- package/.agents/cloud_infrastructure_security/SKILL.md +277 -68
- package/.agents/cloud_infrastructure_security/agents/claude.json +2 -2
- package/.agents/cloud_infrastructure_security/agents/copilot.json +2 -2
- package/.agents/cloud_infrastructure_security/agents/gemini.json +2 -2
- package/.agents/cloud_infrastructure_security/agents/openai.yaml +1 -1
- package/.agents/cloud_infrastructure_security/agents/qwen.json +2 -2
- package/.agents/cloud_infrastructure_security/agents/skill.yaml +2 -2
- package/.agents/code_review_checklist/SKILL.md +200 -47
- package/.agents/code_review_checklist/agents/claude.json +2 -2
- package/.agents/code_review_checklist/agents/copilot.json +2 -2
- package/.agents/code_review_checklist/agents/gemini.json +2 -2
- package/.agents/code_review_checklist/agents/openai.yaml +1 -1
- package/.agents/code_review_checklist/agents/qwen.json +2 -2
- package/.agents/code_review_checklist/agents/skill.yaml +2 -2
- package/.agents/current_state_analysis/SKILL.md +225 -44
- package/.agents/current_state_analysis/agents/claude.json +2 -2
- package/.agents/current_state_analysis/agents/copilot.json +2 -2
- package/.agents/current_state_analysis/agents/gemini.json +2 -2
- package/.agents/current_state_analysis/agents/openai.yaml +1 -1
- package/.agents/current_state_analysis/agents/qwen.json +2 -2
- package/.agents/current_state_analysis/agents/skill.yaml +2 -2
- package/.agents/data_model/SKILL.md +285 -40
- package/.agents/data_model/agents/claude.json +2 -2
- package/.agents/data_model/agents/copilot.json +2 -2
- package/.agents/data_model/agents/gemini.json +2 -2
- package/.agents/data_model/agents/openai.yaml +1 -1
- package/.agents/data_model/agents/qwen.json +2 -2
- package/.agents/data_model/agents/skill.yaml +2 -2
- package/.agents/dependency_supply_chain_review/SKILL.md +300 -20
- package/.agents/dependency_supply_chain_review/agents/claude.json +2 -2
- package/.agents/dependency_supply_chain_review/agents/copilot.json +2 -2
- package/.agents/dependency_supply_chain_review/agents/gemini.json +2 -2
- package/.agents/dependency_supply_chain_review/agents/openai.yaml +1 -1
- package/.agents/dependency_supply_chain_review/agents/qwen.json +2 -2
- package/.agents/dependency_supply_chain_review/agents/skill.yaml +2 -2
- package/.agents/deployment_ci_plan/SKILL.md +410 -51
- package/.agents/deployment_ci_plan/agents/claude.json +3 -2
- package/.agents/deployment_ci_plan/agents/copilot.json +3 -2
- package/.agents/deployment_ci_plan/agents/gemini.json +3 -2
- package/.agents/deployment_ci_plan/agents/openai.yaml +1 -1
- package/.agents/deployment_ci_plan/agents/qwen.json +3 -2
- package/.agents/deployment_ci_plan/agents/skill.yaml +2 -1
- package/.agents/design_intake/SKILL.md +225 -71
- package/.agents/design_intake/agents/claude.json +2 -2
- package/.agents/design_intake/agents/copilot.json +2 -2
- package/.agents/design_intake/agents/gemini.json +2 -2
- package/.agents/design_intake/agents/openai.yaml +1 -1
- package/.agents/design_intake/agents/qwen.json +2 -2
- package/.agents/design_intake/agents/skill.yaml +2 -2
- package/.agents/design_parity_review/SKILL.md +216 -73
- package/.agents/design_systems/SKILL.md +432 -15
- package/.agents/design_systems/agents/claude.json +2 -2
- package/.agents/design_systems/agents/copilot.json +2 -2
- package/.agents/design_systems/agents/gemini.json +2 -2
- package/.agents/design_systems/agents/openai.yaml +1 -1
- package/.agents/design_systems/agents/qwen.json +2 -2
- package/.agents/design_systems/agents/skill.yaml +2 -2
- package/.agents/dev_reference_snippets/SKILL.md +305 -117
- package/.agents/dev_reference_snippets/agents/claude.json +2 -2
- package/.agents/dev_reference_snippets/agents/copilot.json +2 -2
- package/.agents/dev_reference_snippets/agents/gemini.json +2 -2
- package/.agents/dev_reference_snippets/agents/openai.yaml +1 -1
- package/.agents/dev_reference_snippets/agents/qwen.json +2 -2
- package/.agents/dev_reference_snippets/agents/skill.yaml +2 -2
- package/.agents/docker_kubernetes_architecture/SKILL.md +480 -145
- package/.agents/docker_kubernetes_architecture/agents/claude.json +2 -2
- package/.agents/docker_kubernetes_architecture/agents/copilot.json +2 -2
- package/.agents/docker_kubernetes_architecture/agents/gemini.json +2 -2
- package/.agents/docker_kubernetes_architecture/agents/openai.yaml +1 -1
- package/.agents/docker_kubernetes_architecture/agents/qwen.json +2 -2
- package/.agents/docker_kubernetes_architecture/agents/skill.yaml +2 -2
- package/.agents/es2025_beast_practices/SKILL.md +433 -8
- package/.agents/es2025_beast_practices/agents/claude.json +2 -2
- package/.agents/es2025_beast_practices/agents/copilot.json +2 -2
- package/.agents/es2025_beast_practices/agents/gemini.json +2 -2
- package/.agents/es2025_beast_practices/agents/openai.yaml +1 -1
- package/.agents/es2025_beast_practices/agents/qwen.json +2 -2
- package/.agents/es2025_beast_practices/agents/skill.yaml +2 -2
- package/.agents/gates/SKILL.md +134 -35
- package/.agents/gates/agents/claude.json +2 -2
- package/.agents/gates/agents/copilot.json +2 -2
- package/.agents/gates/agents/gemini.json +2 -2
- package/.agents/gates/agents/openai.yaml +1 -1
- package/.agents/gates/agents/qwen.json +2 -2
- package/.agents/gates/agents/skill.yaml +2 -2
- package/.agents/go_beast_practices/SKILL.md +557 -23
- package/.agents/go_beast_practices/agents/claude.json +2 -2
- package/.agents/go_beast_practices/agents/copilot.json +2 -2
- package/.agents/go_beast_practices/agents/gemini.json +2 -2
- package/.agents/go_beast_practices/agents/openai.yaml +1 -1
- package/.agents/go_beast_practices/agents/qwen.json +2 -2
- package/.agents/go_beast_practices/agents/skill.yaml +2 -2
- package/.agents/google_stitch_skill/SKILL.md +1 -1
- package/.agents/google_stitch_skill/agents/claude.json +5 -6
- package/.agents/google_stitch_skill/agents/copilot.json +5 -6
- package/.agents/google_stitch_skill/agents/gemini.json +5 -6
- package/.agents/google_stitch_skill/agents/openai.yaml +1 -1
- package/.agents/google_stitch_skill/agents/qwen.json +5 -6
- package/.agents/google_stitch_skill/agents/skill.yaml +4 -5
- package/.agents/handoff/SKILL.md +212 -52
- package/.agents/handoff/agents/claude.json +2 -2
- package/.agents/handoff/agents/copilot.json +2 -2
- package/.agents/handoff/agents/gemini.json +2 -2
- package/.agents/handoff/agents/openai.yaml +1 -1
- package/.agents/handoff/agents/qwen.json +2 -2
- package/.agents/handoff/agents/skill.yaml +2 -2
- package/.agents/k8s_manifests_conventions/SKILL.md +548 -176
- package/.agents/k8s_manifests_conventions/agents/claude.json +2 -2
- package/.agents/k8s_manifests_conventions/agents/copilot.json +2 -2
- package/.agents/k8s_manifests_conventions/agents/gemini.json +2 -2
- package/.agents/k8s_manifests_conventions/agents/openai.yaml +1 -1
- package/.agents/k8s_manifests_conventions/agents/qwen.json +2 -2
- package/.agents/k8s_manifests_conventions/agents/skill.yaml +2 -2
- package/.agents/memory/SKILL.md +219 -29
- package/.agents/memory/agents/claude.json +2 -2
- package/.agents/memory/agents/copilot.json +2 -2
- package/.agents/memory/agents/gemini.json +2 -2
- package/.agents/memory/agents/openai.yaml +1 -1
- package/.agents/memory/agents/qwen.json +2 -2
- package/.agents/memory/agents/skill.yaml +2 -2
- package/.agents/mongodb_mongoose_best_practices/SKILL.md +724 -236
- package/.agents/mongodb_mongoose_best_practices/agents/claude.json +2 -2
- package/.agents/mongodb_mongoose_best_practices/agents/copilot.json +2 -2
- package/.agents/mongodb_mongoose_best_practices/agents/gemini.json +2 -2
- package/.agents/mongodb_mongoose_best_practices/agents/openai.yaml +1 -1
- package/.agents/mongodb_mongoose_best_practices/agents/qwen.json +2 -2
- package/.agents/mongodb_mongoose_best_practices/agents/skill.yaml +2 -2
- package/.agents/n8n_pinecone_qdrant_supabase/SKILL.md +671 -59
- package/.agents/n8n_pinecone_qdrant_supabase/agents/claude.json +2 -2
- package/.agents/n8n_pinecone_qdrant_supabase/agents/copilot.json +2 -2
- package/.agents/n8n_pinecone_qdrant_supabase/agents/gemini.json +2 -2
- package/.agents/n8n_pinecone_qdrant_supabase/agents/openai.yaml +1 -1
- package/.agents/n8n_pinecone_qdrant_supabase/agents/qwen.json +2 -2
- package/.agents/n8n_pinecone_qdrant_supabase/agents/skill.yaml +2 -2
- package/.agents/node_express_beast_practices/SKILL.md +729 -30
- package/.agents/node_express_beast_practices/agents/claude.json +1 -1
- package/.agents/node_express_beast_practices/agents/copilot.json +1 -1
- package/.agents/node_express_beast_practices/agents/gemini.json +1 -1
- package/.agents/node_express_beast_practices/agents/openai.yaml +1 -1
- package/.agents/node_express_beast_practices/agents/qwen.json +1 -1
- package/.agents/node_express_beast_practices/agents/skill.yaml +1 -1
- package/.agents/observability_logging/SKILL.md +499 -16
- package/.agents/observability_logging/agents/claude.json +2 -2
- package/.agents/observability_logging/agents/copilot.json +2 -2
- package/.agents/observability_logging/agents/gemini.json +2 -2
- package/.agents/observability_logging/agents/openai.yaml +1 -1
- package/.agents/observability_logging/agents/qwen.json +2 -2
- package/.agents/observability_logging/agents/skill.yaml +2 -2
- package/.agents/observability_plan/SKILL.md +279 -38
- package/.agents/observability_plan/agents/claude.json +3 -2
- package/.agents/observability_plan/agents/copilot.json +3 -2
- package/.agents/observability_plan/agents/gemini.json +3 -2
- package/.agents/observability_plan/agents/openai.yaml +1 -1
- package/.agents/observability_plan/agents/qwen.json +3 -2
- package/.agents/observability_plan/agents/skill.yaml +2 -1
- package/.agents/observability_review/SKILL.md +254 -20
- package/.agents/observability_review/agents/claude.json +2 -2
- package/.agents/observability_review/agents/copilot.json +2 -2
- package/.agents/observability_review/agents/gemini.json +2 -2
- package/.agents/observability_review/agents/openai.yaml +1 -1
- package/.agents/observability_review/agents/qwen.json +2 -2
- package/.agents/observability_review/agents/skill.yaml +2 -2
- package/.agents/performance_review_baseline/SKILL.md +239 -17
- package/.agents/performance_review_baseline/agents/claude.json +2 -2
- package/.agents/performance_review_baseline/agents/copilot.json +2 -2
- package/.agents/performance_review_baseline/agents/gemini.json +2 -2
- package/.agents/performance_review_baseline/agents/openai.yaml +1 -1
- package/.agents/performance_review_baseline/agents/qwen.json +2 -2
- package/.agents/performance_review_baseline/agents/skill.yaml +2 -2
- package/.agents/pm_backlog/SKILL.md +250 -32
- package/.agents/pm_backlog/agents/claude.json +2 -2
- package/.agents/pm_backlog/agents/copilot.json +2 -2
- package/.agents/pm_backlog/agents/gemini.json +2 -2
- package/.agents/pm_backlog/agents/openai.yaml +1 -1
- package/.agents/pm_backlog/agents/qwen.json +2 -2
- package/.agents/pm_backlog/agents/skill.yaml +2 -2
- package/.agents/pm_interview/SKILL.md +197 -56
- package/.agents/pm_interview/agents/claude.json +2 -2
- package/.agents/pm_interview/agents/copilot.json +2 -2
- package/.agents/pm_interview/agents/gemini.json +2 -2
- package/.agents/pm_interview/agents/openai.yaml +1 -1
- package/.agents/pm_interview/agents/qwen.json +2 -2
- package/.agents/pm_interview/agents/skill.yaml +2 -2
- package/.agents/pm_prd/SKILL.md +215 -56
- package/.agents/pm_prd/agents/claude.json +2 -2
- package/.agents/pm_prd/agents/copilot.json +2 -2
- package/.agents/pm_prd/agents/gemini.json +2 -2
- package/.agents/pm_prd/agents/openai.yaml +1 -1
- package/.agents/pm_prd/agents/qwen.json +2 -2
- package/.agents/pm_prd/agents/skill.yaml +2 -2
- package/.agents/qa_api_contract_tests/SKILL.md +207 -16
- package/.agents/qa_api_contract_tests/agents/claude.json +2 -2
- package/.agents/qa_api_contract_tests/agents/copilot.json +2 -2
- package/.agents/qa_api_contract_tests/agents/gemini.json +2 -2
- package/.agents/qa_api_contract_tests/agents/openai.yaml +1 -1
- package/.agents/qa_api_contract_tests/agents/qwen.json +2 -2
- package/.agents/qa_api_contract_tests/agents/skill.yaml +2 -2
- package/.agents/qa_manual_run/SKILL.md +209 -16
- package/.agents/qa_manual_run/agents/claude.json +2 -2
- package/.agents/qa_manual_run/agents/copilot.json +2 -2
- package/.agents/qa_manual_run/agents/gemini.json +2 -2
- package/.agents/qa_manual_run/agents/openai.yaml +1 -1
- package/.agents/qa_manual_run/agents/qwen.json +2 -2
- package/.agents/qa_manual_run/agents/skill.yaml +2 -2
- package/.agents/qa_regression_baseline/SKILL.md +217 -0
- package/.agents/qa_regression_baseline/agents/claude.json +19 -0
- package/.agents/qa_regression_baseline/agents/copilot.json +19 -0
- package/.agents/qa_regression_baseline/agents/gemini.json +19 -0
- package/.agents/qa_regression_baseline/agents/openai.yaml +8 -0
- package/.agents/qa_regression_baseline/agents/qwen.json +19 -0
- package/.agents/qa_regression_baseline/agents/skill.yaml +23 -0
- package/.agents/qa_security_smoke_tests/SKILL.md +188 -14
- package/.agents/qa_security_smoke_tests/agents/claude.json +2 -2
- package/.agents/qa_security_smoke_tests/agents/copilot.json +2 -2
- package/.agents/qa_security_smoke_tests/agents/gemini.json +2 -2
- package/.agents/qa_security_smoke_tests/agents/openai.yaml +1 -1
- package/.agents/qa_security_smoke_tests/agents/qwen.json +2 -2
- package/.agents/qa_security_smoke_tests/agents/skill.yaml +2 -2
- package/.agents/qa_test_plan/SKILL.md +203 -20
- package/.agents/qa_test_plan/agents/claude.json +2 -2
- package/.agents/qa_test_plan/agents/copilot.json +2 -2
- package/.agents/qa_test_plan/agents/gemini.json +2 -2
- package/.agents/qa_test_plan/agents/openai.yaml +1 -1
- package/.agents/qa_test_plan/agents/qwen.json +2 -2
- package/.agents/qa_test_plan/agents/skill.yaml +2 -2
- package/.agents/qa_ui_a11y_smoke/SKILL.md +230 -12
- package/.agents/qa_ui_a11y_smoke/agents/claude.json +2 -2
- package/.agents/qa_ui_a11y_smoke/agents/copilot.json +2 -2
- package/.agents/qa_ui_a11y_smoke/agents/gemini.json +2 -2
- package/.agents/qa_ui_a11y_smoke/agents/openai.yaml +1 -1
- package/.agents/qa_ui_a11y_smoke/agents/qwen.json +2 -2
- package/.agents/qa_ui_a11y_smoke/agents/skill.yaml +2 -2
- package/.agents/react_15_3_wix_iframe/SKILL.md +411 -12
- package/.agents/react_15_3_wix_iframe/agents/claude.json +2 -2
- package/.agents/react_15_3_wix_iframe/agents/copilot.json +2 -2
- package/.agents/react_15_3_wix_iframe/agents/gemini.json +2 -2
- package/.agents/react_15_3_wix_iframe/agents/openai.yaml +1 -1
- package/.agents/react_15_3_wix_iframe/agents/qwen.json +2 -2
- package/.agents/react_15_3_wix_iframe/agents/skill.yaml +2 -2
- package/.agents/react_beast_practices/SKILL.md +285 -18
- package/.agents/react_beast_practices/agents/claude.json +2 -2
- package/.agents/react_beast_practices/agents/copilot.json +2 -2
- package/.agents/react_beast_practices/agents/gemini.json +2 -2
- package/.agents/react_beast_practices/agents/openai.yaml +1 -1
- package/.agents/react_beast_practices/agents/qwen.json +2 -2
- package/.agents/react_beast_practices/agents/skill.yaml +2 -2
- package/.agents/release_gate/SKILL.md +213 -77
- package/.agents/release_gate/agents/claude.json +2 -2
- package/.agents/release_gate/agents/copilot.json +2 -2
- package/.agents/release_gate/agents/gemini.json +2 -2
- package/.agents/release_gate/agents/openai.yaml +1 -1
- package/.agents/release_gate/agents/qwen.json +2 -2
- package/.agents/release_gate/agents/skill.yaml +2 -2
- package/.agents/release_gate_checklist_template/SKILL.md +182 -68
- package/.agents/review_reference_snippets/SKILL.md +116 -0
- package/.agents/security_baseline_dev/SKILL.md +496 -16
- package/.agents/security_baseline_dev/agents/claude.json +2 -2
- package/.agents/security_baseline_dev/agents/copilot.json +2 -2
- package/.agents/security_baseline_dev/agents/gemini.json +2 -2
- package/.agents/security_baseline_dev/agents/openai.yaml +1 -1
- package/.agents/security_baseline_dev/agents/qwen.json +2 -2
- package/.agents/security_baseline_dev/agents/skill.yaml +2 -2
- package/.agents/security_review/SKILL.md +277 -55
- package/.agents/security_review_baseline/SKILL.md +119 -25
- package/.agents/security_review_baseline/agents/claude.json +2 -2
- package/.agents/security_review_baseline/agents/copilot.json +2 -2
- package/.agents/security_review_baseline/agents/gemini.json +2 -2
- package/.agents/security_review_baseline/agents/openai.yaml +1 -1
- package/.agents/security_review_baseline/agents/qwen.json +2 -2
- package/.agents/security_review_baseline/agents/skill.yaml +2 -2
- package/.agents/state_rtk_beast_practices/SKILL.md +735 -15
- package/.agents/state_rtk_beast_practices/agents/claude.json +2 -2
- package/.agents/state_rtk_beast_practices/agents/copilot.json +2 -2
- package/.agents/state_rtk_beast_practices/agents/gemini.json +2 -2
- package/.agents/state_rtk_beast_practices/agents/openai.yaml +1 -1
- package/.agents/state_rtk_beast_practices/agents/qwen.json +2 -2
- package/.agents/state_rtk_beast_practices/agents/skill.yaml +2 -2
- package/.agents/state_zustand_beast_practices/SKILL.md +808 -11
- package/.agents/state_zustand_beast_practices/agents/claude.json +2 -2
- package/.agents/state_zustand_beast_practices/agents/copilot.json +2 -2
- package/.agents/state_zustand_beast_practices/agents/gemini.json +2 -2
- package/.agents/state_zustand_beast_practices/agents/openai.yaml +1 -1
- package/.agents/state_zustand_beast_practices/agents/qwen.json +2 -2
- package/.agents/state_zustand_beast_practices/agents/skill.yaml +2 -2
- package/.agents/styling_css_stack/SKILL.md +558 -12
- package/.agents/styling_css_stack/agents/claude.json +2 -2
- package/.agents/styling_css_stack/agents/copilot.json +2 -2
- package/.agents/styling_css_stack/agents/gemini.json +2 -2
- package/.agents/styling_css_stack/agents/openai.yaml +1 -1
- package/.agents/styling_css_stack/agents/qwen.json +2 -2
- package/.agents/styling_css_stack/agents/skill.yaml +2 -2
- package/.agents/system_design_checklist/SKILL.md +207 -48
- package/.agents/system_design_checklist/agents/claude.json +3 -2
- package/.agents/system_design_checklist/agents/copilot.json +3 -2
- package/.agents/system_design_checklist/agents/gemini.json +3 -2
- package/.agents/system_design_checklist/agents/openai.yaml +1 -1
- package/.agents/system_design_checklist/agents/qwen.json +3 -2
- package/.agents/system_design_checklist/agents/skill.yaml +2 -1
- package/.agents/tailwind_beast_practices/SKILL.md +512 -0
- package/.agents/tailwind_beast_practices/agents/claude.json +18 -0
- package/.agents/tailwind_beast_practices/agents/copilot.json +18 -0
- package/.agents/tailwind_beast_practices/agents/gemini.json +18 -0
- package/.agents/tailwind_beast_practices/agents/openai.yaml +8 -0
- package/.agents/tailwind_beast_practices/agents/qwen.json +18 -0
- package/.agents/tailwind_beast_practices/agents/skill.yaml +22 -0
- package/.agents/tanstack_beast_practices/SKILL.md +465 -11
- package/.agents/tanstack_beast_practices/agents/claude.json +2 -2
- package/.agents/tanstack_beast_practices/agents/copilot.json +2 -2
- package/.agents/tanstack_beast_practices/agents/gemini.json +2 -2
- package/.agents/tanstack_beast_practices/agents/openai.yaml +1 -1
- package/.agents/tanstack_beast_practices/agents/qwen.json +2 -2
- package/.agents/tanstack_beast_practices/agents/skill.yaml +2 -2
- package/.agents/tdd_workflow/SKILL.md +441 -22
- package/.agents/tdd_workflow/agents/claude.json +2 -2
- package/.agents/tdd_workflow/agents/copilot.json +2 -2
- package/.agents/tdd_workflow/agents/gemini.json +2 -2
- package/.agents/tdd_workflow/agents/openai.yaml +1 -1
- package/.agents/tdd_workflow/agents/qwen.json +2 -2
- package/.agents/tdd_workflow/agents/skill.yaml +2 -2
- package/.agents/testing_strategy_js/SKILL.md +636 -30
- package/.agents/testing_strategy_js/agents/claude.json +2 -2
- package/.agents/testing_strategy_js/agents/copilot.json +2 -2
- package/.agents/testing_strategy_js/agents/gemini.json +2 -2
- package/.agents/testing_strategy_js/agents/openai.yaml +1 -1
- package/.agents/testing_strategy_js/agents/qwen.json +2 -2
- package/.agents/testing_strategy_js/agents/skill.yaml +2 -2
- package/.agents/tests_quality_review/SKILL.md +279 -18
- package/.agents/tests_quality_review/agents/claude.json +2 -2
- package/.agents/tests_quality_review/agents/copilot.json +2 -2
- package/.agents/tests_quality_review/agents/gemini.json +2 -2
- package/.agents/tests_quality_review/agents/openai.yaml +1 -1
- package/.agents/tests_quality_review/agents/qwen.json +2 -2
- package/.agents/tests_quality_review/agents/skill.yaml +2 -2
- package/.agents/threat_model_baseline/SKILL.md +210 -57
- package/.agents/threat_model_baseline/agents/claude.json +2 -2
- package/.agents/threat_model_baseline/agents/copilot.json +2 -2
- package/.agents/threat_model_baseline/agents/gemini.json +2 -2
- package/.agents/threat_model_baseline/agents/openai.yaml +1 -1
- package/.agents/threat_model_baseline/agents/qwen.json +2 -2
- package/.agents/threat_model_baseline/agents/skill.yaml +2 -2
- package/.agents/tooling_bun_biome/SKILL.md +539 -17
- package/.agents/tooling_bun_biome/agents/claude.json +2 -2
- package/.agents/tooling_bun_biome/agents/copilot.json +2 -2
- package/.agents/tooling_bun_biome/agents/gemini.json +2 -2
- package/.agents/tooling_bun_biome/agents/openai.yaml +1 -1
- package/.agents/tooling_bun_biome/agents/qwen.json +2 -2
- package/.agents/tooling_bun_biome/agents/skill.yaml +2 -2
- package/.agents/typescript_beast_practices/SKILL.md +427 -8
- package/.agents/typescript_beast_practices/agents/claude.json +2 -2
- package/.agents/typescript_beast_practices/agents/copilot.json +2 -2
- package/.agents/typescript_beast_practices/agents/gemini.json +2 -2
- package/.agents/typescript_beast_practices/agents/openai.yaml +1 -1
- package/.agents/typescript_beast_practices/agents/qwen.json +2 -2
- package/.agents/typescript_beast_practices/agents/skill.yaml +2 -2
- package/.agents/ui_a11y_smoke_review/SKILL.md +195 -15
- package/.agents/ui_a11y_smoke_review/agents/claude.json +2 -2
- package/.agents/ui_a11y_smoke_review/agents/copilot.json +2 -2
- package/.agents/ui_a11y_smoke_review/agents/gemini.json +2 -2
- package/.agents/ui_a11y_smoke_review/agents/openai.yaml +1 -1
- package/.agents/ui_a11y_smoke_review/agents/qwen.json +2 -2
- package/.agents/ui_a11y_smoke_review/agents/skill.yaml +2 -2
- package/.agents/ui_inventory/SKILL.md +277 -50
- package/.agents/ui_inventory/agents/claude.json +2 -2
- package/.agents/ui_inventory/agents/copilot.json +2 -2
- package/.agents/ui_inventory/agents/gemini.json +2 -2
- package/.agents/ui_inventory/agents/openai.yaml +1 -1
- package/.agents/ui_inventory/agents/qwen.json +2 -2
- package/.agents/ui_inventory/agents/skill.yaml +2 -2
- package/.agents/ux_discovery/SKILL.md +214 -48
- package/.agents/ux_discovery/agents/claude.json +2 -2
- package/.agents/ux_discovery/agents/copilot.json +2 -2
- package/.agents/ux_discovery/agents/gemini.json +2 -2
- package/.agents/ux_discovery/agents/openai.yaml +1 -1
- package/.agents/ux_discovery/agents/qwen.json +2 -2
- package/.agents/ux_discovery/agents/skill.yaml +2 -2
- package/.agents/ux_spec/SKILL.md +282 -56
- package/.agents/ux_spec/agents/claude.json +2 -2
- package/.agents/ux_spec/agents/copilot.json +2 -2
- package/.agents/ux_spec/agents/gemini.json +2 -2
- package/.agents/ux_spec/agents/openai.yaml +1 -1
- package/.agents/ux_spec/agents/qwen.json +2 -2
- package/.agents/ux_spec/agents/skill.yaml +2 -2
- package/.agents/wix_iframe_sdk/SKILL.md +277 -48
- package/.agents/wix_iframe_sdk/agents/claude.json +2 -2
- package/.agents/wix_iframe_sdk/agents/copilot.json +2 -2
- package/.agents/wix_iframe_sdk/agents/gemini.json +2 -2
- package/.agents/wix_iframe_sdk/agents/openai.yaml +1 -1
- package/.agents/wix_iframe_sdk/agents/qwen.json +2 -2
- package/.agents/wix_iframe_sdk/agents/skill.yaml +2 -2
- package/.agents/wix_self_hosted_embedded_script/SKILL.md +605 -82
- package/.agents/wix_self_hosted_embedded_script/agents/claude.json +2 -2
- package/.agents/wix_self_hosted_embedded_script/agents/copilot.json +2 -2
- package/.agents/wix_self_hosted_embedded_script/agents/gemini.json +2 -2
- package/.agents/wix_self_hosted_embedded_script/agents/openai.yaml +1 -1
- package/.agents/wix_self_hosted_embedded_script/agents/qwen.json +2 -2
- package/.agents/wix_self_hosted_embedded_script/agents/skill.yaml +2 -2
- package/AGENTS.yaml +2 -0
- package/agents/conductor.md +50 -0
- package/agents/devops.md +31 -1
- package/agents/orchestrator.claude.json +2 -0
- package/agents/orchestrator.copilot.json +2 -0
- package/agents/orchestrator.gemini.json +2 -0
- package/agents/orchestrator.openai.yaml +2 -0
- package/agents/orchestrator.qwen.json +2 -0
- package/agents/reviewer.md +0 -1
- package/agents/senior_full_stack.md +1 -0
- package/agents/tester.md +1 -1
- package/agents/ux_ui_designer.md +2 -2
- package/locales/en/.agents/a11y_baseline/SKILL.md +260 -41
- package/locales/en/.agents/a11y_baseline/agents/claude.json +3 -2
- package/locales/en/.agents/a11y_baseline/agents/copilot.json +3 -2
- package/locales/en/.agents/a11y_baseline/agents/gemini.json +3 -2
- package/locales/en/.agents/a11y_baseline/agents/openai.yaml +1 -1
- package/locales/en/.agents/a11y_baseline/agents/qwen.json +3 -2
- package/locales/en/.agents/a11y_baseline/agents/skill.yaml +2 -1
- package/locales/en/.agents/adr_log/SKILL.md +330 -30
- package/locales/en/.agents/adr_log/agents/claude.json +5 -5
- package/locales/en/.agents/adr_log/agents/copilot.json +5 -5
- package/locales/en/.agents/adr_log/agents/gemini.json +5 -5
- package/locales/en/.agents/adr_log/agents/openai.yaml +3 -3
- package/locales/en/.agents/adr_log/agents/qwen.json +5 -5
- package/locales/en/.agents/adr_log/agents/skill.yaml +5 -5
- package/locales/en/.agents/api_contract_compliance_review/SKILL.md +218 -12
- package/locales/en/.agents/api_contract_compliance_review/agents/claude.json +2 -2
- package/locales/en/.agents/api_contract_compliance_review/agents/copilot.json +2 -2
- package/locales/en/.agents/api_contract_compliance_review/agents/gemini.json +2 -2
- package/locales/en/.agents/api_contract_compliance_review/agents/openai.yaml +1 -1
- package/locales/en/.agents/api_contract_compliance_review/agents/qwen.json +2 -2
- package/locales/en/.agents/api_contract_compliance_review/agents/skill.yaml +2 -2
- package/locales/en/.agents/api_contracts/SKILL.md +323 -36
- package/locales/en/.agents/api_contracts/agents/claude.json +2 -2
- package/locales/en/.agents/api_contracts/agents/copilot.json +2 -2
- package/locales/en/.agents/api_contracts/agents/gemini.json +2 -2
- package/locales/en/.agents/api_contracts/agents/openai.yaml +1 -1
- package/locales/en/.agents/api_contracts/agents/qwen.json +2 -2
- package/locales/en/.agents/api_contracts/agents/skill.yaml +2 -2
- package/locales/en/.agents/architecture_compliance_review/SKILL.md +206 -10
- package/locales/en/.agents/architecture_compliance_review/agents/claude.json +5 -4
- package/locales/en/.agents/architecture_compliance_review/agents/copilot.json +5 -4
- package/locales/en/.agents/architecture_compliance_review/agents/gemini.json +5 -4
- package/locales/en/.agents/architecture_compliance_review/agents/openai.yaml +3 -3
- package/locales/en/.agents/architecture_compliance_review/agents/qwen.json +5 -4
- package/locales/en/.agents/architecture_compliance_review/agents/skill.yaml +5 -4
- package/locales/en/.agents/architecture_doc/SKILL.md +374 -82
- package/locales/en/.agents/architecture_doc/agents/claude.json +2 -2
- package/locales/en/.agents/architecture_doc/agents/copilot.json +2 -2
- package/locales/en/.agents/architecture_doc/agents/gemini.json +2 -2
- package/locales/en/.agents/architecture_doc/agents/openai.yaml +1 -1
- package/locales/en/.agents/architecture_doc/agents/qwen.json +2 -2
- package/locales/en/.agents/architecture_doc/agents/skill.yaml +2 -2
- package/locales/en/.agents/board/SKILL.md +232 -43
- package/locales/en/.agents/board/agents/claude.json +2 -2
- package/locales/en/.agents/board/agents/copilot.json +2 -2
- package/locales/en/.agents/board/agents/gemini.json +2 -2
- package/locales/en/.agents/board/agents/openai.yaml +1 -1
- package/locales/en/.agents/board/agents/qwen.json +2 -2
- package/locales/en/.agents/board/agents/skill.yaml +2 -2
- package/locales/en/.agents/cloud_infrastructure_security/SKILL.md +277 -68
- package/locales/en/.agents/cloud_infrastructure_security/agents/claude.json +5 -4
- package/locales/en/.agents/cloud_infrastructure_security/agents/copilot.json +5 -4
- package/locales/en/.agents/cloud_infrastructure_security/agents/gemini.json +5 -4
- package/locales/en/.agents/cloud_infrastructure_security/agents/openai.yaml +3 -3
- package/locales/en/.agents/cloud_infrastructure_security/agents/qwen.json +5 -4
- package/locales/en/.agents/cloud_infrastructure_security/agents/skill.yaml +5 -4
- package/locales/en/.agents/code_review_checklist/SKILL.md +194 -41
- package/locales/en/.agents/code_review_checklist/agents/claude.json +2 -2
- package/locales/en/.agents/code_review_checklist/agents/copilot.json +2 -2
- package/locales/en/.agents/code_review_checklist/agents/gemini.json +2 -2
- package/locales/en/.agents/code_review_checklist/agents/openai.yaml +1 -1
- package/locales/en/.agents/code_review_checklist/agents/qwen.json +2 -2
- package/locales/en/.agents/code_review_checklist/agents/skill.yaml +2 -2
- package/locales/en/.agents/current_state_analysis/SKILL.md +225 -44
- package/locales/en/.agents/current_state_analysis/agents/claude.json +5 -4
- package/locales/en/.agents/current_state_analysis/agents/copilot.json +5 -4
- package/locales/en/.agents/current_state_analysis/agents/gemini.json +5 -4
- package/locales/en/.agents/current_state_analysis/agents/openai.yaml +3 -3
- package/locales/en/.agents/current_state_analysis/agents/qwen.json +5 -4
- package/locales/en/.agents/current_state_analysis/agents/skill.yaml +5 -4
- package/locales/en/.agents/data_model/SKILL.md +277 -32
- package/locales/en/.agents/data_model/agents/claude.json +2 -2
- package/locales/en/.agents/data_model/agents/copilot.json +2 -2
- package/locales/en/.agents/data_model/agents/gemini.json +2 -2
- package/locales/en/.agents/data_model/agents/openai.yaml +1 -1
- package/locales/en/.agents/data_model/agents/qwen.json +2 -2
- package/locales/en/.agents/data_model/agents/skill.yaml +2 -2
- package/locales/en/.agents/dependency_supply_chain_review/SKILL.md +291 -11
- package/locales/en/.agents/dependency_supply_chain_review/agents/claude.json +5 -4
- package/locales/en/.agents/dependency_supply_chain_review/agents/copilot.json +5 -4
- package/locales/en/.agents/dependency_supply_chain_review/agents/gemini.json +5 -4
- package/locales/en/.agents/dependency_supply_chain_review/agents/openai.yaml +3 -3
- package/locales/en/.agents/dependency_supply_chain_review/agents/qwen.json +5 -4
- package/locales/en/.agents/dependency_supply_chain_review/agents/skill.yaml +5 -4
- package/locales/en/.agents/deployment_ci_plan/SKILL.md +404 -45
- package/locales/en/.agents/deployment_ci_plan/agents/claude.json +2 -2
- package/locales/en/.agents/deployment_ci_plan/agents/copilot.json +2 -2
- package/locales/en/.agents/deployment_ci_plan/agents/gemini.json +2 -2
- package/locales/en/.agents/deployment_ci_plan/agents/openai.yaml +1 -1
- package/locales/en/.agents/deployment_ci_plan/agents/qwen.json +2 -2
- package/locales/en/.agents/deployment_ci_plan/agents/skill.yaml +2 -2
- package/locales/en/.agents/design_intake/SKILL.md +221 -67
- package/locales/en/.agents/design_intake/agents/claude.json +4 -5
- package/locales/en/.agents/design_intake/agents/copilot.json +4 -5
- package/locales/en/.agents/design_intake/agents/gemini.json +4 -5
- package/locales/en/.agents/design_intake/agents/openai.yaml +3 -3
- package/locales/en/.agents/design_intake/agents/qwen.json +4 -5
- package/locales/en/.agents/design_intake/agents/skill.yaml +4 -5
- package/locales/en/.agents/design_parity_review/SKILL.md +216 -60
- package/locales/en/.agents/design_parity_review/agents/claude.json +2 -3
- package/locales/en/.agents/design_parity_review/agents/copilot.json +2 -3
- package/locales/en/.agents/design_parity_review/agents/gemini.json +2 -3
- package/locales/en/.agents/design_parity_review/agents/openai.yaml +2 -2
- package/locales/en/.agents/design_parity_review/agents/qwen.json +2 -3
- package/locales/en/.agents/design_parity_review/agents/skill.yaml +2 -3
- package/locales/en/.agents/design_systems/SKILL.md +432 -15
- package/locales/en/.agents/design_systems/agents/claude.json +2 -2
- package/locales/en/.agents/design_systems/agents/copilot.json +2 -2
- package/locales/en/.agents/design_systems/agents/gemini.json +2 -2
- package/locales/en/.agents/design_systems/agents/openai.yaml +1 -1
- package/locales/en/.agents/design_systems/agents/qwen.json +2 -2
- package/locales/en/.agents/design_systems/agents/skill.yaml +2 -2
- package/locales/en/.agents/dev_reference_snippets/SKILL.md +585 -397
- package/locales/en/.agents/dev_reference_snippets/agents/claude.json +2 -2
- package/locales/en/.agents/dev_reference_snippets/agents/copilot.json +2 -2
- package/locales/en/.agents/dev_reference_snippets/agents/gemini.json +2 -2
- package/locales/en/.agents/dev_reference_snippets/agents/openai.yaml +1 -1
- package/locales/en/.agents/dev_reference_snippets/agents/qwen.json +2 -2
- package/locales/en/.agents/dev_reference_snippets/agents/skill.yaml +2 -2
- package/locales/en/.agents/docker_kubernetes_architecture/SKILL.md +473 -137
- package/locales/en/.agents/docker_kubernetes_architecture/agents/claude.json +5 -4
- package/locales/en/.agents/docker_kubernetes_architecture/agents/copilot.json +5 -4
- package/locales/en/.agents/docker_kubernetes_architecture/agents/gemini.json +5 -4
- package/locales/en/.agents/docker_kubernetes_architecture/agents/openai.yaml +3 -3
- package/locales/en/.agents/docker_kubernetes_architecture/agents/qwen.json +5 -4
- package/locales/en/.agents/docker_kubernetes_architecture/agents/skill.yaml +5 -4
- package/locales/en/.agents/es2025_beast_practices/SKILL.md +440 -15
- package/locales/en/.agents/es2025_beast_practices/agents/claude.json +4 -4
- package/locales/en/.agents/es2025_beast_practices/agents/copilot.json +4 -4
- package/locales/en/.agents/es2025_beast_practices/agents/gemini.json +4 -4
- package/locales/en/.agents/es2025_beast_practices/agents/openai.yaml +3 -3
- package/locales/en/.agents/es2025_beast_practices/agents/qwen.json +4 -4
- package/locales/en/.agents/es2025_beast_practices/agents/skill.yaml +4 -4
- package/locales/en/.agents/gates/SKILL.md +128 -29
- package/locales/en/.agents/gates/agents/claude.json +2 -2
- package/locales/en/.agents/gates/agents/copilot.json +2 -2
- package/locales/en/.agents/gates/agents/gemini.json +2 -2
- package/locales/en/.agents/gates/agents/openai.yaml +1 -1
- package/locales/en/.agents/gates/agents/qwen.json +2 -2
- package/locales/en/.agents/gates/agents/skill.yaml +2 -2
- package/locales/en/.agents/go_beast_practices/SKILL.md +557 -23
- package/locales/en/.agents/go_beast_practices/agents/claude.json +5 -4
- package/locales/en/.agents/go_beast_practices/agents/copilot.json +5 -4
- package/locales/en/.agents/go_beast_practices/agents/gemini.json +5 -4
- package/locales/en/.agents/go_beast_practices/agents/openai.yaml +3 -3
- package/locales/en/.agents/go_beast_practices/agents/qwen.json +5 -4
- package/locales/en/.agents/go_beast_practices/agents/skill.yaml +5 -4
- package/locales/en/.agents/google_stitch_skill/SKILL.md +507 -71
- package/locales/en/.agents/google_stitch_skill/agents/claude.json +5 -6
- package/locales/en/.agents/google_stitch_skill/agents/copilot.json +5 -6
- package/locales/en/.agents/google_stitch_skill/agents/gemini.json +5 -6
- package/locales/en/.agents/google_stitch_skill/agents/openai.yaml +1 -1
- package/locales/en/.agents/google_stitch_skill/agents/qwen.json +5 -6
- package/locales/en/.agents/google_stitch_skill/agents/skill.yaml +4 -5
- package/locales/en/.agents/handoff/SKILL.md +206 -46
- package/locales/en/.agents/handoff/agents/claude.json +5 -5
- package/locales/en/.agents/handoff/agents/copilot.json +5 -5
- package/locales/en/.agents/handoff/agents/gemini.json +5 -5
- package/locales/en/.agents/handoff/agents/openai.yaml +3 -3
- package/locales/en/.agents/handoff/agents/qwen.json +5 -5
- package/locales/en/.agents/handoff/agents/skill.yaml +5 -5
- package/locales/en/.agents/k8s_manifests_conventions/SKILL.md +540 -167
- package/locales/en/.agents/k8s_manifests_conventions/agents/claude.json +2 -2
- package/locales/en/.agents/k8s_manifests_conventions/agents/copilot.json +2 -2
- package/locales/en/.agents/k8s_manifests_conventions/agents/gemini.json +2 -2
- package/locales/en/.agents/k8s_manifests_conventions/agents/openai.yaml +1 -1
- package/locales/en/.agents/k8s_manifests_conventions/agents/qwen.json +2 -2
- package/locales/en/.agents/k8s_manifests_conventions/agents/skill.yaml +2 -2
- package/locales/en/.agents/memory/SKILL.md +211 -21
- package/locales/en/.agents/memory/agents/claude.json +5 -4
- package/locales/en/.agents/memory/agents/copilot.json +5 -4
- package/locales/en/.agents/memory/agents/gemini.json +5 -4
- package/locales/en/.agents/memory/agents/openai.yaml +3 -3
- package/locales/en/.agents/memory/agents/qwen.json +5 -4
- package/locales/en/.agents/memory/agents/skill.yaml +5 -4
- package/locales/en/.agents/mongodb_mongoose_best_practices/SKILL.md +669 -178
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/claude.json +4 -5
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/copilot.json +4 -5
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/gemini.json +4 -5
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/openai.yaml +3 -3
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/qwen.json +4 -5
- package/locales/en/.agents/mongodb_mongoose_best_practices/agents/skill.yaml +4 -5
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/SKILL.md +669 -57
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/claude.json +5 -5
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/copilot.json +5 -5
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/gemini.json +5 -5
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/openai.yaml +3 -3
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/qwen.json +5 -5
- package/locales/en/.agents/n8n_pinecone_qdrant_supabase/agents/skill.yaml +5 -5
- package/locales/en/.agents/node_express_beast_practices/SKILL.md +718 -19
- package/locales/en/.agents/node_express_beast_practices/agents/claude.json +1 -1
- package/locales/en/.agents/node_express_beast_practices/agents/copilot.json +1 -1
- package/locales/en/.agents/node_express_beast_practices/agents/gemini.json +1 -1
- package/locales/en/.agents/node_express_beast_practices/agents/openai.yaml +1 -1
- package/locales/en/.agents/node_express_beast_practices/agents/qwen.json +1 -1
- package/locales/en/.agents/node_express_beast_practices/agents/skill.yaml +1 -1
- package/locales/en/.agents/observability_logging/SKILL.md +499 -16
- package/locales/en/.agents/observability_logging/agents/claude.json +4 -4
- package/locales/en/.agents/observability_logging/agents/copilot.json +4 -4
- package/locales/en/.agents/observability_logging/agents/gemini.json +4 -4
- package/locales/en/.agents/observability_logging/agents/openai.yaml +3 -3
- package/locales/en/.agents/observability_logging/agents/qwen.json +4 -4
- package/locales/en/.agents/observability_logging/agents/skill.yaml +4 -4
- package/locales/en/.agents/observability_plan/SKILL.md +273 -32
- package/locales/en/.agents/observability_plan/agents/claude.json +6 -4
- package/locales/en/.agents/observability_plan/agents/copilot.json +6 -4
- package/locales/en/.agents/observability_plan/agents/gemini.json +6 -4
- package/locales/en/.agents/observability_plan/agents/openai.yaml +3 -3
- package/locales/en/.agents/observability_plan/agents/qwen.json +6 -4
- package/locales/en/.agents/observability_plan/agents/skill.yaml +5 -3
- package/locales/en/.agents/observability_review/SKILL.md +245 -11
- package/locales/en/.agents/observability_review/agents/claude.json +6 -4
- package/locales/en/.agents/observability_review/agents/copilot.json +6 -4
- package/locales/en/.agents/observability_review/agents/gemini.json +6 -4
- package/locales/en/.agents/observability_review/agents/openai.yaml +3 -3
- package/locales/en/.agents/observability_review/agents/qwen.json +6 -4
- package/locales/en/.agents/observability_review/agents/skill.yaml +5 -3
- package/locales/en/.agents/performance_review_baseline/SKILL.md +232 -10
- package/locales/en/.agents/performance_review_baseline/agents/claude.json +5 -4
- package/locales/en/.agents/performance_review_baseline/agents/copilot.json +5 -4
- package/locales/en/.agents/performance_review_baseline/agents/gemini.json +5 -4
- package/locales/en/.agents/performance_review_baseline/agents/openai.yaml +3 -3
- package/locales/en/.agents/performance_review_baseline/agents/qwen.json +5 -4
- package/locales/en/.agents/performance_review_baseline/agents/skill.yaml +5 -4
- package/locales/en/.agents/pm_backlog/SKILL.md +239 -21
- package/locales/en/.agents/pm_backlog/agents/claude.json +2 -2
- package/locales/en/.agents/pm_backlog/agents/copilot.json +2 -2
- package/locales/en/.agents/pm_backlog/agents/gemini.json +2 -2
- package/locales/en/.agents/pm_backlog/agents/openai.yaml +1 -1
- package/locales/en/.agents/pm_backlog/agents/qwen.json +2 -2
- package/locales/en/.agents/pm_backlog/agents/skill.yaml +2 -2
- package/locales/en/.agents/pm_interview/SKILL.md +178 -37
- package/locales/en/.agents/pm_interview/agents/claude.json +5 -4
- package/locales/en/.agents/pm_interview/agents/copilot.json +5 -4
- package/locales/en/.agents/pm_interview/agents/gemini.json +5 -4
- package/locales/en/.agents/pm_interview/agents/openai.yaml +3 -3
- package/locales/en/.agents/pm_interview/agents/qwen.json +5 -4
- package/locales/en/.agents/pm_interview/agents/skill.yaml +5 -4
- package/locales/en/.agents/pm_prd/SKILL.md +197 -38
- package/locales/en/.agents/pm_prd/agents/claude.json +2 -2
- package/locales/en/.agents/pm_prd/agents/copilot.json +2 -2
- package/locales/en/.agents/pm_prd/agents/gemini.json +2 -2
- package/locales/en/.agents/pm_prd/agents/openai.yaml +1 -1
- package/locales/en/.agents/pm_prd/agents/qwen.json +2 -2
- package/locales/en/.agents/pm_prd/agents/skill.yaml +2 -2
- package/locales/en/.agents/qa_api_contract_tests/SKILL.md +207 -16
- package/locales/en/.agents/qa_api_contract_tests/agents/claude.json +2 -2
- package/locales/en/.agents/qa_api_contract_tests/agents/copilot.json +2 -2
- package/locales/en/.agents/qa_api_contract_tests/agents/gemini.json +2 -2
- package/locales/en/.agents/qa_api_contract_tests/agents/openai.yaml +1 -1
- package/locales/en/.agents/qa_api_contract_tests/agents/qwen.json +2 -2
- package/locales/en/.agents/qa_api_contract_tests/agents/skill.yaml +2 -2
- package/locales/en/.agents/qa_browser_testing/SKILL.md +254 -86
- package/locales/en/.agents/qa_e2e_playwright/SKILL.md +313 -116
- package/locales/en/.agents/qa_manual_run/SKILL.md +202 -9
- package/locales/en/.agents/qa_manual_run/agents/claude.json +2 -2
- package/locales/en/.agents/qa_manual_run/agents/copilot.json +2 -2
- package/locales/en/.agents/qa_manual_run/agents/gemini.json +2 -2
- package/locales/en/.agents/qa_manual_run/agents/openai.yaml +1 -1
- package/locales/en/.agents/qa_manual_run/agents/qwen.json +2 -2
- package/locales/en/.agents/qa_manual_run/agents/skill.yaml +2 -2
- package/locales/en/.agents/qa_regression_baseline/SKILL.md +217 -0
- package/locales/en/.agents/qa_regression_baseline/agents/claude.json +19 -0
- package/locales/en/.agents/qa_regression_baseline/agents/copilot.json +19 -0
- package/locales/en/.agents/qa_regression_baseline/agents/gemini.json +19 -0
- package/locales/en/.agents/qa_regression_baseline/agents/openai.yaml +8 -0
- package/locales/en/.agents/qa_regression_baseline/agents/qwen.json +19 -0
- package/locales/en/.agents/qa_regression_baseline/agents/skill.yaml +23 -0
- package/locales/en/.agents/qa_security_smoke_tests/SKILL.md +182 -8
- package/locales/en/.agents/qa_security_smoke_tests/agents/claude.json +2 -2
- package/locales/en/.agents/qa_security_smoke_tests/agents/copilot.json +2 -2
- package/locales/en/.agents/qa_security_smoke_tests/agents/gemini.json +2 -2
- package/locales/en/.agents/qa_security_smoke_tests/agents/openai.yaml +1 -1
- package/locales/en/.agents/qa_security_smoke_tests/agents/qwen.json +2 -2
- package/locales/en/.agents/qa_security_smoke_tests/agents/skill.yaml +2 -2
- package/locales/en/.agents/qa_test_plan/SKILL.md +197 -14
- package/locales/en/.agents/qa_test_plan/agents/claude.json +2 -2
- package/locales/en/.agents/qa_test_plan/agents/copilot.json +2 -2
- package/locales/en/.agents/qa_test_plan/agents/gemini.json +2 -2
- package/locales/en/.agents/qa_test_plan/agents/openai.yaml +1 -1
- package/locales/en/.agents/qa_test_plan/agents/qwen.json +2 -2
- package/locales/en/.agents/qa_test_plan/agents/skill.yaml +2 -2
- package/locales/en/.agents/qa_ui_a11y_smoke/SKILL.md +224 -6
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/claude.json +5 -4
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/copilot.json +5 -4
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/gemini.json +5 -4
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/openai.yaml +3 -3
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/qwen.json +5 -4
- package/locales/en/.agents/qa_ui_a11y_smoke/agents/skill.yaml +5 -4
- package/locales/en/.agents/react_15_3_wix_iframe/SKILL.md +419 -20
- package/locales/en/.agents/react_15_3_wix_iframe/agents/claude.json +2 -2
- package/locales/en/.agents/react_15_3_wix_iframe/agents/copilot.json +2 -2
- package/locales/en/.agents/react_15_3_wix_iframe/agents/gemini.json +2 -2
- package/locales/en/.agents/react_15_3_wix_iframe/agents/openai.yaml +1 -1
- package/locales/en/.agents/react_15_3_wix_iframe/agents/qwen.json +2 -2
- package/locales/en/.agents/react_15_3_wix_iframe/agents/skill.yaml +2 -2
- package/locales/en/.agents/react_beast_practices/SKILL.md +285 -18
- package/locales/en/.agents/react_beast_practices/agents/claude.json +4 -4
- package/locales/en/.agents/react_beast_practices/agents/copilot.json +4 -4
- package/locales/en/.agents/react_beast_practices/agents/gemini.json +4 -4
- package/locales/en/.agents/react_beast_practices/agents/openai.yaml +3 -3
- package/locales/en/.agents/react_beast_practices/agents/qwen.json +4 -4
- package/locales/en/.agents/react_beast_practices/agents/skill.yaml +4 -4
- package/locales/en/.agents/release_gate/SKILL.md +205 -69
- package/locales/en/.agents/release_gate/agents/claude.json +5 -4
- package/locales/en/.agents/release_gate/agents/copilot.json +5 -4
- package/locales/en/.agents/release_gate/agents/gemini.json +5 -4
- package/locales/en/.agents/release_gate/agents/openai.yaml +3 -3
- package/locales/en/.agents/release_gate/agents/qwen.json +5 -4
- package/locales/en/.agents/release_gate/agents/skill.yaml +5 -4
- package/locales/en/.agents/release_gate_checklist_template/SKILL.md +175 -61
- package/locales/en/.agents/review_reference_snippets/SKILL.md +163 -46
- package/locales/en/.agents/security_baseline_dev/SKILL.md +496 -16
- package/locales/en/.agents/security_baseline_dev/agents/claude.json +2 -2
- package/locales/en/.agents/security_baseline_dev/agents/copilot.json +2 -2
- package/locales/en/.agents/security_baseline_dev/agents/gemini.json +2 -2
- package/locales/en/.agents/security_baseline_dev/agents/openai.yaml +1 -1
- package/locales/en/.agents/security_baseline_dev/agents/qwen.json +2 -2
- package/locales/en/.agents/security_baseline_dev/agents/skill.yaml +2 -2
- package/locales/en/.agents/security_review/SKILL.md +277 -55
- package/locales/en/.agents/security_review_baseline/SKILL.md +111 -17
- package/locales/en/.agents/security_review_baseline/agents/claude.json +2 -2
- package/locales/en/.agents/security_review_baseline/agents/copilot.json +2 -2
- package/locales/en/.agents/security_review_baseline/agents/gemini.json +2 -2
- package/locales/en/.agents/security_review_baseline/agents/openai.yaml +1 -1
- package/locales/en/.agents/security_review_baseline/agents/qwen.json +2 -2
- package/locales/en/.agents/security_review_baseline/agents/skill.yaml +2 -2
- package/locales/en/.agents/state_rtk_beast_practices/SKILL.md +735 -15
- package/locales/en/.agents/state_rtk_beast_practices/agents/claude.json +2 -2
- package/locales/en/.agents/state_rtk_beast_practices/agents/copilot.json +2 -2
- package/locales/en/.agents/state_rtk_beast_practices/agents/gemini.json +2 -2
- package/locales/en/.agents/state_rtk_beast_practices/agents/openai.yaml +1 -1
- package/locales/en/.agents/state_rtk_beast_practices/agents/qwen.json +2 -2
- package/locales/en/.agents/state_rtk_beast_practices/agents/skill.yaml +2 -2
- package/locales/en/.agents/state_zustand_beast_practices/SKILL.md +808 -11
- package/locales/en/.agents/state_zustand_beast_practices/agents/claude.json +2 -2
- package/locales/en/.agents/state_zustand_beast_practices/agents/copilot.json +2 -2
- package/locales/en/.agents/state_zustand_beast_practices/agents/gemini.json +2 -2
- package/locales/en/.agents/state_zustand_beast_practices/agents/openai.yaml +1 -1
- package/locales/en/.agents/state_zustand_beast_practices/agents/qwen.json +2 -2
- package/locales/en/.agents/state_zustand_beast_practices/agents/skill.yaml +2 -2
- package/locales/en/.agents/styling_css_stack/SKILL.md +558 -12
- package/locales/en/.agents/styling_css_stack/agents/claude.json +5 -5
- package/locales/en/.agents/styling_css_stack/agents/copilot.json +5 -5
- package/locales/en/.agents/styling_css_stack/agents/gemini.json +5 -5
- package/locales/en/.agents/styling_css_stack/agents/openai.yaml +3 -3
- package/locales/en/.agents/styling_css_stack/agents/qwen.json +5 -5
- package/locales/en/.agents/styling_css_stack/agents/skill.yaml +5 -5
- package/locales/en/.agents/system_design_checklist/SKILL.md +199 -40
- package/locales/en/.agents/system_design_checklist/agents/claude.json +3 -2
- package/locales/en/.agents/system_design_checklist/agents/copilot.json +3 -2
- package/locales/en/.agents/system_design_checklist/agents/gemini.json +3 -2
- package/locales/en/.agents/system_design_checklist/agents/openai.yaml +1 -1
- package/locales/en/.agents/system_design_checklist/agents/qwen.json +3 -2
- package/locales/en/.agents/system_design_checklist/agents/skill.yaml +2 -1
- package/locales/en/.agents/tailwind_beast_practices/SKILL.md +512 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/claude.json +18 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/copilot.json +18 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/gemini.json +18 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/openai.yaml +8 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/qwen.json +18 -0
- package/locales/en/.agents/tailwind_beast_practices/agents/skill.yaml +22 -0
- package/locales/en/.agents/tanstack_beast_practices/SKILL.md +473 -19
- package/locales/en/.agents/tanstack_beast_practices/agents/claude.json +2 -2
- package/locales/en/.agents/tanstack_beast_practices/agents/copilot.json +2 -2
- package/locales/en/.agents/tanstack_beast_practices/agents/gemini.json +2 -2
- package/locales/en/.agents/tanstack_beast_practices/agents/openai.yaml +1 -1
- package/locales/en/.agents/tanstack_beast_practices/agents/qwen.json +2 -2
- package/locales/en/.agents/tanstack_beast_practices/agents/skill.yaml +2 -2
- package/locales/en/.agents/tdd_workflow/SKILL.md +453 -34
- package/locales/en/.agents/tdd_workflow/agents/claude.json +2 -2
- package/locales/en/.agents/tdd_workflow/agents/copilot.json +2 -2
- package/locales/en/.agents/tdd_workflow/agents/gemini.json +2 -2
- package/locales/en/.agents/tdd_workflow/agents/openai.yaml +1 -1
- package/locales/en/.agents/tdd_workflow/agents/qwen.json +2 -2
- package/locales/en/.agents/tdd_workflow/agents/skill.yaml +2 -2
- package/locales/en/.agents/testing_strategy_js/SKILL.md +636 -30
- package/locales/en/.agents/testing_strategy_js/agents/claude.json +2 -2
- package/locales/en/.agents/testing_strategy_js/agents/copilot.json +2 -2
- package/locales/en/.agents/testing_strategy_js/agents/gemini.json +2 -2
- package/locales/en/.agents/testing_strategy_js/agents/openai.yaml +1 -1
- package/locales/en/.agents/testing_strategy_js/agents/qwen.json +2 -2
- package/locales/en/.agents/testing_strategy_js/agents/skill.yaml +2 -2
- package/locales/en/.agents/tests_quality_review/SKILL.md +279 -18
- package/locales/en/.agents/tests_quality_review/agents/claude.json +2 -2
- package/locales/en/.agents/tests_quality_review/agents/copilot.json +2 -2
- package/locales/en/.agents/tests_quality_review/agents/gemini.json +2 -2
- package/locales/en/.agents/tests_quality_review/agents/openai.yaml +1 -1
- package/locales/en/.agents/tests_quality_review/agents/qwen.json +2 -2
- package/locales/en/.agents/tests_quality_review/agents/skill.yaml +2 -2
- package/locales/en/.agents/threat_model_baseline/SKILL.md +202 -49
- package/locales/en/.agents/threat_model_baseline/agents/claude.json +2 -2
- package/locales/en/.agents/threat_model_baseline/agents/copilot.json +2 -2
- package/locales/en/.agents/threat_model_baseline/agents/gemini.json +2 -2
- package/locales/en/.agents/threat_model_baseline/agents/openai.yaml +1 -1
- package/locales/en/.agents/threat_model_baseline/agents/qwen.json +2 -2
- package/locales/en/.agents/threat_model_baseline/agents/skill.yaml +2 -2
- package/locales/en/.agents/tooling_bun_biome/SKILL.md +531 -9
- package/locales/en/.agents/tooling_bun_biome/agents/claude.json +5 -5
- package/locales/en/.agents/tooling_bun_biome/agents/copilot.json +5 -5
- package/locales/en/.agents/tooling_bun_biome/agents/gemini.json +5 -5
- package/locales/en/.agents/tooling_bun_biome/agents/openai.yaml +3 -3
- package/locales/en/.agents/tooling_bun_biome/agents/qwen.json +5 -5
- package/locales/en/.agents/tooling_bun_biome/agents/skill.yaml +5 -5
- package/locales/en/.agents/typescript_beast_practices/SKILL.md +434 -15
- package/locales/en/.agents/typescript_beast_practices/agents/claude.json +2 -2
- package/locales/en/.agents/typescript_beast_practices/agents/copilot.json +2 -2
- package/locales/en/.agents/typescript_beast_practices/agents/gemini.json +2 -2
- package/locales/en/.agents/typescript_beast_practices/agents/openai.yaml +1 -1
- package/locales/en/.agents/typescript_beast_practices/agents/qwen.json +2 -2
- package/locales/en/.agents/typescript_beast_practices/agents/skill.yaml +2 -2
- package/locales/en/.agents/ui_a11y_smoke_review/SKILL.md +189 -9
- package/locales/en/.agents/ui_a11y_smoke_review/agents/claude.json +5 -5
- package/locales/en/.agents/ui_a11y_smoke_review/agents/copilot.json +5 -5
- package/locales/en/.agents/ui_a11y_smoke_review/agents/gemini.json +5 -5
- package/locales/en/.agents/ui_a11y_smoke_review/agents/openai.yaml +3 -3
- package/locales/en/.agents/ui_a11y_smoke_review/agents/qwen.json +5 -5
- package/locales/en/.agents/ui_a11y_smoke_review/agents/skill.yaml +5 -5
- package/locales/en/.agents/ui_inventory/SKILL.md +271 -44
- package/locales/en/.agents/ui_inventory/agents/claude.json +2 -2
- package/locales/en/.agents/ui_inventory/agents/copilot.json +2 -2
- package/locales/en/.agents/ui_inventory/agents/gemini.json +2 -2
- package/locales/en/.agents/ui_inventory/agents/openai.yaml +1 -1
- package/locales/en/.agents/ui_inventory/agents/qwen.json +2 -2
- package/locales/en/.agents/ui_inventory/agents/skill.yaml +2 -2
- package/locales/en/.agents/ux_discovery/SKILL.md +199 -33
- package/locales/en/.agents/ux_discovery/agents/claude.json +2 -2
- package/locales/en/.agents/ux_discovery/agents/copilot.json +2 -2
- package/locales/en/.agents/ux_discovery/agents/gemini.json +2 -2
- package/locales/en/.agents/ux_discovery/agents/openai.yaml +1 -1
- package/locales/en/.agents/ux_discovery/agents/qwen.json +2 -2
- package/locales/en/.agents/ux_discovery/agents/skill.yaml +2 -2
- package/locales/en/.agents/ux_spec/SKILL.md +276 -50
- package/locales/en/.agents/ux_spec/agents/claude.json +2 -2
- package/locales/en/.agents/ux_spec/agents/copilot.json +2 -2
- package/locales/en/.agents/ux_spec/agents/gemini.json +2 -2
- package/locales/en/.agents/ux_spec/agents/openai.yaml +1 -1
- package/locales/en/.agents/ux_spec/agents/qwen.json +2 -2
- package/locales/en/.agents/ux_spec/agents/skill.yaml +2 -2
- package/locales/en/.agents/wix_iframe_sdk/SKILL.md +271 -42
- package/locales/en/.agents/wix_iframe_sdk/agents/claude.json +4 -5
- package/locales/en/.agents/wix_iframe_sdk/agents/copilot.json +4 -5
- package/locales/en/.agents/wix_iframe_sdk/agents/gemini.json +4 -5
- package/locales/en/.agents/wix_iframe_sdk/agents/openai.yaml +3 -3
- package/locales/en/.agents/wix_iframe_sdk/agents/qwen.json +4 -5
- package/locales/en/.agents/wix_iframe_sdk/agents/skill.yaml +4 -5
- package/locales/en/.agents/wix_self_hosted_embedded_script/SKILL.md +611 -88
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/claude.json +2 -2
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/copilot.json +2 -2
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/gemini.json +2 -2
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/openai.yaml +1 -1
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/qwen.json +2 -2
- package/locales/en/.agents/wix_self_hosted_embedded_script/agents/skill.yaml +2 -2
- package/locales/en/AGENTS.yaml +2 -0
- package/locales/en/agents/architect.md +1 -1
- package/locales/en/agents/conductor.md +50 -0
- package/locales/en/agents/devops.md +34 -0
- package/locales/en/agents/orchestrator.claude.json +2 -0
- package/locales/en/agents/orchestrator.copilot.json +2 -0
- package/locales/en/agents/orchestrator.gemini.json +2 -0
- package/locales/en/agents/orchestrator.openai.yaml +2 -0
- package/locales/en/agents/orchestrator.qwen.json +2 -0
- package/locales/en/agents/product_manager.md +1 -5
- package/locales/en/agents/reviewer.md +69 -64
- package/locales/en/agents/senior_full_stack.md +2 -2
- package/locales/en/agents/tester.md +50 -11
- package/locales/en/agents/ux_ui_designer.md +3 -5
- package/package.json +1 -1
|
@@ -1,16 +1,28 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: dev_reference_snippets
|
|
3
|
-
description:
|
|
3
|
+
description: Эталонные сниппеты и DO/DON'T для Senior Full Stack: TDD (Vitest), Express API (Route→Controller→Service→Repo), валидация (Zod), централизованные ошибки, структурированное логирование, React + TanStack Query, Zustand, RTK (EntityAdapter), авторизация на сервере, legacy React 15.3 (Wix). Используй этот скилл при написании любого production-кода на Node.js/TypeScript/React — как источник копипаст-эталонов и чеклист для код-ревью. Также используй при вопросах «как правильно сделать X» для любого из перечисленных паттернов.
|
|
4
4
|
---
|
|
5
5
|
|
|
6
6
|
# Skill: Dev Reference Snippets (Do/Don't)
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
Копипаст-эталоны и анти-паттерны для консистентного, тестируемого, безопасного кода.
|
|
9
|
+
|
|
10
|
+
**Разделы:**
|
|
11
|
+
1. [TDD: RED → GREEN → REFACTOR](#1-tdd)
|
|
12
|
+
2. [API: Route → Controller → Service → Repo](#2-api-слои)
|
|
13
|
+
3. [Валидация на границе (Zod)](#3-валидация)
|
|
14
|
+
4. [Централизованный error handler](#4-error-handler)
|
|
15
|
+
5. [Логирование: request_id + структура](#5-логирование)
|
|
16
|
+
6. [React: loading/empty/error/success](#6-react-состояния)
|
|
17
|
+
7. [Zustand: доменные сторы](#7-zustand)
|
|
18
|
+
8. [RTK: slices + EntityAdapter](#8-rtk)
|
|
19
|
+
9. [Авторизация на сервере](#9-авторизация)
|
|
20
|
+
10. [Legacy React 15.3 (Wix)](#10-legacy-react-153)
|
|
21
|
+
11. [DoD Scripts](#11-dod-scripts)
|
|
10
22
|
|
|
11
23
|
---
|
|
12
24
|
|
|
13
|
-
## 1
|
|
25
|
+
## 1. TDD
|
|
14
26
|
|
|
15
27
|
### ✅ DO: тест сначала (Vitest)
|
|
16
28
|
```ts
|
|
@@ -19,14 +31,12 @@ import { describe, it, expect } from "vitest";
|
|
|
19
31
|
import { slugify } from "./slugify";
|
|
20
32
|
|
|
21
33
|
describe("slugify", () => {
|
|
22
|
-
it("
|
|
34
|
+
it("lowercases and replaces spaces with hyphens", () => {
|
|
23
35
|
expect(slugify("Hello World")).toBe("hello-world");
|
|
24
36
|
});
|
|
25
|
-
|
|
26
37
|
it("removes non-alphanumeric characters", () => {
|
|
27
38
|
expect(slugify("Hi, John!")).toBe("hi-john");
|
|
28
39
|
});
|
|
29
|
-
|
|
30
40
|
it("collapses multiple spaces", () => {
|
|
31
41
|
expect(slugify(" Hello World ")).toBe("hello-world");
|
|
32
42
|
});
|
|
@@ -45,56 +55,48 @@ export function slugify(input: string): string {
|
|
|
45
55
|
}
|
|
46
56
|
```
|
|
47
57
|
|
|
48
|
-
### ❌ DON'T:
|
|
58
|
+
### ❌ DON'T: тестировать детали реализации
|
|
49
59
|
```ts
|
|
50
|
-
// Плохо: тест проверяет внутренние
|
|
51
|
-
//
|
|
60
|
+
// Плохо: тест проверяет внутренние переменные, а не поведение.
|
|
61
|
+
// Сломается при рефакторинге без изменения поведения — хрупкие тесты.
|
|
52
62
|
```
|
|
53
63
|
|
|
64
|
+
**Правило**: тестируй *что делает*, не *как устроено внутри*.
|
|
65
|
+
|
|
54
66
|
---
|
|
55
67
|
|
|
56
|
-
## 2
|
|
68
|
+
## 2. API-слои
|
|
57
69
|
|
|
58
|
-
### ✅ DO: структура проекта
|
|
59
|
-
```
|
|
70
|
+
### ✅ DO: структура проекта
|
|
71
|
+
```
|
|
60
72
|
src/
|
|
61
73
|
http/
|
|
62
|
-
routes/
|
|
63
|
-
controllers/
|
|
64
|
-
middleware/
|
|
74
|
+
routes/ ← только маршрутизация
|
|
75
|
+
controllers/ ← I/O: parse input, вызов service, format response
|
|
76
|
+
middleware/ ← auth, errors, request-context
|
|
65
77
|
domain/
|
|
66
|
-
services/
|
|
67
|
-
models/
|
|
78
|
+
services/ ← бизнес-логика
|
|
79
|
+
models/ ← типы домена
|
|
68
80
|
data/
|
|
69
|
-
repos/
|
|
70
|
-
lib/
|
|
81
|
+
repos/ ← SQL/ORM, никакой бизнес-логики
|
|
82
|
+
lib/ ← утилиты без зависимостей
|
|
71
83
|
```
|
|
72
84
|
|
|
73
|
-
### ✅ DO:
|
|
85
|
+
### ✅ DO: тонкий роут
|
|
74
86
|
```ts
|
|
75
87
|
// src/http/routes/users.routes.ts
|
|
76
88
|
import { Router } from "express";
|
|
77
|
-
import { createUser } from "../controllers/users.
|
|
89
|
+
import { createUser, getUser } from "../controllers/users.controller";
|
|
78
90
|
import { requireAuth } from "../middleware/requireAuth";
|
|
79
91
|
|
|
80
92
|
export const usersRouter = Router();
|
|
81
|
-
|
|
82
93
|
usersRouter.post("/", requireAuth, createUser);
|
|
94
|
+
usersRouter.get("/:id", requireAuth, getUser);
|
|
83
95
|
```
|
|
84
96
|
|
|
85
|
-
###
|
|
86
|
-
```ts
|
|
87
|
-
// Плохо: в routes файл запихана валидация, бизнес-логика и доступ к БД.
|
|
88
|
-
// Тестирование и переиспользование становится болью.
|
|
89
|
-
```
|
|
90
|
-
|
|
91
|
-
---
|
|
92
|
-
|
|
93
|
-
## 3) Валидация на границе + безопасные ошибки (Zod)
|
|
94
|
-
|
|
95
|
-
### ✅ DO: parse на входе, безопасная обработка ошибок
|
|
97
|
+
### ✅ DO: контроллер — только I/O
|
|
96
98
|
```ts
|
|
97
|
-
// src/http/controllers/users.
|
|
99
|
+
// src/http/controllers/users.controller.ts
|
|
98
100
|
import { z } from "zod";
|
|
99
101
|
import type { Request, Response, NextFunction } from "express";
|
|
100
102
|
import { usersService } from "../../domain/services/users.service";
|
|
@@ -107,19 +109,64 @@ const CreateUserSchema = z.object({
|
|
|
107
109
|
|
|
108
110
|
export async function createUser(req: Request, res: Response, next: NextFunction) {
|
|
109
111
|
try {
|
|
110
|
-
const input = CreateUserSchema.parse(req.body);
|
|
112
|
+
const input = CreateUserSchema.parse(req.body);
|
|
111
113
|
const user = await usersService.create(input);
|
|
112
114
|
res.status(201).json({ id: user.id });
|
|
113
115
|
} catch (err) {
|
|
114
|
-
// zod errors -> 422
|
|
115
116
|
next(err instanceof z.ZodError ? AppError.validation(err.flatten()) : err);
|
|
116
117
|
}
|
|
117
118
|
}
|
|
118
119
|
```
|
|
119
120
|
|
|
120
|
-
###
|
|
121
|
+
### ✅ DO: сервис — только бизнес-логика, без HTTP
|
|
122
|
+
```ts
|
|
123
|
+
// src/domain/services/users.service.ts
|
|
124
|
+
import { usersRepo } from "../../data/repos/users.repo";
|
|
125
|
+
import { AppError } from "../../http/middleware/errors";
|
|
126
|
+
|
|
127
|
+
export const usersService = {
|
|
128
|
+
async create(input: { email: string; name: string }) {
|
|
129
|
+
const existing = await usersRepo.findByEmail(input.email);
|
|
130
|
+
if (existing) throw new AppError(409, "CONFLICT", "Email already in use");
|
|
131
|
+
return usersRepo.insert(input);
|
|
132
|
+
},
|
|
133
|
+
};
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
### ❌ DON'T: всё в одном файле
|
|
137
|
+
```ts
|
|
138
|
+
// Плохо: маршруты, валидация, бизнес-логика и SQL в одном файле.
|
|
139
|
+
// Нельзя тестировать сервис без HTTP, нельзя переиспользовать логику.
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
---
|
|
143
|
+
|
|
144
|
+
## 3. Валидация
|
|
145
|
+
|
|
146
|
+
### ✅ DO: Zod на границе + parse (бросает при невалидных данных)
|
|
121
147
|
```ts
|
|
122
|
-
|
|
148
|
+
const CreateUserSchema = z.object({
|
|
149
|
+
email: z.string().email(),
|
|
150
|
+
name: z.string().min(1).max(100),
|
|
151
|
+
role: z.enum(["admin", "user"]).default("user"),
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
// В контроллере:
|
|
155
|
+
const input = CreateUserSchema.parse(req.body); // ✅ валидный тип гарантирован дальше
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
### ✅ DO: safeParse для необрасывающей обработки
|
|
159
|
+
```ts
|
|
160
|
+
const result = CreateUserSchema.safeParse(req.body);
|
|
161
|
+
if (!result.success) {
|
|
162
|
+
return next(AppError.validation(result.error.flatten()));
|
|
163
|
+
}
|
|
164
|
+
const input = result.data; // тип выведен автоматически
|
|
165
|
+
```
|
|
166
|
+
|
|
167
|
+
### ❌ DON'T: доверять req.body без валидации
|
|
168
|
+
```ts
|
|
169
|
+
// Плохо: любой мусор, инъекция лишних полей, 500 в runtime — всё это ждёт впереди.
|
|
123
170
|
export async function createUser(req: any, res: any) {
|
|
124
171
|
const user = await usersService.create(req.body);
|
|
125
172
|
res.json(user);
|
|
@@ -128,9 +175,9 @@ export async function createUser(req: any, res: any) {
|
|
|
128
175
|
|
|
129
176
|
---
|
|
130
177
|
|
|
131
|
-
## 4
|
|
178
|
+
## 4. Error Handler
|
|
132
179
|
|
|
133
|
-
### ✅ DO: AppError + единый формат
|
|
180
|
+
### ✅ DO: AppError + единый формат ответа
|
|
134
181
|
```ts
|
|
135
182
|
// src/http/middleware/errors.ts
|
|
136
183
|
import type { ErrorRequestHandler } from "express";
|
|
@@ -143,12 +190,17 @@ export class AppError extends Error {
|
|
|
143
190
|
public readonly details?: unknown
|
|
144
191
|
) {
|
|
145
192
|
super(message);
|
|
193
|
+
this.name = "AppError";
|
|
146
194
|
}
|
|
147
195
|
|
|
148
196
|
static validation(details: unknown) {
|
|
149
197
|
return new AppError(422, "VALIDATION_ERROR", "Invalid input", details);
|
|
150
198
|
}
|
|
151
199
|
|
|
200
|
+
static notFound(resource = "Resource") {
|
|
201
|
+
return new AppError(404, "NOT_FOUND", `${resource} not found`);
|
|
202
|
+
}
|
|
203
|
+
|
|
152
204
|
static forbidden() {
|
|
153
205
|
return new AppError(403, "FORBIDDEN", "Not enough permissions");
|
|
154
206
|
}
|
|
@@ -157,9 +209,8 @@ export class AppError extends Error {
|
|
|
157
209
|
export const errorHandler: ErrorRequestHandler = (err, _req, res, _next) => {
|
|
158
210
|
const isApp = err instanceof AppError;
|
|
159
211
|
const status = isApp ? err.status : 500;
|
|
160
|
-
const code
|
|
161
|
-
|
|
162
|
-
// Без утечек: для 500 — нейтральное сообщение
|
|
212
|
+
const code = isApp ? err.code : "INTERNAL_ERROR";
|
|
213
|
+
// ❗ Для 500 — нейтральное сообщение, стек не утекает клиенту
|
|
163
214
|
const message = status === 500 ? "Unexpected error" : err.message;
|
|
164
215
|
|
|
165
216
|
res.status(status).json({
|
|
@@ -170,17 +221,25 @@ export const errorHandler: ErrorRequestHandler = (err, _req, res, _next) => {
|
|
|
170
221
|
};
|
|
171
222
|
```
|
|
172
223
|
|
|
173
|
-
###
|
|
224
|
+
### ✅ DO: подключить последним middleware
|
|
225
|
+
```ts
|
|
226
|
+
// src/app.ts
|
|
227
|
+
app.use(requestContext);
|
|
228
|
+
app.use("/api/users", usersRouter);
|
|
229
|
+
app.use(errorHandler); // ← последним
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
### ❌ DON'T: отдавать err целиком
|
|
174
233
|
```ts
|
|
175
|
-
// Плохо: утечка
|
|
234
|
+
// Плохо: утечка стека, SQL-ошибок, переменных окружения — прямо в ответ клиенту.
|
|
176
235
|
res.status(500).json({ err });
|
|
177
236
|
```
|
|
178
237
|
|
|
179
238
|
---
|
|
180
239
|
|
|
181
|
-
## 5
|
|
240
|
+
## 5. Логирование
|
|
182
241
|
|
|
183
|
-
### ✅ DO: request_id
|
|
242
|
+
### ✅ DO: request_id + структурированные логи
|
|
184
243
|
```ts
|
|
185
244
|
// src/http/middleware/requestContext.ts
|
|
186
245
|
import { randomUUID } from "node:crypto";
|
|
@@ -195,24 +254,35 @@ export const requestContext: RequestHandler = (req, res, next) => {
|
|
|
195
254
|
```
|
|
196
255
|
|
|
197
256
|
```ts
|
|
198
|
-
//
|
|
257
|
+
// Использование в сервисе/контроллере
|
|
199
258
|
logger.info(
|
|
200
|
-
{ request_id: (req as any).requestId, user_id: ctx.user?.id },
|
|
201
|
-
"
|
|
259
|
+
{ request_id: (req as any).requestId, user_id: ctx.user?.id, action: "user_created" },
|
|
260
|
+
"User created successfully"
|
|
261
|
+
);
|
|
262
|
+
|
|
263
|
+
// Для ошибок — warn/error с контекстом
|
|
264
|
+
logger.error(
|
|
265
|
+
{ request_id: id, error_code: err.code },
|
|
266
|
+
"Request failed"
|
|
202
267
|
);
|
|
203
268
|
```
|
|
204
269
|
|
|
205
|
-
### ❌ DON'T: логировать body целиком
|
|
270
|
+
### ❌ DON'T: логировать body целиком
|
|
206
271
|
```ts
|
|
207
|
-
// Плохо:
|
|
272
|
+
// Плохо: пароли, токены, PII — всё прямо в логи.
|
|
208
273
|
logger.info({ body: req.body }, "incoming_request");
|
|
274
|
+
|
|
275
|
+
// ❌ Также плохо:
|
|
276
|
+
logger.info({ user }); // может содержать password_hash, secrets и т.д.
|
|
209
277
|
```
|
|
210
278
|
|
|
279
|
+
**Правило**: логируй только ID, коды, статусы. Никогда — сырые тела запросов.
|
|
280
|
+
|
|
211
281
|
---
|
|
212
282
|
|
|
213
|
-
## 6
|
|
283
|
+
## 6. React: Состояния запроса
|
|
214
284
|
|
|
215
|
-
### ✅ DO: явные
|
|
285
|
+
### ✅ DO: TanStack Query — явные loading/empty/error/success
|
|
216
286
|
```tsx
|
|
217
287
|
import { useQuery } from "@tanstack/react-query";
|
|
218
288
|
|
|
@@ -220,64 +290,98 @@ type User = { id: string; name: string };
|
|
|
220
290
|
|
|
221
291
|
async function fetchUsers(): Promise<User[]> {
|
|
222
292
|
const r = await fetch("/api/users");
|
|
223
|
-
if (!r.ok) throw new Error(
|
|
293
|
+
if (!r.ok) throw new Error(`HTTP ${r.status}`);
|
|
224
294
|
return r.json();
|
|
225
295
|
}
|
|
226
296
|
|
|
227
297
|
export function UsersList() {
|
|
228
298
|
const q = useQuery({ queryKey: ["users"], queryFn: fetchUsers });
|
|
229
299
|
|
|
230
|
-
if (q.isLoading) return <div aria-busy="true"
|
|
231
|
-
if (q.isError)
|
|
232
|
-
if (!q.data
|
|
300
|
+
if (q.isLoading) return <div aria-busy="true" role="status">Загрузка…</div>;
|
|
301
|
+
if (q.isError) return <div role="alert">Ошибка: {String(q.error)}</div>;
|
|
302
|
+
if (!q.data?.length) return <div>Пользователей пока нет</div>;
|
|
233
303
|
|
|
234
304
|
return (
|
|
235
305
|
<ul>
|
|
236
|
-
{q.data.map(
|
|
237
|
-
<li key={u.id}>{u.name}</li>
|
|
238
|
-
))}
|
|
306
|
+
{q.data.map(u => <li key={u.id}>{u.name}</li>)}
|
|
239
307
|
</ul>
|
|
240
308
|
);
|
|
241
309
|
}
|
|
242
310
|
```
|
|
243
311
|
|
|
244
|
-
###
|
|
312
|
+
### ✅ DO: мутация с оптимистичным обновлением
|
|
245
313
|
```tsx
|
|
246
|
-
|
|
314
|
+
import { useMutation, useQueryClient } from "@tanstack/react-query";
|
|
315
|
+
|
|
316
|
+
export function useDeleteUser() {
|
|
317
|
+
const qc = useQueryClient();
|
|
318
|
+
return useMutation({
|
|
319
|
+
mutationFn: (id: string) =>
|
|
320
|
+
fetch(`/api/users/${id}`, { method: "DELETE" }).then(r => {
|
|
321
|
+
if (!r.ok) throw new Error("Delete failed");
|
|
322
|
+
}),
|
|
323
|
+
onSuccess: () => qc.invalidateQueries({ queryKey: ["users"] }),
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
```
|
|
327
|
+
|
|
328
|
+
### ❌ DON'T: fetch внутри компонента без обработки состояний
|
|
329
|
+
```tsx
|
|
330
|
+
// Плохо: гонки, мерцания, нет loading/error, утечка запроса при анмаунте.
|
|
331
|
+
function UsersList() {
|
|
332
|
+
const [users, setUsers] = useState([]);
|
|
333
|
+
useEffect(() => {
|
|
334
|
+
fetch("/api/users").then(r => r.json()).then(setUsers);
|
|
335
|
+
}, []);
|
|
336
|
+
return <ul>{users.map(u => <li key={u.id}>{u.name}</li>)}</ul>;
|
|
337
|
+
}
|
|
247
338
|
```
|
|
248
339
|
|
|
249
340
|
---
|
|
250
341
|
|
|
251
|
-
## 7
|
|
342
|
+
## 7. Zustand
|
|
252
343
|
|
|
253
|
-
### ✅ DO: доменный стор +
|
|
344
|
+
### ✅ DO: доменный стор + селекторы
|
|
254
345
|
```ts
|
|
255
346
|
import { create } from "zustand";
|
|
347
|
+
import { devtools } from "zustand/middleware";
|
|
256
348
|
|
|
257
349
|
type AuthState = {
|
|
258
350
|
token: string | null;
|
|
259
|
-
|
|
351
|
+
userId: string | null;
|
|
352
|
+
setAuth: (token: string, userId: string) => void;
|
|
353
|
+
clearAuth: () => void;
|
|
260
354
|
};
|
|
261
355
|
|
|
262
|
-
export const useAuthStore = create<AuthState>(
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
356
|
+
export const useAuthStore = create<AuthState>()(
|
|
357
|
+
devtools(
|
|
358
|
+
(set) => ({
|
|
359
|
+
token: null,
|
|
360
|
+
userId: null,
|
|
361
|
+
setAuth: (token, userId) => set({ token, userId }, false, "setAuth"),
|
|
362
|
+
clearAuth: () => set({ token: null, userId: null }, false, "clearAuth"),
|
|
363
|
+
}),
|
|
364
|
+
{ name: "AuthStore" }
|
|
365
|
+
)
|
|
366
|
+
);
|
|
266
367
|
|
|
267
|
-
//
|
|
268
|
-
const token = useAuthStore(
|
|
368
|
+
// ✅ Селектор — подписка только на нужное поле (нет лишних ре-рендеров)
|
|
369
|
+
const token = useAuthStore(s => s.token);
|
|
370
|
+
const isAuthed = useAuthStore(s => s.token !== null);
|
|
269
371
|
```
|
|
270
372
|
|
|
271
|
-
### ❌ DON'T:
|
|
373
|
+
### ❌ DON'T: один "бог-стор" на всё
|
|
272
374
|
```ts
|
|
273
|
-
// Плохо:
|
|
375
|
+
// Плохо: auth + cart + ui + settings в одном сторе.
|
|
376
|
+
// Итог: любое изменение = ре-рендер всех подписчиков.
|
|
377
|
+
// Правило: один стор = один домен.
|
|
274
378
|
```
|
|
275
379
|
|
|
276
380
|
---
|
|
277
381
|
|
|
278
|
-
## 8
|
|
382
|
+
## 8. RTK
|
|
279
383
|
|
|
280
|
-
### ✅ DO:
|
|
384
|
+
### ✅ DO: slice + createAsyncThunk + EntityAdapter
|
|
281
385
|
```ts
|
|
282
386
|
// src/state/usersSlice.ts
|
|
283
387
|
import { createSlice, createAsyncThunk, createEntityAdapter } from "@reduxjs/toolkit";
|
|
@@ -285,7 +389,7 @@ import type { RootState } from "./store";
|
|
|
285
389
|
|
|
286
390
|
type User = { id: string; name: string };
|
|
287
391
|
|
|
288
|
-
|
|
392
|
+
const usersAdapter = createEntityAdapter<User>();
|
|
289
393
|
|
|
290
394
|
export const fetchUsers = createAsyncThunk("users/fetch", async () => {
|
|
291
395
|
const r = await fetch("/api/users");
|
|
@@ -295,103 +399,187 @@ export const fetchUsers = createAsyncThunk("users/fetch", async () => {
|
|
|
295
399
|
|
|
296
400
|
const slice = createSlice({
|
|
297
401
|
name: "users",
|
|
298
|
-
initialState: usersAdapter.getInitialState({
|
|
402
|
+
initialState: usersAdapter.getInitialState({
|
|
403
|
+
status: "idle" as "idle" | "loading" | "failed",
|
|
404
|
+
}),
|
|
299
405
|
reducers: {},
|
|
300
|
-
extraReducers:
|
|
301
|
-
b.addCase(fetchUsers.pending,
|
|
302
|
-
s.status = "loading";
|
|
303
|
-
});
|
|
406
|
+
extraReducers: b => {
|
|
407
|
+
b.addCase(fetchUsers.pending, s => { s.status = "loading"; });
|
|
304
408
|
b.addCase(fetchUsers.fulfilled, (s, a) => {
|
|
305
409
|
s.status = "idle";
|
|
306
410
|
usersAdapter.setAll(s, a.payload);
|
|
307
411
|
});
|
|
308
|
-
b.addCase(fetchUsers.rejected,
|
|
309
|
-
s.status = "failed";
|
|
310
|
-
});
|
|
412
|
+
b.addCase(fetchUsers.rejected, s => { s.status = "failed"; });
|
|
311
413
|
},
|
|
312
414
|
});
|
|
313
415
|
|
|
314
416
|
export const usersReducer = slice.reducer;
|
|
417
|
+
export const usersSelectors = usersAdapter.getSelectors<RootState>(st => st.users);
|
|
418
|
+
```
|
|
419
|
+
|
|
420
|
+
### ✅ DO: подключить reducer в store
|
|
421
|
+
```ts
|
|
422
|
+
// src/state/store.ts
|
|
423
|
+
import { configureStore } from "@reduxjs/toolkit";
|
|
424
|
+
import { usersReducer } from "./usersSlice";
|
|
315
425
|
|
|
316
|
-
export const
|
|
426
|
+
export const store = configureStore({
|
|
427
|
+
reducer: { users: usersReducer },
|
|
428
|
+
});
|
|
429
|
+
|
|
430
|
+
export type RootState = ReturnType<typeof store.getState>;
|
|
431
|
+
export type AppDispatch = typeof store.dispatch;
|
|
317
432
|
```
|
|
318
433
|
|
|
319
|
-
### ❌ DON'T: side effects в
|
|
434
|
+
### ❌ DON'T: side effects в компоненте + ручные редьюсеры
|
|
320
435
|
```ts
|
|
321
|
-
// Плохо:
|
|
322
|
-
// Итог:
|
|
436
|
+
// Плохо: fetch в компоненте, switch/case вручную, нормализация руками.
|
|
437
|
+
// Итог: дублирование, непредсказуемость, тесты требуют реального HTTP.
|
|
323
438
|
```
|
|
324
439
|
|
|
325
440
|
---
|
|
326
441
|
|
|
327
|
-
## 9
|
|
442
|
+
## 9. Авторизация
|
|
328
443
|
|
|
329
444
|
### ✅ DO: проверка прав на сервере
|
|
330
445
|
```ts
|
|
446
|
+
// src/lib/authz.ts
|
|
331
447
|
import { AppError } from "../http/middleware/errors";
|
|
332
448
|
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
449
|
+
type Principal = { id: string; role: "admin" | "user" } | null;
|
|
450
|
+
|
|
451
|
+
export function requireRole(principal: Principal, role: "admin" | "user") {
|
|
452
|
+
if (!principal) throw new AppError(401, "UNAUTHORIZED", "Authentication required");
|
|
453
|
+
if (principal.role !== role) throw AppError.forbidden();
|
|
336
454
|
}
|
|
455
|
+
|
|
456
|
+
// Использование в сервисе:
|
|
457
|
+
export const postsService = {
|
|
458
|
+
async delete(id: string, actor: Principal) {
|
|
459
|
+
requireRole(actor, "admin"); // ✅ сервер всегда проверяет
|
|
460
|
+
return postsRepo.delete(id);
|
|
461
|
+
},
|
|
462
|
+
};
|
|
337
463
|
```
|
|
338
464
|
|
|
339
|
-
###
|
|
465
|
+
### ✅ DO: requireAuth middleware
|
|
340
466
|
```ts
|
|
341
|
-
//
|
|
342
|
-
|
|
467
|
+
// src/http/middleware/requireAuth.ts
|
|
468
|
+
import type { RequestHandler } from "express";
|
|
469
|
+
import { verifyToken } from "../../lib/jwt";
|
|
470
|
+
import { AppError } from "./errors";
|
|
471
|
+
|
|
472
|
+
export const requireAuth: RequestHandler = (req, _res, next) => {
|
|
473
|
+
const header = req.header("Authorization");
|
|
474
|
+
if (!header?.startsWith("Bearer ")) return next(new AppError(401, "UNAUTHORIZED", "Missing token"));
|
|
475
|
+
try {
|
|
476
|
+
(req as any).principal = verifyToken(header.slice(7));
|
|
477
|
+
next();
|
|
478
|
+
} catch {
|
|
479
|
+
next(new AppError(401, "UNAUTHORIZED", "Invalid token"));
|
|
480
|
+
}
|
|
481
|
+
};
|
|
482
|
+
```
|
|
483
|
+
|
|
484
|
+
### ❌ DON'T: безопасность только на UI
|
|
485
|
+
```ts
|
|
486
|
+
// Плохо: скрыть кнопку "Удалить" для не-админов и считать это защитой.
|
|
487
|
+
// Любой fetch("/api/posts/1", { method: "DELETE" }) обойдёт это.
|
|
488
|
+
// Сервер ОБЯЗАН проверять права независимо от UI.
|
|
343
489
|
```
|
|
344
490
|
|
|
345
491
|
---
|
|
346
492
|
|
|
347
|
-
## 10
|
|
493
|
+
## 10. Legacy React 15.3 (Wix)
|
|
348
494
|
|
|
349
|
-
### ✅ DO:
|
|
495
|
+
### ✅ DO: class component + lifecycle
|
|
350
496
|
```jsx
|
|
497
|
+
// ❗ Только ES5/ES6 классы, никаких хуков
|
|
351
498
|
class Widget extends React.Component {
|
|
352
499
|
constructor(props) {
|
|
353
500
|
super(props);
|
|
354
501
|
this.state = { loading: true, data: null, error: null };
|
|
502
|
+
this.handleRetry = this.handleRetry.bind(this);
|
|
355
503
|
}
|
|
356
504
|
|
|
357
505
|
componentDidMount() {
|
|
358
506
|
this.load();
|
|
359
507
|
}
|
|
360
508
|
|
|
509
|
+
componentWillUnmount() {
|
|
510
|
+
this._unmounted = true; // предотвращаем setState после анмаунта
|
|
511
|
+
}
|
|
512
|
+
|
|
361
513
|
load() {
|
|
362
514
|
apiFetch()
|
|
363
|
-
.then(
|
|
364
|
-
|
|
515
|
+
.then(data => {
|
|
516
|
+
if (!this._unmounted) this.setState({ loading: false, data });
|
|
517
|
+
})
|
|
518
|
+
.catch(() => {
|
|
519
|
+
if (!this._unmounted) this.setState({ loading: false, error: "Failed to load" });
|
|
520
|
+
});
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
handleRetry() {
|
|
524
|
+
this.setState({ loading: true, error: null }, () => this.load());
|
|
365
525
|
}
|
|
366
526
|
|
|
367
527
|
render() {
|
|
368
|
-
|
|
369
|
-
if (
|
|
370
|
-
return React.createElement("div",
|
|
528
|
+
const { loading, data, error } = this.state;
|
|
529
|
+
if (loading) return React.createElement("div", null, "Loading…");
|
|
530
|
+
if (error) return React.createElement("div", { role: "alert" },
|
|
531
|
+
error,
|
|
532
|
+
React.createElement("button", { onClick: this.handleRetry }, "Retry")
|
|
533
|
+
);
|
|
534
|
+
return React.createElement("div", null, JSON.stringify(data));
|
|
371
535
|
}
|
|
372
536
|
}
|
|
373
537
|
```
|
|
374
538
|
|
|
375
|
-
### ❌ DON'T:
|
|
539
|
+
### ❌ DON'T: хуки и современные API в React 15.3
|
|
376
540
|
```tsx
|
|
377
|
-
// Нельзя в React
|
|
378
|
-
|
|
541
|
+
// ❌ Нельзя — hooks появились в React 16.8
|
|
542
|
+
function Widget() { const [x, setX] = useState(0); }
|
|
543
|
+
// ❌ Нельзя — React.memo появился в React 16.6
|
|
544
|
+
export default React.memo(Widget);
|
|
545
|
+
// ❌ Нельзя — фрагменты <>...</> появились в React 16.2
|
|
379
546
|
```
|
|
380
547
|
|
|
381
|
-
|
|
548
|
+
---
|
|
549
|
+
|
|
550
|
+
## 11. DoD Scripts
|
|
551
|
+
|
|
552
|
+
### ✅ DO: стандартный package.json
|
|
382
553
|
```json
|
|
383
554
|
{
|
|
384
555
|
"scripts": {
|
|
385
|
-
"dev":
|
|
386
|
-
"
|
|
387
|
-
"test
|
|
388
|
-
"
|
|
389
|
-
"
|
|
556
|
+
"dev": "tsx watch ./src/index.ts",
|
|
557
|
+
"build": "tsc -p tsconfig.build.json",
|
|
558
|
+
"test": "vitest run",
|
|
559
|
+
"test:watch": "vitest",
|
|
560
|
+
"test:coverage": "vitest run --coverage",
|
|
561
|
+
"lint": "biome lint .",
|
|
562
|
+
"lint:fix": "biome lint . --apply",
|
|
563
|
+
"format": "biome format . --write",
|
|
564
|
+
"typecheck": "tsc --noEmit",
|
|
565
|
+
"check": "npm run typecheck && npm run lint && npm run test"
|
|
566
|
+
}
|
|
567
|
+
}
|
|
568
|
+
```
|
|
569
|
+
|
|
570
|
+
### ✅ DO: pre-commit hook (husky + lint-staged)
|
|
571
|
+
```json
|
|
572
|
+
// package.json
|
|
573
|
+
{
|
|
574
|
+
"lint-staged": {
|
|
575
|
+
"*.{ts,tsx}": ["biome lint --apply", "biome format --write"]
|
|
390
576
|
}
|
|
391
577
|
}
|
|
392
578
|
```
|
|
393
579
|
|
|
394
|
-
### ❌ DON'T: смешивать
|
|
395
|
-
```
|
|
396
|
-
// Плохо:
|
|
397
|
-
|
|
580
|
+
### ❌ DON'T: смешивать eslint + prettier + biome
|
|
581
|
+
```
|
|
582
|
+
// Плохо: три инструмента с конфликтующими правилами → вечный шум в PR,
|
|
583
|
+
// разные результаты у разных разработчиков.
|
|
584
|
+
// Выбери один: Biome (быстрый, всё-в-одном) или ESLint + Prettier.
|
|
585
|
+
```
|