ccbot-cli 2.0.0 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/LICENSE +21 -0
  2. package/bin/adapters/claude.js +150 -0
  3. package/bin/adapters/codex.js +439 -0
  4. package/bin/install.js +509 -349
  5. package/bin/lib/ccline.js +82 -0
  6. package/bin/lib/utils.js +87 -34
  7. package/bin/uninstall.js +48 -0
  8. package/config/AGENTS.md +630 -0
  9. package/config/CLAUDE.md +229 -20
  10. package/config/ccline/config.toml +161 -0
  11. package/config/codex-config.example.toml +22 -0
  12. package/config/settings.example.json +32 -0
  13. package/output-styles/abyss-cultivator.md +399 -0
  14. package/package.json +14 -5
  15. package/skills/SKILL.md +159 -0
  16. package/skills/domains/ai/SKILL.md +34 -0
  17. package/skills/domains/ai/agent-dev.md +242 -0
  18. package/skills/domains/ai/llm-security.md +288 -0
  19. package/skills/domains/ai/prompt-and-eval.md +279 -0
  20. package/skills/domains/ai/rag-system.md +542 -0
  21. package/skills/domains/architecture/SKILL.md +42 -0
  22. package/skills/domains/architecture/api-design.md +225 -0
  23. package/skills/domains/architecture/caching.md +299 -0
  24. package/skills/domains/architecture/cloud-native.md +285 -0
  25. package/skills/domains/architecture/message-queue.md +329 -0
  26. package/skills/domains/architecture/security-arch.md +297 -0
  27. package/skills/domains/data-engineering/SKILL.md +207 -0
  28. package/skills/domains/development/SKILL.md +46 -0
  29. package/skills/domains/development/cpp.md +246 -0
  30. package/skills/domains/development/go.md +323 -0
  31. package/skills/domains/development/java.md +277 -0
  32. package/skills/domains/development/python.md +288 -0
  33. package/skills/domains/development/rust.md +313 -0
  34. package/skills/domains/development/shell.md +313 -0
  35. package/skills/domains/development/typescript.md +277 -0
  36. package/skills/domains/devops/SKILL.md +39 -0
  37. package/skills/domains/devops/cost-optimization.md +272 -0
  38. package/skills/domains/devops/database.md +217 -0
  39. package/skills/domains/devops/devsecops.md +198 -0
  40. package/skills/domains/devops/git-workflow.md +181 -0
  41. package/skills/domains/devops/observability.md +280 -0
  42. package/skills/domains/devops/performance.md +336 -0
  43. package/skills/domains/devops/testing.md +283 -0
  44. package/skills/domains/frontend-design/SKILL.md +38 -0
  45. package/skills/domains/frontend-design/claymorphism/SKILL.md +119 -0
  46. package/skills/domains/frontend-design/claymorphism/references/tokens.css +52 -0
  47. package/skills/domains/frontend-design/component-patterns.md +202 -0
  48. package/skills/domains/frontend-design/engineering.md +287 -0
  49. package/skills/domains/frontend-design/glassmorphism/SKILL.md +140 -0
  50. package/skills/domains/frontend-design/glassmorphism/references/tokens.css +32 -0
  51. package/skills/domains/frontend-design/liquid-glass/SKILL.md +137 -0
  52. package/skills/domains/frontend-design/liquid-glass/references/tokens.css +81 -0
  53. package/skills/domains/frontend-design/neubrutalism/SKILL.md +143 -0
  54. package/skills/domains/frontend-design/neubrutalism/references/tokens.css +44 -0
  55. package/skills/domains/frontend-design/state-management.md +680 -0
  56. package/skills/domains/frontend-design/ui-aesthetics.md +110 -0
  57. package/skills/domains/frontend-design/ux-principles.md +156 -0
  58. package/skills/domains/infrastructure/SKILL.md +200 -0
  59. package/skills/domains/mobile/SKILL.md +224 -0
  60. package/skills/domains/orchestration/SKILL.md +29 -0
  61. package/skills/domains/orchestration/multi-agent.md +263 -0
  62. package/skills/domains/security/SKILL.md +54 -0
  63. package/skills/domains/security/blue-team.md +436 -0
  64. package/skills/domains/security/code-audit.md +265 -0
  65. package/skills/domains/security/pentest.md +226 -0
  66. package/skills/domains/security/red-team.md +375 -0
  67. package/skills/domains/security/threat-intel.md +372 -0
  68. package/skills/domains/security/vuln-research.md +369 -0
  69. package/skills/orchestration/multi-agent/SKILL.md +493 -0
  70. package/skills/run_skill.js +129 -0
  71. package/skills/tools/gen-docs/SKILL.md +116 -0
  72. package/skills/tools/gen-docs/scripts/doc_generator.js +435 -0
  73. package/skills/tools/lib/shared.js +98 -0
  74. package/skills/tools/verify-change/SKILL.md +140 -0
  75. package/skills/tools/verify-change/scripts/change_analyzer.js +289 -0
  76. package/skills/tools/verify-module/SKILL.md +127 -0
  77. package/skills/tools/verify-module/scripts/module_scanner.js +171 -0
  78. package/skills/tools/verify-quality/SKILL.md +160 -0
  79. package/skills/tools/verify-quality/scripts/quality_checker.js +337 -0
  80. package/skills/tools/verify-security/SKILL.md +143 -0
  81. package/skills/tools/verify-security/scripts/security_scanner.js +283 -0
  82. package/bin/lib/registry.js +0 -61
  83. package/config/.claudeignore +0 -11
@@ -0,0 +1,110 @@
1
+ # UI 美学
2
+
3
+ ## 色彩理论
4
+
5
+ ### 色彩体系设计
6
+ 60-30-10配色法则:主色60%、辅色30%、强调色10%。使用HSL而非RGB便于调整。建立语义化色彩令牌(primary/success/danger)。
7
+
8
+ ```css
9
+ :root {
10
+ --primary-h: 220;
11
+ --primary-s: 90%;
12
+ --primary-l: 50%;
13
+ --primary: hsl(var(--primary-h) var(--primary-s) var(--primary-l));
14
+ --primary-dark: hsl(var(--primary-h) var(--primary-s) 40%);
15
+ --primary-light: hsl(var(--primary-h) var(--primary-s) 60%);
16
+ }
17
+ ```
18
+
19
+ ## 排版系统
20
+
21
+ ### 排版层级规范
22
+ 使用模块化比例(1.25/1.333/1.5)。基准16px,标题用比例放大,正文14-18px。行高1.5-1.8。限制字体族≤3种。
23
+
24
+ ```css
25
+ :root {
26
+ --fs-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
27
+ --fs-h1: clamp(2rem, 1.5rem + 2vw, 3rem);
28
+ --fs-h2: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem);
29
+ }
30
+ body {
31
+ font-size: var(--fs-base);
32
+ line-height: 1.6;
33
+ }
34
+ ```
35
+
36
+ ## 间距系统
37
+
38
+ ### 8px网格间距体系
39
+ 基准8px,建立4/8/12/16/24/32/48/64px间距令牌。组件内用小间距(4-12),组件间用中间距(16-32),区块间用大间距(48+)。
40
+
41
+ ```css
42
+ :root {
43
+ --sp-1: 0.25rem; --sp-2: 0.5rem; --sp-3: 0.75rem; --sp-4: 1rem;
44
+ --sp-6: 1.5rem; --sp-8: 2rem; --sp-12: 3rem; --sp-16: 4rem;
45
+ }
46
+ .stack-sm > * + * { margin-top: var(--sp-2); }
47
+ .stack-md > * + * { margin-top: var(--sp-4); }
48
+ ```
49
+
50
+ ## 视觉层次
51
+
52
+ ### 视觉层次四原则
53
+ 1. 对比:大小/粗细/颜色差异
54
+ 2. 对齐:统一对齐建立秩序
55
+ 3. 重复:一致性建立认知
56
+ 4. 亲密性:相关元素靠近
57
+
58
+ ## 设计令牌
59
+
60
+ ### Design Token架构
61
+ 三层架构:基础令牌(颜色/字号原始值)→语义令牌(primary/heading)→组件令牌(button-bg)。
62
+
63
+ ```css
64
+ :root {
65
+ --color-gray-50: #f9fafb;
66
+ --color-gray-900: #111827;
67
+ --color-primary: var(--color-blue-600);
68
+ --text-primary: var(--color-gray-900);
69
+ --bg-surface: white;
70
+ --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
71
+ }
72
+ ```
73
+
74
+ ## 暗色模式
75
+
76
+ ### 暗色模式设计规范
77
+ 背景用深灰(#121212)非纯黑。降低白色文本亮度至#e0e0e0。提升表面层级用更亮灰色。注意色彩对比度WCAG AA。
78
+
79
+ ```css
80
+ :root { --bg: white; --text: #111; }
81
+ @media (prefers-color-scheme: dark) {
82
+ :root { --bg: #121212; --text: #e0e0e0; }
83
+ }
84
+ [data-theme="dark"] { --bg: #121212; --text: #e0e0e0; }
85
+ body { background: var(--bg); color: var(--text); }
86
+ ```
87
+
88
+ ## 阴影与层级
89
+
90
+ ### 阴影层级体系
91
+ 5级阴影:1-贴地(1px) 2-悬浮(2-4px) 3-浮起(8-12px) 4-弹出(16-24px) 5-模态(24-32px)。
92
+
93
+ ```css
94
+ :root {
95
+ --shadow-1: 0 1px 2px rgba(0,0,0,0.05);
96
+ --shadow-2: 0 2px 4px rgba(0,0,0,0.08);
97
+ --shadow-3: 0 8px 16px rgba(0,0,0,0.12);
98
+ --shadow-4: 0 16px 24px rgba(0,0,0,0.16);
99
+ --shadow-5: 0 24px 32px rgba(0,0,0,0.2);
100
+ }
101
+ ```
102
+
103
+ ## 审查清单
104
+
105
+ - [ ] 色彩对比度≥4.5:1
106
+ - [ ] 字体≤3种
107
+ - [ ] 间距符合8px网格
108
+ - [ ] 视觉层级清晰
109
+ - [ ] 暗色模式适配
110
+ - [ ] 阴影层级合理
@@ -0,0 +1,156 @@
1
+ # UX 原则
2
+
3
+ ## 可用性
4
+
5
+ ### Nielsen十大可用性原则
6
+ 1. 系统状态可见
7
+ 2. 系统匹配现实
8
+ 3. 用户控制自由
9
+ 4. 一致性标准
10
+ 5. 防错
11
+ 6. 识别优于回忆
12
+ 7. 灵活高效
13
+ 8. 美学简约
14
+ 9. 帮助识别错误
15
+ 10. 帮助文档
16
+
17
+ ## 无障碍
18
+
19
+ ### WCAG 2.1速查
20
+ - **可感知**:文本替代、时基媒体、适配性、可辨别
21
+ - **可操作**:键盘、足够时间、无癫痫、导航
22
+ - **可理解**:可读、可预测、输入辅助
23
+ - **健壮**:兼容性
24
+
25
+ ### ARIA标签最佳实践
26
+ ```html
27
+ <button aria-label="关闭对话框">
28
+ <svg aria-hidden="true">...</svg>
29
+ </button>
30
+ <nav aria-label="主导航">
31
+ <ul role="list">...</ul>
32
+ </nav>
33
+ <div role="alert" aria-live="assertive">错误消息</div>
34
+ ```
35
+
36
+ ### 键盘导航支持
37
+ ```javascript
38
+ element.addEventListener("keydown", e => {
39
+ if (e.key === "Enter" || e.key === " ") {
40
+ e.preventDefault();
41
+ handleClick();
42
+ }
43
+ if (e.key === "Escape") {
44
+ closeModal();
45
+ }
46
+ });
47
+ element.setAttribute("tabindex", "0");
48
+ ```
49
+
50
+ ## 信息架构
51
+
52
+ ### 信息架构设计模式
53
+ - 层级结构(树形)
54
+ - 顺序结构(线性)
55
+ - 矩阵结构(网格)
56
+ - 数据库结构(标签)
57
+
58
+ 导航深度≤3层,广度5±2项。
59
+
60
+ ## 用户流程
61
+
62
+ ### 用户流程设计原则
63
+ 减少步骤、清晰进度、允许跳过、保存状态、提供退出、即时反馈。关键流程≤3步。
64
+
65
+ ## 加载体验
66
+
67
+ ### 骨架屏与加载策略
68
+ 优先级:骨架屏>进度条>加载动画>空白。首屏<1s,交互<100ms,加载>1s显示进度。
69
+
70
+ ```css
71
+ .skeleton {
72
+ background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
73
+ background-size: 200% 100%;
74
+ animation: loading 1.5s ease-in-out infinite;
75
+ }
76
+ @keyframes loading {
77
+ 0% { background-position: 200% 0; }
78
+ 100% { background-position: -200% 0; }
79
+ }
80
+ ```
81
+
82
+ ## 反馈设计
83
+
84
+ ### 用户反馈模式
85
+ - **Toast**(临时提示)
86
+ - **Alert**(重要警告)
87
+ - **Modal**(阻断操作)
88
+ - **Inline**(表单验证)
89
+
90
+ 成功绿、警告黄、错误红、信息蓝。
91
+
92
+ ```css
93
+ .toast {
94
+ position: fixed;
95
+ bottom: 2rem;
96
+ right: 2rem;
97
+ padding: 1rem 1.5rem;
98
+ background: white;
99
+ border-radius: 8px;
100
+ box-shadow: var(--shadow-4);
101
+ animation: slideInRight 0.3s ease;
102
+ }
103
+ @keyframes slideInRight {
104
+ from {
105
+ transform: translateX(100%);
106
+ opacity: 0;
107
+ }
108
+ to {
109
+ transform: translateX(0);
110
+ opacity: 1;
111
+ }
112
+ }
113
+ ```
114
+
115
+ ## 移动端优先
116
+
117
+ ### 移动端设计原则
118
+ 触摸目标≥44px、拇指热区、避免悬停、简化导航、减少输入、优化性能、考虑单手操作。
119
+
120
+ ```css
121
+ .btn-touch {
122
+ min-height: 44px;
123
+ min-width: 44px;
124
+ padding: 0.75rem 1.5rem;
125
+ font-size: 1rem;
126
+ -webkit-tap-highlight-color: transparent;
127
+ touch-action: manipulation;
128
+ }
129
+ @media (hover: hover) {
130
+ .btn-touch:hover {
131
+ background: var(--primary-dark);
132
+ }
133
+ }
134
+ ```
135
+
136
+ ## 性能感知
137
+
138
+ ### 感知性能优化
139
+ 骨架屏、乐观更新、预加载、懒加载、渐进增强。让用户感觉快比实际快更重要。
140
+
141
+ ## 审查清单
142
+
143
+ - [ ] 符合Nielsen原则
144
+ - [ ] WCAG AA达标
145
+ - [ ] 键盘可访问
146
+ - [ ] 移动端友好
147
+ - [ ] 加载状态清晰
148
+ - [ ] 反馈及时
149
+
150
+ ## 最佳实践
151
+
152
+ 1. 用户优先于技术
153
+ 2. 简单优于复杂
154
+ 3. 一致性建立信任
155
+ 4. 反馈建立信心
156
+ 5. 可访问性非可选
@@ -0,0 +1,200 @@
1
+ ---
2
+ name: infrastructure
3
+ description: 云原生基础设施。Kubernetes、Helm、Kustomize、Operator、CRD、GitOps、ArgoCD、Flux、IaC、Terraform、Pulumi、CDK。当用户提到 K8s、Helm、GitOps、IaC 时路由到此。
4
+ license: MIT
5
+ user-invocable: false
6
+ disable-model-invocation: false
7
+ ---
8
+
9
+ # 云原生基础设施 · Infrastructure
10
+
11
+ ## 域概览
12
+
13
+ ```
14
+ GitOps 控制平面
15
+ |
16
+ +-----------------+-----------------+
17
+ | | |
18
+ ArgoCD/Flux Kubernetes IaC 层
19
+ | | |
20
+ Git Repo ------> Helm/Kustomize --> Terraform/Pulumi
21
+ | | |
22
+ 声明式配置 容器编排 云资源管理
23
+ ```
24
+
25
+ ---
26
+
27
+ ## Kubernetes 容器编排
28
+
29
+ ### Helm Chart 开发
30
+
31
+ 标准结构:`Chart.yaml` + `values.yaml` + `templates/` + `charts/`
32
+
33
+ 核心要点:
34
+ - Chart.yaml:`apiVersion: v2`, dependencies 声明子 Chart(condition 控制启用)
35
+ - values.yaml 设计:image / replicaCount / resources / autoscaling / service / ingress / probes / env / persistence
36
+ - Deployment 模板:使用 `_helpers.tpl` 定义 `fullname` / `labels` / `selectorLabels`
37
+ - 配置校验:`checksum/config: {{ include ... | sha256sum }}` 触发滚动更新
38
+ - 安全上下文:`runAsNonRoot: true, runAsUser: 1000`
39
+
40
+ 关键命令:
41
+ - `helm lint` / `helm template --debug` 验证
42
+ - `helm install -f values-prod.yaml` 部署
43
+ - `helm upgrade --reuse-values` 升级
44
+ - `helm rollback <release> <revision>` 回滚
45
+ - `helm push <chart>.tgz oci://registry` 推送 OCI
46
+
47
+ ### Kustomize 配置管理
48
+
49
+ 目录结构:`base/` + `overlays/{dev,staging,production}/`
50
+
51
+ 核心能力:
52
+ - base/kustomization.yaml:resources / commonLabels / images / configMapGenerator / secretGenerator
53
+ - overlay:namespace / patchesStrategicMerge / patchesJson6902 / replicas / images / configMapGenerator(behavior: merge)
54
+ - 命令:`kubectl apply -k overlays/production` / `kubectl diff -k`
55
+
56
+ ### Operator 模式
57
+
58
+ - CRD 定义:openAPIV3Schema 声明 spec/status,subresources(status/scale)
59
+ - Controller 核心循环:Get CR → 构建期望状态 → Create/Update 子资源 → 更新 Status
60
+ - OwnerReferences:子资源关联 CR,级联删除
61
+ - 初始化:`operator-sdk init` → `create api` → `make manifests` → `make install`
62
+
63
+ ### 部署策略
64
+
65
+ | 策略 | 实现方式 | 适用场景 |
66
+ |------|----------|----------|
67
+ | 滚动更新 | `strategy.rollingUpdate` maxSurge/maxUnavailable | 默认策略 |
68
+ | 蓝绿部署 | 两个 Deployment + Service selector 切换 | 零停机切换 |
69
+ | 金丝雀 | stable(9) + canary(1) 共享 Service | 渐进式验证 |
70
+ | Flagger | `Canary` CRD + 自动分析指标 | 自动化金丝雀 |
71
+
72
+ ### K8s Checklist
73
+
74
+ - [ ] 健康检查:livenessProbe + readinessProbe 必配
75
+ - [ ] 资源限制:requests + limits 防止资源耗尽
76
+ - [ ] HPA:CPU/Memory/自定义指标自动扩缩容
77
+ - [ ] PDB:`minAvailable` 防止滚动更新中断
78
+ - [ ] ResourceQuota + LimitRange:命名空间资源配额
79
+ - [ ] 镜像使用 Digest 确保一致性
80
+ - [ ] Pod 反亲和性分散到不同节点
81
+ - [ ] 密钥外部化:External Secrets Operator
82
+
83
+ ---
84
+
85
+ ## GitOps 持续部署
86
+
87
+ ### ArgoCD vs Flux
88
+
89
+ | 特性 | ArgoCD | Flux |
90
+ |------|--------|------|
91
+ | Web UI | 功能强大 | 无(可用 Weave GitOps) |
92
+ | 多租户 | Projects + RBAC | 需额外配置 |
93
+ | 多集群 | 原生支持 | 原生支持 |
94
+ | 镜像自动更新 | 需 Image Updater | 原生支持 |
95
+ | 渐进式交付 | Argo Rollouts | Flagger |
96
+ | CNCF | Graduated | Graduated |
97
+
98
+ ### ArgoCD 核心模式
99
+
100
+ - Application:source(repoURL/path/targetRevision) + destination(server/namespace)
101
+ - syncPolicy:`automated(prune: true, selfHeal: true)` + retry
102
+ - ignoreDifferences:忽略 HPA 修改的 `/spec/replicas`
103
+ - ApplicationSet:Git 目录生成器,一套模板管理多环境
104
+ - 多集群:`argocd cluster add` 注册集群
105
+ - Notifications:ConfigMap 配置 Slack/Email 通知模板
106
+ - Rollouts:`Canary` CRD + steps(setWeight/pause) + AnalysisTemplate(Prometheus 查询)
107
+
108
+ ### Flux 核心模式
109
+
110
+ - GitRepository:`interval: 1m`, ref branch, secretRef
111
+ - Kustomization:path + prune + healthChecks + postBuild substitute
112
+ - HelmRepository + HelmRelease:chart + values + install/upgrade remediation
113
+ - ImageRepository + ImagePolicy + ImageUpdateAutomation:自动检测新镜像并提交 Git
114
+
115
+ ### 多环境管理
116
+
117
+ ```
118
+ fleet-infra/
119
+ ├── clusters/{dev,staging,production}/ # 每集群入口
120
+ ├── infrastructure/base + overlays/ # 基础组件
121
+ └── apps/base + overlays/ # 应用配置
122
+ ```
123
+
124
+ ### 密钥管理
125
+
126
+ - Sealed Secrets:`kubeseal` 加密 → 提交 Git → Controller 解密
127
+ - External Secrets Operator:SecretStore(AWS SM) + ExternalSecret → 自动同步
128
+
129
+ ### GitOps Checklist
130
+
131
+ - [ ] Git 为唯一真相源,所有变更通过 PR
132
+ - [ ] 自动同步 + 自愈(selfHeal)
133
+ - [ ] 密钥加密存储(Sealed Secrets / External Secrets)
134
+ - [ ] 渐进式交付(Rollouts / Flagger)
135
+ - [ ] 多环境目录隔离
136
+ - [ ] 回滚策略:保留历史版本
137
+
138
+ ---
139
+
140
+ ## 基础设施即代码 (IaC)
141
+
142
+ ### 工具对比
143
+
144
+ | 工具 | 语言 | 状态管理 | 云支持 | 学习曲线 |
145
+ |------|------|----------|--------|----------|
146
+ | Terraform | HCL | 显式(S3/TF Cloud) | 全平台 | 中等 |
147
+ | Pulumi | Python/TS/Go | 自动(Pulumi Cloud) | 全平台 | 较低 |
148
+ | AWS CDK | Python/TS | CloudFormation | AWS | 中等 |
149
+
150
+ ### Terraform 核心模式
151
+
152
+ 项目结构:`modules/{vpc,eks,rds}/` + `environments/{dev,staging,prod}/`
153
+
154
+ - Provider:版本锁定 `required_providers` + `default_tags`
155
+ - Backend:S3 + DynamoDB 锁 + KMS 加密
156
+ - 模块化:`variable` → `resource` → `output`,环境通过 `module` 引用
157
+ - 远程状态:`data "terraform_remote_state"` 跨模块引用
158
+ - 命令流:`init` → `validate` → `fmt` → `plan -out=tfplan` → `apply tfplan`
159
+ - 状态管理:`state list/show/mv/rm` / `import` 导入现有资源
160
+ - Workspace:`workspace new/select` 多环境隔离
161
+
162
+ ### Pulumi 核心模式
163
+
164
+ - ComponentResource:自定义资源组(VPC/EKS 封装为类)
165
+ - Config:`pulumi.Config()` 读取 stack 配置
166
+ - Outputs:`pulumi.export()` 导出值
167
+ - 命令:`preview` → `up` → `stack output` / `destroy`
168
+
169
+ ### AWS CDK 核心模式
170
+
171
+ - Stack:继承 `Stack`,使用 L2 Constructs(`ec2.Vpc` / `eks.Cluster`)
172
+ - 跨 Stack 引用:通过构造函数参数传递
173
+ - 命令:`synth` → `diff` → `deploy --all` / `bootstrap`
174
+
175
+ ### IaC Checklist
176
+
177
+ - [ ] 模块化:可复用组件抽象为模块
178
+ - [ ] 环境隔离:不同环境不同 State
179
+ - [ ] 远程状态 + 状态锁定
180
+ - [ ] Provider 版本锁定
181
+ - [ ] 密钥管理:Secrets Manager / SSM
182
+ - [ ] 统一资源标签
183
+ - [ ] Plan 后人工审查再 Apply
184
+ - [ ] CI/CD 集成自动化
185
+
186
+ ---
187
+
188
+ ## 最佳实践
189
+
190
+ | 层级 | 工具选择 | 原则 |
191
+ |------|----------|------|
192
+ | 应用部署 | Helm + Kustomize | 模板化 + 环境差异 |
193
+ | 持续交付 | ArgoCD / Flux | Git 为唯一真相源 |
194
+ | 基础设施 | Terraform / Pulumi | 声明式 + 状态管理 |
195
+ | 配置管理 | External Secrets | 密钥外部化 |
196
+ | 可观测性 | Prometheus + Grafana | 指标 + 可视化 |
197
+
198
+ ## 触发词
199
+
200
+ Kubernetes、K8s、Helm、Kustomize、Operator、CRD、GitOps、ArgoCD、Flux、IaC、Terraform、Pulumi、CDK、基础设施即代码
@@ -0,0 +1,224 @@
1
+ ---
2
+ name: mobile
3
+ description: 移动开发。iOS、Android、SwiftUI、Jetpack Compose、React Native、Flutter、跨平台。当用户提到移动开发、iOS、Android、跨平台时路由到此。
4
+ license: MIT
5
+ user-invocable: false
6
+ disable-model-invocation: false
7
+ ---
8
+
9
+ # 移动开发域 · Mobile Development
10
+
11
+ ## 域概览
12
+
13
+ ```
14
+ 原生开发 跨平台开发
15
+ ├── iOS (SwiftUI/UIKit) ├── React Native (JS/TS)
16
+ ├── Android (Compose/Kotlin) └── Flutter (Dart)
17
+ └── 共通:MVVM / 网络层 / 持久化 / 测试
18
+ ```
19
+
20
+ ---
21
+
22
+ ## iOS 开发
23
+
24
+ ### SwiftUI 核心模式
25
+
26
+ - View 组件:`struct MyView: View { var body: some View { ... } }`
27
+ - State 管理:
28
+ - `@State` — 本地状态
29
+ - `@Binding` — 父子双向绑定
30
+ - `@StateObject` — 拥有 ObservableObject
31
+ - `@ObservedObject` — 引用 ObservableObject
32
+ - `@EnvironmentObject` / `@Environment` — 全局注入
33
+ - ObservableObject:`@Published` 属性自动触发 UI 更新
34
+ - Custom ViewModifier:`struct CardModifier: ViewModifier` + `extension View { func cardStyle() }`
35
+ - 生命周期:`.task { await ... }` / `.onAppear` / `.onDisappear`
36
+
37
+ ### UIKit 集成
38
+
39
+ - UIViewControllerRepresentable:包装 UIViewController 到 SwiftUI
40
+ - UIViewRepresentable:包装 UIView 到 SwiftUI
41
+ - Coordinator 模式:处理 delegate 回调
42
+ - Auto Layout:`NSLayoutConstraint.activate([...])` + `translatesAutoresizingMaskIntoConstraints = false`
43
+
44
+ ### Combine 响应式
45
+
46
+ - Publisher:`URLSession.shared.dataTaskPublisher` → `map` → `decode` → `eraseToAnyPublisher`
47
+ - 订阅:`.sink(receiveCompletion:receiveValue:)` + `.store(in: &cancellables)`
48
+ - 常用 Operators:`debounce` / `removeDuplicates` / `combineLatest` / `flatMap`
49
+ - Subject:`PassthroughSubject`(无初始值)/ `CurrentValueSubject`(有初始值)
50
+
51
+ ### iOS 架构
52
+
53
+ MVVM(推荐):
54
+ - Model:`Codable` 数据结构
55
+ - Repository:`protocol` + `async throws` 方法
56
+ - ViewModel:`@MainActor class VM: ObservableObject` + `@Published` 属性
57
+ - View:`@StateObject private var viewModel = VM()`
58
+
59
+ VIPER(复杂场景):
60
+ - View ←→ Presenter ←→ Interactor → Entity
61
+ - Router 处理导航
62
+
63
+ ### 网络层
64
+
65
+ - APIClient:泛型 `func get<T: Decodable>(_ path:) async throws -> T`
66
+ - Token 管理:`request.setValue("Bearer \(token)", forHTTPHeaderField: "Authorization")`
67
+ - 错误处理:`enum APIError: Error { case invalidURL, invalidResponse, httpError(Int) }`
68
+
69
+ ### 数据持久化
70
+
71
+ - UserDefaults:`@propertyWrapper struct UserDefault<T>` 简化访问
72
+ - Keychain:`SecItemAdd` / `SecItemCopyMatching` 存储敏感数据
73
+ - Core Data:`NSPersistentContainer` + `NSManagedObjectContext`
74
+ - SwiftData(iOS 17+):`@Model` 宏简化持久化
75
+
76
+ ### iOS Checklist
77
+
78
+ - [ ] SwiftUI 优先,UIKit 按需集成
79
+ - [ ] `@MainActor` 确保 UI 线程安全
80
+ - [ ] async/await 替代回调
81
+ - [ ] 依赖注入提升可测试性
82
+ - [ ] LazyVStack/LazyHStack 优化大列表
83
+ - [ ] 图片缓存(NSCache)减少内存压力
84
+ - [ ] Keychain 存储敏感数据(非 UserDefaults)
85
+ - [ ] 单元测试覆盖 ViewModel + Mock Repository
86
+
87
+ ---
88
+
89
+ ## Android 开发
90
+
91
+ ### Jetpack Compose 核心模式
92
+
93
+ - Composable:`@Composable fun MyScreen() { ... }`
94
+ - State 管理:
95
+ - `remember { mutableStateOf(value) }` — 本地状态
96
+ - `rememberSaveable` — 跨配置变更保存
97
+ - `derivedStateOf` — 派生状态避免重组
98
+ - LazyColumn:`items(list, key = { it.id })` 提供稳定 key
99
+ - Side Effects:
100
+ - `LaunchedEffect(key)` — 启动协程
101
+ - `DisposableEffect(key)` — 清理资源(onDispose)
102
+ - `SideEffect` — 同步状态到外部
103
+ - `snapshotFlow { state }` — 监听状态变化转 Flow
104
+ - Navigation:`NavHost` + `composable(route)` + `navController.navigate()`
105
+ - Custom Modifier:`fun Modifier.myModifier(): Modifier = composed { ... }`
106
+
107
+ ### ViewModel + StateFlow
108
+
109
+ - StateFlow(推荐替代 LiveData):
110
+ - `MutableStateFlow(UiState())` + `.asStateFlow()`
111
+ - `_uiState.update { it.copy(isLoading = true) }`
112
+ - Compose 中:`val uiState by viewModel.uiState.collectAsState()`
113
+ - UiState data class:封装 loading / error / data
114
+
115
+ ### Kotlin Coroutines & Flow
116
+
117
+ - 协程:`viewModelScope.launch { withContext(Dispatchers.IO) { ... } }`
118
+ - 并发:`coroutineScope { val a = async { ... }; val b = async { ... } }`
119
+ - Flow:`flow { emit(value) }` + `.flowOn(Dispatchers.IO)`
120
+ - StateFlow:`.stateIn(scope, SharingStarted.WhileSubscribed(5000), initial)`
121
+ - 搜索防抖:`searchQuery.debounce(300).filter { it.isNotEmpty() }.flatMapLatest { ... }`
122
+ - Channel:`Channel<Event>(BUFFERED)` + `.receiveAsFlow()` 一次性事件
123
+
124
+ ### 依赖注入 (Hilt)
125
+
126
+ - `@HiltAndroidApp` Application + `@AndroidEntryPoint` Activity
127
+ - `@Module @InstallIn(SingletonComponent::class)` 提供依赖
128
+ - `@Provides @Singleton` 提供实例 / `@Binds` 绑定接口
129
+ - ViewModel:`@HiltViewModel class VM @Inject constructor(repo)` + `hiltViewModel()`
130
+
131
+ ### Room 数据库
132
+
133
+ - Entity:`@Entity(tableName)` + `@PrimaryKey` + `@ColumnInfo`
134
+ - DAO:`@Query` / `@Insert(onConflict = REPLACE)` / `@Delete` + 返回 `Flow<List<T>>`
135
+ - Database:`@Database(entities, version)` + `Room.databaseBuilder`
136
+
137
+ ### 网络层 (Retrofit)
138
+
139
+ - ApiService:`@GET` / `@POST` / `@Path` / `@Query` / `@Body` / `@Multipart`
140
+ - Interceptor:AuthInterceptor 注入 Bearer Token
141
+ - OkHttpClient:`addInterceptor` + `connectTimeout`
142
+
143
+ ### Android Checklist
144
+
145
+ - [ ] Compose 优先,View 系统按需使用
146
+ - [ ] StateFlow 替代 LiveData
147
+ - [ ] Hilt 依赖注入
148
+ - [ ] Room 本地持久化
149
+ - [ ] `key` 参数优化 LazyColumn
150
+ - [ ] `remember` / `derivedStateOf` 避免过度重组
151
+ - [ ] Coil 图片加载 + 缓存策略
152
+ - [ ] 单元测试覆盖 ViewModel(runTest + advanceUntilIdle)
153
+
154
+ ---
155
+
156
+ ## 跨平台开发
157
+
158
+ ### React Native vs Flutter
159
+
160
+ | 维度 | React Native | Flutter |
161
+ |------|--------------|---------|
162
+ | 语言 | TypeScript | Dart |
163
+ | 渲染 | 原生组件(桥接) | 自绘引擎(Skia) |
164
+ | 性能 | 接近原生 | 接近原生 |
165
+ | 热重载 | Fast Refresh | Hot Reload |
166
+ | 生态 | npm(成熟) | pub.dev(快速增长) |
167
+ | UI 一致性 | 跟随系统 | 完全一致 |
168
+ | 包体积 | ~7MB | ~15MB |
169
+
170
+ ### React Native 核心模式
171
+
172
+ - 组件:函数组件 + Hooks(useState / useEffect / useCallback / useMemo)
173
+ - 列表:`FlatList` + `keyExtractor` + `initialNumToRender` + `windowSize`
174
+ - Navigation:`@react-navigation/native` + `createNativeStackNavigator`
175
+ - 状态管理:Redux Toolkit(`createSlice` + `createAsyncThunk`)/ Zustand
176
+ - 原生桥接:`NativeModules` 调用 iOS(Swift) / Android(Kotlin) 原生代码
177
+ - 性能:`React.memo` / Hermes 引擎 / 新架构 JSI(无桥接序列化)
178
+
179
+ ### Flutter 核心模式
180
+
181
+ - Widget:StatelessWidget / StatefulWidget + `setState`
182
+ - 状态管理:
183
+ - Provider:`ChangeNotifier` + `Consumer` / `context.watch`
184
+ - Riverpod(推荐):`FutureProvider` / `StateNotifierProvider` + `ref.watch`
185
+ - Navigation:go_router(`GoRoute` + `context.go/push/pop`)
186
+ - 原生桥接:`MethodChannel` + Platform Channels(iOS Swift / Android Kotlin)
187
+ - 性能:`const` 构造函数 / `ListView.builder` / `RepaintBoundary` / `ValueKey`
188
+
189
+ ### 选型建议
190
+
191
+ | 场景 | 推荐 | 理由 |
192
+ |------|------|------|
193
+ | 团队有 Web 背景 | React Native | 学习成本低 |
194
+ | 追求极致性能/动画 | Flutter | 自绘引擎 60fps |
195
+ | UI 高度定制 | Flutter | 完全控制渲染 |
196
+ | 大量原生交互 | React Native | 桥接生态成熟 |
197
+ | 需要原生极致体验 | 原生开发 | 无桥接开销 |
198
+
199
+ ### 跨平台 Checklist
200
+
201
+ - [ ] 选型匹配团队技术栈和业务需求
202
+ - [ ] 列表优化:FlatList(RN) / ListView.builder(Flutter) + key
203
+ - [ ] 状态管理:Redux Toolkit(RN) / Riverpod(Flutter)
204
+ - [ ] 原生模块桥接方案验证
205
+ - [ ] 包体积优化:ProGuard(Android) / tree-shake-icons(Flutter)
206
+ - [ ] 性能基线:冷启动 < 1.5s / 渲染 > 55fps
207
+
208
+ ---
209
+
210
+ ## 通用最佳实践
211
+
212
+ | 实践 | 说明 |
213
+ |------|------|
214
+ | MVVM 架构 | 分离 UI / 业务逻辑 / 数据层 |
215
+ | 依赖注入 | Hilt(Android) / Protocol(iOS) / Context(RN) |
216
+ | 响应式状态 | StateFlow / Combine / Hooks / Riverpod |
217
+ | 网络层封装 | 统一错误处理 + Token 管理 + 重试 |
218
+ | 本地持久化 | Room / Core Data / AsyncStorage / Hive |
219
+ | 列表优化 | 懒加载 + 稳定 key + 缓存 |
220
+ | 测试覆盖 | ViewModel 单元测试 + UI 测试关键流程 |
221
+
222
+ ## 触发词
223
+
224
+ iOS、SwiftUI、UIKit、Combine、Android、Jetpack Compose、Kotlin、React Native、Flutter、跨平台、移动开发、MVVM