rosett-ai 1.3.3

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 (527) hide show
  1. checksums.yaml +7 -0
  2. data/.ai-provenance.yml +119 -0
  3. data/.debride_whitelist +186 -0
  4. data/.fasterer.yml +29 -0
  5. data/.mdl_style.rb +10 -0
  6. data/.mdlrc +3 -0
  7. data/.mutant.yml +49 -0
  8. data/.namespace-allowlist +42 -0
  9. data/.reek.yml +1040 -0
  10. data/.rosett-ai/config.yml +3 -0
  11. data/.rspec +5 -0
  12. data/.rubocop.yml +380 -0
  13. data/.ruby-version +1 -0
  14. data/.yamllint +51 -0
  15. data/.yardopts +12 -0
  16. data/AI-DISCLOSURE.md +48 -0
  17. data/CHANGELOG.md +519 -0
  18. data/CLAUDE.md +141 -0
  19. data/CONTRIBUTING.md +734 -0
  20. data/INSTALL.md +154 -0
  21. data/LICENSE +674 -0
  22. data/LICENSE.md +675 -0
  23. data/QUICKSTART.md +73 -0
  24. data/README.md +366 -0
  25. data/Rakefile +200 -0
  26. data/SECURITY.md +114 -0
  27. data/bin/rai +1 -0
  28. data/cliff.toml +52 -0
  29. data/conf/adopt_redactions.yml +8 -0
  30. data/conf/behaviour/.gitkeep +0 -0
  31. data/conf/compliance/cra_rules.yml +25 -0
  32. data/conf/compliance/license_rules.yml +20 -0
  33. data/conf/design/aaif_alignment.yml +181 -0
  34. data/conf/design/ab_testing.yml +172 -0
  35. data/conf/design/accessibility.yml +84 -0
  36. data/conf/design/ai_authorship.yml +210 -0
  37. data/conf/design/ai_provenance.yml +224 -0
  38. data/conf/design/ai_tool_configuration.yml +207 -0
  39. data/conf/design/architecture.yml +139 -0
  40. data/conf/design/autocompletion.yml +115 -0
  41. data/conf/design/backward_compatibility.yml +112 -0
  42. data/conf/design/behaviour_composition.yml +246 -0
  43. data/conf/design/build_rake_extraction.yml +57 -0
  44. data/conf/design/ci_pipeline.yml +100 -0
  45. data/conf/design/claude_code_configuration.yml +157 -0
  46. data/conf/design/compiler.yml +128 -0
  47. data/conf/design/comply.yml +153 -0
  48. data/conf/design/content_packs.yml +84 -0
  49. data/conf/design/desktop_integration.yml +289 -0
  50. data/conf/design/distribution.yml +216 -0
  51. data/conf/design/doctor.yml +184 -0
  52. data/conf/design/documentation.yml +152 -0
  53. data/conf/design/engine_architecture.yml +257 -0
  54. data/conf/design/error_handling.yml +103 -0
  55. data/conf/design/feature_flags.yml +142 -0
  56. data/conf/design/git_hooks.yml +165 -0
  57. data/conf/design/gui_plugins.yml +475 -0
  58. data/conf/design/i18n.yml +84 -0
  59. data/conf/design/integration_testing.yml +56 -0
  60. data/conf/design/licensing_system.yml +88 -0
  61. data/conf/design/lifecycle_management.yml +208 -0
  62. data/conf/design/mcp_integration.yml +207 -0
  63. data/conf/design/mcp_settings.yml +126 -0
  64. data/conf/design/migration.yml +56 -0
  65. data/conf/design/monitoring_observability.yml +194 -0
  66. data/conf/design/namespace_cleanup.yml +145 -0
  67. data/conf/design/plugin_test_segregation.yml +145 -0
  68. data/conf/design/policy_management.yml +229 -0
  69. data/conf/design/project_management.yml +183 -0
  70. data/conf/design/rai_mcp_asset_discovery.yml +164 -0
  71. data/conf/design/rai_mcp_server.yml +605 -0
  72. data/conf/design/release_management.yml +117 -0
  73. data/conf/design/retrofit.yml +199 -0
  74. data/conf/design/retrospective_analyzer.yml +79 -0
  75. data/conf/design/scope_hierarchy.yml +352 -0
  76. data/conf/design/security.yml +115 -0
  77. data/conf/design/session_retrospective.yml +85 -0
  78. data/conf/design/smart_ui_feedback.yml +89 -0
  79. data/conf/design/structured_logging.yml +148 -0
  80. data/conf/design/styles.yml +123 -0
  81. data/conf/design/test_peer_review.yml +89 -0
  82. data/conf/design/testing.yml +136 -0
  83. data/conf/design/threat_model.yml +108 -0
  84. data/conf/design/ui_framework.yml +111 -0
  85. data/conf/design/usage_optimization.yml +122 -0
  86. data/conf/design/version_management.yml +60 -0
  87. data/conf/design/workflow.yml +227 -0
  88. data/conf/mcp/server_defaults.yml +42 -0
  89. data/conf/mcp/trust.yml +21 -0
  90. data/conf/packaging/core.yml +12 -0
  91. data/conf/packaging/gtk4.yml +11 -0
  92. data/conf/packaging/qt6.yml +11 -0
  93. data/conf/policy/default_deny_list.yml +197 -0
  94. data/conf/review/cli-command-audit.yml +857 -0
  95. data/conf/review/design-docs.yml +1064 -0
  96. data/conf/review/design-questionnaire.yml +153 -0
  97. data/conf/review/questionnaire.yml +146 -0
  98. data/conf/review/rosett-ai-core.yml +2919 -0
  99. data/conf/schemas/ai_config_schema.json +73 -0
  100. data/conf/schemas/behaviour_schema.json +132 -0
  101. data/conf/schemas/compliance_rule_schema.json +63 -0
  102. data/conf/schemas/content_pack_manifest_schema.json +51 -0
  103. data/conf/schemas/design_schema.json +210 -0
  104. data/conf/schemas/engine_manifest_schema.json +144 -0
  105. data/conf/schemas/lockfile_schema.json +74 -0
  106. data/conf/schemas/mcp_server_schema.json +48 -0
  107. data/conf/schemas/packaging_schema.json +70 -0
  108. data/conf/schemas/policy_schema.json +85 -0
  109. data/conf/schemas/provenance_schema.json +84 -0
  110. data/conf/schemas/rai_config_schema.json +56 -0
  111. data/conf/schemas/rai_project_schema.json +20 -0
  112. data/conf/schemas/scope_hierarchy_schema.json +49 -0
  113. data/conf/schemas/target_schema.json +67 -0
  114. data/conf/schemas/tooling_schema.json +65 -0
  115. data/conf/schemas/workflow_schema.json +112 -0
  116. data/conf/targets/agents_md.yml +17 -0
  117. data/conf/targets/claude.yml +12 -0
  118. data/conf/tooling/tools.yml +58 -0
  119. data/dist/rosett-ai-mcp.service +48 -0
  120. data/dist/rosett-ai-mcp.yml.default +45 -0
  121. data/doc/AAIF_POSITIONING.md +58 -0
  122. data/doc/ADOPT.md +224 -0
  123. data/doc/AI_PROVENANCE.md +139 -0
  124. data/doc/ARCHITECTURE.md +920 -0
  125. data/doc/BEHAVIOUR.md +409 -0
  126. data/doc/BUILD.md +138 -0
  127. data/doc/CI_CD_RECIPES.md +171 -0
  128. data/doc/CLAUDE_SESSIONS_MOVED.md +16 -0
  129. data/doc/COMMAND_ANALYSIS.md +229 -0
  130. data/doc/CONFIGURATION.md +281 -0
  131. data/doc/DESIGN_AUDIT.md +235 -0
  132. data/doc/DESIGN_PEER_REVIEW.md +771 -0
  133. data/doc/DESKTOP.md +447 -0
  134. data/doc/ENGINES.md +567 -0
  135. data/doc/ENGINE_DEVELOPMENT_GUIDE.md +417 -0
  136. data/doc/FEATURE_AUDIT.md +218 -0
  137. data/doc/IMPLEMENTATION_PLAN.md +669 -0
  138. data/doc/INCIDENT_REPORT_2026-02-02.md +251 -0
  139. data/doc/MIGRATION_GUIDE.md +88 -0
  140. data/doc/PACKAGING.md +232 -0
  141. data/doc/PROJECT_DASHBOARD.md +153 -0
  142. data/doc/PULP_DEPLOYMENT.md +164 -0
  143. data/doc/QUALITY_FIX_SUMMARY.md +110 -0
  144. data/doc/QUICK_START.md +162 -0
  145. data/doc/REEK_CONFIGURATION.md +166 -0
  146. data/doc/REFERENCE.md +253 -0
  147. data/doc/REFERENCES.md +324 -0
  148. data/doc/SECURITY_REVIEW_CHECKLIST.md +72 -0
  149. data/doc/SESSION_2026-02-28_GTK4_HARDENING.md +359 -0
  150. data/doc/SETUP.md +202 -0
  151. data/doc/TEST_PEER_REVIEW.md +152 -0
  152. data/doc/THREAT_MODEL.md +230 -0
  153. data/doc/USAGE.md +545 -0
  154. data/doc/USER_MANUAL.md +585 -0
  155. data/doc/ai_test_review_checklist.md +110 -0
  156. data/doc/changes/2026-02-18-packaging-fpm.md +155 -0
  157. data/doc/changes/2026-02-19-testing-infrastructure.md +221 -0
  158. data/doc/changes/2026-02-20-security-implementation.md +281 -0
  159. data/doc/changes/2026-02-20-styles-implementation.md +220 -0
  160. data/doc/changes/2026-02-21-architecture-completion.md +95 -0
  161. data/doc/changes/2026-02-21-architecture-ui-layer.md +253 -0
  162. data/doc/changes/2026-02-21-cc-config-implementation.md +108 -0
  163. data/doc/changes/2026-02-21-ci-pipeline-implementation.md +214 -0
  164. data/doc/changes/2026-02-21-compiler-multi-target-pipeline.md +241 -0
  165. data/doc/changes/2026-02-21-config-design-show-commands.md +61 -0
  166. data/doc/changes/2026-02-21-design-implementation-overview.md +455 -0
  167. data/doc/changes/2026-02-21-lifecycle-management.md +196 -0
  168. data/doc/changes/2026-02-21-path-resolver.md +128 -0
  169. data/doc/changes/2026-02-24-ci-tmpdir-mutant-fetch.md +45 -0
  170. data/doc/changes/2026-03-01-ci-bundler-strategy.md +120 -0
  171. data/doc/changes/2026-03-20-security-hardening-phase2.md +163 -0
  172. data/doc/context/SESSION-HANDOFF.md +69 -0
  173. data/doc/context/ai-engine-usage-trends-2026.md +80 -0
  174. data/doc/context/plan-pluggable-engines.md +590 -0
  175. data/doc/decisions/001-flog-deferred.md +32 -0
  176. data/doc/decisions/002-path-resolution-strategy.md +158 -0
  177. data/doc/decisions/003-ui-adapter-selection.md +193 -0
  178. data/doc/decisions/004-design-document-validation.md +179 -0
  179. data/doc/decisions/005-package-splitting-strategy.md +200 -0
  180. data/doc/decisions/006-multi-engine-architecture.md +147 -0
  181. data/doc/decisions/007-engine-agnostic-pivot.md +219 -0
  182. data/doc/decisions/008-ci-bundler-strategy.md +129 -0
  183. data/doc/decisions/009-core-only-v1-release.md +60 -0
  184. data/doc/decisions/010-engine-debian-packaging.md +66 -0
  185. data/doc/decisions/011-context-aware-cli.md +71 -0
  186. data/doc/dependency_decisions.yml +247 -0
  187. data/doc/issues/001-wrapper-missing-environment-variables.md +197 -0
  188. data/doc/issues/002-embedded-ruby-wrong-prefix.md +217 -0
  189. data/doc/issues/003-smoke-test-false-positive.md +127 -0
  190. data/doc/issues/004-market-research-design-updates.md +109 -0
  191. data/doc/issues/005-compile-scope-coexistence.md +161 -0
  192. data/doc/locales/.gitkeep +0 -0
  193. data/doc/man/rai.1.ronn +505 -0
  194. data/doc/operations/packaging.md +133 -0
  195. data/doc/operations/rosett-ai-release.md +65 -0
  196. data/doc/reference/error-catalog.md +107 -0
  197. data/doc/reference/rosett-ai-technical-reference.pdf +0 -0
  198. data/doc/reference/src/Pictures/cover.jpg +0 -0
  199. data/doc/reference/src/Pictures/head1.jpg +0 -0
  200. data/doc/reference/src/Pictures/head2.jpg +0 -0
  201. data/doc/reference/src/Pictures/head3.jpg +0 -0
  202. data/doc/reference/src/Pictures/head4.jpg +0 -0
  203. data/doc/reference/src/Pictures/head5.jpg +0 -0
  204. data/doc/reference/src/Pictures/head6.jpg +0 -0
  205. data/doc/reference/src/Pictures/head7.jpg +0 -0
  206. data/doc/reference/src/Pictures/head8.jpg +0 -0
  207. data/doc/reference/src/StyleInd.ist +4 -0
  208. data/doc/reference/src/bibliography.bib +79 -0
  209. data/doc/reference/src/main.tex +1288 -0
  210. data/doc/reference/src/structure.tex +303 -0
  211. data/doc/rosett-ai-bookmarks.html +301 -0
  212. data/kitchen.yml +46 -0
  213. data/lib/rosett_ai/adopter/executor_resolver.rb +77 -0
  214. data/lib/rosett_ai/adopter/local_analysis_collector.rb +154 -0
  215. data/lib/rosett_ai/adopter/rule_adopter.rb +254 -0
  216. data/lib/rosett_ai/ai_config/config_compiler.rb +111 -0
  217. data/lib/rosett_ai/ai_config/context_window.rb +55 -0
  218. data/lib/rosett_ai/ai_config/cost_controls.rb +44 -0
  219. data/lib/rosett_ai/ai_config/fallback_chain.rb +64 -0
  220. data/lib/rosett_ai/ai_config/model_router.rb +121 -0
  221. data/lib/rosett_ai/ai_config/validator.rb +45 -0
  222. data/lib/rosett_ai/authorship/attribution_compiler.rb +99 -0
  223. data/lib/rosett_ai/authorship/disclosure_policy.rb +81 -0
  224. data/lib/rosett_ai/authorship/review_validator.rb +39 -0
  225. data/lib/rosett_ai/authorship/trailer_generator.rb +88 -0
  226. data/lib/rosett_ai/backup/compressor.rb +180 -0
  227. data/lib/rosett_ai/backup/destination.rb +91 -0
  228. data/lib/rosett_ai/behaviour/manager.rb +156 -0
  229. data/lib/rosett_ai/compiler/backend.rb +86 -0
  230. data/lib/rosett_ai/compiler/backends/agents_md_backend.rb +80 -0
  231. data/lib/rosett_ai/compiler/backends/claude_backend.rb +88 -0
  232. data/lib/rosett_ai/compiler/backends/generic_backend.rb +15 -0
  233. data/lib/rosett_ai/compiler/behaviour_compiler.rb +40 -0
  234. data/lib/rosett_ai/compiler/capability_checker.rb +104 -0
  235. data/lib/rosett_ai/compiler/compilation_pipeline.rb +361 -0
  236. data/lib/rosett_ai/compiler/compiled_output.rb +39 -0
  237. data/lib/rosett_ai/compiler/locale_compiler.rb +250 -0
  238. data/lib/rosett_ai/compiler/target_profile.rb +112 -0
  239. data/lib/rosett_ai/completion/generator.rb +101 -0
  240. data/lib/rosett_ai/completion/shells/bash_generator.rb +126 -0
  241. data/lib/rosett_ai/completion/shells/fish_generator.rb +78 -0
  242. data/lib/rosett_ai/completion/shells/zsh_generator.rb +126 -0
  243. data/lib/rosett_ai/comply/checkers/cra_checker.rb +102 -0
  244. data/lib/rosett_ai/comply/checkers/license_checker.rb +85 -0
  245. data/lib/rosett_ai/comply/checkers/spdx_header_checker.rb +98 -0
  246. data/lib/rosett_ai/comply/reporter.rb +113 -0
  247. data/lib/rosett_ai/comply/runner.rb +50 -0
  248. data/lib/rosett_ai/composition/circular_dependency_detector.rb +56 -0
  249. data/lib/rosett_ai/composition/composer.rb +158 -0
  250. data/lib/rosett_ai/composition/composition_result.rb +64 -0
  251. data/lib/rosett_ai/composition/conflict_detector.rb +53 -0
  252. data/lib/rosett_ai/composition/lockfile.rb +103 -0
  253. data/lib/rosett_ai/composition/merge_strategy.rb +131 -0
  254. data/lib/rosett_ai/composition/priority_sorter.rb +29 -0
  255. data/lib/rosett_ai/composition/scope_resolver.rb +55 -0
  256. data/lib/rosett_ai/config/compile_result.rb +37 -0
  257. data/lib/rosett_ai/config/compiler.rb +13 -0
  258. data/lib/rosett_ai/config/domain_transformer.rb +13 -0
  259. data/lib/rosett_ai/config/key_map.rb +13 -0
  260. data/lib/rosett_ai/config/masking_secret_resolver.rb +40 -0
  261. data/lib/rosett_ai/config/scope_router.rb +13 -0
  262. data/lib/rosett_ai/config/secret_resolver.rb +125 -0
  263. data/lib/rosett_ai/configuration.rb +119 -0
  264. data/lib/rosett_ai/content/content_client.rb +60 -0
  265. data/lib/rosett_ai/content/pack_installer.rb +117 -0
  266. data/lib/rosett_ai/content/pack_manifest.rb +50 -0
  267. data/lib/rosett_ai/content/pack_registry.rb +68 -0
  268. data/lib/rosett_ai/content_packs/manager.rb +50 -0
  269. data/lib/rosett_ai/dbus/compositor_detector.rb +77 -0
  270. data/lib/rosett_ai/dbus/focus_adapters/base.rb +59 -0
  271. data/lib/rosett_ai/dbus/focus_adapters/gnome_adapter.rb +172 -0
  272. data/lib/rosett_ai/dbus/focus_adapters/hyprland_adapter.rb +77 -0
  273. data/lib/rosett_ai/dbus/focus_adapters/i3_adapter.rb +65 -0
  274. data/lib/rosett_ai/dbus/focus_adapters/kwin_adapter.rb +103 -0
  275. data/lib/rosett_ai/dbus/focus_adapters/x11_adapter.rb +105 -0
  276. data/lib/rosett_ai/dbus/focus_monitor_interface.rb +103 -0
  277. data/lib/rosett_ai/dbus/manager_interface.rb +213 -0
  278. data/lib/rosett_ai/dbus/plugin_manager_interface.rb +169 -0
  279. data/lib/rosett_ai/dbus/rate_limiter.rb +89 -0
  280. data/lib/rosett_ai/dbus/service.rb +121 -0
  281. data/lib/rosett_ai/dbus/status_notifier_interface.rb +79 -0
  282. data/lib/rosett_ai/deprecation.rb +79 -0
  283. data/lib/rosett_ai/desktop/dbus_client.rb +259 -0
  284. data/lib/rosett_ai/desktop/gtk4_app.rb +371 -0
  285. data/lib/rosett_ai/desktop/gtk4_preferences.rb +331 -0
  286. data/lib/rosett_ai/desktop/gui_logger.rb +236 -0
  287. data/lib/rosett_ai/doctor/check.rb +92 -0
  288. data/lib/rosett_ai/doctor/checks/cache_health_check.rb +50 -0
  289. data/lib/rosett_ai/doctor/checks/dbus_availability_check.rb +39 -0
  290. data/lib/rosett_ai/doctor/checks/engine_detection_check.rb +46 -0
  291. data/lib/rosett_ai/doctor/checks/file_permission_check.rb +44 -0
  292. data/lib/rosett_ai/doctor/checks/gem_dependency_check.rb +55 -0
  293. data/lib/rosett_ai/doctor/checks/ruby_version_check.rb +50 -0
  294. data/lib/rosett_ai/doctor/checks/stale_config_nncc_check.rb +57 -0
  295. data/lib/rosett_ai/doctor/checks/stale_home_nncc_check.rb +59 -0
  296. data/lib/rosett_ai/doctor.rb +81 -0
  297. data/lib/rosett_ai/documentation/reference_compiler.rb +122 -0
  298. data/lib/rosett_ai/documentation/translator.rb +62 -0
  299. data/lib/rosett_ai/engines/base_config_compiler.rb +203 -0
  300. data/lib/rosett_ai/engines/detector.rb +63 -0
  301. data/lib/rosett_ai/engines/registry.rb +50 -0
  302. data/lib/rosett_ai/error_handler.rb +139 -0
  303. data/lib/rosett_ai/exit_codes.rb +76 -0
  304. data/lib/rosett_ai/feature_flags.rb +102 -0
  305. data/lib/rosett_ai/formatting.rb +33 -0
  306. data/lib/rosett_ai/gem_consistency_checker.rb +199 -0
  307. data/lib/rosett_ai/git_hooks/chain_detector.rb +86 -0
  308. data/lib/rosett_ai/git_hooks/installer.rb +175 -0
  309. data/lib/rosett_ai/git_hooks/script_generator.rb +125 -0
  310. data/lib/rosett_ai/gitlab/validators/supplementary_gitlab_ci_yaml_validator.rb +79 -0
  311. data/lib/rosett_ai/i18n/locale_resolver.rb +46 -0
  312. data/lib/rosett_ai/i18n/utf8_checker.rb +32 -0
  313. data/lib/rosett_ai/init/config_file_writer.rb +24 -0
  314. data/lib/rosett_ai/init/directory_builder.rb +38 -0
  315. data/lib/rosett_ai/init/file_copier.rb +95 -0
  316. data/lib/rosett_ai/init/global_initializer.rb +28 -0
  317. data/lib/rosett_ai/init/local_initializer.rb +27 -0
  318. data/lib/rosett_ai/init/mcp_registrar.rb +109 -0
  319. data/lib/rosett_ai/init/project_initializer.rb +38 -0
  320. data/lib/rosett_ai/licensing/license_key.rb +139 -0
  321. data/lib/rosett_ai/licensing/license_store.rb +64 -0
  322. data/lib/rosett_ai/licensing/license_validator.rb +60 -0
  323. data/lib/rosett_ai/licensing/tier.rb +42 -0
  324. data/lib/rosett_ai/mcp/admin/auditor.rb +88 -0
  325. data/lib/rosett_ai/mcp/admin/health_checker.rb +81 -0
  326. data/lib/rosett_ai/mcp/admin/registry.rb +100 -0
  327. data/lib/rosett_ai/mcp/admin/schema_validator.rb +63 -0
  328. data/lib/rosett_ai/mcp/enforcement/.gitkeep +0 -0
  329. data/lib/rosett_ai/mcp/enforcement/hook_generator.rb +197 -0
  330. data/lib/rosett_ai/mcp/enforcement/validator.rb +215 -0
  331. data/lib/rosett_ai/mcp/governance.rb +160 -0
  332. data/lib/rosett_ai/mcp/http_security_config.rb +158 -0
  333. data/lib/rosett_ai/mcp/instructions.rb +266 -0
  334. data/lib/rosett_ai/mcp/key_hasher.rb +66 -0
  335. data/lib/rosett_ai/mcp/keyfile.rb +221 -0
  336. data/lib/rosett_ai/mcp/middleware/authentication.rb +146 -0
  337. data/lib/rosett_ai/mcp/middleware/content_type.rb +56 -0
  338. data/lib/rosett_ai/mcp/middleware/cors.rb +83 -0
  339. data/lib/rosett_ai/mcp/middleware/origin_validation.rb +73 -0
  340. data/lib/rosett_ai/mcp/middleware/rate_limit.rb +106 -0
  341. data/lib/rosett_ai/mcp/middleware/request_size.rb +51 -0
  342. data/lib/rosett_ai/mcp/plugins.rb +143 -0
  343. data/lib/rosett_ai/mcp/prompts/compilation_prompt.rb +40 -0
  344. data/lib/rosett_ai/mcp/prompts/compliance_prompt.rb +41 -0
  345. data/lib/rosett_ai/mcp/prompts/diagnostics_prompt.rb +41 -0
  346. data/lib/rosett_ai/mcp/prompts/validation_prompt.rb +41 -0
  347. data/lib/rosett_ai/mcp/resources/behaviour_resource.rb +127 -0
  348. data/lib/rosett_ai/mcp/resources/config_resource.rb +72 -0
  349. data/lib/rosett_ai/mcp/resources/design_resource.rb +58 -0
  350. data/lib/rosett_ai/mcp/resources/hooks_resource.rb +74 -0
  351. data/lib/rosett_ai/mcp/resources/provenance_resource.rb +51 -0
  352. data/lib/rosett_ai/mcp/resources/rules_resource.rb +60 -0
  353. data/lib/rosett_ai/mcp/resources/schema_resource.rb +72 -0
  354. data/lib/rosett_ai/mcp/response_helper.rb +46 -0
  355. data/lib/rosett_ai/mcp/security_logger.rb +60 -0
  356. data/lib/rosett_ai/mcp/server.rb +212 -0
  357. data/lib/rosett_ai/mcp/settings/server_installer.rb +112 -0
  358. data/lib/rosett_ai/mcp/settings/trust_manager.rb +142 -0
  359. data/lib/rosett_ai/mcp/tools/adopt_tool.rb +70 -0
  360. data/lib/rosett_ai/mcp/tools/backup_tool.rb +64 -0
  361. data/lib/rosett_ai/mcp/tools/behaviour_display_tool.rb +72 -0
  362. data/lib/rosett_ai/mcp/tools/behaviour_list_tool.rb +56 -0
  363. data/lib/rosett_ai/mcp/tools/behaviour_manage_tool.rb +114 -0
  364. data/lib/rosett_ai/mcp/tools/behaviour_show_tool.rb +62 -0
  365. data/lib/rosett_ai/mcp/tools/compile_status_tool.rb +122 -0
  366. data/lib/rosett_ai/mcp/tools/compile_tool.rb +191 -0
  367. data/lib/rosett_ai/mcp/tools/comply_tool.rb +79 -0
  368. data/lib/rosett_ai/mcp/tools/config_compile_tool.rb +71 -0
  369. data/lib/rosett_ai/mcp/tools/config_status_tool.rb +79 -0
  370. data/lib/rosett_ai/mcp/tools/content_tool.rb +78 -0
  371. data/lib/rosett_ai/mcp/tools/context_query_tool.rb +156 -0
  372. data/lib/rosett_ai/mcp/tools/design_list_tool.rb +57 -0
  373. data/lib/rosett_ai/mcp/tools/design_show_tool.rb +69 -0
  374. data/lib/rosett_ai/mcp/tools/doctor_tool.rb +62 -0
  375. data/lib/rosett_ai/mcp/tools/documentation_status_tool.rb +45 -0
  376. data/lib/rosett_ai/mcp/tools/engines_tool.rb +84 -0
  377. data/lib/rosett_ai/mcp/tools/hook_install_tool.rb +190 -0
  378. data/lib/rosett_ai/mcp/tools/hook_preview_tool.rb +173 -0
  379. data/lib/rosett_ai/mcp/tools/hooks_status_tool.rb +84 -0
  380. data/lib/rosett_ai/mcp/tools/init_tool.rb +87 -0
  381. data/lib/rosett_ai/mcp/tools/license_status_tool.rb +44 -0
  382. data/lib/rosett_ai/mcp/tools/project_tool.rb +117 -0
  383. data/lib/rosett_ai/mcp/tools/provenance_tool.rb +97 -0
  384. data/lib/rosett_ai/mcp/tools/provenance_write_tool.rb +40 -0
  385. data/lib/rosett_ai/mcp/tools/retrofit_tool.rb +81 -0
  386. data/lib/rosett_ai/mcp/tools/rule_search_tool.rb +163 -0
  387. data/lib/rosett_ai/mcp/tools/schema_get_tool.rb +94 -0
  388. data/lib/rosett_ai/mcp/tools/tooling_tool.rb +86 -0
  389. data/lib/rosett_ai/mcp/tools/validate_tool.rb +105 -0
  390. data/lib/rosett_ai/mcp/tools/workflow_execute_tool.rb +74 -0
  391. data/lib/rosett_ai/mcp/tools/workflow_tool.rb +78 -0
  392. data/lib/rosett_ai/migration/detector.rb +117 -0
  393. data/lib/rosett_ai/migration/nncc_config_migrator.rb +94 -0
  394. data/lib/rosett_ai/migration/nncc_project_migrator.rb +90 -0
  395. data/lib/rosett_ai/migration/xdg_migrator.rb +123 -0
  396. data/lib/rosett_ai/package_manager/apt.rb +108 -0
  397. data/lib/rosett_ai/package_manager/base.rb +68 -0
  398. data/lib/rosett_ai/package_manager/gem_backend.rb +90 -0
  399. data/lib/rosett_ai/packaging/variant_config.rb +92 -0
  400. data/lib/rosett_ai/path_resolver.rb +115 -0
  401. data/lib/rosett_ai/plugins/contract.rb +43 -0
  402. data/lib/rosett_ai/plugins/engine_contract.rb +60 -0
  403. data/lib/rosett_ai/plugins/gui_contract.rb +74 -0
  404. data/lib/rosett_ai/plugins/mcp_contract.rb +48 -0
  405. data/lib/rosett_ai/plugins/registry.rb +150 -0
  406. data/lib/rosett_ai/policy/auditor.rb +41 -0
  407. data/lib/rosett_ai/policy/deny_list.rb +71 -0
  408. data/lib/rosett_ai/policy/opt_out_scanner.rb +37 -0
  409. data/lib/rosett_ai/policy/policy_compiler.rb +84 -0
  410. data/lib/rosett_ai/policy/protected_files.rb +47 -0
  411. data/lib/rosett_ai/policy/tier_hierarchy.rb +48 -0
  412. data/lib/rosett_ai/policy/validator.rb +35 -0
  413. data/lib/rosett_ai/profiler.rb +79 -0
  414. data/lib/rosett_ai/project/drift_detector.rb +126 -0
  415. data/lib/rosett_ai/project/manager.rb +115 -0
  416. data/lib/rosett_ai/project/sync_manager.rb +138 -0
  417. data/lib/rosett_ai/project/template_applier.rb +105 -0
  418. data/lib/rosett_ai/project_context.rb +82 -0
  419. data/lib/rosett_ai/provenance/entry.rb +63 -0
  420. data/lib/rosett_ai/provenance/file_source.rb +32 -0
  421. data/lib/rosett_ai/provenance/source.rb +62 -0
  422. data/lib/rosett_ai/provenance/store.rb +153 -0
  423. data/lib/rosett_ai/provenance/tracker.rb +62 -0
  424. data/lib/rosett_ai/provenance/trailer_generator.rb +43 -0
  425. data/lib/rosett_ai/provenance/validator.rb +45 -0
  426. data/lib/rosett_ai/quorum/collector.rb +59 -0
  427. data/lib/rosett_ai/quorum/comparator.rb +81 -0
  428. data/lib/rosett_ai/quorum/dispatcher.rb +57 -0
  429. data/lib/rosett_ai/quorum/strategies/adopt.rb +56 -0
  430. data/lib/rosett_ai/rai_config.rb +107 -0
  431. data/lib/rosett_ai/retrofit/base_parser.rb +66 -0
  432. data/lib/rosett_ai/retrofit/engine.rb +171 -0
  433. data/lib/rosett_ai/retrofit/parsers/agents_md_parser.rb +50 -0
  434. data/lib/rosett_ai/retrofit/parsers/claude_parser.rb +69 -0
  435. data/lib/rosett_ai/retrofit/parsers/cursor_parser.rb +82 -0
  436. data/lib/rosett_ai/retrofit/round_trip_validator.rb +65 -0
  437. data/lib/rosett_ai/retrofit/scanner.rb +47 -0
  438. data/lib/rosett_ai/retrofit/secret_detector.rb +87 -0
  439. data/lib/rosett_ai/secrets_resolver.rb +71 -0
  440. data/lib/rosett_ai/smart_feedback/suggester.rb +83 -0
  441. data/lib/rosett_ai/smart_feedback/thor_middleware.rb +84 -0
  442. data/lib/rosett_ai/structured_logger.rb +110 -0
  443. data/lib/rosett_ai/telemetry/json_lines_writer.rb +50 -0
  444. data/lib/rosett_ai/telemetry/log_rotator.rb +67 -0
  445. data/lib/rosett_ai/telemetry/provider.rb +26 -0
  446. data/lib/rosett_ai/telemetry/reporter.rb +144 -0
  447. data/lib/rosett_ai/telemetry.rb +47 -0
  448. data/lib/rosett_ai/text_sanitizer.rb +62 -0
  449. data/lib/rosett_ai/thor/cli.rb +269 -0
  450. data/lib/rosett_ai/thor/tasks/adopt.rb +250 -0
  451. data/lib/rosett_ai/thor/tasks/backup.rb +420 -0
  452. data/lib/rosett_ai/thor/tasks/behaviour.rb +474 -0
  453. data/lib/rosett_ai/thor/tasks/build.rb +1162 -0
  454. data/lib/rosett_ai/thor/tasks/compile.rb +415 -0
  455. data/lib/rosett_ai/thor/tasks/completion.rb +123 -0
  456. data/lib/rosett_ai/thor/tasks/comply.rb +82 -0
  457. data/lib/rosett_ai/thor/tasks/config.rb +265 -0
  458. data/lib/rosett_ai/thor/tasks/content.rb +193 -0
  459. data/lib/rosett_ai/thor/tasks/dbus.rb +321 -0
  460. data/lib/rosett_ai/thor/tasks/design.rb +258 -0
  461. data/lib/rosett_ai/thor/tasks/desktop.rb +129 -0
  462. data/lib/rosett_ai/thor/tasks/doctor.rb +127 -0
  463. data/lib/rosett_ai/thor/tasks/documentation.rb +321 -0
  464. data/lib/rosett_ai/thor/tasks/engines.rb +167 -0
  465. data/lib/rosett_ai/thor/tasks/hooks.rb +219 -0
  466. data/lib/rosett_ai/thor/tasks/init.rb +259 -0
  467. data/lib/rosett_ai/thor/tasks/license.rb +120 -0
  468. data/lib/rosett_ai/thor/tasks/mcp.rb +535 -0
  469. data/lib/rosett_ai/thor/tasks/migrate.rb +121 -0
  470. data/lib/rosett_ai/thor/tasks/plugins.rb +157 -0
  471. data/lib/rosett_ai/thor/tasks/project.rb +260 -0
  472. data/lib/rosett_ai/thor/tasks/provenance.rb +195 -0
  473. data/lib/rosett_ai/thor/tasks/release.rb +314 -0
  474. data/lib/rosett_ai/thor/tasks/retrofit.rb +90 -0
  475. data/lib/rosett_ai/thor/tasks/tooling.rb +308 -0
  476. data/lib/rosett_ai/thor/tasks/validate.rb +108 -0
  477. data/lib/rosett_ai/thor/tasks/workflow.rb +196 -0
  478. data/lib/rosett_ai/tooling/ci_yaml_validator.rb +37 -0
  479. data/lib/rosett_ai/tooling/version_checker.rb +35 -0
  480. data/lib/rosett_ai/ui/accessible_tui.rb +61 -0
  481. data/lib/rosett_ai/ui/base.rb +46 -0
  482. data/lib/rosett_ai/ui/gtk4.rb +98 -0
  483. data/lib/rosett_ai/ui/kde.rb +40 -0
  484. data/lib/rosett_ai/ui/qt6.rb +40 -0
  485. data/lib/rosett_ai/ui/registry.rb +60 -0
  486. data/lib/rosett_ai/ui/tty_helper.rb +74 -0
  487. data/lib/rosett_ai/ui/tui.rb +59 -0
  488. data/lib/rosett_ai/validators/behaviour_validator.rb +20 -0
  489. data/lib/rosett_ai/validators/design_validator.rb +17 -0
  490. data/lib/rosett_ai/validators/schema_validator.rb +84 -0
  491. data/lib/rosett_ai/validators/tooling_validator.rb +17 -0
  492. data/lib/rosett_ai/version.rb +8 -0
  493. data/lib/rosett_ai/version_consistency_checker.rb +129 -0
  494. data/lib/rosett_ai/workflow/audit_log.rb +86 -0
  495. data/lib/rosett_ai/workflow/engine.rb +142 -0
  496. data/lib/rosett_ai/workflow/manager.rb +82 -0
  497. data/lib/rosett_ai/workflow/schema_validator.rb +71 -0
  498. data/lib/rosett_ai/workflow/step_runner.rb +61 -0
  499. data/lib/rosett_ai/workflow/steps/prompt_step.rb +62 -0
  500. data/lib/rosett_ai/workflow/steps/rai_step.rb +74 -0
  501. data/lib/rosett_ai/workflow/steps/shell_step.rb +53 -0
  502. data/lib/rosett_ai/yaml_loader.rb +78 -0
  503. data/lib/rosett_ai.rb +221 -0
  504. data/lib/rubocop/cop/rosett_ai/shell_interpolation.rb +54 -0
  505. data/lib/rubocop/cop/rosett_ai/unsafe_const_get.rb +60 -0
  506. data/lib/rubocop/cop/rosett_ai/unsafe_send.rb +50 -0
  507. data/lib/rubocop/cop/rosett_ai/unsafe_yaml_load.rb +40 -0
  508. data/lib/rubocop/rosett_ai.rb +9 -0
  509. data/lib/scripts/generated/docker_hub_tags.rb +126 -0
  510. data/locales/.gitkeep +0 -0
  511. data/locales/ar.yml +579 -0
  512. data/locales/en.yml +571 -0
  513. data/locales/fr.yml +567 -0
  514. data/packaging/build-engine-deb.sh +81 -0
  515. data/packaging/scripts/postinst +17 -0
  516. data/packaging/scripts/postrm +19 -0
  517. data/packaging/scripts/prerm +10 -0
  518. data/packaging/wrapper.sh.template +38 -0
  519. data/rosett-ai.gemspec +63 -0
  520. data/rules/.gitkeep +0 -0
  521. data/scripts/publish/pulp_upload.sh +123 -0
  522. data/settings.json +29 -0
  523. data/share/applications/be.neatnerds.rosettai.desktop +29 -0
  524. data/share/dbus-1/interfaces/be.neatnerds.rosettai.xml +103 -0
  525. data/share/dbus-1/services/be.neatnerds.rosettai.service +3 -0
  526. data/share/templates/behaviour/criticalthinking.yml +69 -0
  527. metadata +810 -0
@@ -0,0 +1,73 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://neatnerds.be/rosett-ai/schemas/ai_config.json",
4
+ "title": "rosett-ai AI Tool Configuration",
5
+ "description": "Schema for .rosett-ai/conf/ai_config.yml defining engine-agnostic AI tool settings",
6
+ "type": "object",
7
+ "additionalProperties": false,
8
+ "properties": {
9
+ "model_routing": {
10
+ "type": "object",
11
+ "description": "Maps task types to canonical model tiers",
12
+ "additionalProperties": {
13
+ "type": "string",
14
+ "pattern": "^(economy|standard|premium|custom:.+)$"
15
+ }
16
+ },
17
+ "context_window": {
18
+ "type": "object",
19
+ "additionalProperties": false,
20
+ "properties": {
21
+ "max_tokens": {
22
+ "type": "integer",
23
+ "minimum": 1024,
24
+ "description": "Maximum context window size in tokens"
25
+ },
26
+ "output_reserve": {
27
+ "type": "integer",
28
+ "minimum": 256,
29
+ "description": "Tokens reserved for output generation"
30
+ },
31
+ "truncation_strategy": {
32
+ "type": "string",
33
+ "enum": ["tail", "head", "middle"],
34
+ "description": "How to truncate input when exceeding context window"
35
+ }
36
+ }
37
+ },
38
+ "cost_controls": {
39
+ "type": "object",
40
+ "additionalProperties": false,
41
+ "properties": {
42
+ "preferred_tier": {
43
+ "type": "string",
44
+ "enum": ["economy", "standard", "premium"],
45
+ "description": "Default cost tier preference (advisory only)"
46
+ },
47
+ "monthly_budget_note": {
48
+ "type": "string",
49
+ "description": "Advisory budget note for team awareness"
50
+ }
51
+ }
52
+ },
53
+ "fallback_chain": {
54
+ "type": "object",
55
+ "additionalProperties": false,
56
+ "properties": {
57
+ "engines": {
58
+ "type": "array",
59
+ "items": {
60
+ "type": "string",
61
+ "minLength": 1
62
+ },
63
+ "description": "Ordered list of engines to try"
64
+ }
65
+ }
66
+ },
67
+ "operational": {
68
+ "type": "object",
69
+ "description": "Engine-specific operational parameters (temperature, top_p, etc.)",
70
+ "additionalProperties": true
71
+ }
72
+ }
73
+ }
@@ -0,0 +1,132 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/behaviour_schema.json",
4
+ "title": "NeatNerds Behaviour Configuration",
5
+ "description": "Schema for validating behaviour configuration files used by the NeatNerds Code Companion (rosett-ai). Behaviour files define operational rules for Claude Code workflows.",
6
+ "$comment": {
7
+ "date": "2026-04-17",
8
+ "version": "1.3.0",
9
+ "source": "rosett-ai",
10
+ "compatible_claude_code_versions": [">=0.1.0"]
11
+ },
12
+ "type": "object",
13
+ "required": ["name", "description", "rules"],
14
+ "additionalProperties": false,
15
+ "properties": {
16
+ "name": {
17
+ "type": "string",
18
+ "minLength": 1,
19
+ "maxLength": 100,
20
+ "description": "Unique identifier for the behaviour"
21
+ },
22
+ "description": {
23
+ "type": "string",
24
+ "minLength": 1,
25
+ "description": "Human-readable explanation of the behaviour"
26
+ },
27
+ "version": {
28
+ "type": "string",
29
+ "pattern": "^\\d+\\.\\d+\\.\\d+$",
30
+ "description": "Semantic version (e.g. 1.0.0)"
31
+ },
32
+ "author": {
33
+ "type": "string",
34
+ "description": "Creator of the behaviour file"
35
+ },
36
+ "created_at": {
37
+ "type": "string",
38
+ "format": "date",
39
+ "description": "Creation date in ISO 8601 format (YYYY-MM-DD)"
40
+ },
41
+ "modified_at": {
42
+ "type": "string",
43
+ "format": "date",
44
+ "description": "Last modification date in ISO 8601 format (YYYY-MM-DD)"
45
+ },
46
+ "modified_by": {
47
+ "type": "string",
48
+ "description": "Last person to modify the behaviour file"
49
+ },
50
+ "scope": {
51
+ "type": "string",
52
+ "enum": ["global", "project", "personal"],
53
+ "description": "Compilation scope: global (to ~/.claude/rules/), project (to .claude/rules/), personal (to ~/.claude/rules/, not shared). Defaults to global when omitted."
54
+ },
55
+ "sensitive": {
56
+ "type": "boolean",
57
+ "description": "When true, this behaviour is excluded from API analysis during adopt"
58
+ },
59
+ "used_in": {
60
+ "type": "array",
61
+ "items": {
62
+ "type": "string"
63
+ },
64
+ "description": "List of projects using this behaviour"
65
+ },
66
+ "rules": {
67
+ "type": "array",
68
+ "minItems": 1,
69
+ "description": "Operational rules for Claude Code (at least one required)",
70
+ "items": {
71
+ "type": "object",
72
+ "required": ["id", "description"],
73
+ "properties": {
74
+ "id": {
75
+ "type": "string",
76
+ "description": "Unique rule identifier"
77
+ },
78
+ "description": {
79
+ "type": "string",
80
+ "description": "What this rule instructs Claude Code to do"
81
+ },
82
+ "priority": {
83
+ "type": "integer",
84
+ "minimum": 1,
85
+ "maximum": 100,
86
+ "description": "Rule priority: 1-29 minimal, 30-49 low, 50-69 medium, 70-89 high, 90-100 critical"
87
+ },
88
+ "enabled": {
89
+ "type": "boolean",
90
+ "description": "Whether this rule is active"
91
+ },
92
+ "enforcement": {
93
+ "type": "object",
94
+ "description": "Optional enforcement block. When present, enables hook generation for this rule. Requires valid pattern and applies_to for enforceable type.",
95
+ "properties": {
96
+ "type": {
97
+ "type": "string",
98
+ "enum": ["enforceable", "advisory", "informational"],
99
+ "description": "Enforcement tier: enforceable (hook-generatable), advisory (guidance only), informational (context only)"
100
+ },
101
+ "pattern": {
102
+ "type": "string",
103
+ "minLength": 1,
104
+ "description": "Regex pattern to match against tool input. Must not be degenerate (e.g. .*, .+, empty)"
105
+ },
106
+ "applies_to": {
107
+ "type": "array",
108
+ "items": {
109
+ "type": "string",
110
+ "minLength": 1
111
+ },
112
+ "minItems": 1,
113
+ "description": "Tool names this rule applies to (e.g. Bash, Write, Edit)"
114
+ },
115
+ "action": {
116
+ "type": "string",
117
+ "enum": ["block", "warn", "log"],
118
+ "description": "Enforcement action: block (reject tool call), warn (stderr warning), log (silent log)"
119
+ },
120
+ "message": {
121
+ "type": "string",
122
+ "description": "Human-readable message shown when the rule triggers"
123
+ }
124
+ },
125
+ "required": ["type"],
126
+ "additionalProperties": false
127
+ }
128
+ }
129
+ }
130
+ }
131
+ }
132
+ }
@@ -0,0 +1,63 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/compliance_rule_schema.json",
4
+ "title": "Compliance Rule",
5
+ "description": "Schema for conf/compliance/*.yml — declarative compliance check rules.",
6
+ "$comment": {
7
+ "date": "2026-03-16",
8
+ "version": "1.0.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "required": ["name", "version", "rules"],
13
+ "additionalProperties": false,
14
+ "properties": {
15
+ "name": {
16
+ "type": "string",
17
+ "minLength": 1,
18
+ "description": "Compliance rule set name"
19
+ },
20
+ "version": {
21
+ "type": "string",
22
+ "pattern": "^\\d+\\.\\d+\\.\\d+$",
23
+ "description": "Rule set version"
24
+ },
25
+ "description": {
26
+ "type": "string",
27
+ "description": "Human-readable description of the rule set"
28
+ },
29
+ "rules": {
30
+ "type": "array",
31
+ "minItems": 1,
32
+ "items": {
33
+ "type": "object",
34
+ "required": ["id", "description", "severity"],
35
+ "additionalProperties": false,
36
+ "properties": {
37
+ "id": {
38
+ "type": "string",
39
+ "pattern": "^[A-Z]+-\\d+$",
40
+ "description": "Unique rule identifier (e.g., CRA-001)"
41
+ },
42
+ "description": {
43
+ "type": "string",
44
+ "description": "Human-readable rule description"
45
+ },
46
+ "severity": {
47
+ "type": "string",
48
+ "enum": ["error", "warning", "info"],
49
+ "description": "Severity level"
50
+ },
51
+ "check": {
52
+ "type": "string",
53
+ "description": "Check type identifier"
54
+ },
55
+ "remediation": {
56
+ "type": "string",
57
+ "description": "How to fix when this rule fails"
58
+ }
59
+ }
60
+ }
61
+ }
62
+ }
63
+ }
@@ -0,0 +1,51 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "title": "NeatNerds Content Pack Manifest",
4
+ "description": "Schema for premium content pack manifest files",
5
+ "type": "object",
6
+ "required": ["name", "version", "tier_required", "description", "author", "contents"],
7
+ "additionalProperties": false,
8
+ "properties": {
9
+ "name": {
10
+ "type": "string",
11
+ "pattern": "^[a-z][a-z0-9_]*$",
12
+ "description": "Pack identifier (lowercase, underscores)"
13
+ },
14
+ "version": {
15
+ "type": "string",
16
+ "pattern": "^\\d+\\.\\d+\\.\\d+$",
17
+ "description": "Semantic version string"
18
+ },
19
+ "tier_required": {
20
+ "type": "string",
21
+ "enum": ["supporter", "subscriber", "enterprise"],
22
+ "description": "Minimum tier required to access this pack"
23
+ },
24
+ "description": {
25
+ "type": "string",
26
+ "minLength": 1,
27
+ "description": "Human-readable pack description"
28
+ },
29
+ "author": {
30
+ "type": "string",
31
+ "minLength": 1,
32
+ "description": "Pack author"
33
+ },
34
+ "contents": {
35
+ "type": "object",
36
+ "additionalProperties": false,
37
+ "properties": {
38
+ "behaviours": {
39
+ "type": "array",
40
+ "items": { "type": "string" },
41
+ "description": "List of behaviour YAML filenames"
42
+ },
43
+ "designs": {
44
+ "type": "array",
45
+ "items": { "type": "string" },
46
+ "description": "List of design YAML filenames"
47
+ }
48
+ }
49
+ }
50
+ }
51
+ }
@@ -0,0 +1,210 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/design_schema.json",
4
+ "title": "NeatNerds Design Document",
5
+ "description": "Schema for validating design documents used by the NeatNerds Code Companion (rosett-ai). Design documents define application intent, constraints, and requirements for AI-assisted development.",
6
+ "$comment": {
7
+ "date": "2026-02-22",
8
+ "version": "1.2.0",
9
+ "source": "rosett-ai",
10
+ "compatible_claude_code_versions": [">=0.1.0"]
11
+ },
12
+ "type": "object",
13
+ "required": ["name", "domain", "version", "status", "intent", "constraints", "acceptance_criteria"],
14
+ "additionalProperties": false,
15
+ "properties": {
16
+ "name": {
17
+ "type": "string",
18
+ "minLength": 1,
19
+ "maxLength": 100,
20
+ "pattern": "^[a-z][a-z0-9_]*$",
21
+ "description": "Unique identifier for the design document (snake_case)"
22
+ },
23
+ "domain": {
24
+ "type": "string",
25
+ "enum": ["core", "ui", "security", "testing", "styles", "i18n", "accessibility", "licensing", "ci", "compiler", "release", "documentation", "operations", "forge"],
26
+ "description": "Domain category grouping related specs"
27
+ },
28
+ "version": {
29
+ "type": "string",
30
+ "pattern": "^\\d+\\.\\d+\\.\\d+$",
31
+ "description": "Semantic version (e.g. 1.0.0)"
32
+ },
33
+ "status": {
34
+ "type": "string",
35
+ "enum": ["draft", "approved", "implemented"],
36
+ "description": "Draft allows AI deviation; approved means follow strictly; implemented means code exists"
37
+ },
38
+ "priority": {
39
+ "type": "integer",
40
+ "minimum": 1,
41
+ "maximum": 6,
42
+ "description": "Implementation priority: 1=foundation, 2=structure, 3=interface, 4=business, 5=delivery, 6=operations"
43
+ },
44
+ "author": {
45
+ "type": "string",
46
+ "description": "Creator of the design document"
47
+ },
48
+ "created_at": {
49
+ "type": "string",
50
+ "format": "date",
51
+ "description": "Creation date in ISO 8601 format (YYYY-MM-DD)"
52
+ },
53
+ "modified_at": {
54
+ "type": "string",
55
+ "format": "date",
56
+ "description": "Last modification date in ISO 8601 format (YYYY-MM-DD)"
57
+ },
58
+ "modified_by": {
59
+ "type": "string",
60
+ "description": "Last person to modify the design document"
61
+ },
62
+ "depends_on": {
63
+ "type": "array",
64
+ "items": { "type": "string" },
65
+ "description": "List of design document names this document depends on"
66
+ },
67
+ "intent": {
68
+ "type": "string",
69
+ "minLength": 10,
70
+ "description": "Why this exists, what problem it solves, who benefits. Most valuable section for AI decision-making."
71
+ },
72
+ "constraints": {
73
+ "type": "array",
74
+ "minItems": 1,
75
+ "items": { "type": "string" },
76
+ "description": "Hard boundaries that must not be crossed"
77
+ },
78
+ "acceptance_criteria": {
79
+ "type": "array",
80
+ "minItems": 1,
81
+ "items": { "type": "string" },
82
+ "description": "Testable statements defining done"
83
+ },
84
+ "examples": {
85
+ "type": "array",
86
+ "items": {
87
+ "type": "object",
88
+ "required": ["scenario", "expected"],
89
+ "properties": {
90
+ "scenario": { "type": "string", "description": "Description of the situation" },
91
+ "expected": { "type": "string", "description": "What should happen" },
92
+ "not": { "type": "string", "description": "What should NOT happen" }
93
+ }
94
+ },
95
+ "description": "Concrete examples of expected behaviour"
96
+ },
97
+ "anti_patterns": {
98
+ "type": "array",
99
+ "items": { "type": "string" },
100
+ "description": "What NOT to do — common wrong approaches to avoid"
101
+ },
102
+ "preferences": {
103
+ "type": "object",
104
+ "properties": {
105
+ "language": { "type": "string" },
106
+ "patterns": { "type": "array", "items": { "type": "string" } },
107
+ "testing": { "type": "string" },
108
+ "gems": { "type": "array", "items": { "type": "string" } }
109
+ },
110
+ "additionalProperties": true,
111
+ "description": "Technical preferences (only when it matters)"
112
+ },
113
+ "assets": {
114
+ "type": "array",
115
+ "items": {
116
+ "type": "object",
117
+ "required": ["path", "type", "description"],
118
+ "properties": {
119
+ "path": { "type": "string", "description": "Relative path to asset file" },
120
+ "type": { "type": "string", "enum": ["mockup", "reference", "diagram"] },
121
+ "description": { "type": "string" }
122
+ }
123
+ },
124
+ "description": "Visual assets (images) AI can process directly"
125
+ },
126
+ "tui_layout": {
127
+ "type": "string",
128
+ "description": "ASCII art TUI layout (versionable, diffable)"
129
+ },
130
+ "implementation_notes": {
131
+ "type": "string",
132
+ "description": "Post-implementation notes documenting how the design was realised, including intentional divergences from the original design"
133
+ },
134
+ "gui_notes": {
135
+ "type": "string",
136
+ "description": "Platform-specific GUI implementation notes"
137
+ },
138
+ "interactions": {
139
+ "type": "array",
140
+ "items": {
141
+ "type": "object",
142
+ "required": ["action"],
143
+ "properties": {
144
+ "action": { "type": "string" },
145
+ "tui": { "type": "string" },
146
+ "gtk4": { "type": "string" },
147
+ "qt6": { "type": "string" }
148
+ }
149
+ },
150
+ "description": "Cross-platform interaction definitions"
151
+ },
152
+ "accessibility": {
153
+ "type": "object",
154
+ "properties": {
155
+ "roles": {
156
+ "type": "array",
157
+ "items": {
158
+ "type": "object",
159
+ "required": ["element", "role", "label"],
160
+ "properties": {
161
+ "element": { "type": "string" },
162
+ "role": { "type": "string" },
163
+ "label": { "type": "string" },
164
+ "description": { "type": "string" }
165
+ }
166
+ }
167
+ },
168
+ "keyboard": {
169
+ "type": "array",
170
+ "items": {
171
+ "type": "object",
172
+ "required": ["key", "action"],
173
+ "properties": {
174
+ "key": { "type": "string" },
175
+ "action": { "type": "string" }
176
+ }
177
+ }
178
+ },
179
+ "focus_order": { "type": "array", "items": { "type": "string" } },
180
+ "announcements": {
181
+ "type": "array",
182
+ "items": {
183
+ "type": "object",
184
+ "required": ["event", "announce"],
185
+ "properties": {
186
+ "event": { "type": "string" },
187
+ "announce": { "type": "string" },
188
+ "priority": { "type": "string", "enum": ["polite", "assertive"] }
189
+ }
190
+ }
191
+ },
192
+ "target_sizes": {
193
+ "type": "object",
194
+ "properties": {
195
+ "minimum": { "type": "string" },
196
+ "recommended": { "type": "string" }
197
+ }
198
+ },
199
+ "timing": {
200
+ "type": "object",
201
+ "properties": {
202
+ "no_time_limits": { "type": "boolean" },
203
+ "animations_respect_prefers_reduced_motion": { "type": "boolean" }
204
+ }
205
+ }
206
+ },
207
+ "description": "Accessibility requirements for UI components"
208
+ }
209
+ }
210
+ }
@@ -0,0 +1,144 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/engine_manifest_schema.json",
4
+ "title": "Engine Manifest",
5
+ "description": "Schema for conf/engines/<name>/manifest.yml — engine capability declarations.",
6
+ "$comment": {
7
+ "date": "2026-02-26",
8
+ "version": "1.2.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "required": ["name", "display_name", "version", "components", "capabilities"],
13
+ "additionalProperties": false,
14
+ "properties": {
15
+ "name": {
16
+ "type": "string",
17
+ "minLength": 1,
18
+ "pattern": "^[a-z][a-z0-9_]*$",
19
+ "description": "Machine-readable engine identifier"
20
+ },
21
+ "display_name": {
22
+ "type": "string",
23
+ "minLength": 1,
24
+ "description": "Human-readable engine name"
25
+ },
26
+ "version": {
27
+ "type": "string",
28
+ "pattern": "^\\d+\\.\\d+\\.\\d+$",
29
+ "description": "Semantic version of the engine manifest"
30
+ },
31
+ "components": {
32
+ "type": "object",
33
+ "required": ["backend"],
34
+ "additionalProperties": false,
35
+ "properties": {
36
+ "backend": {
37
+ "type": "boolean",
38
+ "description": "Whether the engine provides a compilation backend"
39
+ },
40
+ "config_compiler": {
41
+ "type": "boolean",
42
+ "description": "Whether the engine compiles settings files"
43
+ },
44
+ "executor": {
45
+ "type": "boolean",
46
+ "description": "Whether the engine provides an API executor for adopt"
47
+ },
48
+ "detector": {
49
+ "type": "boolean",
50
+ "description": "Whether the engine provides an autodetector"
51
+ },
52
+ "scaffolder": {
53
+ "type": "boolean",
54
+ "description": "Whether the engine provides project scaffolding"
55
+ }
56
+ }
57
+ },
58
+ "detection": {
59
+ "type": "object",
60
+ "additionalProperties": false,
61
+ "properties": {
62
+ "cli_binary": {
63
+ "type": "string",
64
+ "description": "Binary name to search in PATH"
65
+ },
66
+ "config_dir": {
67
+ "type": "string",
68
+ "description": "Configuration directory to check for existence"
69
+ },
70
+ "env_var": {
71
+ "type": "string",
72
+ "description": "Environment variable indicating engine configuration"
73
+ }
74
+ }
75
+ },
76
+ "execution": {
77
+ "type": "object",
78
+ "additionalProperties": false,
79
+ "properties": {
80
+ "api_gem": {
81
+ "type": "string",
82
+ "description": "Ruby gem name providing the API client"
83
+ },
84
+ "model": {
85
+ "type": "string",
86
+ "description": "Default model identifier"
87
+ },
88
+ "api_type": {
89
+ "type": "string",
90
+ "enum": ["cli", "http", "grpc", "sdk", "openai_compatible"],
91
+ "description": "Type of API interface used by the engine"
92
+ },
93
+ "default_endpoint": {
94
+ "type": "string",
95
+ "format": "uri",
96
+ "description": "Default HTTP endpoint for the engine API"
97
+ },
98
+ "default_model": {
99
+ "type": "string",
100
+ "description": "Default model name for inference requests"
101
+ },
102
+ "cli_binary": {
103
+ "type": "string",
104
+ "description": "CLI binary name for subprocess-based executors"
105
+ }
106
+ }
107
+ },
108
+ "capabilities": {
109
+ "type": "object",
110
+ "required": ["compile"],
111
+ "additionalProperties": false,
112
+ "properties": {
113
+ "compile": {
114
+ "type": "boolean",
115
+ "description": "Can compile behaviour YAML to engine-native format"
116
+ },
117
+ "config": {
118
+ "type": "boolean",
119
+ "description": "Can compile settings/configuration files"
120
+ },
121
+ "adopt_api": {
122
+ "type": "boolean",
123
+ "description": "Can perform remote adopt analysis via API"
124
+ },
125
+ "settings_json": {
126
+ "type": "boolean",
127
+ "description": "Supports settings.json configuration files"
128
+ },
129
+ "local_only": {
130
+ "type": "boolean",
131
+ "description": "Engine only supports local inference (no cloud API)"
132
+ },
133
+ "sensitive_filtering": {
134
+ "type": "boolean",
135
+ "description": "Supports filtering sensitive content during compilation"
136
+ },
137
+ "rule_metadata": {
138
+ "type": "boolean",
139
+ "description": "Supports rule metadata (IDs, priority) in compiled output"
140
+ }
141
+ }
142
+ }
143
+ }
144
+ }