igniter 0.5.1 → 0.5.2

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 (1132) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +169 -215
  3. data/docs/README.md +12 -15
  4. data/docs/assets/README.md +8 -0
  5. data/docs/concepts/README.md +18 -0
  6. data/docs/concepts/igniter.md +119 -0
  7. data/docs/dev/README.md +48 -0
  8. data/docs/dev/agent-orchestra-dna.md +271 -0
  9. data/docs/dev/ai-agents-target-plan.md +178 -0
  10. data/docs/dev/application-target-plan.md +45 -0
  11. data/docs/dev/application-web-integration.md +59 -0
  12. data/docs/dev/application-web-poc-pattern-guide.md +167 -0
  13. data/docs/dev/architect-supervisor-bootstrap.md +322 -0
  14. data/docs/dev/architecture.md +20 -0
  15. data/docs/dev/cluster-target-plan.md +43 -0
  16. data/docs/dev/contract-persistence-target-plan.md +426 -0
  17. data/docs/dev/current-runtime-snapshot.md +73 -0
  18. data/docs/dev/data-ownership.md +29 -0
  19. data/docs/dev/document-rotation.md +51 -0
  20. data/docs/dev/embed-target-plan.md +51 -0
  21. data/docs/dev/execution-model.md +324 -0
  22. data/docs/dev/igniter-web-dsl-sketch.md +151 -0
  23. data/docs/dev/igniter-web-target-plan.md +56 -0
  24. data/docs/dev/mcp-adapter-package-spec.md +81 -0
  25. data/docs/dev/module-system.md +46 -0
  26. data/docs/dev/package-map.md +112 -0
  27. data/docs/guide/README.md +77 -0
  28. data/docs/guide/ai-and-tools.md +33 -0
  29. data/docs/guide/api-and-runtime.md +38 -0
  30. data/docs/guide/app.md +45 -0
  31. data/docs/guide/application-capsules.md +139 -0
  32. data/docs/guide/application-showcase-portfolio.md +181 -0
  33. data/docs/guide/cli.md +70 -0
  34. data/docs/guide/cluster.md +55 -0
  35. data/docs/guide/configuration.md +31 -0
  36. data/docs/guide/contract-class-dsl.md +154 -0
  37. data/docs/guide/core-runtime-features.md +34 -0
  38. data/docs/guide/core.md +43 -0
  39. data/docs/guide/credentials.md +51 -0
  40. data/docs/guide/deployment-modes.md +63 -0
  41. data/docs/guide/distributed-workflows.md +21 -0
  42. data/docs/guide/getting-started.md +49 -0
  43. data/docs/guide/how-tos.md +33 -0
  44. data/docs/guide/igniter-lang-foundation.md +133 -0
  45. data/docs/guide/integrations.md +47 -0
  46. data/docs/guide/interactive-app-structure.md +91 -0
  47. data/docs/guide/store-adapters.md +183 -0
  48. data/docs/research/README.md +131 -0
  49. data/docs/research/contract-persistence-landing-zone.md +126 -0
  50. data/docs/research/contract-persistence-organic-model.md +279 -0
  51. data/docs/research/contract-persistence-organic-model.ru.md +277 -0
  52. data/docs/research/horizon-protocol.md +180 -0
  53. data/docs/research/igniter-lang-convergence-report.md +338 -0
  54. data/docs/research/project-status-horizon-report.md +363 -0
  55. data/docs/research/vision-handoff-protocol.md +141 -0
  56. data/docs/research/wizard-type-spec-architecture.md +293 -0
  57. data/docs/research/wizard-type-spec-research-request.md +134 -0
  58. data/docs/store/README.md +7 -0
  59. data/docs/store/convergence-audit.md +901 -0
  60. data/examples/README.md +148 -65
  61. data/examples/catalog.rb +1374 -300
  62. data/examples/cluster/incident_workflow.rb +70 -0
  63. data/examples/cluster/incidents.rb +63 -0
  64. data/examples/cluster/mesh_diagnostics.rb +89 -0
  65. data/examples/cluster/remediation.rb +63 -0
  66. data/examples/cluster/routing.rb +65 -0
  67. data/examples/contracts/aggregates.rb +39 -0
  68. data/examples/contracts/auditing.rb +35 -0
  69. data/examples/contracts/basic_pricing.rb +31 -0
  70. data/examples/contracts/branching.rb +36 -0
  71. data/examples/contracts/build_effect_executor_pack.rb +88 -0
  72. data/examples/contracts/build_your_own_pack.rb +82 -0
  73. data/examples/contracts/capabilities.rb +34 -0
  74. data/examples/contracts/class_callable.rb +45 -0
  75. data/examples/contracts/class_pricing.rb +32 -0
  76. data/examples/contracts/collection.rb +44 -0
  77. data/examples/contracts/commerce.rb +44 -0
  78. data/examples/contracts/compose_your_own_packs.rb +110 -0
  79. data/examples/contracts/composition.rb +61 -0
  80. data/examples/contracts/content_addressing.rb +33 -0
  81. data/examples/contracts/contractable_service.rb +43 -0
  82. data/examples/contracts/contractable_shadow.rb +69 -0
  83. data/examples/contracts/create_pack.rb +105 -0
  84. data/examples/contracts/dataflow.rb +57 -0
  85. data/examples/contracts/debug.rb +32 -0
  86. data/examples/contracts/debug_pack_authoring.rb +31 -0
  87. data/examples/contracts/diagnostics.rb +33 -0
  88. data/examples/contracts/differential.rb +97 -0
  89. data/examples/contracts/effects.rb +34 -0
  90. data/examples/contracts/embed_class_registration.rb +40 -0
  91. data/examples/contracts/embed_human_sugar.rb +106 -0
  92. data/examples/contracts/formula.rb +32 -0
  93. data/examples/contracts/incremental.rb +44 -0
  94. data/examples/contracts/introspection.rb +48 -0
  95. data/examples/contracts/invariants.rb +54 -0
  96. data/examples/contracts/journal.rb +37 -0
  97. data/examples/contracts/lang_foundation.rb +37 -0
  98. data/examples/contracts/mcp.rb +62 -0
  99. data/examples/contracts/mcp_host.rb +55 -0
  100. data/examples/contracts/mcp_server.rb +25 -0
  101. data/examples/contracts/piecewise.rb +30 -0
  102. data/examples/contracts/provenance.rb +55 -0
  103. data/examples/contracts/reactive.rb +62 -0
  104. data/examples/contracts/saga.rb +56 -0
  105. data/examples/contracts/scale.rb +30 -0
  106. data/examples/contracts/step_result.rb +58 -0
  107. data/examples/run.rb +9 -9
  108. data/lib/igniter/cluster.rb +3 -0
  109. data/lib/igniter/contract.rb +3 -0
  110. data/lib/igniter/monorepo_packages.rb +8 -9
  111. data/lib/igniter/version.rb +5 -0
  112. data/lib/igniter/web.rb +3 -0
  113. data/lib/igniter.rb +46 -54
  114. data/packages/igniter-agents/README.md +37 -15
  115. data/packages/igniter-agents/lib/igniter/agents/agent_definition.rb +26 -0
  116. data/packages/igniter-agents/lib/igniter/agents/agent_run.rb +47 -0
  117. data/packages/igniter-agents/lib/igniter/agents/agent_turn.rb +34 -0
  118. data/packages/igniter-agents/lib/igniter/agents/runner.rb +56 -0
  119. data/packages/igniter-agents/lib/igniter/agents/tool_call.rb +26 -0
  120. data/packages/igniter-agents/lib/igniter/agents/trace_event.rb +24 -0
  121. data/packages/igniter-agents/lib/igniter/agents.rb +25 -15
  122. data/packages/igniter-agents/lib/igniter-agents.rb +0 -4
  123. data/packages/igniter-ai/README.md +35 -13
  124. data/packages/igniter-ai/lib/igniter/ai/client.rb +18 -0
  125. data/packages/igniter-ai/lib/igniter/ai/error.rb +14 -0
  126. data/packages/igniter-ai/lib/igniter/ai/model_request.rb +28 -0
  127. data/packages/igniter-ai/lib/igniter/ai/model_response.rb +31 -0
  128. data/packages/igniter-ai/lib/igniter/ai/providers/fake.rb +24 -0
  129. data/packages/igniter-ai/lib/igniter/ai/providers/openai_responses.rb +100 -0
  130. data/packages/igniter-ai/lib/igniter/ai/providers/recorded.rb +40 -0
  131. data/packages/igniter-ai/lib/igniter/ai/usage.rb +32 -0
  132. data/packages/igniter-ai/lib/igniter/ai.rb +14 -84
  133. data/packages/igniter-application/README.md +194 -0
  134. data/packages/igniter-application/lib/igniter/application/agent_definition.rb +38 -0
  135. data/packages/igniter-application/lib/igniter/application/agent_registry.rb +33 -0
  136. data/packages/igniter-application/lib/igniter/application/agent_runtime.rb +29 -0
  137. data/packages/igniter-application/lib/igniter/application/agents_builder.rb +26 -0
  138. data/packages/igniter-application/lib/igniter/application/ai_builder.rb +26 -0
  139. data/packages/igniter-application/lib/igniter/application/ai_provider_definition.rb +59 -0
  140. data/packages/igniter-application/lib/igniter/application/ai_registry.rb +34 -0
  141. data/packages/igniter-application/lib/igniter/application/application_assembly_plan.rb +67 -0
  142. data/packages/igniter-application/lib/igniter/application/application_blueprint.rb +227 -0
  143. data/packages/igniter-application/lib/igniter/application/application_capsule_report.rb +61 -0
  144. data/packages/igniter-application/lib/igniter/application/application_composition_report.rb +161 -0
  145. data/packages/igniter-application/lib/igniter/application/application_handoff_manifest.rb +100 -0
  146. data/packages/igniter-application/lib/igniter/application/application_host_activation_commit_readiness.rb +182 -0
  147. data/packages/igniter-application/lib/igniter/application/application_host_activation_dry_run_result.rb +190 -0
  148. data/packages/igniter-application/lib/igniter/application/application_host_activation_ledger_commit.rb +285 -0
  149. data/packages/igniter-application/lib/igniter/application/application_host_activation_ledger_verification.rb +301 -0
  150. data/packages/igniter-application/lib/igniter/application/application_host_activation_operation_digest.rb +68 -0
  151. data/packages/igniter-application/lib/igniter/application/application_host_activation_plan.rb +200 -0
  152. data/packages/igniter-application/lib/igniter/application/application_host_activation_plan_verification.rb +140 -0
  153. data/packages/igniter-application/lib/igniter/application/application_host_activation_readiness.rb +226 -0
  154. data/packages/igniter-application/lib/igniter/application/application_host_activation_receipt.rb +151 -0
  155. data/packages/igniter-application/lib/igniter/application/application_layout.rb +91 -0
  156. data/packages/igniter-application/lib/igniter/application/application_load_path.rb +38 -0
  157. data/packages/igniter-application/lib/igniter/application/application_load_report.rb +74 -0
  158. data/packages/igniter-application/lib/igniter/application/application_manifest.rb +65 -0
  159. data/packages/igniter-application/lib/igniter/application/application_structure_entry.rb +58 -0
  160. data/packages/igniter-application/lib/igniter/application/application_structure_plan.rb +128 -0
  161. data/packages/igniter-application/lib/igniter/application/application_transfer_applied_verification.rb +301 -0
  162. data/packages/igniter-application/lib/igniter/application/application_transfer_apply_plan.rb +167 -0
  163. data/packages/igniter-application/lib/igniter/application/application_transfer_apply_result.rb +321 -0
  164. data/packages/igniter-application/lib/igniter/application/application_transfer_bundle_artifact.rb +160 -0
  165. data/packages/igniter-application/lib/igniter/application/application_transfer_bundle_plan.rb +125 -0
  166. data/packages/igniter-application/lib/igniter/application/application_transfer_bundle_verification.rb +154 -0
  167. data/packages/igniter-application/lib/igniter/application/application_transfer_intake_plan.rb +195 -0
  168. data/packages/igniter-application/lib/igniter/application/application_transfer_inventory.rb +153 -0
  169. data/packages/igniter-application/lib/igniter/application/application_transfer_readiness.rb +260 -0
  170. data/packages/igniter-application/lib/igniter/application/application_transfer_receipt.rb +179 -0
  171. data/packages/igniter-application/lib/igniter/application/artifact_reference.rb +39 -0
  172. data/packages/igniter-application/lib/igniter/application/boot_phase.rb +27 -0
  173. data/packages/igniter-application/lib/igniter/application/boot_plan.rb +55 -0
  174. data/packages/igniter-application/lib/igniter/application/boot_report.rb +70 -0
  175. data/packages/igniter-application/lib/igniter/application/capsule_builder.rb +396 -0
  176. data/packages/igniter-application/lib/igniter/application/capsule_export.rb +26 -0
  177. data/packages/igniter-application/lib/igniter/application/capsule_import.rb +38 -0
  178. data/packages/igniter-application/lib/igniter/application/collection_invoker.rb +54 -0
  179. data/packages/igniter-application/lib/igniter/application/collection_transport_adapter.rb +37 -0
  180. data/packages/igniter-application/lib/igniter/application/compose_invoker.rb +51 -0
  181. data/packages/igniter-application/lib/igniter/application/compose_transport_adapter.rb +34 -0
  182. data/packages/igniter-application/lib/igniter/application/config.rb +86 -0
  183. data/packages/igniter-application/lib/igniter/application/config_builder.rb +69 -0
  184. data/packages/igniter-application/lib/igniter/application/contract_registry.rb +30 -0
  185. data/packages/igniter-application/lib/igniter/application/credential_definition.rb +65 -0
  186. data/packages/igniter-application/lib/igniter/application/credential_store.rb +68 -0
  187. data/packages/igniter-application/lib/igniter/application/embedded_host.rb +23 -0
  188. data/packages/igniter-application/lib/igniter/application/environment.rb +1071 -0
  189. data/packages/igniter-application/lib/igniter/application/feature_slice.rb +61 -0
  190. data/packages/igniter-application/lib/igniter/application/feature_slice_report.rb +43 -0
  191. data/packages/igniter-application/lib/igniter/application/file_backed_host_activation_ledger_adapter.rb +138 -0
  192. data/packages/igniter-application/lib/igniter/application/file_backed_installed_capsule_registry.rb +132 -0
  193. data/packages/igniter-application/lib/igniter/application/flow_declaration.rb +62 -0
  194. data/packages/igniter-application/lib/igniter/application/flow_event.rb +50 -0
  195. data/packages/igniter-application/lib/igniter/application/flow_session_snapshot.rb +98 -0
  196. data/packages/igniter-application/lib/igniter/application/installed_capsule_entry.rb +47 -0
  197. data/packages/igniter-application/lib/igniter/application/interface.rb +11 -0
  198. data/packages/igniter-application/lib/igniter/application/kernel.rb +385 -0
  199. data/packages/igniter-application/lib/igniter/application/lifecycle_plan_step.rb +38 -0
  200. data/packages/igniter-application/lib/igniter/application/manual_loader.rb +18 -0
  201. data/packages/igniter-application/lib/igniter/application/manual_scheduler.rb +15 -0
  202. data/packages/igniter-application/lib/igniter/application/memory_session_store.rb +33 -0
  203. data/packages/igniter-application/lib/igniter/application/missing_credential_error.rb +23 -0
  204. data/packages/igniter-application/lib/igniter/application/mount_intent.rb +48 -0
  205. data/packages/igniter-application/lib/igniter/application/mount_registration.rb +49 -0
  206. data/packages/igniter-application/lib/igniter/application/pending_action.rb +39 -0
  207. data/packages/igniter-application/lib/igniter/application/pending_input.rb +45 -0
  208. data/packages/igniter-application/lib/igniter/application/plan_executor.rb +93 -0
  209. data/packages/igniter-application/lib/igniter/application/profile.rb +178 -0
  210. data/packages/igniter-application/lib/igniter/application/provider.rb +19 -0
  211. data/packages/igniter-application/lib/igniter/application/provider_lifecycle_report.rb +72 -0
  212. data/packages/igniter-application/lib/igniter/application/provider_lifecycle_result.rb +54 -0
  213. data/packages/igniter-application/lib/igniter/application/provider_registration.rb +19 -0
  214. data/packages/igniter-application/lib/igniter/application/rack_host.rb +311 -0
  215. data/packages/igniter-application/lib/igniter/application/seam_lifecycle_result.rb +62 -0
  216. data/packages/igniter-application/lib/igniter/application/service_definition.rb +25 -0
  217. data/packages/igniter-application/lib/igniter/application/service_registry.rb +58 -0
  218. data/packages/igniter-application/lib/igniter/application/session_entry.rb +46 -0
  219. data/packages/igniter-application/lib/igniter/application/shutdown_plan.rb +45 -0
  220. data/packages/igniter-application/lib/igniter/application/shutdown_report.rb +54 -0
  221. data/packages/igniter-application/lib/igniter/application/snapshot.rb +35 -0
  222. data/packages/igniter-application/lib/igniter/application/transport_request.rb +40 -0
  223. data/packages/igniter-application/lib/igniter/application/transport_response.rb +22 -0
  224. data/packages/igniter-application/lib/igniter/application.rb +354 -0
  225. data/packages/igniter-application/lib/igniter-application.rb +3 -0
  226. data/packages/igniter-cluster/README.md +112 -5
  227. data/packages/igniter-cluster/lib/igniter/cluster/active_incident_set.rb +40 -0
  228. data/packages/igniter-cluster/lib/igniter/cluster/admission_policy.rb +158 -0
  229. data/packages/igniter-cluster/lib/igniter/cluster/admission_result.rb +47 -0
  230. data/packages/igniter-cluster/lib/igniter/cluster/capability_catalog.rb +66 -0
  231. data/packages/igniter-cluster/lib/igniter/cluster/capability_definition.rb +42 -0
  232. data/packages/igniter-cluster/lib/igniter/cluster/capability_query.rb +162 -0
  233. data/packages/igniter-cluster/lib/igniter/cluster/capability_router.rb +11 -0
  234. data/packages/igniter-cluster/lib/igniter/cluster/cluster_diagnostics_executor.rb +184 -0
  235. data/packages/igniter-cluster/lib/igniter/cluster/cluster_diagnostics_report.rb +49 -0
  236. data/packages/igniter-cluster/lib/igniter/cluster/cluster_event.rb +34 -0
  237. data/packages/igniter-cluster/lib/igniter/cluster/cluster_event_log.rb +27 -0
  238. data/packages/igniter-cluster/lib/igniter/cluster/cluster_incident.rb +42 -0
  239. data/packages/igniter-cluster/lib/igniter/cluster/decision_explanation.rb +31 -0
  240. data/packages/igniter-cluster/lib/igniter/cluster/direct_placement.rb +11 -0
  241. data/packages/igniter-cluster/lib/igniter/cluster/discovery_feed.rb +22 -0
  242. data/packages/igniter-cluster/lib/igniter/cluster/environment.rb +380 -0
  243. data/packages/igniter-cluster/lib/igniter/cluster/errors.rb +9 -0
  244. data/packages/igniter-cluster/lib/igniter/cluster/failover_plan.rb +45 -0
  245. data/packages/igniter-cluster/lib/igniter/cluster/failover_step.rb +32 -0
  246. data/packages/igniter-cluster/lib/igniter/cluster/health_policy.rb +124 -0
  247. data/packages/igniter-cluster/lib/igniter/cluster/incident_action.rb +49 -0
  248. data/packages/igniter-cluster/lib/igniter/cluster/incident_entry.rb +98 -0
  249. data/packages/igniter-cluster/lib/igniter/cluster/incident_executor.rb +145 -0
  250. data/packages/igniter-cluster/lib/igniter/cluster/incident_workflow.rb +64 -0
  251. data/packages/igniter-cluster/lib/igniter/cluster/kernel.rb +75 -0
  252. data/packages/igniter-cluster/lib/igniter/cluster/kernel_seams.rb +249 -0
  253. data/packages/igniter-cluster/lib/igniter/cluster/lease_grant.rb +40 -0
  254. data/packages/igniter-cluster/lib/igniter/cluster/lease_plan.rb +40 -0
  255. data/packages/igniter-cluster/lib/igniter/cluster/lease_policy.rb +96 -0
  256. data/packages/igniter-cluster/lib/igniter/cluster/membership_delta.rb +36 -0
  257. data/packages/igniter-cluster/lib/igniter/cluster/membership_feed.rb +24 -0
  258. data/packages/igniter-cluster/lib/igniter/cluster/membership_projection.rb +45 -0
  259. data/packages/igniter-cluster/lib/igniter/cluster/membership_snapshot.rb +64 -0
  260. data/packages/igniter-cluster/lib/igniter/cluster/memory_incident_registry.rb +169 -0
  261. data/packages/igniter-cluster/lib/igniter/cluster/memory_peer_registry.rb +24 -0
  262. data/packages/igniter-cluster/lib/igniter/cluster/mesh_admission.rb +24 -0
  263. data/packages/igniter-cluster/lib/igniter/cluster/mesh_admission_result.rb +40 -0
  264. data/packages/igniter-cluster/lib/igniter/cluster/mesh_execution_attempt.rb +51 -0
  265. data/packages/igniter-cluster/lib/igniter/cluster/mesh_execution_request.rb +71 -0
  266. data/packages/igniter-cluster/lib/igniter/cluster/mesh_execution_response.rb +28 -0
  267. data/packages/igniter-cluster/lib/igniter/cluster/mesh_execution_trace.rb +32 -0
  268. data/packages/igniter-cluster/lib/igniter/cluster/mesh_executor.rb +497 -0
  269. data/packages/igniter-cluster/lib/igniter/cluster/mesh_membership.rb +89 -0
  270. data/packages/igniter-cluster/lib/igniter/cluster/mesh_membership_event.rb +32 -0
  271. data/packages/igniter-cluster/lib/igniter/cluster/mesh_membership_source.rb +49 -0
  272. data/packages/igniter-cluster/lib/igniter/cluster/mesh_retry_policy.rb +42 -0
  273. data/packages/igniter-cluster/lib/igniter/cluster/mesh_trust_policy.rb +131 -0
  274. data/packages/igniter-cluster/lib/igniter/cluster/operator_timeline.rb +33 -0
  275. data/packages/igniter-cluster/lib/igniter/cluster/ownership_claim.rb +30 -0
  276. data/packages/igniter-cluster/lib/igniter/cluster/ownership_plan.rb +40 -0
  277. data/packages/igniter-cluster/lib/igniter/cluster/ownership_policy.rb +100 -0
  278. data/packages/igniter-cluster/lib/igniter/cluster/peer.rb +86 -0
  279. data/packages/igniter-cluster/lib/igniter/cluster/peer_discovery.rb +62 -0
  280. data/packages/igniter-cluster/lib/igniter/cluster/peer_health.rb +55 -0
  281. data/packages/igniter-cluster/lib/igniter/cluster/peer_profile.rb +102 -0
  282. data/packages/igniter-cluster/lib/igniter/cluster/peer_topology.rb +62 -0
  283. data/packages/igniter-cluster/lib/igniter/cluster/peer_view.rb +42 -0
  284. data/packages/igniter-cluster/lib/igniter/cluster/permissive_admission.rb +11 -0
  285. data/packages/igniter-cluster/lib/igniter/cluster/placement_decision.rb +38 -0
  286. data/packages/igniter-cluster/lib/igniter/cluster/placement_policy.rb +131 -0
  287. data/packages/igniter-cluster/lib/igniter/cluster/plan_action_result.rb +72 -0
  288. data/packages/igniter-cluster/lib/igniter/cluster/plan_execution_report.rb +57 -0
  289. data/packages/igniter-cluster/lib/igniter/cluster/plan_executor.rb +314 -0
  290. data/packages/igniter-cluster/lib/igniter/cluster/policy_admission.rb +18 -0
  291. data/packages/igniter-cluster/lib/igniter/cluster/policy_placement.rb +69 -0
  292. data/packages/igniter-cluster/lib/igniter/cluster/policy_router.rb +70 -0
  293. data/packages/igniter-cluster/lib/igniter/cluster/profile.rb +97 -0
  294. data/packages/igniter-cluster/lib/igniter/cluster/projection_executor.rb +42 -0
  295. data/packages/igniter-cluster/lib/igniter/cluster/projection_policy.rb +107 -0
  296. data/packages/igniter-cluster/lib/igniter/cluster/projection_report.rb +35 -0
  297. data/packages/igniter-cluster/lib/igniter/cluster/projection_stage.rb +32 -0
  298. data/packages/igniter-cluster/lib/igniter/cluster/rebalance_move.rb +30 -0
  299. data/packages/igniter-cluster/lib/igniter/cluster/rebalance_plan.rb +40 -0
  300. data/packages/igniter-cluster/lib/igniter/cluster/recovery_timeline.rb +33 -0
  301. data/packages/igniter-cluster/lib/igniter/cluster/registry_membership_source.rb +97 -0
  302. data/packages/igniter-cluster/lib/igniter/cluster/remediation_plan.rb +45 -0
  303. data/packages/igniter-cluster/lib/igniter/cluster/remediation_policy.rb +119 -0
  304. data/packages/igniter-cluster/lib/igniter/cluster/remediation_step.rb +44 -0
  305. data/packages/igniter-cluster/lib/igniter/cluster/route.rb +34 -0
  306. data/packages/igniter-cluster/lib/igniter/cluster/route_policy.rb +104 -0
  307. data/packages/igniter-cluster/lib/igniter/cluster/route_request.rb +61 -0
  308. data/packages/igniter-cluster/lib/igniter/cluster/topology_policy.rb +154 -0
  309. data/packages/igniter-cluster/lib/igniter/cluster/transport_adapter.rb +53 -0
  310. data/packages/igniter-cluster/lib/igniter/cluster.rb +94 -57
  311. data/packages/igniter-contracts/README.md +239 -0
  312. data/packages/igniter-contracts/lib/igniter/contracts/api.rb +92 -0
  313. data/packages/igniter-contracts/lib/igniter/contracts/assembly/baseline_pack.rb +141 -0
  314. data/packages/igniter-contracts/lib/igniter/contracts/assembly/const_pack.rb +29 -0
  315. data/packages/igniter-contracts/lib/igniter/contracts/assembly/dsl_keyword.rb +21 -0
  316. data/packages/igniter-contracts/lib/igniter/contracts/assembly/hook_result_policies.rb +47 -0
  317. data/packages/igniter-contracts/lib/igniter/contracts/assembly/hook_spec.rb +73 -0
  318. data/packages/igniter-contracts/lib/igniter/contracts/assembly/hook_specs.rb +74 -0
  319. data/packages/igniter-contracts/lib/igniter/contracts/assembly/kernel.rb +220 -0
  320. data/packages/igniter-contracts/lib/igniter/contracts/assembly/node_type.rb +26 -0
  321. data/packages/igniter-contracts/lib/igniter/contracts/assembly/ordered_registry.rb +55 -0
  322. data/packages/igniter-contracts/lib/igniter/contracts/assembly/pack.rb +13 -0
  323. data/packages/igniter-contracts/lib/igniter/contracts/assembly/pack_manifest.rb +131 -0
  324. data/packages/igniter-contracts/lib/igniter/contracts/assembly/path_access.rb +76 -0
  325. data/packages/igniter-contracts/lib/igniter/contracts/assembly/profile.rb +133 -0
  326. data/packages/igniter-contracts/lib/igniter/contracts/assembly/project_pack.rb +42 -0
  327. data/packages/igniter-contracts/lib/igniter/contracts/assembly/registry.rb +57 -0
  328. data/packages/igniter-contracts/lib/igniter/contracts/assembly/step_result_pack.rb +42 -0
  329. data/packages/igniter-contracts/lib/igniter/contracts/assembly.rb +18 -0
  330. data/packages/igniter-contracts/lib/igniter/contracts/contract.rb +135 -0
  331. data/packages/igniter-contracts/lib/igniter/contracts/contractable.rb +288 -0
  332. data/packages/igniter-contracts/lib/igniter/contracts/environment.rb +51 -0
  333. data/packages/igniter-contracts/lib/igniter/contracts/errors.rb +47 -0
  334. data/packages/igniter-contracts/lib/igniter/contracts/execution/baseline_normalizers.rb +23 -0
  335. data/packages/igniter-contracts/lib/igniter/contracts/execution/baseline_runtime.rb +55 -0
  336. data/packages/igniter-contracts/lib/igniter/contracts/execution/baseline_validators.rb +113 -0
  337. data/packages/igniter-contracts/lib/igniter/contracts/execution/builder.rb +43 -0
  338. data/packages/igniter-contracts/lib/igniter/contracts/execution/compilation_report.rb +46 -0
  339. data/packages/igniter-contracts/lib/igniter/contracts/execution/compiled_graph.rb +21 -0
  340. data/packages/igniter-contracts/lib/igniter/contracts/execution/compiler.rb +66 -0
  341. data/packages/igniter-contracts/lib/igniter/contracts/execution/const_runtime.rb +15 -0
  342. data/packages/igniter-contracts/lib/igniter/contracts/execution/diagnostics.rb +24 -0
  343. data/packages/igniter-contracts/lib/igniter/contracts/execution/diagnostics_report.rb +40 -0
  344. data/packages/igniter-contracts/lib/igniter/contracts/execution/diagnostics_section.rb +37 -0
  345. data/packages/igniter-contracts/lib/igniter/contracts/execution/effect_invocation.rb +26 -0
  346. data/packages/igniter-contracts/lib/igniter/contracts/execution/execution_request.rb +28 -0
  347. data/packages/igniter-contracts/lib/igniter/contracts/execution/execution_result.rb +32 -0
  348. data/packages/igniter-contracts/lib/igniter/contracts/execution/inline_executor.rb +19 -0
  349. data/packages/igniter-contracts/lib/igniter/contracts/execution/mutable_named_values.rb +52 -0
  350. data/packages/igniter-contracts/lib/igniter/contracts/execution/named_values.rb +48 -0
  351. data/packages/igniter-contracts/lib/igniter/contracts/execution/operation.rb +42 -0
  352. data/packages/igniter-contracts/lib/igniter/contracts/execution/runtime.rb +43 -0
  353. data/packages/igniter-contracts/lib/igniter/contracts/execution/step_result.rb +51 -0
  354. data/packages/igniter-contracts/lib/igniter/contracts/execution/step_result_diagnostics.rb +35 -0
  355. data/packages/igniter-contracts/lib/igniter/contracts/execution/step_result_runtime.rb +51 -0
  356. data/packages/igniter-contracts/lib/igniter/contracts/execution/step_result_validators.rb +44 -0
  357. data/packages/igniter-contracts/lib/igniter/contracts/execution/structured_dump.rb +49 -0
  358. data/packages/igniter-contracts/lib/igniter/contracts/execution/validation_finding.rb +28 -0
  359. data/packages/igniter-contracts/lib/igniter/contracts/execution/validation_report.rb +46 -0
  360. data/packages/igniter-contracts/lib/igniter/contracts/execution.rb +28 -0
  361. data/packages/igniter-contracts/lib/igniter/contracts.rb +54 -0
  362. data/packages/igniter-contracts/lib/igniter/lang/backend.rb +19 -0
  363. data/packages/igniter-contracts/lib/igniter/lang/backends/ruby.rb +42 -0
  364. data/packages/igniter-contracts/lib/igniter/lang/diagnostic_payload.rb +174 -0
  365. data/packages/igniter-contracts/lib/igniter/lang/metadata_carrier_manifest.rb +112 -0
  366. data/packages/igniter-contracts/lib/igniter/lang/metadata_manifest.rb +128 -0
  367. data/packages/igniter-contracts/lib/igniter/lang/receipt_payload.rb +152 -0
  368. data/packages/igniter-contracts/lib/igniter/lang/schema_compatibility_diagnostic.rb +300 -0
  369. data/packages/igniter-contracts/lib/igniter/lang/types.rb +84 -0
  370. data/packages/igniter-contracts/lib/igniter/lang/verification_report.rb +226 -0
  371. data/packages/igniter-contracts/lib/igniter/lang.rb +27 -0
  372. data/packages/igniter-contracts/lib/igniter-contracts.rb +3 -0
  373. data/packages/igniter-embed/README.md +360 -0
  374. data/packages/igniter-embed/lib/igniter/embed/config.rb +155 -0
  375. data/packages/igniter-embed/lib/igniter/embed/container.rb +165 -0
  376. data/packages/igniter-embed/lib/igniter/embed/contract_handle.rb +23 -0
  377. data/packages/igniter-embed/lib/igniter/embed/contract_naming.rb +38 -0
  378. data/packages/igniter-embed/lib/igniter/embed/contractable/acceptance.rb +52 -0
  379. data/packages/igniter-embed/lib/igniter/embed/contractable/adapters.rb +33 -0
  380. data/packages/igniter-embed/lib/igniter/embed/contractable/config.rb +234 -0
  381. data/packages/igniter-embed/lib/igniter/embed/contractable/runner.rb +393 -0
  382. data/packages/igniter-embed/lib/igniter/embed/contractable/sugar_builder.rb +145 -0
  383. data/packages/igniter-embed/lib/igniter/embed/contractable.rb +29 -0
  384. data/packages/igniter-embed/lib/igniter/embed/contracts_builder.rb +54 -0
  385. data/packages/igniter-embed/lib/igniter/embed/errors.rb +14 -0
  386. data/packages/igniter-embed/lib/igniter/embed/execution_envelope.rb +50 -0
  387. data/packages/igniter-embed/lib/igniter/embed/host_builder.rb +39 -0
  388. data/packages/igniter-embed/lib/igniter/embed/rails.rb +21 -0
  389. data/packages/igniter-embed/lib/igniter/embed/registry.rb +78 -0
  390. data/packages/igniter-embed/lib/igniter/embed/sugar_expansion.rb +152 -0
  391. data/packages/igniter-embed/lib/igniter/embed.rb +38 -0
  392. data/packages/igniter-embed/lib/igniter-embed.rb +3 -0
  393. data/packages/igniter-extensions/README.md +364 -4
  394. data/packages/igniter-extensions/lib/igniter/extensions/contracts/aggregate_pack.rb +103 -0
  395. data/packages/igniter-extensions/lib/igniter/extensions/contracts/audit/builder.rb +132 -0
  396. data/packages/igniter-extensions/lib/igniter/extensions/contracts/audit/event.rb +34 -0
  397. data/packages/igniter-extensions/lib/igniter/extensions/contracts/audit/snapshot.rb +44 -0
  398. data/packages/igniter-extensions/lib/igniter/extensions/contracts/audit_pack.rb +60 -0
  399. data/packages/igniter-extensions/lib/igniter/extensions/contracts/branch_pack.rb +199 -0
  400. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities/declaration.rb +31 -0
  401. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities/error.rb +35 -0
  402. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities/policy.rb +20 -0
  403. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities/report.rb +47 -0
  404. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities/violation.rb +30 -0
  405. data/packages/igniter-extensions/lib/igniter/extensions/contracts/capabilities_pack.rb +146 -0
  406. data/packages/igniter-extensions/lib/igniter/extensions/contracts/collection_pack.rb +212 -0
  407. data/packages/igniter-extensions/lib/igniter/extensions/contracts/commerce_pack.rb +91 -0
  408. data/packages/igniter-extensions/lib/igniter/extensions/contracts/compose_pack.rb +213 -0
  409. data/packages/igniter-extensions/lib/igniter/extensions/contracts/content_addressing/cache.rb +59 -0
  410. data/packages/igniter-extensions/lib/igniter/extensions/contracts/content_addressing/content_key.rb +63 -0
  411. data/packages/igniter-extensions/lib/igniter/extensions/contracts/content_addressing/declaration.rb +47 -0
  412. data/packages/igniter-extensions/lib/igniter/extensions/contracts/content_addressing_pack.rb +90 -0
  413. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/profile.rb +196 -0
  414. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/report.rb +85 -0
  415. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/scaffold.rb +461 -0
  416. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/scope.rb +79 -0
  417. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/wizard.rb +269 -0
  418. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/workflow.rb +189 -0
  419. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/workflow_step.rb +51 -0
  420. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/write_result.rb +48 -0
  421. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/write_step.rb +63 -0
  422. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator/writer.rb +131 -0
  423. data/packages/igniter-extensions/lib/igniter/extensions/contracts/creator_pack.rb +128 -0
  424. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/aggregate_operators.rb +119 -0
  425. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/aggregate_state.rb +60 -0
  426. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/builder.rb +66 -0
  427. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/collection_result.rb +70 -0
  428. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/diff.rb +37 -0
  429. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/item_result.rb +44 -0
  430. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/result.rb +58 -0
  431. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/session.rb +173 -0
  432. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow/window_filter.rb +49 -0
  433. data/packages/igniter-extensions/lib/igniter/extensions/contracts/dataflow_pack.rb +66 -0
  434. data/packages/igniter-extensions/lib/igniter/extensions/contracts/debug/pack_audit.rb +181 -0
  435. data/packages/igniter-extensions/lib/igniter/extensions/contracts/debug/pack_snapshot.rb +46 -0
  436. data/packages/igniter-extensions/lib/igniter/extensions/contracts/debug/profile_snapshot.rb +50 -0
  437. data/packages/igniter-extensions/lib/igniter/extensions/contracts/debug/report.rb +50 -0
  438. data/packages/igniter-extensions/lib/igniter/extensions/contracts/debug_pack.rb +115 -0
  439. data/packages/igniter-extensions/lib/igniter/extensions/contracts/differential/divergence.rb +37 -0
  440. data/packages/igniter-extensions/lib/igniter/extensions/contracts/differential/formatter.rb +85 -0
  441. data/packages/igniter-extensions/lib/igniter/extensions/contracts/differential/report.rb +83 -0
  442. data/packages/igniter-extensions/lib/igniter/extensions/contracts/differential/runner.rb +136 -0
  443. data/packages/igniter-extensions/lib/igniter/extensions/contracts/differential_pack.rb +61 -0
  444. data/packages/igniter-extensions/lib/igniter/extensions/contracts/execution_report_pack.rb +38 -0
  445. data/packages/igniter-extensions/lib/igniter/extensions/contracts/incremental/formatter.rb +60 -0
  446. data/packages/igniter-extensions/lib/igniter/extensions/contracts/incremental/node_state.rb +30 -0
  447. data/packages/igniter-extensions/lib/igniter/extensions/contracts/incremental/result.rb +65 -0
  448. data/packages/igniter-extensions/lib/igniter/extensions/contracts/incremental/session.rb +146 -0
  449. data/packages/igniter-extensions/lib/igniter/extensions/contracts/incremental_pack.rb +40 -0
  450. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/builder.rb +27 -0
  451. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/cases_report.rb +47 -0
  452. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/error.rb +34 -0
  453. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/invariant.rb +30 -0
  454. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/report.rb +45 -0
  455. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/suite.rb +36 -0
  456. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants/violation.rb +39 -0
  457. data/packages/igniter-extensions/lib/igniter/extensions/contracts/invariants_pack.rb +88 -0
  458. data/packages/igniter-extensions/lib/igniter/extensions/contracts/journal_pack.rb +55 -0
  459. data/packages/igniter-extensions/lib/igniter/extensions/contracts/language/formula_pack.rb +185 -0
  460. data/packages/igniter-extensions/lib/igniter/extensions/contracts/language/piecewise_pack.rb +166 -0
  461. data/packages/igniter-extensions/lib/igniter/extensions/contracts/language/scale_pack.rb +147 -0
  462. data/packages/igniter-extensions/lib/igniter/extensions/contracts/lookup_pack.rb +50 -0
  463. data/packages/igniter-extensions/lib/igniter/extensions/contracts/mcp/creator_session.rb +105 -0
  464. data/packages/igniter-extensions/lib/igniter/extensions/contracts/mcp/tool_argument.rb +35 -0
  465. data/packages/igniter-extensions/lib/igniter/extensions/contracts/mcp/tool_definition.rb +33 -0
  466. data/packages/igniter-extensions/lib/igniter/extensions/contracts/mcp/tool_result.rb +28 -0
  467. data/packages/igniter-extensions/lib/igniter/extensions/contracts/mcp_pack.rb +335 -0
  468. data/packages/igniter-extensions/lib/igniter/extensions/contracts/provenance/builder.rb +80 -0
  469. data/packages/igniter-extensions/lib/igniter/extensions/contracts/provenance/lineage.rb +59 -0
  470. data/packages/igniter-extensions/lib/igniter/extensions/contracts/provenance/node_trace.rb +53 -0
  471. data/packages/igniter-extensions/lib/igniter/extensions/contracts/provenance/text_formatter.rb +62 -0
  472. data/packages/igniter-extensions/lib/igniter/extensions/contracts/provenance_pack.rb +52 -0
  473. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/builder.rb +43 -0
  474. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/dispatch_result.rb +59 -0
  475. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/engine.rb +79 -0
  476. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/event.rb +36 -0
  477. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/matcher.rb +20 -0
  478. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/plan.rb +58 -0
  479. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive/subscription.rb +29 -0
  480. data/packages/igniter-extensions/lib/igniter/extensions/contracts/reactive_pack.rb +169 -0
  481. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/compensation.rb +25 -0
  482. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/compensation_record.rb +28 -0
  483. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/compensation_set.rb +47 -0
  484. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/formatter.rb +39 -0
  485. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/result.rb +56 -0
  486. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga/runner.rb +124 -0
  487. data/packages/igniter-extensions/lib/igniter/extensions/contracts/saga_pack.rb +56 -0
  488. data/packages/igniter-extensions/lib/igniter/extensions/contracts.rb +445 -0
  489. data/packages/igniter-extensions/lib/igniter/extensions.rb +0 -2
  490. data/packages/igniter-hub/README.md +25 -0
  491. data/packages/igniter-hub/lib/igniter/hub/catalog_entry.rb +35 -0
  492. data/packages/igniter-hub/lib/igniter/hub/local_catalog.rb +51 -0
  493. data/packages/igniter-hub/lib/igniter/hub.rb +16 -0
  494. data/packages/igniter-hub/lib/igniter-hub.rb +3 -0
  495. data/packages/igniter-mcp-adapter/README.md +65 -0
  496. data/packages/igniter-mcp-adapter/exe/igniter-mcp-adapter +6 -0
  497. data/packages/igniter-mcp-adapter/lib/igniter/mcp/adapter/host.rb +226 -0
  498. data/packages/igniter-mcp-adapter/lib/igniter/mcp/adapter/server.rb +148 -0
  499. data/packages/igniter-mcp-adapter/lib/igniter/mcp/adapter.rb +40 -0
  500. data/packages/igniter-mcp-adapter/lib/igniter-mcp-adapter.rb +5 -0
  501. data/packages/igniter-web/README.md +539 -0
  502. data/packages/igniter-web/lib/igniter/web/api.rb +49 -0
  503. data/packages/igniter-web/lib/igniter/web/application.rb +99 -0
  504. data/packages/igniter-web/lib/igniter/web/application_web_mount.rb +162 -0
  505. data/packages/igniter-web/lib/igniter/web/arbre.rb +41 -0
  506. data/packages/igniter-web/lib/igniter/web/component.rb +103 -0
  507. data/packages/igniter-web/lib/igniter/web/components/view_action_node.rb +38 -0
  508. data/packages/igniter-web/lib/igniter/web/components/view_ask_node.rb +52 -0
  509. data/packages/igniter-web/lib/igniter/web/components/view_chat_node.rb +34 -0
  510. data/packages/igniter-web/lib/igniter/web/components/view_compare_node.rb +41 -0
  511. data/packages/igniter-web/lib/igniter/web/components/view_node.rb +30 -0
  512. data/packages/igniter-web/lib/igniter/web/components/view_screen.rb +34 -0
  513. data/packages/igniter-web/lib/igniter/web/components/view_stream_node.rb +32 -0
  514. data/packages/igniter-web/lib/igniter/web/components/view_zone.rb +26 -0
  515. data/packages/igniter-web/lib/igniter/web/components.rb +10 -0
  516. data/packages/igniter-web/lib/igniter/web/composer.rb +84 -0
  517. data/packages/igniter-web/lib/igniter/web/composition_finding.rb +16 -0
  518. data/packages/igniter-web/lib/igniter/web/composition_policy.rb +88 -0
  519. data/packages/igniter-web/lib/igniter/web/composition_preset.rb +131 -0
  520. data/packages/igniter-web/lib/igniter/web/composition_result.rb +27 -0
  521. data/packages/igniter-web/lib/igniter/web/flow_interaction_adapter.rb +104 -0
  522. data/packages/igniter-web/lib/igniter/web/flow_surface_projection.rb +121 -0
  523. data/packages/igniter-web/lib/igniter/web/interaction_target.rb +50 -0
  524. data/packages/igniter-web/lib/igniter/web/mount_context.rb +80 -0
  525. data/packages/igniter-web/lib/igniter/web/page.rb +110 -0
  526. data/packages/igniter-web/lib/igniter/web/record.rb +54 -0
  527. data/packages/igniter-web/lib/igniter/web/screen_spec.rb +109 -0
  528. data/packages/igniter-web/lib/igniter/web/surface_manifest.rb +370 -0
  529. data/packages/igniter-web/lib/igniter/web/surface_structure.rb +57 -0
  530. data/packages/igniter-web/lib/igniter/web/view_graph.rb +25 -0
  531. data/packages/igniter-web/lib/igniter/web/view_graph_renderer.rb +63 -0
  532. data/packages/igniter-web/lib/igniter/web/view_node.rb +37 -0
  533. data/packages/igniter-web/lib/igniter/web.rb +107 -0
  534. data/packages/igniter-web/lib/igniter-web.rb +3 -0
  535. metadata +531 -641
  536. data/bin/igniter-stack +0 -94
  537. data/examples/agent_orchestration.rb +0 -76
  538. data/examples/agents.rb +0 -151
  539. data/examples/async_store.rb +0 -47
  540. data/examples/basic_pricing.rb +0 -27
  541. data/examples/collection.rb +0 -43
  542. data/examples/collection_partial_failure.rb +0 -50
  543. data/examples/composition.rb +0 -39
  544. data/examples/consensus.rb +0 -241
  545. data/examples/dataflow.rb +0 -309
  546. data/examples/diagnostics.rb +0 -28
  547. data/examples/differential.rb +0 -161
  548. data/examples/distributed_server.rb +0 -94
  549. data/examples/distributed_workflow.rb +0 -52
  550. data/examples/effects.rb +0 -185
  551. data/examples/elocal_webhook.rb +0 -1
  552. data/examples/incremental.rb +0 -143
  553. data/examples/introspection.rb +0 -49
  554. data/examples/invariants.rb +0 -180
  555. data/examples/llm_tools.rb +0 -237
  556. data/examples/marketing_ergonomics.rb +0 -57
  557. data/examples/mesh.rb +0 -241
  558. data/examples/mesh_discovery.rb +0 -287
  559. data/examples/mesh_gossip.rb +0 -164
  560. data/examples/order_pipeline.rb +0 -163
  561. data/examples/provenance.rb +0 -122
  562. data/examples/reactive_auditing.rb +0 -50
  563. data/examples/ringcentral_routing.rb +0 -269
  564. data/examples/saga.rb +0 -110
  565. data/lib/igniter/stack.rb +0 -5
  566. data/packages/igniter-agents/lib/igniter/agent/mailbox.rb +0 -96
  567. data/packages/igniter-agents/lib/igniter/agent/message.rb +0 -21
  568. data/packages/igniter-agents/lib/igniter/agent/ref.rb +0 -87
  569. data/packages/igniter-agents/lib/igniter/agent/runner.rb +0 -141
  570. data/packages/igniter-agents/lib/igniter/agent/state_holder.rb +0 -23
  571. data/packages/igniter-agents/lib/igniter/agent.rb +0 -161
  572. data/packages/igniter-agents/lib/igniter/agents/observability/metrics_agent.rb +0 -130
  573. data/packages/igniter-agents/lib/igniter/agents/pipeline/batch_processor_agent.rb +0 -131
  574. data/packages/igniter-agents/lib/igniter/agents/proactive/alert_agent.rb +0 -111
  575. data/packages/igniter-agents/lib/igniter/agents/proactive/health_check_agent.rb +0 -122
  576. data/packages/igniter-agents/lib/igniter/agents/proactive_agent.rb +0 -208
  577. data/packages/igniter-agents/lib/igniter/agents/reliability/retry_agent.rb +0 -99
  578. data/packages/igniter-agents/lib/igniter/agents/scheduling/cron_agent.rb +0 -110
  579. data/packages/igniter-agents/lib/igniter/ai/agents/chain_agent.rb +0 -129
  580. data/packages/igniter-agents/lib/igniter/ai/agents/critic_agent.rb +0 -165
  581. data/packages/igniter-agents/lib/igniter/ai/agents/evaluator_agent.rb +0 -195
  582. data/packages/igniter-agents/lib/igniter/ai/agents/evolution_agent.rb +0 -288
  583. data/packages/igniter-agents/lib/igniter/ai/agents/observer_agent.rb +0 -186
  584. data/packages/igniter-agents/lib/igniter/ai/agents/planner_agent.rb +0 -212
  585. data/packages/igniter-agents/lib/igniter/ai/agents/router_agent.rb +0 -133
  586. data/packages/igniter-agents/lib/igniter/ai/agents/self_reflection_agent.rb +0 -177
  587. data/packages/igniter-agents/lib/igniter/ai/agents.rb +0 -25
  588. data/packages/igniter-agents/lib/igniter/registry.rb +0 -69
  589. data/packages/igniter-agents/lib/igniter/runtime/registry_agent_adapter.rb +0 -102
  590. data/packages/igniter-agents/lib/igniter/supervisor.rb +0 -170
  591. data/packages/igniter-ai/lib/igniter/ai/config.rb +0 -113
  592. data/packages/igniter-ai/lib/igniter/ai/context.rb +0 -74
  593. data/packages/igniter-ai/lib/igniter/ai/executor.rb +0 -352
  594. data/packages/igniter-ai/lib/igniter/ai/providers/anthropic.rb +0 -181
  595. data/packages/igniter-ai/lib/igniter/ai/providers/base.rb +0 -33
  596. data/packages/igniter-ai/lib/igniter/ai/providers/ollama.rb +0 -137
  597. data/packages/igniter-ai/lib/igniter/ai/providers/openai.rb +0 -182
  598. data/packages/igniter-ai/lib/igniter/ai/skill/feedback.rb +0 -116
  599. data/packages/igniter-ai/lib/igniter/ai/skill/output_schema.rb +0 -110
  600. data/packages/igniter-ai/lib/igniter/ai/skill/runtime_contract.rb +0 -87
  601. data/packages/igniter-ai/lib/igniter/ai/skill.rb +0 -107
  602. data/packages/igniter-ai/lib/igniter/ai/tool_registry.rb +0 -79
  603. data/packages/igniter-ai/lib/igniter/ai/transcription/providers/assemblyai.rb +0 -200
  604. data/packages/igniter-ai/lib/igniter/ai/transcription/providers/base.rb +0 -122
  605. data/packages/igniter-ai/lib/igniter/ai/transcription/providers/deepgram.rb +0 -162
  606. data/packages/igniter-ai/lib/igniter/ai/transcription/providers/openai.rb +0 -102
  607. data/packages/igniter-ai/lib/igniter/ai/transcription/transcriber.rb +0 -145
  608. data/packages/igniter-ai/lib/igniter/ai/transcription/transcript_result.rb +0 -29
  609. data/packages/igniter-app/README.md +0 -19
  610. data/packages/igniter-app/lib/igniter/app/app_config.rb +0 -43
  611. data/packages/igniter-app/lib/igniter/app/app_host.rb +0 -56
  612. data/packages/igniter-app/lib/igniter/app/app_host_config.rb +0 -27
  613. data/packages/igniter-app/lib/igniter/app/app_host_pack.rb +0 -13
  614. data/packages/igniter-app/lib/igniter/app/autoloader.rb +0 -18
  615. data/packages/igniter-app/lib/igniter/app/cluster_app_host.rb +0 -95
  616. data/packages/igniter-app/lib/igniter/app/cluster_app_host_config.rb +0 -78
  617. data/packages/igniter-app/lib/igniter/app/credentials/config_loader.rb +0 -152
  618. data/packages/igniter-app/lib/igniter/app/credentials/credential.rb +0 -48
  619. data/packages/igniter-app/lib/igniter/app/credentials/credential_policy.rb +0 -38
  620. data/packages/igniter-app/lib/igniter/app/credentials/events/credential_event.rb +0 -179
  621. data/packages/igniter-app/lib/igniter/app/credentials/events.rb +0 -12
  622. data/packages/igniter-app/lib/igniter/app/credentials/lease_request.rb +0 -153
  623. data/packages/igniter-app/lib/igniter/app/credentials/policies/ephemeral_lease_policy.rb +0 -35
  624. data/packages/igniter-app/lib/igniter/app/credentials/policies/local_only_policy.rb +0 -33
  625. data/packages/igniter-app/lib/igniter/app/credentials/policies.rb +0 -13
  626. data/packages/igniter-app/lib/igniter/app/credentials/store.rb +0 -21
  627. data/packages/igniter-app/lib/igniter/app/credentials/stores/file_store.rb +0 -114
  628. data/packages/igniter-app/lib/igniter/app/credentials/trail.rb +0 -254
  629. data/packages/igniter-app/lib/igniter/app/credentials.rb +0 -20
  630. data/packages/igniter-app/lib/igniter/app/dev_output_sync.rb +0 -4
  631. data/packages/igniter-app/lib/igniter/app/diagnostics/app_host_contributor.rb +0 -71
  632. data/packages/igniter-app/lib/igniter/app/diagnostics/cluster_app_host_contributor.rb +0 -97
  633. data/packages/igniter-app/lib/igniter/app/diagnostics/credential_contributor.rb +0 -66
  634. data/packages/igniter-app/lib/igniter/app/diagnostics/evolution_contributor.rb +0 -74
  635. data/packages/igniter-app/lib/igniter/app/diagnostics/ignite_contributor.rb +0 -121
  636. data/packages/igniter-app/lib/igniter/app/diagnostics/loader_contributor.rb +0 -68
  637. data/packages/igniter-app/lib/igniter/app/diagnostics/orchestration_contributor.rb +0 -200
  638. data/packages/igniter-app/lib/igniter/app/diagnostics/runtime_contributor.rb +0 -68
  639. data/packages/igniter-app/lib/igniter/app/diagnostics/scheduler_contributor.rb +0 -72
  640. data/packages/igniter-app/lib/igniter/app/diagnostics/sdk_contributor.rb +0 -284
  641. data/packages/igniter-app/lib/igniter/app/diagnostics.rb +0 -62
  642. data/packages/igniter-app/lib/igniter/app/evolution/approval_decision.rb +0 -115
  643. data/packages/igniter-app/lib/igniter/app/evolution/approval_request.rb +0 -36
  644. data/packages/igniter-app/lib/igniter/app/evolution/plan.rb +0 -72
  645. data/packages/igniter-app/lib/igniter/app/evolution/planner.rb +0 -85
  646. data/packages/igniter-app/lib/igniter/app/evolution/result.rb +0 -45
  647. data/packages/igniter-app/lib/igniter/app/evolution/runner.rb +0 -102
  648. data/packages/igniter-app/lib/igniter/app/evolution/store.rb +0 -21
  649. data/packages/igniter-app/lib/igniter/app/evolution/stores/file_store.rb +0 -241
  650. data/packages/igniter-app/lib/igniter/app/evolution/trail.rb +0 -108
  651. data/packages/igniter-app/lib/igniter/app/evolution.rb +0 -11
  652. data/packages/igniter-app/lib/igniter/app/filesystem_loader_adapter.rb +0 -21
  653. data/packages/igniter-app/lib/igniter/app/generator.rb +0 -636
  654. data/packages/igniter-app/lib/igniter/app/generators/cluster.rb +0 -1367
  655. data/packages/igniter-app/lib/igniter/app/generators/dashboard.rb +0 -152
  656. data/packages/igniter-app/lib/igniter/app/generators/playground.rb +0 -1227
  657. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/README.md.erb +0 -37
  658. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/app.rb.erb +0 -19
  659. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/contexts/home_context.rb.erb +0 -54
  660. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/frontend/application.js.erb +0 -3
  661. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/spec/dashboard_app_spec.rb.erb +0 -79
  662. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/support/stack_overview.rb.erb +0 -23
  663. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/web/handlers/home_handler.rb.erb +0 -27
  664. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/web/views/home_page.arb.erb +0 -44
  665. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/web/views/home_page.rb.erb +0 -56
  666. data/packages/igniter-app/lib/igniter/app/generators/templates/dashboard/web/views/layout.arb.erb +0 -17
  667. data/packages/igniter-app/lib/igniter/app/host_adapter.rb +0 -26
  668. data/packages/igniter-app/lib/igniter/app/host_config.rb +0 -40
  669. data/packages/igniter-app/lib/igniter/app/host_registry.rb +0 -43
  670. data/packages/igniter-app/lib/igniter/app/loader_adapter.rb +0 -15
  671. data/packages/igniter-app/lib/igniter/app/loader_pack.rb +0 -8
  672. data/packages/igniter-app/lib/igniter/app/loader_registry.rb +0 -39
  673. data/packages/igniter-app/lib/igniter/app/observability/operator_action_handler.rb +0 -147
  674. data/packages/igniter-app/lib/igniter/app/observability/operator_console_handler.rb +0 -747
  675. data/packages/igniter-app/lib/igniter/app/observability/operator_overview_handler.rb +0 -350
  676. data/packages/igniter-app/lib/igniter/app/observability.rb +0 -5
  677. data/packages/igniter-app/lib/igniter/app/observability_pack.rb +0 -71
  678. data/packages/igniter-app/lib/igniter/app/operator/dispatcher.rb +0 -40
  679. data/packages/igniter-app/lib/igniter/app/operator/handler_registry.rb +0 -40
  680. data/packages/igniter-app/lib/igniter/app/operator/handler_result.rb +0 -67
  681. data/packages/igniter-app/lib/igniter/app/operator/handlers/base.rb +0 -79
  682. data/packages/igniter-app/lib/igniter/app/operator/handlers/ignite_handler.rb +0 -108
  683. data/packages/igniter-app/lib/igniter/app/operator/handlers/orchestration_handler.rb +0 -33
  684. data/packages/igniter-app/lib/igniter/app/operator/handlers.rb +0 -5
  685. data/packages/igniter-app/lib/igniter/app/operator/lifecycle_contract.rb +0 -55
  686. data/packages/igniter-app/lib/igniter/app/operator/policy.rb +0 -157
  687. data/packages/igniter-app/lib/igniter/app/operator.rb +0 -17
  688. data/packages/igniter-app/lib/igniter/app/orchestration/action_result_builder.rb +0 -65
  689. data/packages/igniter-app/lib/igniter/app/orchestration/followup_request.rb +0 -36
  690. data/packages/igniter-app/lib/igniter/app/orchestration/handler_registry.rb +0 -58
  691. data/packages/igniter-app/lib/igniter/app/orchestration/handlers.rb +0 -106
  692. data/packages/igniter-app/lib/igniter/app/orchestration/inbox.rb +0 -283
  693. data/packages/igniter-app/lib/igniter/app/orchestration/inbox_query.rb +0 -293
  694. data/packages/igniter-app/lib/igniter/app/orchestration/lane_registry.rb +0 -100
  695. data/packages/igniter-app/lib/igniter/app/orchestration/operator_query.rb +0 -449
  696. data/packages/igniter-app/lib/igniter/app/orchestration/plan.rb +0 -68
  697. data/packages/igniter-app/lib/igniter/app/orchestration/planner.rb +0 -89
  698. data/packages/igniter-app/lib/igniter/app/orchestration/policies.rb +0 -125
  699. data/packages/igniter-app/lib/igniter/app/orchestration/policy_registry.rb +0 -63
  700. data/packages/igniter-app/lib/igniter/app/orchestration/result.rb +0 -43
  701. data/packages/igniter-app/lib/igniter/app/orchestration/routing_registry.rb +0 -43
  702. data/packages/igniter-app/lib/igniter/app/orchestration/runner.rb +0 -50
  703. data/packages/igniter-app/lib/igniter/app/orchestration/runtime_event_query.rb +0 -205
  704. data/packages/igniter-app/lib/igniter/app/orchestration/runtime_overview_builder.rb +0 -286
  705. data/packages/igniter-app/lib/igniter/app/orchestration/runtime_query_overview_builder.rb +0 -20
  706. data/packages/igniter-app/lib/igniter/app/orchestration/runtime_result_builder.rb +0 -23
  707. data/packages/igniter-app/lib/igniter/app/orchestration.rb +0 -113
  708. data/packages/igniter-app/lib/igniter/app/runtime.rb +0 -4
  709. data/packages/igniter-app/lib/igniter/app/runtime_context.rb +0 -101
  710. data/packages/igniter-app/lib/igniter/app/runtime_pack.rb +0 -16
  711. data/packages/igniter-app/lib/igniter/app/scaffold_pack.rb +0 -6
  712. data/packages/igniter-app/lib/igniter/app/scheduler.rb +0 -109
  713. data/packages/igniter-app/lib/igniter/app/scheduler_adapter.rb +0 -17
  714. data/packages/igniter-app/lib/igniter/app/scheduler_pack.rb +0 -8
  715. data/packages/igniter-app/lib/igniter/app/scheduler_registry.rb +0 -39
  716. data/packages/igniter-app/lib/igniter/app/stack.rb +0 -1726
  717. data/packages/igniter-app/lib/igniter/app/stack_pack.rb +0 -3
  718. data/packages/igniter-app/lib/igniter/app/threaded_scheduler_adapter.rb +0 -35
  719. data/packages/igniter-app/lib/igniter/app/yml_loader.rb +0 -43
  720. data/packages/igniter-app/lib/igniter/app.rb +0 -2367
  721. data/packages/igniter-app/lib/igniter/ignite/bootstrap_agent.rb +0 -334
  722. data/packages/igniter-app/lib/igniter/ignite/bootstrap_target.rb +0 -79
  723. data/packages/igniter-app/lib/igniter/ignite/deployment_intent.rb +0 -82
  724. data/packages/igniter-app/lib/igniter/ignite/ignition_agent.rb +0 -1011
  725. data/packages/igniter-app/lib/igniter/ignite/ignition_plan.rb +0 -83
  726. data/packages/igniter-app/lib/igniter/ignite/ignition_report.rb +0 -144
  727. data/packages/igniter-app/lib/igniter/ignite/store.rb +0 -19
  728. data/packages/igniter-app/lib/igniter/ignite/stores/file_store.rb +0 -112
  729. data/packages/igniter-app/lib/igniter/ignite/trail.rb +0 -215
  730. data/packages/igniter-app/lib/igniter/ignite.rb +0 -11
  731. data/packages/igniter-app/lib/igniter-app.rb +0 -5
  732. data/packages/igniter-cluster/lib/igniter/cluster/agent_route_resolver.rb +0 -58
  733. data/packages/igniter-cluster/lib/igniter/cluster/consensus/cluster.rb +0 -187
  734. data/packages/igniter-cluster/lib/igniter/cluster/consensus/errors.rb +0 -16
  735. data/packages/igniter-cluster/lib/igniter/cluster/consensus/executors.rb +0 -45
  736. data/packages/igniter-cluster/lib/igniter/cluster/consensus/node.rb +0 -322
  737. data/packages/igniter-cluster/lib/igniter/cluster/consensus/read_query.rb +0 -32
  738. data/packages/igniter-cluster/lib/igniter/cluster/consensus/state_machine.rb +0 -60
  739. data/packages/igniter-cluster/lib/igniter/cluster/consensus.rb +0 -18
  740. data/packages/igniter-cluster/lib/igniter/cluster/diagnostics/governance_contributor.rb +0 -90
  741. data/packages/igniter-cluster/lib/igniter/cluster/diagnostics/identity_contributor.rb +0 -98
  742. data/packages/igniter-cluster/lib/igniter/cluster/diagnostics/routing_contributor.rb +0 -674
  743. data/packages/igniter-cluster/lib/igniter/cluster/diagnostics.rb +0 -24
  744. data/packages/igniter-cluster/lib/igniter/cluster/events/envelope.rb +0 -136
  745. data/packages/igniter-cluster/lib/igniter/cluster/events/hook_support.rb +0 -33
  746. data/packages/igniter-cluster/lib/igniter/cluster/events/log.rb +0 -102
  747. data/packages/igniter-cluster/lib/igniter/cluster/events/projection_feed.rb +0 -98
  748. data/packages/igniter-cluster/lib/igniter/cluster/events/read_model_projector.rb +0 -32
  749. data/packages/igniter-cluster/lib/igniter/cluster/events.rb +0 -131
  750. data/packages/igniter-cluster/lib/igniter/cluster/governance/admission_decision.rb +0 -41
  751. data/packages/igniter-cluster/lib/igniter/cluster/governance/admission_policy.rb +0 -66
  752. data/packages/igniter-cluster/lib/igniter/cluster/governance/admission_queue.rb +0 -88
  753. data/packages/igniter-cluster/lib/igniter/cluster/governance/admission_request.rb +0 -62
  754. data/packages/igniter-cluster/lib/igniter/cluster/governance/admission_workflow.rb +0 -214
  755. data/packages/igniter-cluster/lib/igniter/cluster/governance/checkpoint.rb +0 -141
  756. data/packages/igniter-cluster/lib/igniter/cluster/governance/compaction_record.rb +0 -33
  757. data/packages/igniter-cluster/lib/igniter/cluster/governance/stores/checkpoint_store.rb +0 -89
  758. data/packages/igniter-cluster/lib/igniter/cluster/governance/stores/file_store.rb +0 -249
  759. data/packages/igniter-cluster/lib/igniter/cluster/governance/trail.rb +0 -164
  760. data/packages/igniter-cluster/lib/igniter/cluster/governance.rb +0 -12
  761. data/packages/igniter-cluster/lib/igniter/cluster/identity/capability_attestation.rb +0 -114
  762. data/packages/igniter-cluster/lib/igniter/cluster/identity/manifest.rb +0 -139
  763. data/packages/igniter-cluster/lib/igniter/cluster/identity/node_identity.rb +0 -106
  764. data/packages/igniter-cluster/lib/igniter/cluster/identity.rb +0 -5
  765. data/packages/igniter-cluster/lib/igniter/cluster/mesh/announcer.rb +0 -88
  766. data/packages/igniter-cluster/lib/igniter/cluster/mesh/checkpoint_gossip.rb +0 -60
  767. data/packages/igniter-cluster/lib/igniter/cluster/mesh/config.rb +0 -146
  768. data/packages/igniter-cluster/lib/igniter/cluster/mesh/discovery.rb +0 -44
  769. data/packages/igniter-cluster/lib/igniter/cluster/mesh/errors.rb +0 -36
  770. data/packages/igniter-cluster/lib/igniter/cluster/mesh/gossip.rb +0 -62
  771. data/packages/igniter-cluster/lib/igniter/cluster/mesh/mesh_ql.rb +0 -470
  772. data/packages/igniter-cluster/lib/igniter/cluster/mesh/node_observation.rb +0 -281
  773. data/packages/igniter-cluster/lib/igniter/cluster/mesh/observation_query.rb +0 -284
  774. data/packages/igniter-cluster/lib/igniter/cluster/mesh/peer.rb +0 -51
  775. data/packages/igniter-cluster/lib/igniter/cluster/mesh/peer_capacity_report.rb +0 -42
  776. data/packages/igniter-cluster/lib/igniter/cluster/mesh/peer_identity_envelope.rb +0 -158
  777. data/packages/igniter-cluster/lib/igniter/cluster/mesh/peer_metadata.rb +0 -122
  778. data/packages/igniter-cluster/lib/igniter/cluster/mesh/peer_registry.rb +0 -81
  779. data/packages/igniter-cluster/lib/igniter/cluster/mesh/placement_decision.rb +0 -64
  780. data/packages/igniter-cluster/lib/igniter/cluster/mesh/placement_planner.rb +0 -154
  781. data/packages/igniter-cluster/lib/igniter/cluster/mesh/placement_policy.rb +0 -103
  782. data/packages/igniter-cluster/lib/igniter/cluster/mesh/poller.rb +0 -92
  783. data/packages/igniter-cluster/lib/igniter/cluster/mesh/rebalance_plan.rb +0 -66
  784. data/packages/igniter-cluster/lib/igniter/cluster/mesh/rebalance_planner.rb +0 -153
  785. data/packages/igniter-cluster/lib/igniter/cluster/mesh/repair_loop.rb +0 -169
  786. data/packages/igniter-cluster/lib/igniter/cluster/mesh/router.rb +0 -306
  787. data/packages/igniter-cluster/lib/igniter/cluster/mesh/workload_signal.rb +0 -46
  788. data/packages/igniter-cluster/lib/igniter/cluster/mesh/workload_tracker.rb +0 -215
  789. data/packages/igniter-cluster/lib/igniter/cluster/mesh.rb +0 -452
  790. data/packages/igniter-cluster/lib/igniter/cluster/ownership/claim.rb +0 -69
  791. data/packages/igniter-cluster/lib/igniter/cluster/ownership/errors.rb +0 -19
  792. data/packages/igniter-cluster/lib/igniter/cluster/ownership/owner_client.rb +0 -76
  793. data/packages/igniter-cluster/lib/igniter/cluster/ownership/registry.rb +0 -98
  794. data/packages/igniter-cluster/lib/igniter/cluster/ownership/resolver.rb +0 -62
  795. data/packages/igniter-cluster/lib/igniter/cluster/ownership.rb +0 -81
  796. data/packages/igniter-cluster/lib/igniter/cluster/projection_store.rb +0 -62
  797. data/packages/igniter-cluster/lib/igniter/cluster/rag/chunk.rb +0 -49
  798. data/packages/igniter-cluster/lib/igniter/cluster/rag/fanout_retriever.rb +0 -93
  799. data/packages/igniter-cluster/lib/igniter/cluster/rag/knowledge_shard.rb +0 -140
  800. data/packages/igniter-cluster/lib/igniter/cluster/rag/net_http_adapter.rb +0 -85
  801. data/packages/igniter-cluster/lib/igniter/cluster/rag/ranker.rb +0 -46
  802. data/packages/igniter-cluster/lib/igniter/cluster/rag/retrieval_query.rb +0 -30
  803. data/packages/igniter-cluster/lib/igniter/cluster/rag/retrieval_result.rb +0 -77
  804. data/packages/igniter-cluster/lib/igniter/cluster/rag.rb +0 -38
  805. data/packages/igniter-cluster/lib/igniter/cluster/remote_adapter.rb +0 -101
  806. data/packages/igniter-cluster/lib/igniter/cluster/replication/bootstrapper.rb +0 -63
  807. data/packages/igniter-cluster/lib/igniter/cluster/replication/bootstrappers/gem.rb +0 -39
  808. data/packages/igniter-cluster/lib/igniter/cluster/replication/bootstrappers/git.rb +0 -46
  809. data/packages/igniter-cluster/lib/igniter/cluster/replication/bootstrappers/tarball.rb +0 -62
  810. data/packages/igniter-cluster/lib/igniter/cluster/replication/capability_query.rb +0 -675
  811. data/packages/igniter-cluster/lib/igniter/cluster/replication/expansion_plan.rb +0 -40
  812. data/packages/igniter-cluster/lib/igniter/cluster/replication/expansion_planner.rb +0 -154
  813. data/packages/igniter-cluster/lib/igniter/cluster/replication/manifest.rb +0 -47
  814. data/packages/igniter-cluster/lib/igniter/cluster/replication/network_topology.rb +0 -150
  815. data/packages/igniter-cluster/lib/igniter/cluster/replication/node_profile.rb +0 -134
  816. data/packages/igniter-cluster/lib/igniter/cluster/replication/reflective_replication_agent.rb +0 -259
  817. data/packages/igniter-cluster/lib/igniter/cluster/replication/replication_agent.rb +0 -89
  818. data/packages/igniter-cluster/lib/igniter/cluster/replication/ssh_session.rb +0 -79
  819. data/packages/igniter-cluster/lib/igniter/cluster/replication.rb +0 -38
  820. data/packages/igniter-cluster/lib/igniter/cluster/routed_agent_adapter.rb +0 -79
  821. data/packages/igniter-cluster/lib/igniter/cluster/routing_plan_executor.rb +0 -427
  822. data/packages/igniter-cluster/lib/igniter/cluster/routing_plan_result.rb +0 -38
  823. data/packages/igniter-cluster/lib/igniter/cluster/trust/admission_plan.rb +0 -34
  824. data/packages/igniter-cluster/lib/igniter/cluster/trust/admission_planner.rb +0 -76
  825. data/packages/igniter-cluster/lib/igniter/cluster/trust/admission_result.rb +0 -34
  826. data/packages/igniter-cluster/lib/igniter/cluster/trust/admission_runner.rb +0 -125
  827. data/packages/igniter-cluster/lib/igniter/cluster/trust/trust_assessment.rb +0 -37
  828. data/packages/igniter-cluster/lib/igniter/cluster/trust/trust_store.rb +0 -58
  829. data/packages/igniter-cluster/lib/igniter/cluster/trust/verifier.rb +0 -80
  830. data/packages/igniter-cluster/lib/igniter/cluster/trust.rb +0 -9
  831. data/packages/igniter-core/README.md +0 -21
  832. data/packages/igniter-core/lib/igniter/core/capabilities.rb +0 -70
  833. data/packages/igniter-core/lib/igniter/core/compiler/compiled_graph.rb +0 -218
  834. data/packages/igniter-core/lib/igniter/core/compiler/graph_compiler.rb +0 -70
  835. data/packages/igniter-core/lib/igniter/core/compiler/type_resolver.rb +0 -54
  836. data/packages/igniter-core/lib/igniter/core/compiler/validation_context.rb +0 -61
  837. data/packages/igniter-core/lib/igniter/core/compiler/validation_pipeline.rb +0 -33
  838. data/packages/igniter-core/lib/igniter/core/compiler/validator.rb +0 -19
  839. data/packages/igniter-core/lib/igniter/core/compiler/validators/agent_validator.rb +0 -142
  840. data/packages/igniter-core/lib/igniter/core/compiler/validators/await_validator.rb +0 -53
  841. data/packages/igniter-core/lib/igniter/core/compiler/validators/callable_validator.rb +0 -125
  842. data/packages/igniter-core/lib/igniter/core/compiler/validators/dependencies_validator.rb +0 -280
  843. data/packages/igniter-core/lib/igniter/core/compiler/validators/outputs_validator.rb +0 -66
  844. data/packages/igniter-core/lib/igniter/core/compiler/validators/remote_validator.rb +0 -60
  845. data/packages/igniter-core/lib/igniter/core/compiler/validators/type_compatibility_validator.rb +0 -84
  846. data/packages/igniter-core/lib/igniter/core/compiler/validators/uniqueness_validator.rb +0 -60
  847. data/packages/igniter-core/lib/igniter/core/compiler.rb +0 -21
  848. data/packages/igniter-core/lib/igniter/core/content_addressing.rb +0 -133
  849. data/packages/igniter-core/lib/igniter/core/contract.rb +0 -398
  850. data/packages/igniter-core/lib/igniter/core/dataflow/aggregate_operators.rb +0 -147
  851. data/packages/igniter-core/lib/igniter/core/dataflow/aggregate_state.rb +0 -77
  852. data/packages/igniter-core/lib/igniter/core/dataflow/diff.rb +0 -37
  853. data/packages/igniter-core/lib/igniter/core/dataflow/diff_state.rb +0 -81
  854. data/packages/igniter-core/lib/igniter/core/dataflow/incremental_collection_result.rb +0 -39
  855. data/packages/igniter-core/lib/igniter/core/dataflow/window_filter.rb +0 -48
  856. data/packages/igniter-core/lib/igniter/core/dataflow.rb +0 -65
  857. data/packages/igniter-core/lib/igniter/core/diagnostics/agent_contributor.rb +0 -241
  858. data/packages/igniter-core/lib/igniter/core/diagnostics/auditing/report/console_formatter.rb +0 -80
  859. data/packages/igniter-core/lib/igniter/core/diagnostics/auditing/report/markdown_formatter.rb +0 -22
  860. data/packages/igniter-core/lib/igniter/core/diagnostics/capability_contributor.rb +0 -162
  861. data/packages/igniter-core/lib/igniter/core/diagnostics/introspection/formatters/mermaid_formatter.rb +0 -58
  862. data/packages/igniter-core/lib/igniter/core/diagnostics/introspection/formatters/text_tree_formatter.rb +0 -44
  863. data/packages/igniter-core/lib/igniter/core/diagnostics/orchestration_contributor.rb +0 -75
  864. data/packages/igniter-core/lib/igniter/core/diagnostics/report.rb +0 -424
  865. data/packages/igniter-core/lib/igniter/core/diagnostics.rb +0 -58
  866. data/packages/igniter-core/lib/igniter/core/differential/divergence.rb +0 -29
  867. data/packages/igniter-core/lib/igniter/core/differential/formatter.rb +0 -96
  868. data/packages/igniter-core/lib/igniter/core/differential/report.rb +0 -86
  869. data/packages/igniter-core/lib/igniter/core/differential/runner.rb +0 -130
  870. data/packages/igniter-core/lib/igniter/core/differential.rb +0 -51
  871. data/packages/igniter-core/lib/igniter/core/dsl/contract_builder.rb +0 -652
  872. data/packages/igniter-core/lib/igniter/core/dsl/schema_builder.rb +0 -73
  873. data/packages/igniter-core/lib/igniter/core/dsl.rb +0 -9
  874. data/packages/igniter-core/lib/igniter/core/dto/record.rb +0 -189
  875. data/packages/igniter-core/lib/igniter/core/dto.rb +0 -8
  876. data/packages/igniter-core/lib/igniter/core/effect.rb +0 -95
  877. data/packages/igniter-core/lib/igniter/core/effect_registry.rb +0 -78
  878. data/packages/igniter-core/lib/igniter/core/errors.rb +0 -102
  879. data/packages/igniter-core/lib/igniter/core/events/bus.rb +0 -44
  880. data/packages/igniter-core/lib/igniter/core/events/event.rb +0 -82
  881. data/packages/igniter-core/lib/igniter/core/events.rb +0 -9
  882. data/packages/igniter-core/lib/igniter/core/execution_report/builder.rb +0 -54
  883. data/packages/igniter-core/lib/igniter/core/execution_report/formatter.rb +0 -50
  884. data/packages/igniter-core/lib/igniter/core/execution_report/node_entry.rb +0 -24
  885. data/packages/igniter-core/lib/igniter/core/execution_report/report.rb +0 -65
  886. data/packages/igniter-core/lib/igniter/core/execution_report.rb +0 -32
  887. data/packages/igniter-core/lib/igniter/core/executor.rb +0 -134
  888. data/packages/igniter-core/lib/igniter/core/executor_registry.rb +0 -44
  889. data/packages/igniter-core/lib/igniter/core/extensions/auditing/timeline.rb +0 -103
  890. data/packages/igniter-core/lib/igniter/core/extensions/auditing.rb +0 -10
  891. data/packages/igniter-core/lib/igniter/core/extensions/introspection/graph_formatter.rb +0 -134
  892. data/packages/igniter-core/lib/igniter/core/extensions/introspection/plan_formatter.rb +0 -85
  893. data/packages/igniter-core/lib/igniter/core/extensions/introspection/runtime_formatter.rb +0 -143
  894. data/packages/igniter-core/lib/igniter/core/extensions/introspection.rb +0 -12
  895. data/packages/igniter-core/lib/igniter/core/extensions/invariants.rb +0 -70
  896. data/packages/igniter-core/lib/igniter/core/extensions/reactive/engine.rb +0 -83
  897. data/packages/igniter-core/lib/igniter/core/extensions/reactive/matcher.rb +0 -21
  898. data/packages/igniter-core/lib/igniter/core/extensions/reactive/reaction.rb +0 -18
  899. data/packages/igniter-core/lib/igniter/core/extensions/reactive.rb +0 -12
  900. data/packages/igniter-core/lib/igniter/core/extensions.rb +0 -10
  901. data/packages/igniter-core/lib/igniter/core/fingerprint.rb +0 -43
  902. data/packages/igniter-core/lib/igniter/core/incremental/formatter.rb +0 -81
  903. data/packages/igniter-core/lib/igniter/core/incremental/result.rb +0 -69
  904. data/packages/igniter-core/lib/igniter/core/incremental/tracker.rb +0 -108
  905. data/packages/igniter-core/lib/igniter/core/incremental.rb +0 -50
  906. data/packages/igniter-core/lib/igniter/core/invariant.rb +0 -50
  907. data/packages/igniter-core/lib/igniter/core/memory/agent_memory.rb +0 -104
  908. data/packages/igniter-core/lib/igniter/core/memory/episode.rb +0 -29
  909. data/packages/igniter-core/lib/igniter/core/memory/fact.rb +0 -27
  910. data/packages/igniter-core/lib/igniter/core/memory/memorable.rb +0 -90
  911. data/packages/igniter-core/lib/igniter/core/memory/reflection_cycle.rb +0 -96
  912. data/packages/igniter-core/lib/igniter/core/memory/reflection_record.rb +0 -28
  913. data/packages/igniter-core/lib/igniter/core/memory/store.rb +0 -115
  914. data/packages/igniter-core/lib/igniter/core/memory/stores/in_memory.rb +0 -136
  915. data/packages/igniter-core/lib/igniter/core/memory/stores/sqlite.rb +0 -286
  916. data/packages/igniter-core/lib/igniter/core/memory.rb +0 -80
  917. data/packages/igniter-core/lib/igniter/core/metrics/collector.rb +0 -131
  918. data/packages/igniter-core/lib/igniter/core/metrics/prometheus_exporter.rb +0 -104
  919. data/packages/igniter-core/lib/igniter/core/metrics/snapshot.rb +0 -8
  920. data/packages/igniter-core/lib/igniter/core/metrics.rb +0 -37
  921. data/packages/igniter-core/lib/igniter/core/model/agent_interaction_contract.rb +0 -172
  922. data/packages/igniter-core/lib/igniter/core/model/agent_node.rb +0 -86
  923. data/packages/igniter-core/lib/igniter/core/model/aggregate_node.rb +0 -34
  924. data/packages/igniter-core/lib/igniter/core/model/await_node.rb +0 -21
  925. data/packages/igniter-core/lib/igniter/core/model/branch_node.rb +0 -82
  926. data/packages/igniter-core/lib/igniter/core/model/collection_node.rb +0 -32
  927. data/packages/igniter-core/lib/igniter/core/model/composition_node.rb +0 -22
  928. data/packages/igniter-core/lib/igniter/core/model/compute_node.rb +0 -90
  929. data/packages/igniter-core/lib/igniter/core/model/effect_node.rb +0 -37
  930. data/packages/igniter-core/lib/igniter/core/model/graph.rb +0 -15
  931. data/packages/igniter-core/lib/igniter/core/model/input_node.rb +0 -27
  932. data/packages/igniter-core/lib/igniter/core/model/node.rb +0 -22
  933. data/packages/igniter-core/lib/igniter/core/model/output_node.rb +0 -41
  934. data/packages/igniter-core/lib/igniter/core/model/remote_node.rb +0 -91
  935. data/packages/igniter-core/lib/igniter/core/model.rb +0 -20
  936. data/packages/igniter-core/lib/igniter/core/node_cache.rb +0 -231
  937. data/packages/igniter-core/lib/igniter/core/property_testing/formatter.rb +0 -66
  938. data/packages/igniter-core/lib/igniter/core/property_testing/generators.rb +0 -115
  939. data/packages/igniter-core/lib/igniter/core/property_testing/result.rb +0 -45
  940. data/packages/igniter-core/lib/igniter/core/property_testing/run.rb +0 -43
  941. data/packages/igniter-core/lib/igniter/core/property_testing/runner.rb +0 -47
  942. data/packages/igniter-core/lib/igniter/core/property_testing.rb +0 -64
  943. data/packages/igniter-core/lib/igniter/core/provenance/builder.rb +0 -126
  944. data/packages/igniter-core/lib/igniter/core/provenance/lineage.rb +0 -82
  945. data/packages/igniter-core/lib/igniter/core/provenance/node_trace.rb +0 -65
  946. data/packages/igniter-core/lib/igniter/core/provenance/text_formatter.rb +0 -70
  947. data/packages/igniter-core/lib/igniter/core/provenance.rb +0 -29
  948. data/packages/igniter-core/lib/igniter/core/runtime/agent_adapter.rb +0 -41
  949. data/packages/igniter-core/lib/igniter/core/runtime/agent_result_contract.rb +0 -91
  950. data/packages/igniter-core/lib/igniter/core/runtime/agent_route.rb +0 -60
  951. data/packages/igniter-core/lib/igniter/core/runtime/agent_route_resolver.rb +0 -26
  952. data/packages/igniter-core/lib/igniter/core/runtime/agent_session.rb +0 -922
  953. data/packages/igniter-core/lib/igniter/core/runtime/agent_session_query.rb +0 -379
  954. data/packages/igniter-core/lib/igniter/core/runtime/agent_transport.rb +0 -30
  955. data/packages/igniter-core/lib/igniter/core/runtime/cache.rb +0 -129
  956. data/packages/igniter-core/lib/igniter/core/runtime/collection_result.rb +0 -111
  957. data/packages/igniter-core/lib/igniter/core/runtime/deferred_result.rb +0 -66
  958. data/packages/igniter-core/lib/igniter/core/runtime/execution.rb +0 -913
  959. data/packages/igniter-core/lib/igniter/core/runtime/input_validator.rb +0 -129
  960. data/packages/igniter-core/lib/igniter/core/runtime/invalidator.rb +0 -52
  961. data/packages/igniter-core/lib/igniter/core/runtime/job_worker.rb +0 -39
  962. data/packages/igniter-core/lib/igniter/core/runtime/node_state.rb +0 -58
  963. data/packages/igniter-core/lib/igniter/core/runtime/orchestration_overview.rb +0 -213
  964. data/packages/igniter-core/lib/igniter/core/runtime/orchestration_runtime_state.rb +0 -176
  965. data/packages/igniter-core/lib/igniter/core/runtime/orchestration_transition_query.rb +0 -208
  966. data/packages/igniter-core/lib/igniter/core/runtime/planner.rb +0 -301
  967. data/packages/igniter-core/lib/igniter/core/runtime/proxy_agent_adapter.rb +0 -124
  968. data/packages/igniter-core/lib/igniter/core/runtime/remote_adapter.rb +0 -26
  969. data/packages/igniter-core/lib/igniter/core/runtime/resolver.rb +0 -951
  970. data/packages/igniter-core/lib/igniter/core/runtime/result.rb +0 -119
  971. data/packages/igniter-core/lib/igniter/core/runtime/runner_factory.rb +0 -20
  972. data/packages/igniter-core/lib/igniter/core/runtime/runners/inline_runner.rb +0 -21
  973. data/packages/igniter-core/lib/igniter/core/runtime/runners/store_runner.rb +0 -29
  974. data/packages/igniter-core/lib/igniter/core/runtime/runners/thread_pool_runner.rb +0 -37
  975. data/packages/igniter-core/lib/igniter/core/runtime/stores/active_record_store.rb +0 -53
  976. data/packages/igniter-core/lib/igniter/core/runtime/stores/file_store.rb +0 -91
  977. data/packages/igniter-core/lib/igniter/core/runtime/stores/memory_store.rb +0 -93
  978. data/packages/igniter-core/lib/igniter/core/runtime/stores/redis_store.rb +0 -93
  979. data/packages/igniter-core/lib/igniter/core/runtime/stores/sqlite_store.rb +0 -155
  980. data/packages/igniter-core/lib/igniter/core/runtime/stream_result.rb +0 -171
  981. data/packages/igniter-core/lib/igniter/core/runtime.rb +0 -41
  982. data/packages/igniter-core/lib/igniter/core/saga/compensation.rb +0 -31
  983. data/packages/igniter-core/lib/igniter/core/saga/compensation_record.rb +0 -20
  984. data/packages/igniter-core/lib/igniter/core/saga/executor.rb +0 -85
  985. data/packages/igniter-core/lib/igniter/core/saga/formatter.rb +0 -49
  986. data/packages/igniter-core/lib/igniter/core/saga/result.rb +0 -47
  987. data/packages/igniter-core/lib/igniter/core/saga.rb +0 -56
  988. data/packages/igniter-core/lib/igniter/core/stream_loop.rb +0 -80
  989. data/packages/igniter-core/lib/igniter/core/temporal.rb +0 -84
  990. data/packages/igniter-core/lib/igniter/core/tool/discoverable.rb +0 -151
  991. data/packages/igniter-core/lib/igniter/core/tool.rb +0 -56
  992. data/packages/igniter-core/lib/igniter/core/type_system.rb +0 -44
  993. data/packages/igniter-core/lib/igniter/core/version.rb +0 -5
  994. data/packages/igniter-core/lib/igniter/core.rb +0 -23
  995. data/packages/igniter-core/lib/igniter-core.rb +0 -3
  996. data/packages/igniter-extensions/lib/igniter/extensions/auditing.rb +0 -3
  997. data/packages/igniter-extensions/lib/igniter/extensions/capabilities.rb +0 -39
  998. data/packages/igniter-extensions/lib/igniter/extensions/content_addressing.rb +0 -5
  999. data/packages/igniter-extensions/lib/igniter/extensions/dataflow.rb +0 -117
  1000. data/packages/igniter-extensions/lib/igniter/extensions/differential.rb +0 -114
  1001. data/packages/igniter-extensions/lib/igniter/extensions/execution_report.rb +0 -27
  1002. data/packages/igniter-extensions/lib/igniter/extensions/incremental.rb +0 -50
  1003. data/packages/igniter-extensions/lib/igniter/extensions/introspection.rb +0 -3
  1004. data/packages/igniter-extensions/lib/igniter/extensions/invariants.rb +0 -3
  1005. data/packages/igniter-extensions/lib/igniter/extensions/provenance.rb +0 -45
  1006. data/packages/igniter-extensions/lib/igniter/extensions/reactive.rb +0 -3
  1007. data/packages/igniter-extensions/lib/igniter/extensions/saga.rb +0 -74
  1008. data/packages/igniter-frontend/README.md +0 -224
  1009. data/packages/igniter-frontend/lib/igniter/frontend/app.rb +0 -90
  1010. data/packages/igniter-frontend/lib/igniter/frontend/app_access.rb +0 -36
  1011. data/packages/igniter-frontend/lib/igniter/frontend/arbre/component.rb +0 -120
  1012. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/action_group.rb +0 -53
  1013. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/badge.rb +0 -91
  1014. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/boolean.rb +0 -53
  1015. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/breadcrumbs.rb +0 -71
  1016. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/card.rb +0 -114
  1017. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/conversation_panel.rb +0 -61
  1018. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/datetime.rb +0 -42
  1019. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/display_value_support.rb +0 -38
  1020. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/empty_state.rb +0 -39
  1021. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/event_list.rb +0 -44
  1022. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/filters.rb +0 -183
  1023. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/indicator.rb +0 -59
  1024. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/json_panel.rb +0 -36
  1025. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/key_value_list.rb +0 -40
  1026. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/loading_state.rb +0 -43
  1027. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/metric_grid.rb +0 -37
  1028. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/number.rb +0 -53
  1029. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/page_header.rb +0 -53
  1030. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/pagination.rb +0 -143
  1031. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/panel.rb +0 -67
  1032. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/percentage.rb +0 -79
  1033. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/resource_list.rb +0 -38
  1034. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/scenario_card.rb +0 -48
  1035. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/shell_columns.rb +0 -67
  1036. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/sidebar_shell.rb +0 -106
  1037. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/table_with.rb +0 -203
  1038. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/tabs.rb +0 -147
  1039. data/packages/igniter-frontend/lib/igniter/frontend/arbre/components/viz.rb +0 -185
  1040. data/packages/igniter-frontend/lib/igniter/frontend/arbre/page.rb +0 -74
  1041. data/packages/igniter-frontend/lib/igniter/frontend/arbre/raw_text_node.rb +0 -40
  1042. data/packages/igniter-frontend/lib/igniter/frontend/arbre/template_page.rb +0 -243
  1043. data/packages/igniter-frontend/lib/igniter/frontend/arbre.rb +0 -48
  1044. data/packages/igniter-frontend/lib/igniter/frontend/arbre_page.rb +0 -7
  1045. data/packages/igniter-frontend/lib/igniter/frontend/assets.rb +0 -101
  1046. data/packages/igniter-frontend/lib/igniter/frontend/builder.rb +0 -124
  1047. data/packages/igniter-frontend/lib/igniter/frontend/component.rb +0 -24
  1048. data/packages/igniter-frontend/lib/igniter/frontend/components.rb +0 -7
  1049. data/packages/igniter-frontend/lib/igniter/frontend/context.rb +0 -53
  1050. data/packages/igniter-frontend/lib/igniter/frontend/form_builder.rb +0 -63
  1051. data/packages/igniter-frontend/lib/igniter/frontend/handler.rb +0 -92
  1052. data/packages/igniter-frontend/lib/igniter/frontend/javascript.rb +0 -353
  1053. data/packages/igniter-frontend/lib/igniter/frontend/page.rb +0 -24
  1054. data/packages/igniter-frontend/lib/igniter/frontend/request.rb +0 -61
  1055. data/packages/igniter-frontend/lib/igniter/frontend/response.rb +0 -67
  1056. data/packages/igniter-frontend/lib/igniter/frontend/tailwind/realtime/adapters.rb +0 -226
  1057. data/packages/igniter-frontend/lib/igniter/frontend/tailwind/realtime/presets.rb +0 -147
  1058. data/packages/igniter-frontend/lib/igniter/frontend/tailwind/realtime.rb +0 -259
  1059. data/packages/igniter-frontend/lib/igniter/frontend/tailwind/surfaces.rb +0 -1074
  1060. data/packages/igniter-frontend/lib/igniter/frontend/tailwind/ui.rb +0 -1438
  1061. data/packages/igniter-frontend/lib/igniter/frontend/tailwind.rb +0 -180
  1062. data/packages/igniter-frontend/lib/igniter/frontend/version.rb +0 -9
  1063. data/packages/igniter-frontend/lib/igniter/frontend.rb +0 -35
  1064. data/packages/igniter-frontend/lib/igniter-frontend.rb +0 -3
  1065. data/packages/igniter-rails/README.md +0 -96
  1066. data/packages/igniter-rails/lib/igniter/plugins/rails/cable_adapter.rb +0 -49
  1067. data/packages/igniter-rails/lib/igniter/plugins/rails/contract_job.rb +0 -76
  1068. data/packages/igniter-rails/lib/igniter/plugins/rails/generators/contract/contract_generator.rb +0 -22
  1069. data/packages/igniter-rails/lib/igniter/plugins/rails/generators/contract/templates/contract.rb.tt +0 -22
  1070. data/packages/igniter-rails/lib/igniter/plugins/rails/generators/install/install_generator.rb +0 -33
  1071. data/packages/igniter-rails/lib/igniter/plugins/rails/generators/install/templates/igniter.rb.tt +0 -16
  1072. data/packages/igniter-rails/lib/igniter/plugins/rails/railtie.rb +0 -25
  1073. data/packages/igniter-rails/lib/igniter/plugins/rails/webhook_concern.rb +0 -49
  1074. data/packages/igniter-rails/lib/igniter/plugins/rails.rb +0 -12
  1075. data/packages/igniter-rails/lib/igniter-rails.rb +0 -3
  1076. data/packages/igniter-schema-rendering/README.md +0 -27
  1077. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/page.rb +0 -35
  1078. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/patcher.rb +0 -47
  1079. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/renderer.rb +0 -268
  1080. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/schema.rb +0 -172
  1081. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/store.rb +0 -53
  1082. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/submission_normalizer.rb +0 -117
  1083. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/submission_processor.rb +0 -91
  1084. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/submission_validator.rb +0 -62
  1085. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering/version.rb +0 -9
  1086. data/packages/igniter-schema-rendering/lib/igniter/schema_rendering.rb +0 -20
  1087. data/packages/igniter-schema-rendering/lib/igniter-schema-rendering.rb +0 -3
  1088. data/packages/igniter-sdk/README.md +0 -25
  1089. data/packages/igniter-sdk/lib/igniter/sdk/channels/base.rb +0 -84
  1090. data/packages/igniter-sdk/lib/igniter/sdk/channels/delivery_result.rb +0 -61
  1091. data/packages/igniter-sdk/lib/igniter/sdk/channels/message.rb +0 -101
  1092. data/packages/igniter-sdk/lib/igniter/sdk/channels/telegram.rb +0 -161
  1093. data/packages/igniter-sdk/lib/igniter/sdk/channels/webhook.rb +0 -213
  1094. data/packages/igniter-sdk/lib/igniter/sdk/channels.rb +0 -17
  1095. data/packages/igniter-sdk/lib/igniter/sdk/data/store.rb +0 -31
  1096. data/packages/igniter-sdk/lib/igniter/sdk/data/stores/file.rb +0 -113
  1097. data/packages/igniter-sdk/lib/igniter/sdk/data/stores/in_memory.rb +0 -63
  1098. data/packages/igniter-sdk/lib/igniter/sdk/data/stores/sqlite.rb +0 -144
  1099. data/packages/igniter-sdk/lib/igniter/sdk/data.rb +0 -34
  1100. data/packages/igniter-sdk/lib/igniter/sdk/tools/agent_bootstrap_tool.rb +0 -151
  1101. data/packages/igniter-sdk/lib/igniter/sdk/tools/local_workflow_selector_tool.rb +0 -269
  1102. data/packages/igniter-sdk/lib/igniter/sdk/tools/system_discovery_tool.rb +0 -198
  1103. data/packages/igniter-sdk/lib/igniter/sdk/tools.rb +0 -9
  1104. data/packages/igniter-sdk/lib/igniter/sdk.rb +0 -86
  1105. data/packages/igniter-sdk/lib/igniter-sdk.rb +0 -3
  1106. data/packages/igniter-server/README.md +0 -9
  1107. data/packages/igniter-server/lib/igniter/server/agent_session_store.rb +0 -98
  1108. data/packages/igniter-server/lib/igniter/server/agent_transport.rb +0 -95
  1109. data/packages/igniter-server/lib/igniter/server/app_host.rb +0 -3
  1110. data/packages/igniter-server/lib/igniter/server/client.rb +0 -256
  1111. data/packages/igniter-server/lib/igniter/server/config.rb +0 -70
  1112. data/packages/igniter-server/lib/igniter/server/handlers/agent_message_handler.rb +0 -107
  1113. data/packages/igniter-server/lib/igniter/server/handlers/agent_session_handler.rb +0 -125
  1114. data/packages/igniter-server/lib/igniter/server/handlers/base.rb +0 -105
  1115. data/packages/igniter-server/lib/igniter/server/handlers/contracts_handler.rb +0 -15
  1116. data/packages/igniter-server/lib/igniter/server/handlers/event_handler.rb +0 -32
  1117. data/packages/igniter-server/lib/igniter/server/handlers/execute_handler.rb +0 -43
  1118. data/packages/igniter-server/lib/igniter/server/handlers/health_handler.rb +0 -32
  1119. data/packages/igniter-server/lib/igniter/server/handlers/liveness_handler.rb +0 -20
  1120. data/packages/igniter-server/lib/igniter/server/handlers/manifest_handler.rb +0 -77
  1121. data/packages/igniter-server/lib/igniter/server/handlers/metrics_handler.rb +0 -51
  1122. data/packages/igniter-server/lib/igniter/server/handlers/peers_handler.rb +0 -136
  1123. data/packages/igniter-server/lib/igniter/server/handlers/readiness_handler.rb +0 -47
  1124. data/packages/igniter-server/lib/igniter/server/handlers/status_handler.rb +0 -27
  1125. data/packages/igniter-server/lib/igniter/server/http_server.rb +0 -222
  1126. data/packages/igniter-server/lib/igniter/server/rack_app.rb +0 -60
  1127. data/packages/igniter-server/lib/igniter/server/registry.rb +0 -56
  1128. data/packages/igniter-server/lib/igniter/server/remote_adapter.rb +0 -27
  1129. data/packages/igniter-server/lib/igniter/server/router.rb +0 -291
  1130. data/packages/igniter-server/lib/igniter/server/server_logger.rb +0 -54
  1131. data/packages/igniter-server/lib/igniter/server.rb +0 -130
  1132. data/packages/igniter-server/lib/igniter-server.rb +0 -3
@@ -1,187 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Manages a consensus cluster: node lifecycle, leader discovery,
7
- # high-level read/write, quorum checks, and Igniter::Contract integration.
8
- #
9
- # == Quick start (default KV state machine)
10
- #
11
- # cluster = Igniter::Cluster::Consensus::Cluster.start(nodes: %i[n1 n2 n3 n4 n5])
12
- # cluster.wait_for_leader
13
- # cluster.write(key: :price, value: 99)
14
- # cluster.read(:price) # => 99
15
- # cluster.stop!
16
- #
17
- # == Custom state machine
18
- #
19
- # class OrderBook < Igniter::Cluster::Consensus::StateMachine
20
- # apply :add do |state, cmd| state.merge(cmd[:id] => cmd[:data]) end
21
- # apply :cancel do |state, cmd| state.reject { |k, _| k == cmd[:id] } end
22
- # end
23
- #
24
- # cluster = Igniter::Cluster::Consensus::Cluster.start(
25
- # nodes: %i[n1 n2 n3 n4 n5],
26
- # state_machine: OrderBook,
27
- # )
28
- # cluster.write(type: :add, id: "o1", data: { price: 42 })
29
- # cluster.read("o1") # => { price: 42 }
30
- #
31
- # == Contract integration
32
- #
33
- # q = cluster.read_contract(key: :price)
34
- # q.resolve_all
35
- # q.result.value # => 99
36
- class Cluster
37
- attr_reader :node_ids, :state_machine_class
38
-
39
- # Start a cluster. Does NOT wait for leader election.
40
- # Call +wait_for_leader+ if you need a leader before proceeding.
41
- #
42
- # @param nodes [Array<Symbol>] Registry names for each node
43
- # @param state_machine [Class] StateMachine subclass (default: StateMachine)
44
- # @param verbose [Boolean] print Raft events to stdout
45
- def self.start(nodes:, state_machine: nil, verbose: false)
46
- new(nodes: nodes, state_machine: state_machine, verbose: verbose).tap(&:start!)
47
- end
48
-
49
- def initialize(nodes:, state_machine: nil, verbose: false)
50
- @node_ids = nodes.freeze
51
- @state_machine_class = state_machine || StateMachine
52
- @verbose = verbose
53
- end
54
-
55
- # Start all nodes.
56
- def start!
57
- @node_ids.each do |nid|
58
- Node.start(
59
- name: nid,
60
- peers: @node_ids.reject { |id| id == nid },
61
- state_machine: @state_machine_class,
62
- verbose: @verbose,
63
- )
64
- end
65
- self
66
- end
67
-
68
- # Stop all nodes gracefully.
69
- def stop!(timeout: 2)
70
- @node_ids.each do |nid|
71
- begin
72
- Igniter::Registry.find(nid)&.stop(timeout: timeout)
73
- Igniter::Registry.unregister(nid)
74
- rescue StandardError
75
- nil
76
- end
77
- end
78
- self
79
- end
80
-
81
- # Returns the Ref for the current leader, or +nil+ if none is available.
82
- def leader
83
- @node_ids.each do |nid|
84
- ref = Igniter::Registry.find(nid)
85
- next unless ref&.alive?
86
- return ref if ref.state[:role] == :leader
87
- end
88
- nil
89
- end
90
-
91
- # Block until a leader is elected or +timeout+ seconds elapse.
92
- #
93
- # @param timeout [Float] seconds to wait (default: ~2s, covers max election jitter)
94
- # @return [Agent::Ref] the leader Ref
95
- # @raise [NoLeaderError] if no leader is elected within the timeout
96
- def wait_for_leader(timeout: ELECTION_TIMEOUT_BASE + ELECTION_TIMEOUT_JITTER + 0.5)
97
- deadline = Process.clock_gettime(Process::CLOCK_MONOTONIC) + timeout
98
- loop do
99
- ref = leader
100
- return ref if ref
101
-
102
- remaining = deadline - Process.clock_gettime(Process::CLOCK_MONOTONIC)
103
- raise NoLeaderError, "No leader elected within #{timeout}s — cluster may lack quorum" if remaining <= 0
104
-
105
- sleep 0.05
106
- end
107
- end
108
-
109
- # Submit a command to the consensus log via the current leader.
110
- #
111
- # Default KV protocol: +cluster.write(key: :x, value: 42)+
112
- # Custom state machine: +cluster.write(type: :add_order, id: "o1", data: {...})+
113
- #
114
- # @raise [NoLeaderError] if no leader is currently available
115
- def write(command = {})
116
- raise NoLeaderError, "No quorum available — cluster cannot commit writes" unless has_quorum?
117
-
118
- ref = leader
119
- raise NoLeaderError, "No leader available — cluster may be electing or lacks quorum" unless ref
120
- ref.send(:client_write, command: command)
121
- self
122
- end
123
-
124
- # Read a key from the current leader's committed state machine.
125
- #
126
- # @raise [NoLeaderError] if no leader is available
127
- def read(key)
128
- ref = leader
129
- raise NoLeaderError, "No leader available" unless ref
130
- ref.state[:state_machine][key]
131
- end
132
-
133
- # Return a snapshot of the full state machine from the current leader.
134
- #
135
- # @raise [NoLeaderError] if no leader is available
136
- def state_machine_snapshot
137
- ref = leader
138
- raise NoLeaderError, "No leader available" unless ref
139
- ref.state[:state_machine].dup
140
- end
141
-
142
- # Number of alive nodes.
143
- def alive_count
144
- @node_ids.count { |nid| Igniter::Registry.find(nid)&.alive? }
145
- end
146
-
147
- # Minimum votes required for any Raft decision (⌊N/2⌋ + 1).
148
- def quorum_size
149
- (@node_ids.size / 2) + 1
150
- end
151
-
152
- # Returns +true+ if enough nodes are alive to elect a leader.
153
- def has_quorum?
154
- alive_count >= quorum_size
155
- end
156
-
157
- # Returns a +ReadQuery+ contract pre-configured for this cluster and key.
158
- # Resolve it like any Igniter::Contract:
159
- #
160
- # q = cluster.read_contract(key: :price)
161
- # q.resolve_all
162
- # q.result.value # => 99
163
- def read_contract(key:)
164
- ReadQuery.new(cluster: self, key: key)
165
- end
166
-
167
- # Status snapshot for every alive node in the cluster.
168
- # @return [Array<Hash>] one hash per alive node
169
- def status
170
- @node_ids.filter_map do |nid|
171
- ref = Igniter::Registry.find(nid)
172
- next unless ref&.alive?
173
- s = ref.state
174
- {
175
- node_id: s[:node_id],
176
- role: s[:role],
177
- term: s[:term],
178
- commit_index: s[:commit_index],
179
- log_size: s[:log].size,
180
- state_machine: s[:state_machine],
181
- }
182
- end
183
- end
184
- end
185
- end
186
- end
187
- end
@@ -1,16 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Base class for all consensus errors.
7
- class Error < Igniter::Error; end
8
-
9
- # Raised when no leader is available — cluster may be electing or lacks quorum.
10
- class NoLeaderError < Error; end
11
-
12
- # Raised when the cluster loses quorum mid-operation.
13
- class QuorumLostError < Error; end
14
- end
15
- end
16
- end
@@ -1,45 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Finds the current leader in a Cluster.
7
- # Raises +Igniter::ResolutionError+ if no leader is available —
8
- # the Resolver will enrich the error with graph/node context.
9
- class FindLeader < Igniter::Executor
10
- def call(cluster:)
11
- ref = cluster.leader
12
- raise Igniter::ResolutionError, "No leader in cluster — retry later" unless ref
13
- s = ref.state
14
- { ref: ref, term: s[:term], node_id: s[:node_id] }
15
- end
16
- end
17
-
18
- # Reads a single key from the leader's committed state machine.
19
- class ReadValue < Igniter::Executor
20
- def call(leader:, key:)
21
- leader[:ref].state[:state_machine][key]
22
- end
23
- end
24
-
25
- # Submits an arbitrary command to the consensus log and returns the command.
26
- # Useful for fan-out patterns (e.g., multiple parallel writes in a Contract).
27
- #
28
- # Receives +cluster:+ plus any additional named keyword arguments; those
29
- # extra kwargs become the command body:
30
- #
31
- # compute :write1, with: [:cluster, :cmd1], call: SubmitCommand
32
- #
33
- # The executor forwards +:cluster+ as the Cluster ref and treats all other
34
- # keyword arguments as the command payload.
35
- class SubmitCommand < Igniter::Executor
36
- def call(cluster:, **command_kwargs)
37
- ref = cluster.leader
38
- raise Igniter::ResolutionError, "No leader — cannot submit command" unless ref
39
- ref.send(:client_write, command: command_kwargs)
40
- command_kwargs
41
- end
42
- end
43
- end
44
- end
45
- end
@@ -1,322 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Value objects for sync-reply handlers.
7
- # Must be non-Hash so the Agent runner sends them as replies rather than
8
- # treating them as new state.
9
- NodeStatus = Struct.new(:node_id, :role, :term, :commit_index,
10
- :log_size, :state_machine, :leader, keyword_init: true)
11
- NodeReadResult = Struct.new(:data, keyword_init: true)
12
-
13
- # Timing constants — 1:20 heartbeat-to-election ratio for Ruby scheduling jitter.
14
- ELECTION_CHECK_INTERVAL = 0.05 # how often to poll for timeout (s)
15
- ELECTION_TIMEOUT_BASE = 1.0 # minimum idle time before election (s)
16
- ELECTION_TIMEOUT_JITTER = 0.5 # random addition to prevent split votes (s)
17
- HEARTBEAT_INTERVAL = 0.05 # leader heartbeat cadence (s)
18
-
19
- # Raft consensus agent — internal implementation.
20
- # Users should interact with +Cluster+ rather than +Node+ directly.
21
- #
22
- # The full Raft protocol (leader election, log replication, quorum-based
23
- # commit) is encapsulated here. The user-defined state machine is stored in
24
- # the agent state as +:state_machine_class+ and invoked on every commit.
25
- class Node < Igniter::Agent
26
- mailbox_size 2000
27
- mailbox_overflow :drop_oldest
28
-
29
- # Convenience factory — builds the correct initial_state automatically.
30
- #
31
- # @param name [Symbol] Registry key for this node
32
- # @param peers [Array<Symbol>] Registry keys of all other nodes
33
- # @param state_machine [Class] StateMachine subclass (default: StateMachine)
34
- # @param verbose [Boolean] print protocol events to stdout
35
- def self.start(name:, peers:, state_machine: StateMachine, verbose: false)
36
- super(
37
- name: name,
38
- initial_state: {
39
- node_id: name,
40
- peers: peers,
41
- state_machine_class: state_machine,
42
- verbose: verbose,
43
- role: :follower,
44
- term: 0,
45
- voted_for: nil,
46
- log: [],
47
- commit_index: -1,
48
- last_applied: -1,
49
- votes_received: [],
50
- state_machine: {},
51
- next_index: {},
52
- match_index: {},
53
- current_leader: nil,
54
- last_heartbeat_at: Process.clock_gettime(Process::CLOCK_MONOTONIC),
55
- election_timeout: ELECTION_TIMEOUT_BASE + rand * ELECTION_TIMEOUT_JITTER,
56
- }
57
- )
58
- end
59
-
60
- # Minimum votes required for a decision in a cluster of +size+ nodes.
61
- def self.quorum(size) = (size / 2) + 1
62
-
63
- # ── Internal helpers (called from schedule/on blocks) ────────────────────
64
-
65
- def self.find_peer(id) = Igniter::Registry.find(id)
66
-
67
- def self.log_msg(state, msg)
68
- $stdout.puts " [#{state[:node_id]}] #{msg}" if state[:verbose]
69
- end
70
-
71
- # Apply committed log entries to the state machine and return the updated
72
- # state_machine hash + last_applied index.
73
- def self.apply_entries(sm, last_applied, log, commit_index, sm_class)
74
- sm = sm.dup
75
- while last_applied < commit_index
76
- last_applied += 1
77
- cmd = log[last_applied]&.dig(:command)
78
- sm = sm_class.call(sm, cmd) if cmd
79
- end
80
- [sm, last_applied]
81
- end
82
-
83
- # ── Timer: election check ──────────────────────────────────────────────
84
- schedule :election_check, every: ELECTION_CHECK_INTERVAL do |state:|
85
- next state if state[:role] == :leader
86
-
87
- elapsed = Process.clock_gettime(Process::CLOCK_MONOTONIC) - state[:last_heartbeat_at]
88
- next state if elapsed < state[:election_timeout]
89
-
90
- new_term = state[:term] + 1
91
- nid = state[:node_id]
92
- lli = state[:log].size - 1
93
- llt = state[:log].empty? ? -1 : state[:log].last[:term]
94
-
95
- Node.log_msg(state, "timeout #{elapsed.round(2)}s → Candidate term=#{new_term}")
96
-
97
- state[:peers].each do |pid|
98
- Node.find_peer(pid)&.send(:request_vote, {
99
- term: new_term, candidate_id: nid,
100
- last_log_index: lli, last_log_term: llt,
101
- })
102
- end
103
-
104
- state.merge(
105
- role: :candidate, term: new_term,
106
- voted_for: nid, votes_received: [nid],
107
- last_heartbeat_at: Process.clock_gettime(Process::CLOCK_MONOTONIC),
108
- election_timeout: ELECTION_TIMEOUT_BASE + rand * ELECTION_TIMEOUT_JITTER,
109
- )
110
- end
111
-
112
- # ── Timer: heartbeat (leader only) ────────────────────────────────────
113
- schedule :heartbeat, every: HEARTBEAT_INTERVAL do |state:|
114
- next state unless state[:role] == :leader
115
-
116
- state[:peers].each do |pid|
117
- peer = Node.find_peer(pid)
118
- next unless peer
119
-
120
- mi = state[:match_index][pid] || -1
121
- next_idx = mi + 1
122
- prev_idx = next_idx - 1
123
- prev_term = state[:log][prev_idx]&.dig(:term) || -1
124
- entries = state[:log][next_idx..] || []
125
-
126
- peer.send(:append_entries, {
127
- term: state[:term], leader_id: state[:node_id],
128
- prev_log_index: prev_idx, prev_log_term: prev_term,
129
- entries: entries, leader_commit: state[:commit_index],
130
- })
131
- end
132
-
133
- state
134
- end
135
-
136
- # ── RequestVote ──────────────────────────────────────────────────────
137
- on :request_vote do |state:, payload:|
138
- msg = payload
139
- base = msg[:term] > state[:term] ?
140
- state.merge(term: msg[:term], role: :follower, voted_for: nil) : state
141
-
142
- our_lt = base[:log].empty? ? -1 : base[:log].last[:term]
143
- our_li = base[:log].size - 1
144
- log_ok = msg[:last_log_term] > our_lt ||
145
- (msg[:last_log_term] == our_lt && msg[:last_log_index] >= our_li)
146
-
147
- can_vote = msg[:term] >= base[:term] && log_ok &&
148
- (base[:voted_for].nil? || base[:voted_for] == msg[:candidate_id])
149
-
150
- sender = Node.find_peer(msg[:candidate_id])
151
-
152
- if can_vote
153
- Node.log_msg(state, "votes for #{msg[:candidate_id]} (term #{msg[:term]})")
154
- sender&.send(:vote_response, {
155
- term: msg[:term], vote_granted: true, voter_id: state[:node_id],
156
- })
157
- base.merge(
158
- voted_for: msg[:candidate_id],
159
- last_heartbeat_at: Process.clock_gettime(Process::CLOCK_MONOTONIC),
160
- )
161
- else
162
- sender&.send(:vote_response, {
163
- term: base[:term], vote_granted: false, voter_id: state[:node_id],
164
- })
165
- base
166
- end
167
- end
168
-
169
- # ── VoteResponse ────────────────────────────────────────────────────
170
- on :vote_response do |state:, payload:|
171
- msg = payload
172
- next state unless state[:role] == :candidate && msg[:term] == state[:term]
173
-
174
- if msg[:term] > state[:term]
175
- next state.merge(role: :follower, term: msg[:term], voted_for: nil)
176
- end
177
- next state unless msg[:vote_granted]
178
-
179
- votes = (state[:votes_received] + [msg[:voter_id]]).uniq
180
- quorum = Node.quorum(state[:peers].size + 1) # full cluster = peers + self
181
-
182
- if votes.size >= quorum
183
- ni = state[:peers].each_with_object({}) { |p, h| h[p] = state[:log].size }
184
- mi = state[:peers].each_with_object({}) { |p, h| h[p] = -1 }
185
- Node.log_msg(state, "*** LEADER (term=#{state[:term]}, votes=#{votes.size}/#{state[:peers].size + 1}) ***")
186
- state.merge(role: :leader, votes_received: votes,
187
- next_index: ni, match_index: mi)
188
- else
189
- state.merge(votes_received: votes)
190
- end
191
- end
192
-
193
- # ── AppendEntries ───────────────────────────────────────────────────
194
- on :append_entries do |state:, payload:|
195
- msg = payload
196
- sender = Node.find_peer(msg[:leader_id])
197
-
198
- if msg[:term] < state[:term]
199
- sender&.send(:append_entries_response, {
200
- term: state[:term], success: false,
201
- follower_id: state[:node_id], match_index: -1,
202
- })
203
- next state
204
- end
205
-
206
- s = state.merge(
207
- term: [state[:term], msg[:term]].max,
208
- role: :follower,
209
- voted_for: state[:term] == msg[:term] ? state[:voted_for] : nil,
210
- current_leader: msg[:leader_id],
211
- last_heartbeat_at: Process.clock_gettime(Process::CLOCK_MONOTONIC),
212
- )
213
-
214
- if msg[:prev_log_index] >= 0
215
- ok = s[:log].size > msg[:prev_log_index] &&
216
- s[:log][msg[:prev_log_index]]&.dig(:term) == msg[:prev_log_term]
217
- unless ok
218
- sender&.send(:append_entries_response, {
219
- term: s[:term], success: false,
220
- follower_id: state[:node_id], match_index: s[:log].size - 1,
221
- })
222
- next s
223
- end
224
- end
225
-
226
- new_log = s[:log].take(msg[:prev_log_index] + 1).concat(msg[:entries])
227
- new_commit = [[msg[:leader_commit], new_log.size - 1].min, s[:commit_index]].max
228
-
229
- sm, la = Node.apply_entries(s[:state_machine], s[:last_applied],
230
- new_log, new_commit, s[:state_machine_class])
231
-
232
- sender&.send(:append_entries_response, {
233
- term: s[:term], success: true,
234
- follower_id: state[:node_id], match_index: new_log.size - 1,
235
- })
236
-
237
- s.merge(log: new_log, commit_index: new_commit,
238
- last_applied: la, state_machine: sm)
239
- end
240
-
241
- # ── AppendEntriesResponse (leader) ──────────────────────────────────
242
- on :append_entries_response do |state:, payload:|
243
- msg = payload
244
- next state unless state[:role] == :leader
245
-
246
- if msg[:term] > state[:term]
247
- next state.merge(role: :follower, term: msg[:term], voted_for: nil)
248
- end
249
-
250
- pid = msg[:follower_id]
251
- new_mi = state[:match_index].dup
252
- new_ni = state[:next_index].dup
253
-
254
- if msg[:success]
255
- new_mi[pid] = [new_mi[pid] || -1, msg[:match_index]].max
256
- new_ni[pid] = new_mi[pid] + 1
257
- else
258
- new_ni[pid] = [(new_ni[pid] || 1) - 1, 0].max
259
- end
260
-
261
- new_log = state[:log]
262
- new_commit = state[:commit_index]
263
- quorum = Node.quorum(state[:peers].size + 1)
264
-
265
- ((new_commit + 1)...new_log.size).each do |n|
266
- next unless new_log[n][:term] == state[:term]
267
- replicated = new_mi.values.count { |m| m >= n } + 1 # +1 for leader
268
- new_commit = n if replicated >= quorum
269
- end
270
-
271
- sm, la = Node.apply_entries(state[:state_machine], state[:last_applied],
272
- new_log, new_commit, state[:state_machine_class])
273
-
274
- if new_commit > state[:commit_index]
275
- Node.log_msg(state, "committed idx=#{new_commit} → #{sm.inspect}")
276
- end
277
-
278
- state.merge(match_index: new_mi, next_index: new_ni,
279
- commit_index: new_commit, last_applied: la, state_machine: sm)
280
- end
281
-
282
- # ── client_write — appends to log (leader) or forwards ──────────────
283
- on :client_write do |state:, payload:|
284
- unless state[:role] == :leader
285
- ref = state[:current_leader] && Node.find_peer(state[:current_leader])
286
- if ref
287
- ref.send(:client_write, payload)
288
- else
289
- Node.log_msg(state, "no leader known — write dropped")
290
- end
291
- next state
292
- end
293
-
294
- entry = { term: state[:term], command: payload[:command] }
295
- new_log = state[:log] + [entry]
296
- Node.log_msg(state, "Leader appends log[#{new_log.size - 1}]: #{payload[:command].inspect}")
297
- state.merge(log: new_log)
298
- end
299
-
300
- # ── Sync query: status ───────────────────────────────────────────────
301
- # Returns NodeStatus (non-Hash) → runner sends as sync reply, NOT new state.
302
- on :status do |state:, payload:|
303
- NodeStatus.new(
304
- node_id: state[:node_id],
305
- role: state[:role],
306
- term: state[:term],
307
- commit_index: state[:commit_index],
308
- log_size: state[:log].size,
309
- state_machine: state[:state_machine],
310
- leader: state[:current_leader],
311
- )
312
- end
313
-
314
- # ── Sync query: read full state machine snapshot ─────────────────────
315
- # Returns NodeReadResult (non-Hash) so the runner sends it as sync reply.
316
- on :read do |state:, payload:|
317
- NodeReadResult.new(data: state[:state_machine].dup)
318
- end
319
- end
320
- end
321
- end
322
- end
@@ -1,32 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Built-in single-shot read Contract. Dependency graph: find_leader → read_value.
7
- #
8
- # Prefer +Cluster#read_contract+ for convenience:
9
- #
10
- # q = cluster.read_contract(key: :price)
11
- # q.resolve_all
12
- # q.result.value # => 99
13
- #
14
- # Or instantiate directly:
15
- #
16
- # q = Igniter::Cluster::Consensus::ReadQuery.new(cluster: my_cluster, key: :price)
17
- # q.resolve_all
18
- # q.result.value # => 99
19
- class ReadQuery < Igniter::Contract
20
- define do
21
- input :cluster # Igniter::Cluster::Consensus::Cluster
22
- input :key # key to read from the state machine
23
-
24
- compute :leader, with: :cluster, call: FindLeader
25
- compute :value, with: [:leader, :key], call: ReadValue
26
-
27
- output :value
28
- end
29
- end
30
- end
31
- end
32
- end
@@ -1,60 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module Igniter
4
- module Cluster
5
- module Consensus
6
- # Base class for user-defined consensus state machines.
7
- #
8
- # Subclass and declare command handlers with +apply+. Each handler receives
9
- # the current state (Hash) and a command Hash and must return the NEW state —
10
- # without mutating the original.
11
- #
12
- # class PriceStore < Igniter::Cluster::Consensus::StateMachine
13
- # apply :set do |state, cmd| state.merge(cmd[:key] => cmd[:value]) end
14
- # apply :delete do |state, cmd| state.reject { |k, _| k == cmd[:key] } end
15
- # end
16
- #
17
- # Passing no subclass to Cluster uses the default KV protocol:
18
- # +{ key:, value: }+ sets a key; +{ key:, op: :delete }+ removes it.
19
- class StateMachine
20
- class << self
21
- # Declare a reducer for a named command type.
22
- # The block receives +(state, command)+ and must return the new state Hash.
23
- def apply(type, &block)
24
- reducers[type.to_sym] = block
25
- end
26
-
27
- # @api private
28
- def reducers
29
- @reducers ||= {}
30
- end
31
-
32
- # Apply +command+ to +state+ and return the resulting state.
33
- # Dispatches to the registered reducer for +command[:type]+, or falls back
34
- # to the built-in KV protocol when no reducer is found.
35
- #
36
- # @param state [Hash] current state machine snapshot
37
- # @param command [Hash, nil] command to apply
38
- # @return [Hash] new state
39
- def call(state, command)
40
- return state unless command
41
-
42
- type = command[:type]&.to_sym
43
- if type && (reducer = reducers[type])
44
- reducer.call(state, command)
45
- else
46
- # Default KV protocol: { key:, value: } → set; { key:, op: :delete } → remove
47
- return state unless command.key?(:key)
48
-
49
- if command[:op] == :delete
50
- state.reject { |k, _| k == command[:key] }
51
- else
52
- state.merge(command[:key] => command[:value])
53
- end
54
- end
55
- end
56
- end
57
- end
58
- end
59
- end
60
- end
@@ -1,18 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- require "igniter/core"
4
- require "igniter/agent"
5
- require_relative "consensus/errors"
6
- require_relative "consensus/state_machine"
7
- require_relative "consensus/node"
8
- require_relative "consensus/cluster"
9
- require_relative "consensus/executors"
10
- require_relative "consensus/read_query"
11
-
12
- module Igniter
13
- module Cluster
14
- # Consensus protocol primitives built on Igniter::Agent and Igniter::Contract.
15
- module Consensus
16
- end
17
- end
18
- end