@maestro-ai/mcp-server 1.0.0 → 1.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 (448) hide show
  1. package/README.md +266 -227
  2. package/dist/content/design-system/README.md +231 -231
  3. package/dist/content/design-system/indexes/README.md +211 -211
  4. package/dist/content/design-system/indexes/colors-index.md +156 -156
  5. package/dist/content/design-system/indexes/quick-search.md +111 -111
  6. package/dist/content/design-system/indexes/stacks-index.md +341 -341
  7. package/dist/content/examples/Exemplo de Fluxo Completo com Java e Spring Boot.md +249 -249
  8. package/dist/content/examples/Exemplo de Fluxo Completo com Laravel e Filament.md +277 -277
  9. package/dist/content/examples/Exemplo de Fluxo Completo com Laravel e Livewire.md +260 -260
  10. package/dist/content/examples/Exemplo de Fluxo Completo com Node e NestJS.md +257 -257
  11. package/dist/content/guides/Cat/303/241logo de Stacks para Cloud Moderna.md" +119 -119
  12. package/dist/content/guides/Cat/303/241logo de Stacks para Hospedagem Compartilhada.md" +147 -147
  13. package/dist/content/guides/Checklist Mestre de Entrega.md +68 -68
  14. package/dist/content/guides/Gates de Qualidade.md +209 -209
  15. package/dist/content/guides/Guia de Adi/303/247/303/243o de Novas Funcionalidades.md" +355 -355
  16. package/dist/content/guides/Guia de Chaos Engineering.md +267 -267
  17. package/dist/content/guides/Guia de Debugging com IA.md +135 -135
  18. package/dist/content/guides/Guia de Estrat/303/251gias de Cache.md" +352 -352
  19. package/dist/content/guides/Guia de Migrations Zero-Downtime.md +311 -311
  20. package/dist/content/guides/Guia de Multi-tenancy.md +368 -368
  21. package/dist/content/guides/Guia de Otimiza/303/247/303/243o de Custos Cloud.md" +195 -195
  22. package/dist/content/guides/Guia de Refatora/303/247/303/243o de C/303/263digo Legado com IA.md" +162 -162
  23. package/dist/content/guides/Guia de SLOs e Error Budgets.md +315 -315
  24. package/dist/content/guides/M/303/251tricas de Efici/303/252ncia do Desenvolvimento com IA.md" +93 -93
  25. package/dist/content/guides/Rules base.md +90 -90
  26. package/dist/content/playbook/Playbook de Desenvolvimento com IA.md +364 -364
  27. package/dist/content/prompts/README.md +203 -203
  28. package/dist/content/prompts/acessibilidade/analise-acessibilidade.md +257 -257
  29. package/dist/content/prompts/apis/design-api-rest.md +303 -303
  30. package/dist/content/prompts/apis/idempotencia.md +254 -254
  31. package/dist/content/prompts/apis/versionamento.md +313 -313
  32. package/dist/content/prompts/arquitetura/arquitetura-c4-completo.md +190 -190
  33. package/dist/content/prompts/arquitetura/clean-architecture.md +151 -151
  34. package/dist/content/prompts/arquitetura/ddd-bounded-contexts.md +183 -183
  35. package/dist/content/prompts/arquitetura/ddd-cqrs.md +176 -176
  36. package/dist/content/prompts/arquitetura/modelo-dominio.md +207 -207
  37. package/dist/content/prompts/arquitetura/multi-tenancy.md +235 -235
  38. package/dist/content/prompts/database/migrations-zero-downtime.md +192 -192
  39. package/dist/content/prompts/database/otimizacao-queries.md +296 -296
  40. package/dist/content/prompts/desenvolvimento/code-review.md +301 -301
  41. package/dist/content/prompts/desenvolvimento/gerar-servico.md +271 -271
  42. package/dist/content/prompts/devops/docker-compose.md +336 -336
  43. package/dist/content/prompts/devops/feature-flags.md +374 -374
  44. package/dist/content/prompts/devops/kubernetes-deploy.md +460 -460
  45. package/dist/content/prompts/devops/pipeline-cicd.md +358 -358
  46. package/dist/content/prompts/devops/terraform-iac.md +502 -502
  47. package/dist/content/prompts/escalabilidade/analise-performance.md +240 -240
  48. package/dist/content/prompts/escalabilidade/analise-performance.txt +94 -94
  49. package/dist/content/prompts/escalabilidade/caching.md +255 -255
  50. package/dist/content/prompts/observabilidade/chaos-testing.md +237 -237
  51. package/dist/content/prompts/observabilidade/estrategia-observabilidade.md +263 -263
  52. package/dist/content/prompts/observabilidade/estrategia-observabilidade.txt +134 -134
  53. package/dist/content/prompts/observabilidade/slos.md +215 -215
  54. package/dist/content/prompts/produto/discovery-inicial.md +203 -203
  55. package/dist/content/prompts/produto/discovery-inicial.txt +33 -33
  56. package/dist/content/prompts/requisitos/refinar-requisitos.md +232 -232
  57. package/dist/content/prompts/requisitos/refinar-requisitos.txt +40 -40
  58. package/dist/content/prompts/seguranca/analise-seguranca.md +243 -243
  59. package/dist/content/prompts/seguranca/pentest-checklist.md +333 -333
  60. package/dist/content/prompts/seguranca/rate-limiting.md +356 -356
  61. package/dist/content/prompts/seguranca/revisao-lgpd.md +227 -227
  62. package/dist/content/prompts/seguranca/threat-modeling.md +224 -224
  63. package/dist/content/prompts/testes/contract-testing.md +340 -340
  64. package/dist/content/prompts/testes/gerar-testes-unitarios.md +474 -474
  65. package/dist/content/prompts/testes/testes-e2e.md +460 -460
  66. package/dist/content/prompts/testes/testes-integracao.md +418 -418
  67. package/dist/content/prompts/testes/testes-performance.md +458 -458
  68. package/dist/content/prompts/ux/gerar-ui-stitch.md +151 -151
  69. package/dist/content/rules/RULES.md +835 -835
  70. package/dist/content/rules/adapters/copilot.md +10 -10
  71. package/dist/content/rules/adapters/cursor.md +10 -10
  72. package/dist/content/rules/adapters/gemini.md +13 -13
  73. package/dist/content/rules/adapters/windsurf.md +10 -10
  74. package/dist/content/specialists/Especialista em Acessibilidade.md +266 -266
  75. package/dist/content/specialists/Especialista em An/303/241lise de Testes.md" +434 -434
  76. package/dist/content/specialists/Especialista em Arquitetura Avan/303/247ada.md" +358 -358
  77. package/dist/content/specialists/Especialista em Arquitetura de Software.md +177 -177
  78. package/dist/content/specialists/Especialista em Banco de Dados.md +260 -260
  79. package/dist/content/specialists/Especialista em Contrato de API.md +172 -172
  80. package/dist/content/specialists/Especialista em Dados e Analytics com IA.md +246 -246
  81. package/dist/content/specialists/Especialista em Debugging e Troubleshooting.md +191 -191
  82. package/dist/content/specialists/Especialista em Desenvolvimento Frontend.md +477 -477
  83. package/dist/content/specialists/Especialista em Desenvolvimento Mobile.md +241 -241
  84. package/dist/content/specialists/Especialista em Desenvolvimento e Vibe Coding Estruturado.md +417 -417
  85. package/dist/content/specialists/Especialista em DevOps e Infraestrutura.md +294 -294
  86. package/dist/content/specialists/Especialista em Documenta/303/247/303/243o T/303/251cnica.md" +227 -227
  87. package/dist/content/specialists/Especialista em Engenharia de Requisitos com IA.md +299 -299
  88. package/dist/content/specialists/Especialista em Explora/303/247/303/243o de Codebase.md" +179 -179
  89. package/dist/content/specialists/Especialista em Gest/303/243o de Produto.md" +179 -179
  90. package/dist/content/specialists/Especialista em Migra/303/247/303/243o e Moderniza/303/247/303/243o.md" +410 -410
  91. package/dist/content/specialists/Especialista em Modelagem e Arquitetura de Dom/303/255nio com IA.md" +248 -248
  92. package/dist/content/specialists/Especialista em Observabilidade.md +415 -415
  93. package/dist/content/specialists/Especialista em Performance e Escalabilidade.md +373 -373
  94. package/dist/content/specialists/Especialista em Plano de Execu/303/247/303/243o com IA.md" +341 -341
  95. package/dist/content/specialists/Especialista em Prototipagem R/303/241pida com Google Stitch.md" +419 -419
  96. package/dist/content/specialists/Especialista em Seguran/303/247a da Informa/303/247/303/243o.md" +508 -508
  97. package/dist/content/specialists/Especialista em UX Design.md +453 -453
  98. package/dist/content/specialists/INDEX.md +43 -43
  99. package/dist/content/templates/PRD.md +165 -165
  100. package/dist/content/templates/README.md +65 -65
  101. package/dist/content/templates/adr.md +103 -103
  102. package/dist/content/templates/arquitetura.md +279 -279
  103. package/dist/content/templates/backlog.md +185 -185
  104. package/dist/content/templates/checklist-seguranca.md +180 -180
  105. package/dist/content/templates/contexto.md +120 -120
  106. package/dist/content/templates/criterios-aceite.md +99 -99
  107. package/dist/content/templates/design-banco.md +270 -270
  108. package/dist/content/templates/design-doc.md +240 -240
  109. package/dist/content/templates/feature.md +88 -88
  110. package/dist/content/templates/historia-backend.md +84 -84
  111. package/dist/content/templates/historia-frontend.md +75 -75
  112. package/dist/content/templates/historia-usuario.md +125 -125
  113. package/dist/content/templates/mapa-navegacao.md +133 -133
  114. package/dist/content/templates/matriz-rastreabilidade.md +121 -121
  115. package/dist/content/templates/modelo-dominio.md +219 -219
  116. package/dist/content/templates/plano-testes.md +199 -199
  117. package/dist/content/templates/prototipo-stitch.md +138 -138
  118. package/dist/content/templates/requisitos.md +162 -162
  119. package/dist/content/templates/slo-sli.md +197 -197
  120. package/dist/content/workflows/README-MCP.md +363 -363
  121. package/dist/content/workflows/mcp-debug.md +506 -506
  122. package/dist/content/workflows/mcp-feature.md +385 -385
  123. package/dist/content/workflows/mcp-gate.md +413 -413
  124. package/dist/content/workflows/mcp-next.md +388 -388
  125. package/dist/content/workflows/mcp-refactor.md +600 -600
  126. package/dist/content/workflows/mcp-start.md +304 -304
  127. package/dist/content/workflows/mcp-status.md +400 -400
  128. package/dist/gates/tiers.test.js +14 -14
  129. package/dist/index.js +133 -133
  130. package/dist/resources/index.js +61 -61
  131. package/dist/stdio.js +39 -32
  132. package/dist/stdio.js.map +1 -1
  133. package/dist/tools/analise/performance.js +23 -23
  134. package/dist/tools/analise/qualidade.js +23 -23
  135. package/dist/tools/analise/relatorio.js +24 -24
  136. package/dist/tools/analise/seguranca.js +28 -28
  137. package/dist/tools/aprovar-gate.js +81 -81
  138. package/dist/tools/atualizar-codebase.js +18 -18
  139. package/dist/tools/avaliar-entregavel.js +18 -18
  140. package/dist/tools/carregar-projeto.d.ts.map +1 -1
  141. package/dist/tools/carregar-projeto.js +91 -116
  142. package/dist/tools/carregar-projeto.js.map +1 -1
  143. package/dist/tools/classificar.js +36 -36
  144. package/dist/tools/confirmar-classificacao.js +36 -36
  145. package/dist/tools/confirmar-stitch.js +75 -75
  146. package/dist/tools/contexto.js +56 -56
  147. package/dist/tools/fluxos-alternativos.js +98 -98
  148. package/dist/tools/implementar-historia.js +63 -63
  149. package/dist/tools/iniciar-projeto.d.ts.map +1 -1
  150. package/dist/tools/iniciar-projeto.js +139 -224
  151. package/dist/tools/iniciar-projeto.js.map +1 -1
  152. package/dist/tools/proximo.d.ts.map +1 -1
  153. package/dist/tools/proximo.js +224 -252
  154. package/dist/tools/proximo.js.map +1 -1
  155. package/dist/tools/salvar.js +59 -59
  156. package/dist/tools/status.d.ts.map +1 -1
  157. package/dist/tools/status.js +64 -93
  158. package/dist/tools/status.js.map +1 -1
  159. package/dist/tools/validar-gate.js +35 -35
  160. package/dist/types/response.js +11 -11
  161. package/dist/utils/instructions.js +48 -48
  162. package/dist/utils/prompt-mapper.js +16 -16
  163. package/dist/utils/system-md.js +33 -33
  164. package/package.json +67 -67
  165. package/dist/content/content/design-system/README.md +0 -231
  166. package/dist/content/content/design-system/data/charts.csv +0 -26
  167. package/dist/content/content/design-system/data/colors.csv +0 -97
  168. package/dist/content/content/design-system/data/icons.csv +0 -101
  169. package/dist/content/content/design-system/data/landing.csv +0 -31
  170. package/dist/content/content/design-system/data/products.csv +0 -97
  171. package/dist/content/content/design-system/data/prompts.csv +0 -24
  172. package/dist/content/content/design-system/data/react-performance.csv +0 -45
  173. package/dist/content/content/design-system/data/styles.csv +0 -59
  174. package/dist/content/content/design-system/data/typography.csv +0 -58
  175. package/dist/content/content/design-system/data/ui-reasoning.csv +0 -101
  176. package/dist/content/content/design-system/data/ux-guidelines.csv +0 -100
  177. package/dist/content/content/design-system/data/web-interface.csv +0 -31
  178. package/dist/content/content/design-system/indexes/README.md +0 -211
  179. package/dist/content/content/design-system/indexes/colors-index.md +0 -156
  180. package/dist/content/content/design-system/indexes/quick-search.md +0 -111
  181. package/dist/content/content/design-system/indexes/stacks-index.md +0 -341
  182. package/dist/content/content/design-system/stacks/flutter.csv +0 -53
  183. package/dist/content/content/design-system/stacks/html-tailwind.csv +0 -56
  184. package/dist/content/content/design-system/stacks/jetpack-compose.csv +0 -53
  185. package/dist/content/content/design-system/stacks/nextjs.csv +0 -53
  186. package/dist/content/content/design-system/stacks/nuxt-ui.csv +0 -51
  187. package/dist/content/content/design-system/stacks/nuxtjs.csv +0 -59
  188. package/dist/content/content/design-system/stacks/react-native.csv +0 -52
  189. package/dist/content/content/design-system/stacks/react.csv +0 -54
  190. package/dist/content/content/design-system/stacks/shadcn.csv +0 -61
  191. package/dist/content/content/design-system/stacks/svelte.csv +0 -54
  192. package/dist/content/content/design-system/stacks/swiftui.csv +0 -51
  193. package/dist/content/content/design-system/stacks/vue.csv +0 -50
  194. package/dist/content/content/examples/Exemplo de Fluxo Completo com Java e Spring Boot.md +0 -250
  195. package/dist/content/content/examples/Exemplo de Fluxo Completo com Laravel e Filament.md +0 -278
  196. package/dist/content/content/examples/Exemplo de Fluxo Completo com Laravel e Livewire.md +0 -261
  197. package/dist/content/content/examples/Exemplo de Fluxo Completo com Node e NestJS.md +0 -258
  198. package/dist/content/content/guides/Cat/303/241logo de Stacks para Cloud Moderna.md" +0 -119
  199. package/dist/content/content/guides/Cat/303/241logo de Stacks para Hospedagem Compartilhada.md" +0 -147
  200. package/dist/content/content/guides/Checklist Mestre de Entrega.md +0 -68
  201. package/dist/content/content/guides/Gates de Qualidade.md +0 -209
  202. package/dist/content/content/guides/Guia de Adi/303/247/303/243o de Novas Funcionalidades.md" +0 -355
  203. package/dist/content/content/guides/Guia de Chaos Engineering.md +0 -267
  204. package/dist/content/content/guides/Guia de Debugging com IA.md +0 -135
  205. package/dist/content/content/guides/Guia de Estrat/303/251gias de Cache.md" +0 -352
  206. package/dist/content/content/guides/Guia de Migrations Zero-Downtime.md +0 -311
  207. package/dist/content/content/guides/Guia de Multi-tenancy.md +0 -368
  208. package/dist/content/content/guides/Guia de Otimiza/303/247/303/243o de Custos Cloud.md" +0 -195
  209. package/dist/content/content/guides/Guia de Refatora/303/247/303/243o de C/303/263digo Legado com IA.md" +0 -162
  210. package/dist/content/content/guides/Guia de SLOs e Error Budgets.md +0 -315
  211. package/dist/content/content/guides/M/303/251tricas de Efici/303/252ncia do Desenvolvimento com IA.md" +0 -93
  212. package/dist/content/content/guides/Rules base.md +0 -90
  213. package/dist/content/content/playbook/Playbook de Desenvolvimento com IA.md +0 -364
  214. package/dist/content/content/prompts/README.md +0 -203
  215. package/dist/content/content/prompts/acessibilidade/analise-acessibilidade.md +0 -257
  216. package/dist/content/content/prompts/apis/design-api-rest.md +0 -303
  217. package/dist/content/content/prompts/apis/idempotencia.md +0 -254
  218. package/dist/content/content/prompts/apis/versionamento.md +0 -313
  219. package/dist/content/content/prompts/arquitetura/arquitetura-c4-completo.md +0 -190
  220. package/dist/content/content/prompts/arquitetura/clean-architecture.md +0 -151
  221. package/dist/content/content/prompts/arquitetura/ddd-bounded-contexts.md +0 -183
  222. package/dist/content/content/prompts/arquitetura/ddd-cqrs.md +0 -176
  223. package/dist/content/content/prompts/arquitetura/modelo-dominio.md +0 -207
  224. package/dist/content/content/prompts/arquitetura/multi-tenancy.md +0 -235
  225. package/dist/content/content/prompts/database/migrations-zero-downtime.md +0 -192
  226. package/dist/content/content/prompts/database/otimizacao-queries.md +0 -296
  227. package/dist/content/content/prompts/desenvolvimento/code-review.md +0 -301
  228. package/dist/content/content/prompts/desenvolvimento/gerar-servico.md +0 -271
  229. package/dist/content/content/prompts/devops/docker-compose.md +0 -336
  230. package/dist/content/content/prompts/devops/feature-flags.md +0 -374
  231. package/dist/content/content/prompts/devops/kubernetes-deploy.md +0 -460
  232. package/dist/content/content/prompts/devops/pipeline-cicd.md +0 -358
  233. package/dist/content/content/prompts/devops/terraform-iac.md +0 -502
  234. package/dist/content/content/prompts/escalabilidade/analise-performance.md +0 -240
  235. package/dist/content/content/prompts/escalabilidade/analise-performance.txt +0 -94
  236. package/dist/content/content/prompts/escalabilidade/caching.md +0 -255
  237. package/dist/content/content/prompts/observabilidade/chaos-testing.md +0 -237
  238. package/dist/content/content/prompts/observabilidade/estrategia-observabilidade.md +0 -263
  239. package/dist/content/content/prompts/observabilidade/estrategia-observabilidade.txt +0 -134
  240. package/dist/content/content/prompts/observabilidade/slos.md +0 -215
  241. package/dist/content/content/prompts/produto/discovery-inicial.md +0 -203
  242. package/dist/content/content/prompts/produto/discovery-inicial.txt +0 -33
  243. package/dist/content/content/prompts/requisitos/refinar-requisitos.md +0 -232
  244. package/dist/content/content/prompts/requisitos/refinar-requisitos.txt +0 -40
  245. package/dist/content/content/prompts/seguranca/analise-seguranca.md +0 -243
  246. package/dist/content/content/prompts/seguranca/pentest-checklist.md +0 -333
  247. package/dist/content/content/prompts/seguranca/rate-limiting.md +0 -356
  248. package/dist/content/content/prompts/seguranca/revisao-lgpd.md +0 -227
  249. package/dist/content/content/prompts/seguranca/threat-modeling.md +0 -224
  250. package/dist/content/content/prompts/testes/contract-testing.md +0 -340
  251. package/dist/content/content/prompts/testes/gerar-testes-unitarios.md +0 -474
  252. package/dist/content/content/prompts/testes/testes-e2e.md +0 -460
  253. package/dist/content/content/prompts/testes/testes-integracao.md +0 -418
  254. package/dist/content/content/prompts/testes/testes-performance.md +0 -458
  255. package/dist/content/content/prompts/ux/gerar-ui-stitch.md +0 -151
  256. package/dist/content/content/rules/GEMINI.md +0 -841
  257. package/dist/content/content/rules/RULES.md +0 -835
  258. package/dist/content/content/rules/adapters/copilot.md +0 -10
  259. package/dist/content/content/rules/adapters/cursor.md +0 -10
  260. package/dist/content/content/rules/adapters/gemini.md +0 -13
  261. package/dist/content/content/rules/adapters/windsurf.md +0 -10
  262. package/dist/content/content/skills/api-patterns/SKILL.md +0 -81
  263. package/dist/content/content/skills/api-patterns/api-style.md +0 -42
  264. package/dist/content/content/skills/api-patterns/auth.md +0 -24
  265. package/dist/content/content/skills/api-patterns/documentation.md +0 -26
  266. package/dist/content/content/skills/api-patterns/graphql.md +0 -41
  267. package/dist/content/content/skills/api-patterns/rate-limiting.md +0 -31
  268. package/dist/content/content/skills/api-patterns/response.md +0 -37
  269. package/dist/content/content/skills/api-patterns/rest.md +0 -40
  270. package/dist/content/content/skills/api-patterns/scripts/api_validator.py +0 -211
  271. package/dist/content/content/skills/api-patterns/security-testing.md +0 -122
  272. package/dist/content/content/skills/api-patterns/trpc.md +0 -41
  273. package/dist/content/content/skills/api-patterns/versioning.md +0 -22
  274. package/dist/content/content/skills/app-builder/SKILL.md +0 -75
  275. package/dist/content/content/skills/app-builder/agent-coordination.md +0 -71
  276. package/dist/content/content/skills/app-builder/feature-building.md +0 -53
  277. package/dist/content/content/skills/app-builder/project-detection.md +0 -34
  278. package/dist/content/content/skills/app-builder/scaffolding.md +0 -118
  279. package/dist/content/content/skills/app-builder/tech-stack.md +0 -40
  280. package/dist/content/content/skills/app-builder/templates/SKILL.md +0 -39
  281. package/dist/content/content/skills/app-builder/templates/astro-static/TEMPLATE.md +0 -76
  282. package/dist/content/content/skills/app-builder/templates/chrome-extension/TEMPLATE.md +0 -92
  283. package/dist/content/content/skills/app-builder/templates/cli-tool/TEMPLATE.md +0 -88
  284. package/dist/content/content/skills/app-builder/templates/electron-desktop/TEMPLATE.md +0 -88
  285. package/dist/content/content/skills/app-builder/templates/express-api/TEMPLATE.md +0 -83
  286. package/dist/content/content/skills/app-builder/templates/flutter-app/TEMPLATE.md +0 -90
  287. package/dist/content/content/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +0 -90
  288. package/dist/content/content/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +0 -82
  289. package/dist/content/content/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +0 -100
  290. package/dist/content/content/skills/app-builder/templates/nextjs-static/TEMPLATE.md +0 -106
  291. package/dist/content/content/skills/app-builder/templates/nuxt-app/TEMPLATE.md +0 -101
  292. package/dist/content/content/skills/app-builder/templates/python-fastapi/TEMPLATE.md +0 -83
  293. package/dist/content/content/skills/app-builder/templates/react-native-app/TEMPLATE.md +0 -93
  294. package/dist/content/content/skills/architecture/SKILL.md +0 -55
  295. package/dist/content/content/skills/architecture/context-discovery.md +0 -43
  296. package/dist/content/content/skills/architecture/examples.md +0 -94
  297. package/dist/content/content/skills/architecture/pattern-selection.md +0 -68
  298. package/dist/content/content/skills/architecture/patterns-reference.md +0 -50
  299. package/dist/content/content/skills/architecture/trade-off-analysis.md +0 -77
  300. package/dist/content/content/skills/bash-linux/SKILL.md +0 -199
  301. package/dist/content/content/skills/behavioral-modes/SKILL.md +0 -242
  302. package/dist/content/content/skills/brainstorming/SKILL.md +0 -163
  303. package/dist/content/content/skills/brainstorming/dynamic-questioning.md +0 -350
  304. package/dist/content/content/skills/clean-code/SKILL.md +0 -201
  305. package/dist/content/content/skills/code-review-checklist/SKILL.md +0 -109
  306. package/dist/content/content/skills/database-design/SKILL.md +0 -52
  307. package/dist/content/content/skills/database-design/database-selection.md +0 -43
  308. package/dist/content/content/skills/database-design/indexing.md +0 -39
  309. package/dist/content/content/skills/database-design/migrations.md +0 -48
  310. package/dist/content/content/skills/database-design/optimization.md +0 -36
  311. package/dist/content/content/skills/database-design/orm-selection.md +0 -30
  312. package/dist/content/content/skills/database-design/schema-design.md +0 -56
  313. package/dist/content/content/skills/database-design/scripts/schema_validator.py +0 -172
  314. package/dist/content/content/skills/deployment-procedures/SKILL.md +0 -241
  315. package/dist/content/content/skills/doc.md +0 -177
  316. package/dist/content/content/skills/documentation-templates/SKILL.md +0 -194
  317. package/dist/content/content/skills/frontend-design/SKILL.md +0 -396
  318. package/dist/content/content/skills/frontend-design/animation-guide.md +0 -331
  319. package/dist/content/content/skills/frontend-design/color-system.md +0 -311
  320. package/dist/content/content/skills/frontend-design/decision-trees.md +0 -418
  321. package/dist/content/content/skills/frontend-design/motion-graphics.md +0 -306
  322. package/dist/content/content/skills/frontend-design/scripts/accessibility_checker.py +0 -183
  323. package/dist/content/content/skills/frontend-design/scripts/ux_audit.py +0 -722
  324. package/dist/content/content/skills/frontend-design/typography-system.md +0 -345
  325. package/dist/content/content/skills/frontend-design/ux-psychology.md +0 -541
  326. package/dist/content/content/skills/frontend-design/visual-effects.md +0 -383
  327. package/dist/content/content/skills/game-development/2d-games/SKILL.md +0 -119
  328. package/dist/content/content/skills/game-development/3d-games/SKILL.md +0 -135
  329. package/dist/content/content/skills/game-development/SKILL.md +0 -167
  330. package/dist/content/content/skills/game-development/game-art/SKILL.md +0 -185
  331. package/dist/content/content/skills/game-development/game-audio/SKILL.md +0 -190
  332. package/dist/content/content/skills/game-development/game-design/SKILL.md +0 -129
  333. package/dist/content/content/skills/game-development/mobile-games/SKILL.md +0 -108
  334. package/dist/content/content/skills/game-development/multiplayer/SKILL.md +0 -132
  335. package/dist/content/content/skills/game-development/pc-games/SKILL.md +0 -144
  336. package/dist/content/content/skills/game-development/vr-ar/SKILL.md +0 -123
  337. package/dist/content/content/skills/game-development/web-games/SKILL.md +0 -150
  338. package/dist/content/content/skills/geo-fundamentals/SKILL.md +0 -156
  339. package/dist/content/content/skills/geo-fundamentals/scripts/geo_checker.py +0 -289
  340. package/dist/content/content/skills/i18n-localization/SKILL.md +0 -154
  341. package/dist/content/content/skills/i18n-localization/scripts/i18n_checker.py +0 -241
  342. package/dist/content/content/skills/intelligent-routing/SKILL.md +0 -334
  343. package/dist/content/content/skills/lint-and-validate/SKILL.md +0 -45
  344. package/dist/content/content/skills/lint-and-validate/scripts/lint_runner.py +0 -172
  345. package/dist/content/content/skills/lint-and-validate/scripts/type_coverage.py +0 -173
  346. package/dist/content/content/skills/mcp-builder/SKILL.md +0 -176
  347. package/dist/content/content/skills/mobile-design/SKILL.md +0 -394
  348. package/dist/content/content/skills/mobile-design/decision-trees.md +0 -516
  349. package/dist/content/content/skills/mobile-design/mobile-backend.md +0 -491
  350. package/dist/content/content/skills/mobile-design/mobile-color-system.md +0 -420
  351. package/dist/content/content/skills/mobile-design/mobile-debugging.md +0 -122
  352. package/dist/content/content/skills/mobile-design/mobile-design-thinking.md +0 -357
  353. package/dist/content/content/skills/mobile-design/mobile-navigation.md +0 -458
  354. package/dist/content/content/skills/mobile-design/mobile-performance.md +0 -767
  355. package/dist/content/content/skills/mobile-design/mobile-testing.md +0 -356
  356. package/dist/content/content/skills/mobile-design/mobile-typography.md +0 -433
  357. package/dist/content/content/skills/mobile-design/platform-android.md +0 -666
  358. package/dist/content/content/skills/mobile-design/platform-ios.md +0 -561
  359. package/dist/content/content/skills/mobile-design/scripts/mobile_audit.py +0 -670
  360. package/dist/content/content/skills/mobile-design/touch-psychology.md +0 -537
  361. package/dist/content/content/skills/nextjs-best-practices/SKILL.md +0 -203
  362. package/dist/content/content/skills/nodejs-best-practices/SKILL.md +0 -333
  363. package/dist/content/content/skills/parallel-agents/SKILL.md +0 -175
  364. package/dist/content/content/skills/performance-profiling/SKILL.md +0 -143
  365. package/dist/content/content/skills/performance-profiling/scripts/lighthouse_audit.py +0 -76
  366. package/dist/content/content/skills/plan-writing/SKILL.md +0 -152
  367. package/dist/content/content/skills/powershell-windows/SKILL.md +0 -167
  368. package/dist/content/content/skills/python-patterns/SKILL.md +0 -441
  369. package/dist/content/content/skills/react-patterns/SKILL.md +0 -198
  370. package/dist/content/content/skills/red-team-tactics/SKILL.md +0 -199
  371. package/dist/content/content/skills/seo-fundamentals/SKILL.md +0 -129
  372. package/dist/content/content/skills/seo-fundamentals/scripts/seo_checker.py +0 -219
  373. package/dist/content/content/skills/server-management/SKILL.md +0 -161
  374. package/dist/content/content/skills/systematic-debugging/SKILL.md +0 -109
  375. package/dist/content/content/skills/tailwind-patterns/SKILL.md +0 -269
  376. package/dist/content/content/skills/tdd-workflow/SKILL.md +0 -149
  377. package/dist/content/content/skills/testing-patterns/SKILL.md +0 -178
  378. package/dist/content/content/skills/testing-patterns/scripts/test_runner.py +0 -219
  379. package/dist/content/content/skills/vulnerability-scanner/SKILL.md +0 -276
  380. package/dist/content/content/skills/vulnerability-scanner/checklists.md +0 -121
  381. package/dist/content/content/skills/vulnerability-scanner/scripts/security_scan.py +0 -458
  382. package/dist/content/content/skills/webapp-testing/SKILL.md +0 -187
  383. package/dist/content/content/skills/webapp-testing/scripts/playwright_runner.py +0 -173
  384. package/dist/content/content/specialists/Especialista em Acessibilidade.md +0 -266
  385. package/dist/content/content/specialists/Especialista em An/303/241lise de Testes.md" +0 -434
  386. package/dist/content/content/specialists/Especialista em Arquitetura Avan/303/247ada.md" +0 -358
  387. package/dist/content/content/specialists/Especialista em Arquitetura de Software.md +0 -177
  388. package/dist/content/content/specialists/Especialista em Banco de Dados.md +0 -260
  389. package/dist/content/content/specialists/Especialista em Contrato de API.md +0 -172
  390. package/dist/content/content/specialists/Especialista em Dados e Analytics com IA.md +0 -246
  391. package/dist/content/content/specialists/Especialista em Debugging e Troubleshooting.md +0 -191
  392. package/dist/content/content/specialists/Especialista em Desenvolvimento Frontend.md +0 -477
  393. package/dist/content/content/specialists/Especialista em Desenvolvimento Mobile.md +0 -241
  394. package/dist/content/content/specialists/Especialista em Desenvolvimento e Vibe Coding Estruturado.md +0 -417
  395. package/dist/content/content/specialists/Especialista em DevOps e Infraestrutura.md +0 -294
  396. package/dist/content/content/specialists/Especialista em Documenta/303/247/303/243o T/303/251cnica.md" +0 -227
  397. package/dist/content/content/specialists/Especialista em Engenharia de Requisitos com IA.md +0 -299
  398. package/dist/content/content/specialists/Especialista em Explora/303/247/303/243o de Codebase.md" +0 -179
  399. package/dist/content/content/specialists/Especialista em Gest/303/243o de Produto.md" +0 -179
  400. package/dist/content/content/specialists/Especialista em Migra/303/247/303/243o e Moderniza/303/247/303/243o.md" +0 -410
  401. package/dist/content/content/specialists/Especialista em Modelagem e Arquitetura de Dom/303/255nio com IA.md" +0 -248
  402. package/dist/content/content/specialists/Especialista em Observabilidade.md +0 -415
  403. package/dist/content/content/specialists/Especialista em Performance e Escalabilidade.md +0 -373
  404. package/dist/content/content/specialists/Especialista em Plano de Execu/303/247/303/243o com IA.md" +0 -341
  405. package/dist/content/content/specialists/Especialista em Prototipagem R/303/241pida com Google Stitch.md" +0 -419
  406. package/dist/content/content/specialists/Especialista em Seguran/303/247a da Informa/303/247/303/243o.md" +0 -508
  407. package/dist/content/content/specialists/Especialista em UX Design.md +0 -453
  408. package/dist/content/content/specialists/INDEX.md +0 -43
  409. package/dist/content/content/templates/PRD.md +0 -165
  410. package/dist/content/content/templates/README.md +0 -65
  411. package/dist/content/content/templates/adr.md +0 -103
  412. package/dist/content/content/templates/arquitetura.md +0 -279
  413. package/dist/content/content/templates/backlog.md +0 -185
  414. package/dist/content/content/templates/checklist-seguranca.md +0 -180
  415. package/dist/content/content/templates/contexto.md +0 -120
  416. package/dist/content/content/templates/criterios-aceite.md +0 -99
  417. package/dist/content/content/templates/design-banco.md +0 -270
  418. package/dist/content/content/templates/design-doc.md +0 -240
  419. package/dist/content/content/templates/feature.md +0 -88
  420. package/dist/content/content/templates/historia-backend.md +0 -84
  421. package/dist/content/content/templates/historia-frontend.md +0 -75
  422. package/dist/content/content/templates/historia-usuario.md +0 -125
  423. package/dist/content/content/templates/mapa-navegacao.md +0 -133
  424. package/dist/content/content/templates/matriz-rastreabilidade.md +0 -121
  425. package/dist/content/content/templates/modelo-dominio.md +0 -219
  426. package/dist/content/content/templates/plano-testes.md +0 -199
  427. package/dist/content/content/templates/prototipo-stitch.md +0 -138
  428. package/dist/content/content/templates/requisitos.md +0 -162
  429. package/dist/content/content/templates/slo-sli.md +0 -197
  430. package/dist/content/content/workflows/README-MCP.md +0 -363
  431. package/dist/content/content/workflows/brainstorm.md +0 -113
  432. package/dist/content/content/workflows/create.md +0 -59
  433. package/dist/content/content/workflows/debug.md +0 -103
  434. package/dist/content/content/workflows/deploy.md +0 -176
  435. package/dist/content/content/workflows/enhance.md +0 -63
  436. package/dist/content/content/workflows/mcp-debug.md +0 -506
  437. package/dist/content/content/workflows/mcp-feature.md +0 -385
  438. package/dist/content/content/workflows/mcp-gate.md +0 -413
  439. package/dist/content/content/workflows/mcp-next.md +0 -388
  440. package/dist/content/content/workflows/mcp-refactor.md +0 -600
  441. package/dist/content/content/workflows/mcp-start.md +0 -304
  442. package/dist/content/content/workflows/mcp-status.md +0 -400
  443. package/dist/content/content/workflows/orchestrate.md +0 -237
  444. package/dist/content/content/workflows/plan.md +0 -89
  445. package/dist/content/content/workflows/preview.md +0 -81
  446. package/dist/content/content/workflows/status.md +0 -86
  447. package/dist/content/content/workflows/test.md +0 -144
  448. package/dist/content/content/workflows/ui-ux-pro-max.md +0 -296
@@ -1,670 +0,0 @@
1
- #!/usr/bin/env python3
2
- """
3
- Mobile UX Audit Script - Full Mobile Design Coverage
4
-
5
- Analyzes React Native / Flutter code for compliance with:
6
-
7
- 1. TOUCH PSYCHOLOGY (touch-psychology.md):
8
- - Touch Target Sizes (44pt iOS, 48dp Android, 44px WCAG)
9
- - Touch Target Spacing (8px minimum gap)
10
- - Thumb Zone Placement (primary CTAs at bottom)
11
- - Gesture Alternatives (visible buttons for swipe)
12
- - Haptic Feedback Patterns
13
- - Touch Feedback Timing (<50ms)
14
- - Touch Accessibility (motor impairment support)
15
-
16
- 2. MOBILE PERFORMANCE (mobile-performance.md):
17
- - ScrollView vs FlatList (CRITICAL)
18
- - React.memo for List Items
19
- - useCallback for renderItem
20
- - Stable keyExtractor (NOT index)
21
- - useNativeDriver for Animations
22
- - Memory Leak Prevention (cleanup)
23
- - Console.log Detection
24
- - Inline Function Detection
25
- - Animation Performance (transform/opacity only)
26
-
27
- 3. MOBILE NAVIGATION (mobile-navigation.md):
28
- - Tab Bar Max Items (5)
29
- - Tab State Preservation
30
- - Proper Back Handling
31
- - Deep Link Support
32
- - Navigation Structure
33
-
34
- 4. MOBILE TYPOGRAPHY (mobile-typography.md):
35
- - System Font Usage
36
- - Dynamic Type Support (iOS)
37
- - Text Scaling Constraints
38
- - Mobile Line Height
39
- - Font Size Limits
40
-
41
- 5. MOBILE COLOR SYSTEM (mobile-color-system.md):
42
- - Pure Black Avoidance (#000000)
43
- - OLED Optimization
44
- - Dark Mode Support
45
- - Contrast Ratios
46
-
47
- 6. PLATFORM iOS (platform-ios.md):
48
- - SF Symbols Usage
49
- - iOS Navigation Patterns
50
- - iOS Haptic Types
51
- - iOS-Specific Components
52
-
53
- 7. PLATFORM ANDROID (platform-android.md):
54
- - Material Icons Usage
55
- - Android Navigation Patterns
56
- - Ripple Effects
57
- - Android-Specific Components
58
-
59
- 8. MOBILE BACKEND (mobile-backend.md):
60
- - Secure Storage (NOT AsyncStorage)
61
- - Offline Handling
62
- - Push Notification Support
63
- - API Response Caching
64
-
65
- Total: 50+ mobile-specific checks
66
- """
67
-
68
- import sys
69
- import os
70
- import re
71
- import json
72
- from pathlib import Path
73
-
74
- class MobileAuditor:
75
- def __init__(self):
76
- self.issues = []
77
- self.warnings = []
78
- self.passed_count = 0
79
- self.files_checked = 0
80
-
81
- def audit_file(self, filepath: str) -> None:
82
- try:
83
- with open(filepath, 'r', encoding='utf-8', errors='replace') as f:
84
- content = f.read()
85
- except:
86
- return
87
-
88
- self.files_checked += 1
89
- filename = os.path.basename(filepath)
90
-
91
- # Detect framework
92
- is_react_native = bool(re.search(r'react-native|@react-navigation|React\.Native', content))
93
- is_flutter = bool(re.search(r'import \'package:flutter|MaterialApp|Widget\.build', content))
94
-
95
- if not (is_react_native or is_flutter):
96
- return # Skip non-mobile files
97
-
98
- # --- 1. TOUCH PSYCHOLOGY CHECKS ---
99
-
100
- # 1.1 Touch Target Size Check
101
- # Look for small touch targets
102
- small_sizes = re.findall(r'(?:width|height|size):\s*([0-3]\d)', content)
103
- for size in small_sizes:
104
- if int(size) < 44:
105
- self.issues.append(f"[Touch Target] {filename}: Touch target size {size}px < 44px minimum (iOS: 44pt, Android: 48dp)")
106
-
107
- # 1.2 Touch Target Spacing Check
108
- # Look for inadequate spacing between touchable elements
109
- small_gaps = re.findall(r'(?:margin|gap):\s*([0-7])\s*(?:px|dp)', content)
110
- for gap in small_gaps:
111
- if int(gap) < 8:
112
- self.warnings.append(f"[Touch Spacing] {filename}: Touch target spacing {gap}px < 8px minimum. Accidental taps risk.")
113
-
114
- # 1.3 Thumb Zone Placement Check
115
- # Primary CTAs should be at bottom (easy thumb reach)
116
- primary_buttons = re.findall(r'(?:testID|id):\s*["\'](?:.*(?:primary|cta|submit|confirm)[^"\']*)["\']', content, re.IGNORECASE)
117
- has_bottom_placement = bool(re.search(r'position:\s*["\']?absolute["\']?|bottom:\s*\d+|style.*bottom|justifyContent:\s*["\']?flex-end', content))
118
- if primary_buttons and not has_bottom_placement:
119
- self.warnings.append(f"[Thumb Zone] {filename}: Primary CTA may not be in thumb zone (bottom). Place primary actions at bottom for easy reach.")
120
-
121
- # 1.4 Gesture Alternatives Check
122
- # Swipe actions should have visible button alternatives
123
- has_swipe_gestures = bool(re.search(r'Swipeable|onSwipe|PanGestureHandler|swipe', content))
124
- has_visible_buttons = bool(re.search(r'Button.*(?:delete|archive|more)|TouchableOpacity|Pressable', content))
125
- if has_swipe_gestures and not has_visible_buttons:
126
- self.warnings.append(f"[Gestures] {filename}: Swipe gestures detected without visible button alternatives. Motor impaired users need alternatives.")
127
-
128
- # 1.5 Haptic Feedback Check
129
- # Important actions should have haptic feedback
130
- has_important_actions = bool(re.search(r'(?:onPress|onSubmit|delete|remove|confirm|purchase)', content))
131
- has_haptics = bool(re.search(r'Haptics|Vibration|react-native-haptic-feedback|FeedbackManager', content))
132
- if has_important_actions and not has_haptics:
133
- self.warnings.append(f"[Haptics] {filename}: Important actions without haptic feedback. Consider adding haptic confirmation.")
134
-
135
- # 1.6 Touch Feedback Timing Check
136
- # Touch feedback should be immediate (<50ms)
137
- if is_react_native:
138
- has_pressable = bool(re.search(r'Pressable|TouchableOpacity', content))
139
- has_feedback_state = bool(re.search(r'pressed|style.*opacity|underlay', content))
140
- if has_pressable and not has_feedback_state:
141
- self.warnings.append(f"[Touch Feedback] {filename}: Pressable without visual feedback state. Add opacity/scale change for tap confirmation.")
142
-
143
- # --- 2. MOBILE PERFORMANCE CHECKS ---
144
-
145
- # 2.1 CRITICAL: ScrollView vs FlatList
146
- has_scrollview = bool(re.search(r'<ScrollView|ScrollView\.', content))
147
- has_map_in_scrollview = bool(re.search(r'ScrollView.*\.map\(|ScrollView.*\{.*\.map', content))
148
- if has_scrollview and has_map_in_scrollview:
149
- self.issues.append(f"[Performance CRITICAL] {filename}: ScrollView with .map() detected. Use FlatList for lists to prevent memory explosion.")
150
-
151
- # 2.2 React.memo Check
152
- if is_react_native:
153
- has_list = bool(re.search(r'FlatList|FlashList|SectionList', content))
154
- has_react_memo = bool(re.search(r'React\.memo|memo\(', content))
155
- if has_list and not has_react_memo:
156
- self.warnings.append(f"[Performance] {filename}: FlatList without React.memo on list items. Items will re-render on every parent update.")
157
-
158
- # 2.3 useCallback Check
159
- if is_react_native:
160
- has_flatlist = bool(re.search(r'FlatList|FlashList', content))
161
- has_use_callback = bool(re.search(r'useCallback', content))
162
- if has_flatlist and not has_use_callback:
163
- self.warnings.append(f"[Performance] {filename}: FlatList renderItem without useCallback. New function created every render.")
164
-
165
- # 2.4 keyExtractor Check (CRITICAL)
166
- if is_react_native:
167
- has_flatlist = bool(re.search(r'FlatList', content))
168
- has_key_extractor = bool(re.search(r'keyExtractor', content))
169
- uses_index_key = bool(re.search(r'key=\{.*index.*\}|key:\s*index', content))
170
- if has_flatlist and not has_key_extractor:
171
- self.issues.append(f"[Performance CRITICAL] {filename}: FlatList without keyExtractor. Index-based keys cause bugs on reorder/delete.")
172
- if uses_index_key:
173
- self.issues.append(f"[Performance CRITICAL] {filename}: Using index as key. This causes bugs when list changes. Use unique ID from data.")
174
-
175
- # 2.5 useNativeDriver Check
176
- if is_react_native:
177
- has_animated = bool(re.search(r'Animated\.', content))
178
- has_native_driver = bool(re.search(r'useNativeDriver:\s*true', content))
179
- has_native_driver_false = bool(re.search(r'useNativeDriver:\s*false', content))
180
- if has_animated and has_native_driver_false:
181
- self.warnings.append(f"[Performance] {filename}: Animation with useNativeDriver: false. Use true for 60fps (only supports transform/opacity).")
182
- if has_animated and not has_native_driver:
183
- self.warnings.append(f"[Performance] {filename}: Animated component without useNativeDriver. Add useNativeDriver: true for 60fps.")
184
-
185
- # 2.6 Memory Leak Check
186
- if is_react_native:
187
- has_effect = bool(re.search(r'useEffect', content))
188
- has_cleanup = bool(re.search(r'return\s*\(\)\s*=>|return\s+function', content))
189
- has_subscriptions = bool(re.search(r'addEventListener|subscribe|\.focus\(\)|\.off\(', content))
190
- if has_effect and has_subscriptions and not has_cleanup:
191
- self.issues.append(f"[Memory Leak] {filename}: useEffect with subscriptions but no cleanup function. Memory leak on unmount.")
192
-
193
- # 2.7 Console.log Detection
194
- console_logs = len(re.findall(r'console\.log|console\.warn|console\.error|console\.debug', content))
195
- if console_logs > 5:
196
- self.warnings.append(f"[Performance] {filename}: {console_logs} console.log statements detected. Remove before production (blocks JS thread).")
197
-
198
- # 2.8 Inline Function Detection
199
- if is_react_native:
200
- inline_functions = re.findall(r'(?:onPress|onPressIn|onPressOut|renderItem):\s*\([^)]*\)\s*=>', content)
201
- if len(inline_functions) > 3:
202
- self.warnings.append(f"[Performance] {filename}: {len(inline_functions)} inline arrow functions in props. Creates new function every render. Use useCallback.")
203
-
204
- # 2.9 Animation Properties Check
205
- # Warn if animating expensive properties
206
- animating_layout = bool(re.search(r'Animated\.timing.*(?:width|height|margin|padding)', content))
207
- if animating_layout:
208
- self.issues.append(f"[Performance] {filename}: Animating layout properties (width/height/margin). Use transform/opacity for 60fps.")
209
-
210
- # --- 3. MOBILE NAVIGATION CHECKS ---
211
-
212
- # 3.1 Tab Bar Max Items Check
213
- tab_bar_items = len(re.findall(r'Tab\.Screen|createBottomTabNavigator|BottomTab', content))
214
- if tab_bar_items > 5:
215
- self.warnings.append(f"[Navigation] {filename}: {tab_bar_items} tab bar items (max 5 recommended). More than 5 becomes hard to tap.")
216
-
217
- # 3.2 Tab State Preservation Check
218
- has_tab_nav = bool(re.search(r'createBottomTabNavigator|Tab\.Navigator', content))
219
- if has_tab_nav:
220
- # Look for lazy prop (false preserves state)
221
- has_lazy_false = bool(re.search(r'lazy:\s*false', content))
222
- if not has_lazy_false:
223
- self.warnings.append(f"[Navigation] {filename}: Tab navigation without lazy: false. Tabs may lose state on switch.")
224
-
225
- # 3.3 Back Handling Check
226
- has_back_listener = bool(re.search(r'BackHandler|useFocusEffect|navigation\.addListener', content))
227
- has_custom_back = bool(re.search(r'onBackPress|handleBackPress', content))
228
- if has_custom_back and not has_back_listener:
229
- self.warnings.append(f"[Navigation] {filename}: Custom back handling without BackHandler listener. May not work correctly.")
230
-
231
- # 3.4 Deep Link Support Check
232
- has_linking = bool(re.search(r'Linking\.|Linking\.openURL|deepLink|universalLink', content))
233
- has_config = bool(re.search(r'apollo-link|react-native-screens|navigation\.link', content))
234
- if not has_linking and not has_config:
235
- self.passed_count += 1
236
- else:
237
- if has_linking and not has_config:
238
- self.warnings.append(f"[Navigation] {filename}: Deep linking detected but may lack proper configuration. Test notification/share flows.")
239
-
240
- # --- 4. MOBILE TYPOGRAPHY CHECKS ---
241
-
242
- # 4.1 System Font Check
243
- if is_react_native:
244
- has_custom_font = bool(re.search(r"fontFamily:\s*[\"'][^\"']+", content))
245
- has_system_font = bool(re.search(r"fontFamily:\s*[\"']?(?:System|San Francisco|Roboto|-apple-system)", content))
246
- if has_custom_font and not has_system_font:
247
- self.warnings.append(f"[Typography] {filename}: Custom font detected. Consider system fonts (iOS: SF Pro, Android: Roboto) for native feel.")
248
-
249
- # 4.2 Text Scaling Check (iOS Dynamic Type)
250
- if is_react_native:
251
- has_font_sizes = bool(re.search(r'fontSize:', content))
252
- has_scaling = bool(re.search(r'allowFontScaling:\s*true|responsiveFontSize|useWindowDimensions', content))
253
- if has_font_sizes and not has_scaling:
254
- self.warnings.append(f"[Typography] {filename}: Fixed font sizes without scaling support. Consider allowFontScaling for accessibility.")
255
-
256
- # 4.3 Mobile Line Height Check
257
- line_heights = re.findall(r'lineHeight:\s*([\d.]+)', content)
258
- for lh in line_heights:
259
- if float(lh) > 1.8:
260
- self.warnings.append(f"[Typography] {filename}: lineHeight {lh} too high for mobile. Mobile text needs tighter spacing (1.3-1.5).")
261
-
262
- # 4.4 Font Size Limits
263
- font_sizes = re.findall(r'fontSize:\s*([\d.]+)', content)
264
- for fs in font_sizes:
265
- size = float(fs)
266
- if size < 12:
267
- self.warnings.append(f"[Typography] {filename}: fontSize {size}px below 12px minimum readability.")
268
- elif size > 32:
269
- self.warnings.append(f"[Typography] {filename}: fontSize {size}px very large. Consider using responsive scaling.")
270
-
271
- # --- 5. MOBILE COLOR SYSTEM CHECKS ---
272
-
273
- # 5.1 Pure Black Avoidance
274
- if re.search(r'#000000|color:\s*black|backgroundColor:\s*["\']?black', content):
275
- self.warnings.append(f"[Color] {filename}: Pure black (#000000) detected. Use dark gray (#1C1C1E iOS, #121212 Android) for better OLED/battery.")
276
-
277
- # 5.2 Dark Mode Support
278
- has_color_schemes = bool(re.search(r'useColorScheme|colorScheme|appearance:\s*["\']?dark', content))
279
- has_dark_mode_style = bool(re.search(r'\\\?.*dark|style:\s*.*dark|isDark', content))
280
- if not has_color_schemes and not has_dark_mode_style:
281
- self.warnings.append(f"[Color] {filename}: No dark mode support detected. Consider useColorScheme for system dark mode.")
282
-
283
- # --- 6. PLATFORM iOS CHECKS ---
284
-
285
- if is_react_native:
286
- # 6.1 SF Symbols Check
287
- has_ios_icons = bool(re.search(r'@expo/vector-icons|ionicons', content))
288
- has_sf_symbols = bool(re.search(r'sf-symbol|SF Symbols', content))
289
- if has_ios_icons and not has_sf_symbols:
290
- self.passed_count += 1
291
-
292
- # 6.2 iOS Haptic Types
293
- has_haptic_import = bool(re.search(r'expo-haptics|react-native-haptic-feedback', content))
294
- has_haptic_types = bool(re.search(r'ImpactFeedback|NotificationFeedback|SelectionFeedback', content))
295
- if has_haptic_import and not has_haptic_types:
296
- self.warnings.append(f"[iOS Haptics] {filename}: Haptic library imported but not using typed haptics (Impact/Notification/Selection).")
297
-
298
- # 6.3 iOS Safe Area
299
- has_safe_area = bool(re.search(r'SafeAreaView|useSafeAreaInsets|safeArea', content))
300
- if not has_safe_area:
301
- self.warnings.append(f"[iOS] {filename}: No SafeArea detected. Content may be hidden by notch/home indicator.")
302
-
303
- # --- 7. PLATFORM ANDROID CHECKS ---
304
-
305
- if is_react_native:
306
- # 7.1 Material Icons Check
307
- has_material_icons = bool(re.search(r'@expo/vector-icons|MaterialIcons', content))
308
- if has_material_icons:
309
- self.passed_count += 1
310
-
311
- # 7.2 Ripple Effect
312
- has_ripple = bool(re.search(r'ripple|android_ripple|foregroundRipple', content))
313
- has_pressable = bool(re.search(r'Pressable|Touchable', content))
314
- if has_pressable and not has_ripple:
315
- self.warnings.append(f"[Android] {filename}: Touchable without ripple effect. Android users expect ripple feedback.")
316
-
317
- # 7.3 Hardware Back Button
318
- if is_react_native:
319
- has_back_button = bool(re.search(r'BackHandler|useBackHandler', content))
320
- has_navigation = bool(re.search(r'@react-navigation', content))
321
- if has_navigation and not has_back_button:
322
- self.warnings.append(f"[Android] {filename}: React Navigation detected without BackHandler listener. Android hardware back may not work correctly.")
323
-
324
- # --- 8. MOBILE BACKEND CHECKS ---
325
-
326
- # 8.1 Secure Storage Check
327
- has_async_storage = bool(re.search(r'AsyncStorage|@react-native-async-storage', content))
328
- has_secure_storage = bool(re.search(r'SecureStore|Keychain|EncryptedSharedPreferences', content))
329
- has_token_storage = bool(re.search(r'token|jwt|auth.*storage', content, re.IGNORECASE))
330
- if has_token_storage and has_async_storage and not has_secure_storage:
331
- self.issues.append(f"[Security] {filename}: Storing auth tokens in AsyncStorage (insecure). Use SecureStore (iOS) / EncryptedSharedPreferences (Android).")
332
-
333
- # 8.2 Offline Handling Check
334
- has_network = bool(re.search(r'fetch|axios|netinfo|@react-native-community/netinfo', content))
335
- has_offline = bool(re.search(r'offline|isConnected|netInfo|cache.*offline', content))
336
- if has_network and not has_offline:
337
- self.warnings.append(f"[Offline] {filename}: Network requests detected without offline handling. Consider NetInfo for connection status.")
338
-
339
- # 8.3 Push Notification Support
340
- has_push = bool(re.search(r'Notifications|pushNotification|Firebase\.messaging|PushNotificationIOS', content))
341
- has_push_handler = bool(re.search(r'onNotification|addNotificationListener|notification\.open', content))
342
- if has_push and not has_push_handler:
343
- self.warnings.append(f"[Push] {filename}: Push notifications imported but no handler found. May miss notifications.")
344
-
345
- # --- 9. EXTENDED MOBILE TYPOGRAPHY CHECKS ---
346
-
347
- # 9.1 iOS Type Scale Check
348
- if is_react_native:
349
- # Check for iOS text styles that match HIG
350
- has_large_title = bool(re.search(r'fontSize:\s*34|largeTitle|font-weight:\s*["\']?bold', content))
351
- has_title_1 = bool(re.search(r'fontSize:\s*28', content))
352
- has_headline = bool(re.search(r'fontSize:\s*17.*semibold|headline', content))
353
- has_body = bool(re.search(r'fontSize:\s*17.*regular|body', content))
354
-
355
- # Check if following iOS scale roughly
356
- font_sizes = re.findall(r'fontSize:\s*([\d.]+)', content)
357
- ios_scale_sizes = [34, 28, 22, 20, 17, 16, 15, 13, 12, 11]
358
- matching_ios = sum(1 for size in font_sizes if any(abs(float(size) - ios_size) < 1 for ios_size in ios_scale_sizes))
359
-
360
- if len(font_sizes) > 3 and matching_ios < len(font_sizes) / 2:
361
- self.warnings.append(f"[iOS Typography] {filename}: Font sizes don't match iOS type scale. Consider iOS text styles for native feel.")
362
-
363
- # 9.2 Android Material Type Scale Check
364
- if is_react_native:
365
- # Check for Material 3 text styles
366
- has_display = bool(re.search(r'fontSize:\s*[456][0-9]|display', content))
367
- has_headline_material = bool(re.search(r'fontSize:\s*[23][0-9]|headline', content))
368
- has_title_material = bool(re.search(r'fontSize:\s*2[12][0-9].*medium|title', content))
369
- has_body_material = bool(re.search(r'fontSize:\s*1[456].*regular|body', content))
370
- has_label = bool(re.search(r'fontSize:\s*1[1234].*medium|label', content))
371
-
372
- # Check if using sp (scale-independent pixels)
373
- uses_sp = bool(re.search(r'\d+\s*sp\b', content))
374
- if has_display or has_headline_material:
375
- if not uses_sp:
376
- self.warnings.append(f"[Android Typography] {filename}: Material typography detected without sp units. Use sp for text to respect user font size preferences.")
377
-
378
- # 9.3 Modular Scale Check
379
- # Check if font sizes follow modular scale
380
- font_sizes = re.findall(r'fontSize:\s*(\d+(?:\.\d+)?)', content)
381
- if len(font_sizes) > 3:
382
- sorted_sizes = sorted(set([float(s) for s in font_sizes]))
383
- ratios = []
384
- for i in range(1, len(sorted_sizes)):
385
- if sorted_sizes[i-1] > 0:
386
- ratios.append(sorted_sizes[i] / sorted_sizes[i-1])
387
-
388
- # Common ratios: 1.125, 1.2, 1.25, 1.333, 1.5
389
- common_ratios = {1.125, 1.2, 1.25, 1.333, 1.5}
390
- for ratio in ratios[:3]:
391
- if not any(abs(ratio - cr) < 0.03 for cr in common_ratios):
392
- self.warnings.append(f"[Typography] {filename}: Font sizes may not follow modular scale (ratio: {ratio:.2f}). Consider consistent ratio.")
393
- break
394
-
395
- # 9.4 Line Length Check (Mobile-specific)
396
- # Mobile text should be 40-60 characters max
397
- if is_react_native:
398
- has_long_text = bool(re.search(r'<Text[^>]*>[^<]{40,}', content))
399
- has_max_width = bool(re.search(r'maxWidth|max-w-\d+|width:\s*["\']?\d+', content))
400
- if has_long_text and not has_max_width:
401
- self.warnings.append(f"[Mobile Typography] {filename}: Text without max-width constraint. Mobile text should be 40-60 characters per line for readability.")
402
-
403
- # 9.5 Font Weight Pattern Check
404
- # Check for font weight distribution
405
- if is_react_native:
406
- font_weights = re.findall(r'fontWeight:\s*["\']?(\d+|normal|bold|medium|light)', content)
407
- weight_map = {'normal': '400', 'light': '300', 'medium': '500', 'bold': '700'}
408
- numeric_weights = []
409
- for w in font_weights:
410
- val = weight_map.get(w.lower(), w)
411
- try:
412
- numeric_weights.append(int(val))
413
- except:
414
- pass
415
-
416
- # Check if overusing bold (mobile should be regular-dominant)
417
- bold_count = sum(1 for w in numeric_weights if w >= 700)
418
- regular_count = sum(1 for w in numeric_weights if 400 <= w < 500)
419
- if bold_count > regular_count:
420
- self.warnings.append(f"[Mobile Typography] {filename}: More bold weights than regular. Mobile typography should be regular-dominant for readability.")
421
-
422
- # --- 10. EXTENDED MOBILE COLOR SYSTEM CHECKS ---
423
-
424
- # 10.1 OLED Optimization Check
425
- # Check for near-black colors instead of pure black
426
- if re.search(r'#121212|#1A1A1A|#0D0D0D', content):
427
- self.passed_count += 1 # Good OLED optimization
428
- elif re.search(r'backgroundColor:\s*["\']?#000000', content):
429
- # Using pure black for background is OK for OLED
430
- pass
431
- elif re.search(r'backgroundColor:\s*["\']?#[0-9A-Fa-f]{6}', content):
432
- # Check if using light colors in dark mode (bad for OLED)
433
- self.warnings.append(f"[Mobile Color] {filename}: Consider OLED-optimized dark backgrounds (#121212 Android, #000000 iOS) for battery savings.")
434
-
435
- # 10.2 Saturated Color Detection (Battery)
436
- # Highly saturated colors consume more power on OLED
437
- hex_colors = re.findall(r'#([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})([0-9A-Fa-f]{2})', content)
438
- saturated_count = 0
439
- for r, g, b in hex_colors:
440
- # Convert to RGB 0-255
441
- try:
442
- r_val, g_val, b_val = int(r, 16), int(g, 16), int(b, 16)
443
- max_val = max(r_val, g_val, b_val)
444
- min_val = min(r_val, g_val, b_val)
445
- # Saturation = (max - min) / max
446
- if max_val > 0:
447
- saturation = (max_val - min_val) / max_val
448
- if saturation > 0.8: # Highly saturated
449
- saturated_count += 1
450
- except:
451
- pass
452
-
453
- if saturated_count > 10:
454
- self.warnings.append(f"[Mobile Color] {filename}: {saturated_count} highly saturated colors detected. Desaturated colors save battery on OLED screens.")
455
-
456
- # 10.3 Outdoor Visibility Check
457
- # Low contrast combinations fail in outdoor sunlight
458
- light_colors = re.findall(r'#[0-9A-Fa-f]{6}|rgba?\([^)]+\)', content)
459
- # Check for potential low contrast (light gray on white, dark gray on black)
460
- potential_low_contrast = bool(re.search(r'#[EeEeEeEe].*#ffffff|#999999.*#ffffff|#333333.*#000000|#666666.*#000000', content))
461
- if potential_low_contrast:
462
- self.warnings.append(f"[Mobile Color] {filename}: Possible low contrast combination detected. Critical for outdoor visibility. Ensure WCAG AAA (7:1) for mobile.")
463
-
464
- # 10.4 Dark Mode Text Color Check
465
- # In dark mode, text should not be pure white
466
- has_dark_mode = bool(re.search(r'dark:\s*|isDark|useColorScheme|colorScheme:\s*["\']?dark', content))
467
- if has_dark_mode:
468
- has_pure_white_text = bool(re.search(r'color:\s*["\']?#ffffff|#fff["\']?\}|textColor:\s*["\']?white', content))
469
- if has_pure_white_text:
470
- self.warnings.append(f"[Mobile Color] {filename}: Pure white text (#FFFFFF) in dark mode. Use #E8E8E8 or light gray for better readability.")
471
-
472
- # --- 11. EXTENDED PLATFORM IOS CHECKS ---
473
-
474
- if is_react_native:
475
- # 11.1 SF Pro Font Detection
476
- has_sf_pro = bool(re.search(r'SF Pro|SFPro|fontFamily:\s*["\']?[-\s]*SF', content))
477
- has_custom_font = bool(re.search(r'fontFamily:\s*["\'][^"\']+', content))
478
- if has_custom_font and not has_sf_pro:
479
- self.warnings.append(f"[iOS] {filename}: Custom font without SF Pro fallback. Consider SF Pro Text for body, SF Pro Display for headings.")
480
-
481
- # 11.2 iOS System Colors Check
482
- # Check for semantic color usage
483
- has_label = bool(re.search(r'color:\s*["\']?label|\.label', content))
484
- has_secondaryLabel = bool(re.search(r'secondaryLabel|\.secondaryLabel', content))
485
- has_systemBackground = bool(re.search(r'systemBackground|\.systemBackground', content))
486
-
487
- has_hardcoded_gray = bool(re.search(r'#[78]0{4}', content))
488
- if has_hardcoded_gray and not (has_label or has_secondaryLabel):
489
- self.warnings.append(f"[iOS] {filename}: Hardcoded gray colors detected. Consider iOS semantic colors (label, secondaryLabel) for automatic dark mode.")
490
-
491
- # 11.3 iOS Accent Colors Check
492
- ios_blue = bool(re.search(r'#007AFF|#0A84FF|systemBlue', content))
493
- ios_green = bool(re.search(r'#34C759|#30D158|systemGreen', content))
494
- ios_red = bool(re.search(r'#FF3B30|#FF453A|systemRed', content))
495
-
496
- has_custom_primary = bool(re.search(r'primaryColor|theme.*primary|colors\.primary', content))
497
- if has_custom_primary and not (ios_blue or ios_green or ios_red):
498
- self.warnings.append(f"[iOS] {filename}: Custom primary color without iOS system color fallback. Consider systemBlue for consistent iOS feel.")
499
-
500
- # 11.4 iOS Navigation Patterns Check
501
- has_navigation_bar = bool(re.search(r'navigationOptions|headerStyle|cardStyle', content))
502
- has_header_title = bool(re.search(r'title:\s*["\']|headerTitle|navigation\.setOptions', content))
503
- if has_navigation_bar and not has_header_title:
504
- self.warnings.append(f"[iOS] {filename}: Navigation bar detected without title. iOS apps should have clear context in nav bar.")
505
-
506
- # 11.5 iOS Component Patterns Check
507
- # Check for iOS-specific components
508
- has_alert = bool(re.search(r'Alert\.alert|showAlert', content))
509
- has_action_sheet = bool(re.search(r'ActionSheet|ActionSheetIOS|showActionSheetWithOptions', content))
510
- has_activity_indicator = bool(re.search(r'ActivityIndicator|ActivityIndic', content))
511
-
512
- if has_alert or has_action_sheet or has_activity_indicator:
513
- self.passed_count += 1 # Good iOS component usage
514
-
515
- # --- 12. EXTENDED PLATFORM ANDROID CHECKS ---
516
-
517
- if is_react_native:
518
- # 12.1 Roboto Font Detection
519
- has_roboto = bool(re.search(r'Roboto|fontFamily:\s*["\']?[-\s]*Roboto', content))
520
- has_custom_font = bool(re.search(r'fontFamily:\s*["\'][^"\']+', content))
521
- if has_custom_font and not has_roboto:
522
- self.warnings.append(f"[Android] {filename}: Custom font without Roboto fallback. Roboto is optimized for Android displays.")
523
-
524
- # 12.2 Material 3 Dynamic Color Check
525
- has_material_colors = bool(re.search(r'MD3|MaterialYou|dynamicColor|useColorScheme', content))
526
- has_theme_provider = bool(re.search(r'MaterialTheme|ThemeProvider|PaperProvider|ThemeProvider', content))
527
- if not has_material_colors and not has_theme_provider:
528
- self.warnings.append(f"[Android] {filename}: No Material 3 dynamic color detected. Consider Material 3 theming for personalized feel.")
529
-
530
- # 12.3 Material Elevation Check
531
- # Check for elevation values (Material 3 uses elevation for depth)
532
- has_elevation = bool(re.search(r'elevation:\s*\d+|shadowOpacity|shadowRadius|android:elevation', content))
533
- has_box_shadow = bool(re.search(r'boxShadow:', content))
534
- if has_box_shadow and not has_elevation:
535
- self.warnings.append(f"[Android] {filename}: CSS box-shadow detected without elevation. Consider Material elevation system for consistent depth.")
536
-
537
- # 12.4 Material Component Patterns Check
538
- # Check for Material components
539
- has_ripple = bool(re.search(r'ripple|android_ripple|foregroundRipple', content))
540
- has_card = bool(re.search(r'Card|Paper|elevation.*\d+', content))
541
- has_fab = bool(re.search(r'FAB|FloatingActionButton|fab', content))
542
- has_snackbar = bool(re.search(r'Snackbar|showSnackBar|Toast', content))
543
-
544
- material_component_count = sum([has_ripple, has_card, has_fab, has_snackbar])
545
- if material_component_count >= 2:
546
- self.passed_count += 1 # Good Material design usage
547
-
548
- # 12.5 Android Navigation Patterns Check
549
- has_top_app_bar = bool(re.search(r'TopAppBar|AppBar|CollapsingToolbar', content))
550
- has_bottom_nav = bool(re.search(r'BottomNavigation|BottomNav', content))
551
- has_navigation_rail = bool(re.search(r'NavigationRail', content))
552
-
553
- if has_bottom_nav:
554
- self.passed_count += 1 # Good Android pattern
555
- elif has_top_app_bar and not (has_bottom_nav or has_navigation_rail):
556
- self.warnings.append(f"[Android] {filename}: TopAppBar without bottom navigation. Consider BottomNavigation for thumb-friendly access.")
557
-
558
- # --- 13. MOBILE TESTING CHECKS ---
559
-
560
- # 13.1 Testing Tool Detection
561
- has_rntl = bool(re.search(r'react-native-testing-library|@testing-library', content))
562
- has_detox = bool(re.search(r'detox|element\(|by\.text|by\.id', content))
563
- has_maestro = bool(re.search(r'maestro|\.yaml$', content))
564
- has_jest = bool(re.search(r'jest|describe\(|test\(|it\(', content))
565
-
566
- testing_tools = []
567
- if has_jest: testing_tools.append('Jest')
568
- if has_rntl: testing_tools.append('RNTL')
569
- if has_detox: testing_tools.append('Detox')
570
- if has_maestro: testing_tools.append('Maestro')
571
-
572
- if len(testing_tools) == 0:
573
- self.warnings.append(f"[Testing] {filename}: No testing framework detected. Consider Jest (unit) + Detox/Maestro (E2E) for mobile.")
574
-
575
- # 13.2 Test Pyramid Balance Check
576
- test_files = len(re.findall(r'\.test\.(tsx|ts|js|jsx)|\.spec\.', content))
577
- e2e_tests = len(re.findall(r'detox|maestro|e2e|spec\.e2e', content.lower()))
578
-
579
- if test_files > 0 and e2e_tests == 0:
580
- self.warnings.append(f"[Testing] {filename}: Unit tests found but no E2E tests. Mobile needs E2E on real devices for complete coverage.")
581
-
582
- # 13.3 Accessibility Label Check (Mobile-specific)
583
- if is_react_native:
584
- has_pressable = bool(re.search(r'Pressable|TouchableOpacity|TouchableHighlight', content))
585
- has_a11y_label = bool(re.search(r'accessibilityLabel|aria-label|testID', content))
586
- if has_pressable and not has_a11y_label:
587
- self.warnings.append(f"[A11y Mobile] {filename}: Touchable element without accessibilityLabel. Screen readers need labels for all interactive elements.")
588
-
589
- # --- 14. MOBILE DEBUGGING CHECKS ---
590
-
591
- # 14.1 Performance Profiling Check
592
- has_performance = bool(re.search(r'Performance|systrace|profile|Flipper', content))
593
- has_console_log = len(re.findall(r'console\.(log|warn|error|debug|info)', content))
594
- has_debugger = bool(re.search(r'debugger|__DEV__|React\.DevTools', content))
595
-
596
- if has_console_log > 10:
597
- self.warnings.append(f"[Debugging] {filename}: {has_console_log} console.log statements. Remove before production; they block JS thread.")
598
-
599
- if has_performance:
600
- self.passed_count += 1 # Good performance monitoring
601
-
602
- # 14.2 Error Boundary Check
603
- has_error_boundary = bool(re.search(r'ErrorBoundary|componentDidCatch|getDerivedStateFromError', content))
604
- if not has_error_boundary and is_react_native:
605
- self.warnings.append(f"[Debugging] {filename}: No ErrorBoundary detected. Consider adding ErrorBoundary to prevent app crashes.")
606
-
607
- # 14.3 Hermes Check (React Native specific)
608
- if is_react_native:
609
- # Check if using Hermes engine (should be default in modern RN)
610
- # This is more of a configuration check, not code pattern
611
- self.passed_count += 1 # Hermes is default in RN 0.70+
612
-
613
- def audit_directory(self, directory: str) -> None:
614
- extensions = {'.tsx', '.ts', '.jsx', '.js', '.dart'}
615
- for root, dirs, files in os.walk(directory):
616
- dirs[:] = [d for d in dirs if d not in {'node_modules', '.git', 'dist', 'build', '.next', 'ios', 'android', 'build', '.idea'}]
617
- for file in files:
618
- if Path(file).suffix in extensions:
619
- self.audit_file(os.path.join(root, file))
620
-
621
- def get_report(self):
622
- return {
623
- "files_checked": self.files_checked,
624
- "issues": self.issues,
625
- "warnings": self.warnings,
626
- "passed_checks": self.passed_count,
627
- "compliant": len(self.issues) == 0
628
- }
629
-
630
-
631
- def main():
632
- if len(sys.argv) < 2:
633
- print("Usage: python mobile_audit.py <directory>")
634
- sys.exit(1)
635
-
636
- path = sys.argv[1]
637
- is_json = "--json" in sys.argv
638
-
639
- auditor = MobileAuditor()
640
- if os.path.isfile(path):
641
- auditor.audit_file(path)
642
- else:
643
- auditor.audit_directory(path)
644
-
645
- report = auditor.get_report()
646
-
647
- if is_json:
648
- print(json.dumps(report, indent=2))
649
- else:
650
- print(f"\n[MOBILE AUDIT] {report['files_checked']} mobile files checked")
651
- print("-" * 50)
652
- if report['issues']:
653
- print(f"[!] ISSUES ({len(report['issues'])}):")
654
- for i in report['issues'][:10]:
655
- print(f" - {i}")
656
- if report['warnings']:
657
- print(f"[*] WARNINGS ({len(report['warnings'])}):")
658
- for w in report['warnings'][:15]:
659
- print(f" - {w}")
660
- print(f"[+] PASSED CHECKS: {report['passed_checks']}")
661
- status = "PASS" if report['compliant'] else "FAIL"
662
- print(f"STATUS: {status}")
663
-
664
- sys.exit(0 if report['compliant'] else 1)
665
-
666
-
667
- if __name__ == "__main__":
668
- # Fix missing import
669
- import re
670
- main()