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,74 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://neatnerds.be/schemas/rosett-ai/lockfile_schema.json",
4
+ "title": "rosett-ai Lockfile Schema",
5
+ "description": "Schema for .rosett-ai-lock.yml behaviour composition lockfile",
6
+ "type": "object",
7
+ "required": ["lockfile_version", "generated_at", "generator", "generator_version", "rule_count", "behaviours", "composition"],
8
+ "properties": {
9
+ "lockfile_version": {
10
+ "type": "integer",
11
+ "const": 1,
12
+ "description": "Lockfile format version"
13
+ },
14
+ "generated_at": {
15
+ "type": "string",
16
+ "format": "date-time",
17
+ "description": "ISO 8601 timestamp of generation"
18
+ },
19
+ "generator": {
20
+ "type": "string",
21
+ "const": "rosett-ai",
22
+ "description": "Tool that generated this lockfile"
23
+ },
24
+ "generator_version": {
25
+ "type": "string",
26
+ "pattern": "^\\d+\\.\\d+\\.\\d+",
27
+ "description": "Version of Rosett-AI that generated this lockfile"
28
+ },
29
+ "rule_count": {
30
+ "type": "integer",
31
+ "minimum": 0,
32
+ "description": "Total number of composed rules"
33
+ },
34
+ "behaviours": {
35
+ "type": "object",
36
+ "description": "Map of behaviour file relative paths to SHA-256 checksums",
37
+ "additionalProperties": {
38
+ "type": "string",
39
+ "pattern": "^sha256:[a-f0-9]{64}$"
40
+ }
41
+ },
42
+ "composition": {
43
+ "type": "array",
44
+ "description": "Ordered list of composed rules",
45
+ "items": {
46
+ "type": "object",
47
+ "required": ["id", "behaviour", "scope", "priority"],
48
+ "properties": {
49
+ "id": {
50
+ "type": "string",
51
+ "description": "Rule identifier"
52
+ },
53
+ "behaviour": {
54
+ "type": "string",
55
+ "description": "Source behaviour name"
56
+ },
57
+ "scope": {
58
+ "type": "string",
59
+ "enum": ["global", "organisation", "project", "local"],
60
+ "description": "Scope in which this rule was defined"
61
+ },
62
+ "priority": {
63
+ "type": "integer",
64
+ "minimum": 1,
65
+ "maximum": 100,
66
+ "description": "Rule priority (1=highest)"
67
+ }
68
+ },
69
+ "additionalProperties": false
70
+ }
71
+ }
72
+ },
73
+ "additionalProperties": false
74
+ }
@@ -0,0 +1,48 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "title": "MCP Server Configuration",
4
+ "description": "Schema for Rosett-AI MCP server configuration files",
5
+ "type": "object",
6
+ "required": ["name", "transport"],
7
+ "properties": {
8
+ "name": {
9
+ "type": "string",
10
+ "minLength": 1,
11
+ "description": "Unique server name"
12
+ },
13
+ "transport": {
14
+ "type": "string",
15
+ "enum": ["stdio", "http", "streamable-http"],
16
+ "description": "Transport protocol"
17
+ },
18
+ "command": {
19
+ "type": ["string", "array"],
20
+ "description": "Command to launch stdio server"
21
+ },
22
+ "url": {
23
+ "type": "string",
24
+ "format": "uri",
25
+ "description": "URL for HTTP transport"
26
+ },
27
+ "args": {
28
+ "type": "array",
29
+ "items": { "type": "string" },
30
+ "description": "Additional command arguments"
31
+ },
32
+ "env": {
33
+ "type": "object",
34
+ "additionalProperties": { "type": "string" },
35
+ "description": "Environment variables"
36
+ },
37
+ "source_file": {
38
+ "type": "string",
39
+ "description": "Path to source configuration file"
40
+ }
41
+ },
42
+ "if": { "properties": { "transport": { "const": "stdio" } } },
43
+ "then": { "required": ["command"] },
44
+ "else": {
45
+ "if": { "properties": { "transport": { "enum": ["http", "streamable-http"] } } },
46
+ "then": { "required": ["url"] }
47
+ }
48
+ }
@@ -0,0 +1,70 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/packaging_schema.json",
4
+ "title": "NeatNerds Package Variant",
5
+ "description": "Schema for validating packaging variant configurations. Each variant defines a Debian package with its dependencies and metadata.",
6
+ "$comment": {
7
+ "date": "2026-02-21",
8
+ "version": "1.0.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "required": ["name", "variant", "description"],
13
+ "additionalProperties": false,
14
+ "properties": {
15
+ "name": {
16
+ "type": "string",
17
+ "minLength": 1,
18
+ "maxLength": 100,
19
+ "pattern": "^rosett-ai(-[a-z0-9]+)?$",
20
+ "description": "Debian package name (e.g. rosett-ai, rosett-ai-gtk4)"
21
+ },
22
+ "variant": {
23
+ "type": "string",
24
+ "enum": ["core", "gtk4", "qt6", "kde"],
25
+ "description": "Package variant identifier"
26
+ },
27
+ "description": {
28
+ "type": "string",
29
+ "minLength": 1,
30
+ "description": "Human-readable package description"
31
+ },
32
+ "ui_adapter": {
33
+ "type": "string",
34
+ "enum": ["tui", "gtk4", "qt6", "kde"],
35
+ "description": "UI adapter this variant provides"
36
+ },
37
+ "system_dependencies": {
38
+ "type": "array",
39
+ "items": {
40
+ "type": "string",
41
+ "minLength": 1
42
+ },
43
+ "uniqueItems": true,
44
+ "description": "Debian system package dependencies"
45
+ },
46
+ "package_dependencies": {
47
+ "type": "array",
48
+ "items": {
49
+ "type": "object",
50
+ "required": ["name", "version"],
51
+ "additionalProperties": false,
52
+ "properties": {
53
+ "name": {
54
+ "type": "string",
55
+ "minLength": 1,
56
+ "description": "Dependency package name"
57
+ },
58
+ "version": {
59
+ "type": "string",
60
+ "minLength": 1,
61
+ "description": "Version constraint. Use 'current' to resolve to RosettAi::VERSION at load time.",
62
+ "pattern": "^(current|[><=~!]+\\s*\\d+\\.\\d+(\\.\\d+)?)$"
63
+ }
64
+ }
65
+ },
66
+ "uniqueItems": true,
67
+ "description": "rosett-ai package dependencies with version constraints"
68
+ }
69
+ }
70
+ }
@@ -0,0 +1,85 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://neatnerds.be/rosett-ai/schemas/policy",
4
+ "title": "rosett-ai Policy Schema",
5
+ "description": "Schema for rai policy configuration files",
6
+ "type": "object",
7
+ "required": ["policy_version", "tier"],
8
+ "properties": {
9
+ "policy_version": {
10
+ "type": "integer",
11
+ "minimum": 1,
12
+ "description": "Schema version for this policy file"
13
+ },
14
+ "tier": {
15
+ "type": "string",
16
+ "enum": ["mandatory", "advisory", "informational"],
17
+ "description": "Policy enforcement tier"
18
+ },
19
+ "scope": {
20
+ "type": "string",
21
+ "enum": ["org", "team", "project"],
22
+ "description": "Policy scope in the hierarchy"
23
+ },
24
+ "deny_list": {
25
+ "type": "object",
26
+ "properties": {
27
+ "patterns": {
28
+ "type": "array",
29
+ "items": {
30
+ "type": "string",
31
+ "minLength": 1
32
+ },
33
+ "description": "Glob patterns for denied file access"
34
+ }
35
+ },
36
+ "required": ["patterns"]
37
+ },
38
+ "protected_files": {
39
+ "type": "object",
40
+ "properties": {
41
+ "paths": {
42
+ "type": "array",
43
+ "items": {
44
+ "type": "string",
45
+ "minLength": 1
46
+ },
47
+ "description": "File paths that AI may read but not modify"
48
+ }
49
+ },
50
+ "required": ["paths"]
51
+ },
52
+ "rate_limiting": {
53
+ "type": "object",
54
+ "properties": {
55
+ "max_ai_prs_per_week": {
56
+ "type": "integer",
57
+ "minimum": 0,
58
+ "description": "Maximum AI-assisted PRs per contributor per week (advisory)"
59
+ },
60
+ "enforcement": {
61
+ "type": "string",
62
+ "enum": ["advisory", "enforced"],
63
+ "default": "advisory",
64
+ "description": "Whether rate limiting is advisory or enforced"
65
+ }
66
+ }
67
+ },
68
+ "license_policy": {
69
+ "type": "object",
70
+ "properties": {
71
+ "allowed": {
72
+ "type": "array",
73
+ "items": { "type": "string" },
74
+ "description": "Allowed SPDX license identifiers"
75
+ },
76
+ "rejected": {
77
+ "type": "array",
78
+ "items": { "type": "string" },
79
+ "description": "Rejected SPDX license identifiers"
80
+ }
81
+ }
82
+ }
83
+ },
84
+ "additionalProperties": false
85
+ }
@@ -0,0 +1,84 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://neatnerds.be/rosett-ai/schemas/provenance.json",
4
+ "title": "rosett-ai AI Provenance",
5
+ "description": "Schema for .ai-provenance.yml files tracking AI involvement in code contributions",
6
+ "type": "object",
7
+ "required": ["provenance_version", "entries"],
8
+ "additionalProperties": false,
9
+ "properties": {
10
+ "provenance_version": {
11
+ "type": "integer",
12
+ "const": 1,
13
+ "description": "Schema version for forwards compatibility"
14
+ },
15
+ "entries": {
16
+ "type": "array",
17
+ "items": {
18
+ "$ref": "#/$defs/entry"
19
+ }
20
+ }
21
+ },
22
+ "$defs": {
23
+ "entry": {
24
+ "type": "object",
25
+ "required": ["commit", "timestamp", "contributor", "ai_tool", "ai_role", "files"],
26
+ "additionalProperties": false,
27
+ "properties": {
28
+ "commit": {
29
+ "type": "string",
30
+ "pattern": "^[0-9a-f]{7,40}$",
31
+ "description": "Git commit SHA (short or full)"
32
+ },
33
+ "timestamp": {
34
+ "type": "string",
35
+ "pattern": "^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}Z$",
36
+ "description": "ISO 8601 UTC timestamp"
37
+ },
38
+ "contributor": {
39
+ "type": "string",
40
+ "minLength": 1,
41
+ "description": "Contributor name and email"
42
+ },
43
+ "ai_tool": {
44
+ "type": "string",
45
+ "minLength": 1,
46
+ "description": "AI tool identifier (e.g. 'Claude Opus 4.6 (Anthropic)')"
47
+ },
48
+ "ai_role": {
49
+ "type": "string",
50
+ "enum": ["AI-Generated-By", "AI-Co-Author", "AI-Assisted-By", "AI-Reviewed-By"],
51
+ "description": "Role the AI played in the contribution"
52
+ },
53
+ "files": {
54
+ "type": "array",
55
+ "items": {
56
+ "$ref": "#/$defs/file_source"
57
+ }
58
+ }
59
+ }
60
+ },
61
+ "file_source": {
62
+ "type": "object",
63
+ "required": ["path", "source_type"],
64
+ "additionalProperties": false,
65
+ "properties": {
66
+ "path": {
67
+ "type": "string",
68
+ "minLength": 1,
69
+ "description": "Relative path from project root"
70
+ },
71
+ "lines": {
72
+ "type": "string",
73
+ "pattern": "^\\d+(-\\d+)?$",
74
+ "description": "Line range (e.g. '1-50')"
75
+ },
76
+ "source_type": {
77
+ "type": "string",
78
+ "enum": ["library_api", "project_code", "documentation", "pattern", "external_source"],
79
+ "description": "Classification of the AI's source material"
80
+ }
81
+ }
82
+ }
83
+ }
84
+ }
@@ -0,0 +1,56 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/rai_config_schema.json",
4
+ "title": "NeatNerds Code Companion Configuration",
5
+ "description": "Schema for ~/.config/rosett-ai/config.yml — rosett-ai runtime configuration.",
6
+ "$comment": {
7
+ "date": "2026-02-26",
8
+ "version": "1.0.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "additionalProperties": false,
13
+ "properties": {
14
+ "default_engine": {
15
+ "type": "string",
16
+ "enum": ["claude", "generic"],
17
+ "description": "Default engine for compile and adopt commands"
18
+ },
19
+ "cache": {
20
+ "type": "object",
21
+ "additionalProperties": false,
22
+ "properties": {
23
+ "enabled": {
24
+ "type": "boolean",
25
+ "description": "Enable adopt result caching"
26
+ },
27
+ "ttl_hours": {
28
+ "type": "integer",
29
+ "minimum": 1,
30
+ "maximum": 720,
31
+ "description": "Cache time-to-live in hours"
32
+ }
33
+ }
34
+ },
35
+ "detect": {
36
+ "type": "object",
37
+ "additionalProperties": false,
38
+ "properties": {
39
+ "on_init": {
40
+ "type": "boolean",
41
+ "description": "Run engine detection during rai init"
42
+ }
43
+ }
44
+ },
45
+ "dbus": {
46
+ "type": "object",
47
+ "additionalProperties": false,
48
+ "properties": {
49
+ "allow_plugin_management": {
50
+ "type": "boolean",
51
+ "description": "Allow InstallPlugin/RemovePlugin D-Bus methods. Disabled by default for security."
52
+ }
53
+ }
54
+ }
55
+ }
56
+ }
@@ -0,0 +1,20 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "title": "rai project configuration",
4
+ "description": "Schema for .rosett-ai/config.yml project marker files",
5
+ "type": "object",
6
+ "required": ["project_name"],
7
+ "properties": {
8
+ "project_name": {
9
+ "type": "string",
10
+ "minLength": 1,
11
+ "description": "Human-readable project name"
12
+ },
13
+ "default_engine": {
14
+ "type": "string",
15
+ "default": "claude",
16
+ "description": "Default compilation engine for this project"
17
+ }
18
+ },
19
+ "additionalProperties": false
20
+ }
@@ -0,0 +1,49 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/scope_hierarchy_schema.json",
4
+ "title": "NeatNerds Scope Hierarchy Configuration",
5
+ "description": "Schema for scope hierarchy merge strategy configuration in .rosett-ai/config.yml",
6
+ "$comment": {
7
+ "date": "2026-03-23",
8
+ "version": "0.1.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "additionalProperties": false,
13
+ "properties": {
14
+ "merge_strategies": {
15
+ "type": "object",
16
+ "description": "Per-key merge strategy overrides. Keys are dot-separated paths into behaviour data.",
17
+ "additionalProperties": {
18
+ "type": "string",
19
+ "enum": ["deep_merge", "replace", "array_union", "first_found"],
20
+ "description": "Merge strategy for this key"
21
+ }
22
+ },
23
+ "scope_defaults": {
24
+ "type": "object",
25
+ "description": "Default merge strategies by value type when no per-key override is set.",
26
+ "additionalProperties": false,
27
+ "properties": {
28
+ "hash": {
29
+ "type": "string",
30
+ "enum": ["deep_merge", "replace", "first_found"],
31
+ "default": "deep_merge",
32
+ "description": "Default strategy for hash values"
33
+ },
34
+ "array": {
35
+ "type": "string",
36
+ "enum": ["array_union", "replace", "first_found"],
37
+ "default": "array_union",
38
+ "description": "Default strategy for array values"
39
+ },
40
+ "scalar": {
41
+ "type": "string",
42
+ "enum": ["replace", "first_found"],
43
+ "default": "replace",
44
+ "description": "Default strategy for scalar values"
45
+ }
46
+ }
47
+ }
48
+ }
49
+ }
@@ -0,0 +1,67 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/target_schema.json",
4
+ "title": "NeatNerds Target Profile",
5
+ "description": "Schema for validating compiler target profiles. Each profile defines how rai compiles source documents for a specific AI assistant target.",
6
+ "$comment": {
7
+ "date": "2026-02-21",
8
+ "version": "1.0.0",
9
+ "source": "rosett-ai"
10
+ },
11
+ "type": "object",
12
+ "required": ["name", "backend", "output_format"],
13
+ "additionalProperties": false,
14
+ "properties": {
15
+ "name": {
16
+ "type": "string",
17
+ "minLength": 1,
18
+ "maxLength": 100,
19
+ "description": "Unique identifier for the target profile"
20
+ },
21
+ "description": {
22
+ "type": "string",
23
+ "description": "Human-readable description of the target"
24
+ },
25
+ "backend": {
26
+ "type": "string",
27
+ "enum": ["acme", "aider", "agents_md", "claude", "copilot", "cursor", "generic", "goose", "gpt_neox", "ollama", "windsurf"],
28
+ "description": "Compiler backend to use for this target"
29
+ },
30
+ "engine_version": {
31
+ "type": "string",
32
+ "description": "Semver constraint for engine compatibility"
33
+ },
34
+ "output_format": {
35
+ "type": "string",
36
+ "enum": ["markdown", "json", "yaml"],
37
+ "description": "Output format for compiled files"
38
+ },
39
+ "output_dir": {
40
+ "type": ["string", "null"],
41
+ "description": "Override output directory (null uses default rules_dir)"
42
+ },
43
+ "max_context_window": {
44
+ "type": ["integer", "null"],
45
+ "minimum": 1,
46
+ "description": "Maximum context window size in tokens (null for unlimited)"
47
+ },
48
+ "rendering": {
49
+ "type": "object",
50
+ "additionalProperties": false,
51
+ "properties": {
52
+ "include_source_metadata": {
53
+ "type": "boolean",
54
+ "description": "Include source file metadata in output"
55
+ },
56
+ "include_priority_annotations": {
57
+ "type": "boolean",
58
+ "description": "Include priority annotations in rule headings"
59
+ },
60
+ "include_generated_marker": {
61
+ "type": "boolean",
62
+ "description": "Include generated-by marker comment"
63
+ }
64
+ }
65
+ }
66
+ }
67
+ }
@@ -0,0 +1,65 @@
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://gitlab.neatnerds.be/neatnerds/NeatNerds-AI/rosett-ai/schemas/tooling_schema.json",
4
+ "title": "NeatNerds Tool Registry Configuration",
5
+ "description": "Schema for validating the tools.yml registry file used by the NeatNerds Code Companion (rosett-ai) tooling commands.",
6
+ "$comment": {
7
+ "date": "2026-02-09",
8
+ "version": "1.0.0",
9
+ "source": "rosett-ai",
10
+ "compatible_claude_code_versions": [">=0.1.0"]
11
+ },
12
+ "type": "object",
13
+ "required": ["tools"],
14
+ "additionalProperties": false,
15
+ "properties": {
16
+ "tools": {
17
+ "type": "object",
18
+ "description": "Map of tool names to their configuration",
19
+ "minProperties": 1,
20
+ "additionalProperties": {
21
+ "type": "object",
22
+ "required": ["description", "permission_pattern", "packages"],
23
+ "additionalProperties": false,
24
+ "properties": {
25
+ "description": {
26
+ "type": "string",
27
+ "minLength": 1,
28
+ "description": "Human-readable description of the tool"
29
+ },
30
+ "homepage": {
31
+ "type": "string",
32
+ "format": "uri",
33
+ "description": "URL to the tool's homepage or documentation"
34
+ },
35
+ "category": {
36
+ "type": "string",
37
+ "enum": ["json", "yaml", "search", "text", "system", "network", "other"],
38
+ "description": "Category for organizing tools"
39
+ },
40
+ "permission_pattern": {
41
+ "type": "string",
42
+ "pattern": "^Bash\\([a-z0-9_-]+:\\*\\)$",
43
+ "description": "Claude Code permission pattern (e.g., 'Bash(jq:*)')"
44
+ },
45
+ "packages": {
46
+ "type": "object",
47
+ "description": "Map of package manager to package name",
48
+ "minProperties": 1,
49
+ "additionalProperties": false,
50
+ "properties": {
51
+ "apt": { "type": "string", "minLength": 1 },
52
+ "dnf": { "type": "string", "minLength": 1 },
53
+ "pacman": { "type": "string", "minLength": 1 },
54
+ "zypper": { "type": "string", "minLength": 1 },
55
+ "brew": { "type": "string", "minLength": 1 },
56
+ "flatpak": { "type": "string", "minLength": 1 },
57
+ "snap": { "type": "string", "minLength": 1 },
58
+ "nix": { "type": "string", "minLength": 1 }
59
+ }
60
+ }
61
+ }
62
+ }
63
+ }
64
+ }
65
+ }