omnibase_infra 0.2.1__py3-none-any.whl

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 (675) hide show
  1. omnibase_infra/__init__.py +101 -0
  2. omnibase_infra/cli/__init__.py +1 -0
  3. omnibase_infra/cli/commands.py +216 -0
  4. omnibase_infra/clients/__init__.py +0 -0
  5. omnibase_infra/contracts/handlers/filesystem/handler_contract.yaml +261 -0
  6. omnibase_infra/contracts/handlers/mcp/handler_contract.yaml +138 -0
  7. omnibase_infra/decorators/__init__.py +29 -0
  8. omnibase_infra/decorators/allow_any.py +109 -0
  9. omnibase_infra/dlq/__init__.py +90 -0
  10. omnibase_infra/dlq/constants_dlq.py +57 -0
  11. omnibase_infra/dlq/models/__init__.py +26 -0
  12. omnibase_infra/dlq/models/enum_replay_status.py +37 -0
  13. omnibase_infra/dlq/models/model_dlq_replay_record.py +135 -0
  14. omnibase_infra/dlq/models/model_dlq_tracking_config.py +184 -0
  15. omnibase_infra/dlq/service_dlq_tracking.py +611 -0
  16. omnibase_infra/enums/__init__.py +123 -0
  17. omnibase_infra/enums/enum_any_type_violation.py +104 -0
  18. omnibase_infra/enums/enum_backend_type.py +27 -0
  19. omnibase_infra/enums/enum_capture_outcome.py +42 -0
  20. omnibase_infra/enums/enum_capture_state.py +88 -0
  21. omnibase_infra/enums/enum_chain_violation_type.py +119 -0
  22. omnibase_infra/enums/enum_circuit_state.py +51 -0
  23. omnibase_infra/enums/enum_confirmation_event_type.py +27 -0
  24. omnibase_infra/enums/enum_contract_type.py +84 -0
  25. omnibase_infra/enums/enum_dedupe_strategy.py +46 -0
  26. omnibase_infra/enums/enum_dispatch_status.py +191 -0
  27. omnibase_infra/enums/enum_environment.py +46 -0
  28. omnibase_infra/enums/enum_execution_shape_violation.py +103 -0
  29. omnibase_infra/enums/enum_handler_error_type.py +101 -0
  30. omnibase_infra/enums/enum_handler_loader_error.py +178 -0
  31. omnibase_infra/enums/enum_handler_source_type.py +87 -0
  32. omnibase_infra/enums/enum_handler_type.py +77 -0
  33. omnibase_infra/enums/enum_handler_type_category.py +61 -0
  34. omnibase_infra/enums/enum_infra_transport_type.py +73 -0
  35. omnibase_infra/enums/enum_introspection_reason.py +154 -0
  36. omnibase_infra/enums/enum_message_category.py +213 -0
  37. omnibase_infra/enums/enum_node_archetype.py +74 -0
  38. omnibase_infra/enums/enum_node_output_type.py +185 -0
  39. omnibase_infra/enums/enum_non_retryable_error_category.py +224 -0
  40. omnibase_infra/enums/enum_policy_type.py +32 -0
  41. omnibase_infra/enums/enum_registration_state.py +261 -0
  42. omnibase_infra/enums/enum_registration_status.py +33 -0
  43. omnibase_infra/enums/enum_registry_response_status.py +28 -0
  44. omnibase_infra/enums/enum_response_status.py +26 -0
  45. omnibase_infra/enums/enum_retry_error_category.py +98 -0
  46. omnibase_infra/enums/enum_security_rule_id.py +103 -0
  47. omnibase_infra/enums/enum_selection_strategy.py +91 -0
  48. omnibase_infra/enums/enum_topic_standard.py +42 -0
  49. omnibase_infra/enums/enum_validation_severity.py +78 -0
  50. omnibase_infra/errors/__init__.py +156 -0
  51. omnibase_infra/errors/error_architecture_violation.py +152 -0
  52. omnibase_infra/errors/error_chain_propagation.py +188 -0
  53. omnibase_infra/errors/error_compute_registry.py +92 -0
  54. omnibase_infra/errors/error_consul.py +132 -0
  55. omnibase_infra/errors/error_container_wiring.py +243 -0
  56. omnibase_infra/errors/error_event_bus_registry.py +102 -0
  57. omnibase_infra/errors/error_infra.py +608 -0
  58. omnibase_infra/errors/error_message_type_registry.py +101 -0
  59. omnibase_infra/errors/error_policy_registry.py +112 -0
  60. omnibase_infra/errors/error_vault.py +123 -0
  61. omnibase_infra/event_bus/__init__.py +72 -0
  62. omnibase_infra/event_bus/configs/kafka_event_bus_config.yaml +86 -0
  63. omnibase_infra/event_bus/event_bus_inmemory.py +743 -0
  64. omnibase_infra/event_bus/event_bus_kafka.py +1658 -0
  65. omnibase_infra/event_bus/mixin_kafka_broadcast.py +184 -0
  66. omnibase_infra/event_bus/mixin_kafka_dlq.py +765 -0
  67. omnibase_infra/event_bus/models/__init__.py +29 -0
  68. omnibase_infra/event_bus/models/config/__init__.py +20 -0
  69. omnibase_infra/event_bus/models/config/model_kafka_event_bus_config.py +725 -0
  70. omnibase_infra/event_bus/models/model_dlq_event.py +206 -0
  71. omnibase_infra/event_bus/models/model_dlq_metrics.py +304 -0
  72. omnibase_infra/event_bus/models/model_event_headers.py +115 -0
  73. omnibase_infra/event_bus/models/model_event_message.py +60 -0
  74. omnibase_infra/event_bus/topic_constants.py +376 -0
  75. omnibase_infra/handlers/__init__.py +75 -0
  76. omnibase_infra/handlers/filesystem/__init__.py +48 -0
  77. omnibase_infra/handlers/filesystem/enum_file_system_operation.py +35 -0
  78. omnibase_infra/handlers/filesystem/model_file_system_request.py +298 -0
  79. omnibase_infra/handlers/filesystem/model_file_system_result.py +166 -0
  80. omnibase_infra/handlers/handler_consul.py +787 -0
  81. omnibase_infra/handlers/handler_db.py +1039 -0
  82. omnibase_infra/handlers/handler_filesystem.py +1478 -0
  83. omnibase_infra/handlers/handler_graph.py +1154 -0
  84. omnibase_infra/handlers/handler_http.py +920 -0
  85. omnibase_infra/handlers/handler_manifest_persistence.contract.yaml +184 -0
  86. omnibase_infra/handlers/handler_manifest_persistence.py +1539 -0
  87. omnibase_infra/handlers/handler_mcp.py +748 -0
  88. omnibase_infra/handlers/handler_qdrant.py +1076 -0
  89. omnibase_infra/handlers/handler_vault.py +422 -0
  90. omnibase_infra/handlers/mcp/__init__.py +19 -0
  91. omnibase_infra/handlers/mcp/adapter_onex_to_mcp.py +446 -0
  92. omnibase_infra/handlers/mcp/protocols.py +178 -0
  93. omnibase_infra/handlers/mcp/transport_streamable_http.py +352 -0
  94. omnibase_infra/handlers/mixins/__init__.py +42 -0
  95. omnibase_infra/handlers/mixins/mixin_consul_initialization.py +349 -0
  96. omnibase_infra/handlers/mixins/mixin_consul_kv.py +337 -0
  97. omnibase_infra/handlers/mixins/mixin_consul_service.py +277 -0
  98. omnibase_infra/handlers/mixins/mixin_vault_initialization.py +338 -0
  99. omnibase_infra/handlers/mixins/mixin_vault_retry.py +412 -0
  100. omnibase_infra/handlers/mixins/mixin_vault_secrets.py +450 -0
  101. omnibase_infra/handlers/mixins/mixin_vault_token.py +365 -0
  102. omnibase_infra/handlers/models/__init__.py +286 -0
  103. omnibase_infra/handlers/models/consul/__init__.py +81 -0
  104. omnibase_infra/handlers/models/consul/enum_consul_operation_type.py +57 -0
  105. omnibase_infra/handlers/models/consul/model_consul_deregister_payload.py +51 -0
  106. omnibase_infra/handlers/models/consul/model_consul_handler_config.py +153 -0
  107. omnibase_infra/handlers/models/consul/model_consul_handler_payload.py +89 -0
  108. omnibase_infra/handlers/models/consul/model_consul_kv_get_found_payload.py +55 -0
  109. omnibase_infra/handlers/models/consul/model_consul_kv_get_not_found_payload.py +49 -0
  110. omnibase_infra/handlers/models/consul/model_consul_kv_get_recurse_payload.py +50 -0
  111. omnibase_infra/handlers/models/consul/model_consul_kv_item.py +33 -0
  112. omnibase_infra/handlers/models/consul/model_consul_kv_put_payload.py +41 -0
  113. omnibase_infra/handlers/models/consul/model_consul_register_payload.py +53 -0
  114. omnibase_infra/handlers/models/consul/model_consul_retry_config.py +66 -0
  115. omnibase_infra/handlers/models/consul/model_payload_consul.py +66 -0
  116. omnibase_infra/handlers/models/consul/registry_payload_consul.py +214 -0
  117. omnibase_infra/handlers/models/graph/__init__.py +35 -0
  118. omnibase_infra/handlers/models/graph/enum_graph_operation_type.py +20 -0
  119. omnibase_infra/handlers/models/graph/model_graph_execute_payload.py +38 -0
  120. omnibase_infra/handlers/models/graph/model_graph_handler_config.py +54 -0
  121. omnibase_infra/handlers/models/graph/model_graph_handler_payload.py +44 -0
  122. omnibase_infra/handlers/models/graph/model_graph_query_payload.py +40 -0
  123. omnibase_infra/handlers/models/graph/model_graph_record.py +22 -0
  124. omnibase_infra/handlers/models/http/__init__.py +50 -0
  125. omnibase_infra/handlers/models/http/enum_http_operation_type.py +29 -0
  126. omnibase_infra/handlers/models/http/model_http_body_content.py +45 -0
  127. omnibase_infra/handlers/models/http/model_http_get_payload.py +88 -0
  128. omnibase_infra/handlers/models/http/model_http_handler_payload.py +90 -0
  129. omnibase_infra/handlers/models/http/model_http_post_payload.py +88 -0
  130. omnibase_infra/handlers/models/http/model_payload_http.py +66 -0
  131. omnibase_infra/handlers/models/http/registry_payload_http.py +212 -0
  132. omnibase_infra/handlers/models/mcp/__init__.py +23 -0
  133. omnibase_infra/handlers/models/mcp/enum_mcp_operation_type.py +24 -0
  134. omnibase_infra/handlers/models/mcp/model_mcp_handler_config.py +40 -0
  135. omnibase_infra/handlers/models/mcp/model_mcp_tool_call.py +32 -0
  136. omnibase_infra/handlers/models/mcp/model_mcp_tool_result.py +45 -0
  137. omnibase_infra/handlers/models/model_consul_handler_response.py +96 -0
  138. omnibase_infra/handlers/models/model_db_describe_response.py +83 -0
  139. omnibase_infra/handlers/models/model_db_query_payload.py +95 -0
  140. omnibase_infra/handlers/models/model_db_query_response.py +60 -0
  141. omnibase_infra/handlers/models/model_filesystem_config.py +98 -0
  142. omnibase_infra/handlers/models/model_filesystem_delete_payload.py +54 -0
  143. omnibase_infra/handlers/models/model_filesystem_delete_result.py +77 -0
  144. omnibase_infra/handlers/models/model_filesystem_directory_entry.py +75 -0
  145. omnibase_infra/handlers/models/model_filesystem_ensure_directory_payload.py +54 -0
  146. omnibase_infra/handlers/models/model_filesystem_ensure_directory_result.py +60 -0
  147. omnibase_infra/handlers/models/model_filesystem_list_directory_payload.py +60 -0
  148. omnibase_infra/handlers/models/model_filesystem_list_directory_result.py +68 -0
  149. omnibase_infra/handlers/models/model_filesystem_read_payload.py +62 -0
  150. omnibase_infra/handlers/models/model_filesystem_read_result.py +61 -0
  151. omnibase_infra/handlers/models/model_filesystem_write_payload.py +70 -0
  152. omnibase_infra/handlers/models/model_filesystem_write_result.py +55 -0
  153. omnibase_infra/handlers/models/model_graph_handler_response.py +98 -0
  154. omnibase_infra/handlers/models/model_handler_response.py +103 -0
  155. omnibase_infra/handlers/models/model_http_handler_response.py +101 -0
  156. omnibase_infra/handlers/models/model_manifest_metadata.py +75 -0
  157. omnibase_infra/handlers/models/model_manifest_persistence_config.py +62 -0
  158. omnibase_infra/handlers/models/model_manifest_query_payload.py +90 -0
  159. omnibase_infra/handlers/models/model_manifest_query_result.py +97 -0
  160. omnibase_infra/handlers/models/model_manifest_retrieve_payload.py +44 -0
  161. omnibase_infra/handlers/models/model_manifest_retrieve_result.py +98 -0
  162. omnibase_infra/handlers/models/model_manifest_store_payload.py +47 -0
  163. omnibase_infra/handlers/models/model_manifest_store_result.py +67 -0
  164. omnibase_infra/handlers/models/model_operation_context.py +187 -0
  165. omnibase_infra/handlers/models/model_qdrant_handler_response.py +98 -0
  166. omnibase_infra/handlers/models/model_retry_state.py +162 -0
  167. omnibase_infra/handlers/models/model_vault_handler_response.py +98 -0
  168. omnibase_infra/handlers/models/qdrant/__init__.py +44 -0
  169. omnibase_infra/handlers/models/qdrant/enum_qdrant_operation_type.py +26 -0
  170. omnibase_infra/handlers/models/qdrant/model_qdrant_collection_payload.py +42 -0
  171. omnibase_infra/handlers/models/qdrant/model_qdrant_delete_payload.py +36 -0
  172. omnibase_infra/handlers/models/qdrant/model_qdrant_handler_config.py +42 -0
  173. omnibase_infra/handlers/models/qdrant/model_qdrant_handler_payload.py +54 -0
  174. omnibase_infra/handlers/models/qdrant/model_qdrant_search_payload.py +42 -0
  175. omnibase_infra/handlers/models/qdrant/model_qdrant_search_result.py +30 -0
  176. omnibase_infra/handlers/models/qdrant/model_qdrant_upsert_payload.py +36 -0
  177. omnibase_infra/handlers/models/vault/__init__.py +69 -0
  178. omnibase_infra/handlers/models/vault/enum_vault_operation_type.py +35 -0
  179. omnibase_infra/handlers/models/vault/model_payload_vault.py +66 -0
  180. omnibase_infra/handlers/models/vault/model_vault_delete_payload.py +57 -0
  181. omnibase_infra/handlers/models/vault/model_vault_handler_config.py +148 -0
  182. omnibase_infra/handlers/models/vault/model_vault_handler_payload.py +101 -0
  183. omnibase_infra/handlers/models/vault/model_vault_list_payload.py +58 -0
  184. omnibase_infra/handlers/models/vault/model_vault_renew_token_payload.py +67 -0
  185. omnibase_infra/handlers/models/vault/model_vault_retry_config.py +66 -0
  186. omnibase_infra/handlers/models/vault/model_vault_secret_payload.py +106 -0
  187. omnibase_infra/handlers/models/vault/model_vault_write_payload.py +66 -0
  188. omnibase_infra/handlers/models/vault/registry_payload_vault.py +213 -0
  189. omnibase_infra/handlers/registration_storage/__init__.py +43 -0
  190. omnibase_infra/handlers/registration_storage/handler_registration_storage_mock.py +392 -0
  191. omnibase_infra/handlers/registration_storage/handler_registration_storage_postgres.py +915 -0
  192. omnibase_infra/handlers/registration_storage/models/__init__.py +23 -0
  193. omnibase_infra/handlers/registration_storage/models/model_delete_registration_request.py +58 -0
  194. omnibase_infra/handlers/registration_storage/models/model_update_registration_request.py +73 -0
  195. omnibase_infra/handlers/registration_storage/protocol_registration_persistence.py +191 -0
  196. omnibase_infra/handlers/service_discovery/__init__.py +43 -0
  197. omnibase_infra/handlers/service_discovery/handler_service_discovery_consul.py +747 -0
  198. omnibase_infra/handlers/service_discovery/handler_service_discovery_mock.py +258 -0
  199. omnibase_infra/handlers/service_discovery/models/__init__.py +22 -0
  200. omnibase_infra/handlers/service_discovery/models/model_discovery_result.py +64 -0
  201. omnibase_infra/handlers/service_discovery/models/model_registration_result.py +138 -0
  202. omnibase_infra/handlers/service_discovery/models/model_service_info.py +99 -0
  203. omnibase_infra/handlers/service_discovery/protocol_discovery_operations.py +170 -0
  204. omnibase_infra/idempotency/__init__.py +94 -0
  205. omnibase_infra/idempotency/models/__init__.py +43 -0
  206. omnibase_infra/idempotency/models/model_idempotency_check_result.py +85 -0
  207. omnibase_infra/idempotency/models/model_idempotency_guard_config.py +130 -0
  208. omnibase_infra/idempotency/models/model_idempotency_record.py +86 -0
  209. omnibase_infra/idempotency/models/model_idempotency_store_health_check_result.py +81 -0
  210. omnibase_infra/idempotency/models/model_idempotency_store_metrics.py +140 -0
  211. omnibase_infra/idempotency/models/model_postgres_idempotency_store_config.py +299 -0
  212. omnibase_infra/idempotency/protocol_idempotency_store.py +184 -0
  213. omnibase_infra/idempotency/store_inmemory.py +265 -0
  214. omnibase_infra/idempotency/store_postgres.py +923 -0
  215. omnibase_infra/infrastructure/__init__.py +0 -0
  216. omnibase_infra/mixins/__init__.py +71 -0
  217. omnibase_infra/mixins/mixin_async_circuit_breaker.py +655 -0
  218. omnibase_infra/mixins/mixin_dict_like_accessors.py +146 -0
  219. omnibase_infra/mixins/mixin_envelope_extraction.py +119 -0
  220. omnibase_infra/mixins/mixin_node_introspection.py +2465 -0
  221. omnibase_infra/mixins/mixin_retry_execution.py +386 -0
  222. omnibase_infra/mixins/protocol_circuit_breaker_aware.py +133 -0
  223. omnibase_infra/models/__init__.py +136 -0
  224. omnibase_infra/models/corpus/__init__.py +17 -0
  225. omnibase_infra/models/corpus/model_capture_config.py +133 -0
  226. omnibase_infra/models/corpus/model_capture_result.py +86 -0
  227. omnibase_infra/models/discovery/__init__.py +42 -0
  228. omnibase_infra/models/discovery/model_dependency_spec.py +319 -0
  229. omnibase_infra/models/discovery/model_discovered_capabilities.py +50 -0
  230. omnibase_infra/models/discovery/model_introspection_config.py +311 -0
  231. omnibase_infra/models/discovery/model_introspection_performance_metrics.py +169 -0
  232. omnibase_infra/models/discovery/model_introspection_task_config.py +116 -0
  233. omnibase_infra/models/dispatch/__init__.py +147 -0
  234. omnibase_infra/models/dispatch/model_dispatch_context.py +439 -0
  235. omnibase_infra/models/dispatch/model_dispatch_error.py +336 -0
  236. omnibase_infra/models/dispatch/model_dispatch_log_context.py +400 -0
  237. omnibase_infra/models/dispatch/model_dispatch_metadata.py +228 -0
  238. omnibase_infra/models/dispatch/model_dispatch_metrics.py +496 -0
  239. omnibase_infra/models/dispatch/model_dispatch_outcome.py +317 -0
  240. omnibase_infra/models/dispatch/model_dispatch_outputs.py +231 -0
  241. omnibase_infra/models/dispatch/model_dispatch_result.py +436 -0
  242. omnibase_infra/models/dispatch/model_dispatch_route.py +279 -0
  243. omnibase_infra/models/dispatch/model_dispatcher_metrics.py +275 -0
  244. omnibase_infra/models/dispatch/model_dispatcher_registration.py +352 -0
  245. omnibase_infra/models/dispatch/model_parsed_topic.py +135 -0
  246. omnibase_infra/models/dispatch/model_topic_parser.py +725 -0
  247. omnibase_infra/models/dispatch/model_tracing_context.py +285 -0
  248. omnibase_infra/models/errors/__init__.py +45 -0
  249. omnibase_infra/models/errors/model_handler_validation_error.py +594 -0
  250. omnibase_infra/models/errors/model_infra_error_context.py +99 -0
  251. omnibase_infra/models/errors/model_message_type_registry_error_context.py +71 -0
  252. omnibase_infra/models/errors/model_timeout_error_context.py +110 -0
  253. omnibase_infra/models/handlers/__init__.py +37 -0
  254. omnibase_infra/models/handlers/model_contract_discovery_result.py +80 -0
  255. omnibase_infra/models/handlers/model_handler_descriptor.py +185 -0
  256. omnibase_infra/models/handlers/model_handler_identifier.py +215 -0
  257. omnibase_infra/models/health/__init__.py +9 -0
  258. omnibase_infra/models/health/model_health_check_result.py +40 -0
  259. omnibase_infra/models/lifecycle/__init__.py +39 -0
  260. omnibase_infra/models/logging/__init__.py +51 -0
  261. omnibase_infra/models/logging/model_log_context.py +756 -0
  262. omnibase_infra/models/model_retry_error_classification.py +78 -0
  263. omnibase_infra/models/projection/__init__.py +43 -0
  264. omnibase_infra/models/projection/model_capability_fields.py +112 -0
  265. omnibase_infra/models/projection/model_registration_projection.py +434 -0
  266. omnibase_infra/models/projection/model_registration_snapshot.py +322 -0
  267. omnibase_infra/models/projection/model_sequence_info.py +182 -0
  268. omnibase_infra/models/projection/model_snapshot_topic_config.py +590 -0
  269. omnibase_infra/models/projectors/__init__.py +41 -0
  270. omnibase_infra/models/projectors/model_projector_column.py +289 -0
  271. omnibase_infra/models/projectors/model_projector_discovery_result.py +65 -0
  272. omnibase_infra/models/projectors/model_projector_index.py +270 -0
  273. omnibase_infra/models/projectors/model_projector_schema.py +415 -0
  274. omnibase_infra/models/projectors/model_projector_validation_error.py +63 -0
  275. omnibase_infra/models/projectors/util_sql_identifiers.py +115 -0
  276. omnibase_infra/models/registration/__init__.py +59 -0
  277. omnibase_infra/models/registration/commands/__init__.py +15 -0
  278. omnibase_infra/models/registration/commands/model_node_registration_acked.py +108 -0
  279. omnibase_infra/models/registration/events/__init__.py +56 -0
  280. omnibase_infra/models/registration/events/model_node_became_active.py +103 -0
  281. omnibase_infra/models/registration/events/model_node_liveness_expired.py +103 -0
  282. omnibase_infra/models/registration/events/model_node_registration_accepted.py +98 -0
  283. omnibase_infra/models/registration/events/model_node_registration_ack_received.py +98 -0
  284. omnibase_infra/models/registration/events/model_node_registration_ack_timed_out.py +112 -0
  285. omnibase_infra/models/registration/events/model_node_registration_initiated.py +107 -0
  286. omnibase_infra/models/registration/events/model_node_registration_rejected.py +104 -0
  287. omnibase_infra/models/registration/model_introspection_metrics.py +253 -0
  288. omnibase_infra/models/registration/model_node_capabilities.py +179 -0
  289. omnibase_infra/models/registration/model_node_heartbeat_event.py +126 -0
  290. omnibase_infra/models/registration/model_node_introspection_event.py +175 -0
  291. omnibase_infra/models/registration/model_node_metadata.py +79 -0
  292. omnibase_infra/models/registration/model_node_registration.py +162 -0
  293. omnibase_infra/models/registration/model_node_registration_record.py +162 -0
  294. omnibase_infra/models/registry/__init__.py +29 -0
  295. omnibase_infra/models/registry/model_domain_constraint.py +202 -0
  296. omnibase_infra/models/registry/model_message_type_entry.py +271 -0
  297. omnibase_infra/models/resilience/__init__.py +9 -0
  298. omnibase_infra/models/resilience/model_circuit_breaker_config.py +227 -0
  299. omnibase_infra/models/routing/__init__.py +25 -0
  300. omnibase_infra/models/routing/model_routing_entry.py +52 -0
  301. omnibase_infra/models/routing/model_routing_subcontract.py +70 -0
  302. omnibase_infra/models/runtime/__init__.py +40 -0
  303. omnibase_infra/models/runtime/model_contract_security_config.py +41 -0
  304. omnibase_infra/models/runtime/model_discovery_error.py +81 -0
  305. omnibase_infra/models/runtime/model_discovery_result.py +162 -0
  306. omnibase_infra/models/runtime/model_discovery_warning.py +74 -0
  307. omnibase_infra/models/runtime/model_failed_plugin_load.py +63 -0
  308. omnibase_infra/models/runtime/model_handler_contract.py +280 -0
  309. omnibase_infra/models/runtime/model_loaded_handler.py +120 -0
  310. omnibase_infra/models/runtime/model_plugin_load_context.py +93 -0
  311. omnibase_infra/models/runtime/model_plugin_load_summary.py +124 -0
  312. omnibase_infra/models/security/__init__.py +50 -0
  313. omnibase_infra/models/security/classification_levels.py +99 -0
  314. omnibase_infra/models/security/model_environment_policy.py +145 -0
  315. omnibase_infra/models/security/model_handler_security_policy.py +107 -0
  316. omnibase_infra/models/security/model_security_error.py +81 -0
  317. omnibase_infra/models/security/model_security_validation_result.py +328 -0
  318. omnibase_infra/models/security/model_security_warning.py +67 -0
  319. omnibase_infra/models/snapshot/__init__.py +27 -0
  320. omnibase_infra/models/snapshot/model_field_change.py +65 -0
  321. omnibase_infra/models/snapshot/model_snapshot.py +270 -0
  322. omnibase_infra/models/snapshot/model_snapshot_diff.py +203 -0
  323. omnibase_infra/models/snapshot/model_subject_ref.py +81 -0
  324. omnibase_infra/models/types/__init__.py +71 -0
  325. omnibase_infra/models/validation/__init__.py +89 -0
  326. omnibase_infra/models/validation/model_any_type_validation_result.py +118 -0
  327. omnibase_infra/models/validation/model_any_type_violation.py +141 -0
  328. omnibase_infra/models/validation/model_category_match_result.py +345 -0
  329. omnibase_infra/models/validation/model_chain_violation.py +166 -0
  330. omnibase_infra/models/validation/model_coverage_metrics.py +316 -0
  331. omnibase_infra/models/validation/model_execution_shape_rule.py +159 -0
  332. omnibase_infra/models/validation/model_execution_shape_validation.py +208 -0
  333. omnibase_infra/models/validation/model_execution_shape_validation_result.py +294 -0
  334. omnibase_infra/models/validation/model_execution_shape_violation.py +122 -0
  335. omnibase_infra/models/validation/model_localhandler_validation_result.py +139 -0
  336. omnibase_infra/models/validation/model_localhandler_violation.py +100 -0
  337. omnibase_infra/models/validation/model_output_validation_params.py +74 -0
  338. omnibase_infra/models/validation/model_validate_and_raise_params.py +84 -0
  339. omnibase_infra/models/validation/model_validation_error_params.py +84 -0
  340. omnibase_infra/models/validation/model_validation_outcome.py +287 -0
  341. omnibase_infra/nodes/__init__.py +48 -0
  342. omnibase_infra/nodes/architecture_validator/__init__.py +79 -0
  343. omnibase_infra/nodes/architecture_validator/contract.yaml +252 -0
  344. omnibase_infra/nodes/architecture_validator/contract_architecture_validator.yaml +208 -0
  345. omnibase_infra/nodes/architecture_validator/mixins/__init__.py +16 -0
  346. omnibase_infra/nodes/architecture_validator/mixins/mixin_file_path_rule.py +92 -0
  347. omnibase_infra/nodes/architecture_validator/models/__init__.py +36 -0
  348. omnibase_infra/nodes/architecture_validator/models/model_architecture_validation_request.py +56 -0
  349. omnibase_infra/nodes/architecture_validator/models/model_architecture_validation_result.py +311 -0
  350. omnibase_infra/nodes/architecture_validator/models/model_architecture_violation.py +163 -0
  351. omnibase_infra/nodes/architecture_validator/models/model_rule_check_result.py +265 -0
  352. omnibase_infra/nodes/architecture_validator/models/model_validation_request.py +105 -0
  353. omnibase_infra/nodes/architecture_validator/models/model_validation_result.py +314 -0
  354. omnibase_infra/nodes/architecture_validator/node.py +262 -0
  355. omnibase_infra/nodes/architecture_validator/node_architecture_validator.py +383 -0
  356. omnibase_infra/nodes/architecture_validator/protocols/__init__.py +9 -0
  357. omnibase_infra/nodes/architecture_validator/protocols/protocol_architecture_rule.py +225 -0
  358. omnibase_infra/nodes/architecture_validator/registry/__init__.py +28 -0
  359. omnibase_infra/nodes/architecture_validator/registry/registry_infra_architecture_validator.py +99 -0
  360. omnibase_infra/nodes/architecture_validator/validators/__init__.py +104 -0
  361. omnibase_infra/nodes/architecture_validator/validators/validator_no_direct_dispatch.py +422 -0
  362. omnibase_infra/nodes/architecture_validator/validators/validator_no_handler_publishing.py +481 -0
  363. omnibase_infra/nodes/architecture_validator/validators/validator_no_orchestrator_fsm.py +491 -0
  364. omnibase_infra/nodes/effects/README.md +358 -0
  365. omnibase_infra/nodes/effects/__init__.py +26 -0
  366. omnibase_infra/nodes/effects/contract.yaml +172 -0
  367. omnibase_infra/nodes/effects/models/__init__.py +32 -0
  368. omnibase_infra/nodes/effects/models/model_backend_result.py +190 -0
  369. omnibase_infra/nodes/effects/models/model_effect_idempotency_config.py +92 -0
  370. omnibase_infra/nodes/effects/models/model_registry_request.py +132 -0
  371. omnibase_infra/nodes/effects/models/model_registry_response.py +263 -0
  372. omnibase_infra/nodes/effects/protocol_consul_client.py +89 -0
  373. omnibase_infra/nodes/effects/protocol_effect_idempotency_store.py +143 -0
  374. omnibase_infra/nodes/effects/protocol_postgres_adapter.py +96 -0
  375. omnibase_infra/nodes/effects/registry_effect.py +525 -0
  376. omnibase_infra/nodes/effects/store_effect_idempotency_inmemory.py +425 -0
  377. omnibase_infra/nodes/node_registration_orchestrator/README.md +542 -0
  378. omnibase_infra/nodes/node_registration_orchestrator/__init__.py +120 -0
  379. omnibase_infra/nodes/node_registration_orchestrator/contract.yaml +475 -0
  380. omnibase_infra/nodes/node_registration_orchestrator/dispatchers/__init__.py +53 -0
  381. omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_node_introspected.py +376 -0
  382. omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_node_registration_acked.py +376 -0
  383. omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_runtime_tick.py +373 -0
  384. omnibase_infra/nodes/node_registration_orchestrator/handlers/__init__.py +62 -0
  385. omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_heartbeat.py +376 -0
  386. omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_introspected.py +609 -0
  387. omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_registration_acked.py +458 -0
  388. omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_runtime_tick.py +364 -0
  389. omnibase_infra/nodes/node_registration_orchestrator/introspection_event_router.py +544 -0
  390. omnibase_infra/nodes/node_registration_orchestrator/models/__init__.py +75 -0
  391. omnibase_infra/nodes/node_registration_orchestrator/models/model_consul_intent_payload.py +194 -0
  392. omnibase_infra/nodes/node_registration_orchestrator/models/model_consul_registration_intent.py +67 -0
  393. omnibase_infra/nodes/node_registration_orchestrator/models/model_intent_execution_result.py +50 -0
  394. omnibase_infra/nodes/node_registration_orchestrator/models/model_node_liveness_expired.py +107 -0
  395. omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_config.py +67 -0
  396. omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_input.py +41 -0
  397. omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_output.py +166 -0
  398. omnibase_infra/nodes/node_registration_orchestrator/models/model_postgres_intent_payload.py +235 -0
  399. omnibase_infra/nodes/node_registration_orchestrator/models/model_postgres_upsert_intent.py +68 -0
  400. omnibase_infra/nodes/node_registration_orchestrator/models/model_reducer_execution_result.py +384 -0
  401. omnibase_infra/nodes/node_registration_orchestrator/models/model_reducer_state.py +60 -0
  402. omnibase_infra/nodes/node_registration_orchestrator/models/model_registration_intent.py +177 -0
  403. omnibase_infra/nodes/node_registration_orchestrator/models/model_registry_intent.py +247 -0
  404. omnibase_infra/nodes/node_registration_orchestrator/node.py +195 -0
  405. omnibase_infra/nodes/node_registration_orchestrator/plugin.py +909 -0
  406. omnibase_infra/nodes/node_registration_orchestrator/protocols.py +439 -0
  407. omnibase_infra/nodes/node_registration_orchestrator/registry/__init__.py +41 -0
  408. omnibase_infra/nodes/node_registration_orchestrator/registry/registry_infra_node_registration_orchestrator.py +525 -0
  409. omnibase_infra/nodes/node_registration_orchestrator/timeout_coordinator.py +392 -0
  410. omnibase_infra/nodes/node_registration_orchestrator/wiring.py +742 -0
  411. omnibase_infra/nodes/node_registration_reducer/__init__.py +15 -0
  412. omnibase_infra/nodes/node_registration_reducer/contract.yaml +301 -0
  413. omnibase_infra/nodes/node_registration_reducer/models/__init__.py +38 -0
  414. omnibase_infra/nodes/node_registration_reducer/models/model_validation_result.py +113 -0
  415. omnibase_infra/nodes/node_registration_reducer/node.py +139 -0
  416. omnibase_infra/nodes/node_registration_reducer/registry/__init__.py +9 -0
  417. omnibase_infra/nodes/node_registration_reducer/registry/registry_infra_node_registration_reducer.py +79 -0
  418. omnibase_infra/nodes/node_registration_storage_effect/__init__.py +41 -0
  419. omnibase_infra/nodes/node_registration_storage_effect/contract.yaml +225 -0
  420. omnibase_infra/nodes/node_registration_storage_effect/models/__init__.py +44 -0
  421. omnibase_infra/nodes/node_registration_storage_effect/models/model_delete_result.py +132 -0
  422. omnibase_infra/nodes/node_registration_storage_effect/models/model_registration_record.py +199 -0
  423. omnibase_infra/nodes/node_registration_storage_effect/models/model_registration_update.py +155 -0
  424. omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_health_check_details.py +123 -0
  425. omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_health_check_result.py +117 -0
  426. omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_query.py +100 -0
  427. omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_result.py +136 -0
  428. omnibase_infra/nodes/node_registration_storage_effect/models/model_upsert_result.py +127 -0
  429. omnibase_infra/nodes/node_registration_storage_effect/node.py +109 -0
  430. omnibase_infra/nodes/node_registration_storage_effect/protocols/__init__.py +22 -0
  431. omnibase_infra/nodes/node_registration_storage_effect/protocols/protocol_registration_persistence.py +333 -0
  432. omnibase_infra/nodes/node_registration_storage_effect/registry/__init__.py +23 -0
  433. omnibase_infra/nodes/node_registration_storage_effect/registry/registry_infra_registration_storage.py +194 -0
  434. omnibase_infra/nodes/node_registry_effect/__init__.py +85 -0
  435. omnibase_infra/nodes/node_registry_effect/contract.yaml +682 -0
  436. omnibase_infra/nodes/node_registry_effect/handlers/__init__.py +70 -0
  437. omnibase_infra/nodes/node_registry_effect/handlers/handler_consul_deregister.py +211 -0
  438. omnibase_infra/nodes/node_registry_effect/handlers/handler_consul_register.py +212 -0
  439. omnibase_infra/nodes/node_registry_effect/handlers/handler_partial_retry.py +416 -0
  440. omnibase_infra/nodes/node_registry_effect/handlers/handler_postgres_deactivate.py +215 -0
  441. omnibase_infra/nodes/node_registry_effect/handlers/handler_postgres_upsert.py +208 -0
  442. omnibase_infra/nodes/node_registry_effect/models/__init__.py +43 -0
  443. omnibase_infra/nodes/node_registry_effect/models/model_partial_retry_request.py +92 -0
  444. omnibase_infra/nodes/node_registry_effect/node.py +165 -0
  445. omnibase_infra/nodes/node_registry_effect/registry/__init__.py +27 -0
  446. omnibase_infra/nodes/node_registry_effect/registry/registry_infra_registry_effect.py +196 -0
  447. omnibase_infra/nodes/node_service_discovery_effect/__init__.py +111 -0
  448. omnibase_infra/nodes/node_service_discovery_effect/contract.yaml +246 -0
  449. omnibase_infra/nodes/node_service_discovery_effect/models/__init__.py +67 -0
  450. omnibase_infra/nodes/node_service_discovery_effect/models/enum_health_status.py +72 -0
  451. omnibase_infra/nodes/node_service_discovery_effect/models/enum_service_discovery_operation.py +58 -0
  452. omnibase_infra/nodes/node_service_discovery_effect/models/model_discovery_query.py +99 -0
  453. omnibase_infra/nodes/node_service_discovery_effect/models/model_discovery_result.py +98 -0
  454. omnibase_infra/nodes/node_service_discovery_effect/models/model_health_check_config.py +121 -0
  455. omnibase_infra/nodes/node_service_discovery_effect/models/model_query_metadata.py +63 -0
  456. omnibase_infra/nodes/node_service_discovery_effect/models/model_registration_result.py +130 -0
  457. omnibase_infra/nodes/node_service_discovery_effect/models/model_service_discovery_health_check_details.py +111 -0
  458. omnibase_infra/nodes/node_service_discovery_effect/models/model_service_discovery_health_check_result.py +119 -0
  459. omnibase_infra/nodes/node_service_discovery_effect/models/model_service_info.py +106 -0
  460. omnibase_infra/nodes/node_service_discovery_effect/models/model_service_registration.py +121 -0
  461. omnibase_infra/nodes/node_service_discovery_effect/node.py +111 -0
  462. omnibase_infra/nodes/node_service_discovery_effect/protocols/__init__.py +14 -0
  463. omnibase_infra/nodes/node_service_discovery_effect/protocols/protocol_discovery_operations.py +279 -0
  464. omnibase_infra/nodes/node_service_discovery_effect/registry/__init__.py +13 -0
  465. omnibase_infra/nodes/node_service_discovery_effect/registry/registry_infra_service_discovery.py +214 -0
  466. omnibase_infra/nodes/reducers/__init__.py +30 -0
  467. omnibase_infra/nodes/reducers/models/__init__.py +32 -0
  468. omnibase_infra/nodes/reducers/models/model_payload_consul_register.py +76 -0
  469. omnibase_infra/nodes/reducers/models/model_payload_postgres_upsert_registration.py +60 -0
  470. omnibase_infra/nodes/reducers/models/model_registration_confirmation.py +166 -0
  471. omnibase_infra/nodes/reducers/models/model_registration_state.py +433 -0
  472. omnibase_infra/nodes/reducers/registration_reducer.py +1137 -0
  473. omnibase_infra/observability/__init__.py +143 -0
  474. omnibase_infra/observability/constants_metrics.py +91 -0
  475. omnibase_infra/observability/factory_observability_sink.py +525 -0
  476. omnibase_infra/observability/handlers/__init__.py +118 -0
  477. omnibase_infra/observability/handlers/handler_logging_structured.py +967 -0
  478. omnibase_infra/observability/handlers/handler_metrics_prometheus.py +1120 -0
  479. omnibase_infra/observability/handlers/model_logging_handler_config.py +71 -0
  480. omnibase_infra/observability/handlers/model_logging_handler_response.py +77 -0
  481. omnibase_infra/observability/handlers/model_metrics_handler_config.py +172 -0
  482. omnibase_infra/observability/handlers/model_metrics_handler_payload.py +135 -0
  483. omnibase_infra/observability/handlers/model_metrics_handler_response.py +101 -0
  484. omnibase_infra/observability/hooks/__init__.py +74 -0
  485. omnibase_infra/observability/hooks/hook_observability.py +1223 -0
  486. omnibase_infra/observability/models/__init__.py +30 -0
  487. omnibase_infra/observability/models/enum_required_log_context_key.py +77 -0
  488. omnibase_infra/observability/models/model_buffered_log_entry.py +117 -0
  489. omnibase_infra/observability/models/model_logging_sink_config.py +73 -0
  490. omnibase_infra/observability/models/model_metrics_sink_config.py +156 -0
  491. omnibase_infra/observability/sinks/__init__.py +69 -0
  492. omnibase_infra/observability/sinks/sink_logging_structured.py +809 -0
  493. omnibase_infra/observability/sinks/sink_metrics_prometheus.py +710 -0
  494. omnibase_infra/plugins/__init__.py +27 -0
  495. omnibase_infra/plugins/examples/__init__.py +28 -0
  496. omnibase_infra/plugins/examples/plugin_json_normalizer.py +271 -0
  497. omnibase_infra/plugins/examples/plugin_json_normalizer_error_handling.py +210 -0
  498. omnibase_infra/plugins/models/__init__.py +21 -0
  499. omnibase_infra/plugins/models/model_plugin_context.py +76 -0
  500. omnibase_infra/plugins/models/model_plugin_input_data.py +58 -0
  501. omnibase_infra/plugins/models/model_plugin_output_data.py +62 -0
  502. omnibase_infra/plugins/plugin_compute_base.py +435 -0
  503. omnibase_infra/projectors/__init__.py +30 -0
  504. omnibase_infra/projectors/contracts/__init__.py +63 -0
  505. omnibase_infra/projectors/contracts/registration_projector.yaml +370 -0
  506. omnibase_infra/projectors/projection_reader_registration.py +1559 -0
  507. omnibase_infra/projectors/snapshot_publisher_registration.py +1329 -0
  508. omnibase_infra/protocols/__init__.py +99 -0
  509. omnibase_infra/protocols/protocol_capability_projection.py +253 -0
  510. omnibase_infra/protocols/protocol_capability_query.py +251 -0
  511. omnibase_infra/protocols/protocol_event_bus_like.py +127 -0
  512. omnibase_infra/protocols/protocol_event_projector.py +96 -0
  513. omnibase_infra/protocols/protocol_idempotency_store.py +142 -0
  514. omnibase_infra/protocols/protocol_message_dispatcher.py +247 -0
  515. omnibase_infra/protocols/protocol_message_type_registry.py +306 -0
  516. omnibase_infra/protocols/protocol_plugin_compute.py +368 -0
  517. omnibase_infra/protocols/protocol_projector_schema_validator.py +82 -0
  518. omnibase_infra/protocols/protocol_registry_metrics.py +215 -0
  519. omnibase_infra/protocols/protocol_snapshot_publisher.py +396 -0
  520. omnibase_infra/protocols/protocol_snapshot_store.py +567 -0
  521. omnibase_infra/runtime/__init__.py +296 -0
  522. omnibase_infra/runtime/binding_config_resolver.py +2706 -0
  523. omnibase_infra/runtime/chain_aware_dispatch.py +467 -0
  524. omnibase_infra/runtime/contract_handler_discovery.py +582 -0
  525. omnibase_infra/runtime/contract_loaders/__init__.py +42 -0
  526. omnibase_infra/runtime/contract_loaders/handler_routing_loader.py +464 -0
  527. omnibase_infra/runtime/dispatch_context_enforcer.py +427 -0
  528. omnibase_infra/runtime/enums/__init__.py +18 -0
  529. omnibase_infra/runtime/enums/enum_config_ref_scheme.py +33 -0
  530. omnibase_infra/runtime/enums/enum_scheduler_status.py +170 -0
  531. omnibase_infra/runtime/envelope_validator.py +179 -0
  532. omnibase_infra/runtime/handler_contract_source.py +669 -0
  533. omnibase_infra/runtime/handler_plugin_loader.py +2029 -0
  534. omnibase_infra/runtime/handler_registry.py +321 -0
  535. omnibase_infra/runtime/invocation_security_enforcer.py +427 -0
  536. omnibase_infra/runtime/kernel.py +40 -0
  537. omnibase_infra/runtime/mixin_policy_validation.py +522 -0
  538. omnibase_infra/runtime/mixin_semver_cache.py +378 -0
  539. omnibase_infra/runtime/mixins/__init__.py +17 -0
  540. omnibase_infra/runtime/mixins/mixin_projector_sql_operations.py +757 -0
  541. omnibase_infra/runtime/models/__init__.py +192 -0
  542. omnibase_infra/runtime/models/model_batch_lifecycle_result.py +217 -0
  543. omnibase_infra/runtime/models/model_binding_config.py +168 -0
  544. omnibase_infra/runtime/models/model_binding_config_cache_stats.py +135 -0
  545. omnibase_infra/runtime/models/model_binding_config_resolver_config.py +329 -0
  546. omnibase_infra/runtime/models/model_cached_secret.py +138 -0
  547. omnibase_infra/runtime/models/model_compute_key.py +138 -0
  548. omnibase_infra/runtime/models/model_compute_registration.py +97 -0
  549. omnibase_infra/runtime/models/model_config_cache_entry.py +61 -0
  550. omnibase_infra/runtime/models/model_config_ref.py +331 -0
  551. omnibase_infra/runtime/models/model_config_ref_parse_result.py +125 -0
  552. omnibase_infra/runtime/models/model_domain_plugin_config.py +92 -0
  553. omnibase_infra/runtime/models/model_domain_plugin_result.py +270 -0
  554. omnibase_infra/runtime/models/model_duplicate_response.py +54 -0
  555. omnibase_infra/runtime/models/model_enabled_protocols_config.py +61 -0
  556. omnibase_infra/runtime/models/model_event_bus_config.py +54 -0
  557. omnibase_infra/runtime/models/model_failed_component.py +55 -0
  558. omnibase_infra/runtime/models/model_health_check_response.py +168 -0
  559. omnibase_infra/runtime/models/model_health_check_result.py +228 -0
  560. omnibase_infra/runtime/models/model_lifecycle_result.py +245 -0
  561. omnibase_infra/runtime/models/model_logging_config.py +42 -0
  562. omnibase_infra/runtime/models/model_optional_correlation_id.py +167 -0
  563. omnibase_infra/runtime/models/model_optional_string.py +94 -0
  564. omnibase_infra/runtime/models/model_optional_uuid.py +110 -0
  565. omnibase_infra/runtime/models/model_policy_context.py +100 -0
  566. omnibase_infra/runtime/models/model_policy_key.py +138 -0
  567. omnibase_infra/runtime/models/model_policy_registration.py +139 -0
  568. omnibase_infra/runtime/models/model_policy_result.py +103 -0
  569. omnibase_infra/runtime/models/model_policy_type_filter.py +157 -0
  570. omnibase_infra/runtime/models/model_projector_plugin_loader_config.py +47 -0
  571. omnibase_infra/runtime/models/model_protocol_registration_config.py +65 -0
  572. omnibase_infra/runtime/models/model_retry_policy.py +105 -0
  573. omnibase_infra/runtime/models/model_runtime_config.py +150 -0
  574. omnibase_infra/runtime/models/model_runtime_scheduler_config.py +624 -0
  575. omnibase_infra/runtime/models/model_runtime_scheduler_metrics.py +233 -0
  576. omnibase_infra/runtime/models/model_runtime_tick.py +193 -0
  577. omnibase_infra/runtime/models/model_secret_cache_stats.py +82 -0
  578. omnibase_infra/runtime/models/model_secret_mapping.py +63 -0
  579. omnibase_infra/runtime/models/model_secret_resolver_config.py +107 -0
  580. omnibase_infra/runtime/models/model_secret_resolver_metrics.py +111 -0
  581. omnibase_infra/runtime/models/model_secret_source_info.py +72 -0
  582. omnibase_infra/runtime/models/model_secret_source_spec.py +66 -0
  583. omnibase_infra/runtime/models/model_shutdown_batch_result.py +75 -0
  584. omnibase_infra/runtime/models/model_shutdown_config.py +94 -0
  585. omnibase_infra/runtime/projector_plugin_loader.py +1462 -0
  586. omnibase_infra/runtime/projector_schema_manager.py +565 -0
  587. omnibase_infra/runtime/projector_shell.py +1102 -0
  588. omnibase_infra/runtime/protocol_contract_descriptor.py +92 -0
  589. omnibase_infra/runtime/protocol_contract_source.py +92 -0
  590. omnibase_infra/runtime/protocol_domain_plugin.py +474 -0
  591. omnibase_infra/runtime/protocol_handler_discovery.py +221 -0
  592. omnibase_infra/runtime/protocol_handler_plugin_loader.py +327 -0
  593. omnibase_infra/runtime/protocol_lifecycle_executor.py +435 -0
  594. omnibase_infra/runtime/protocol_policy.py +366 -0
  595. omnibase_infra/runtime/protocols/__init__.py +27 -0
  596. omnibase_infra/runtime/protocols/protocol_runtime_scheduler.py +468 -0
  597. omnibase_infra/runtime/registry/__init__.py +93 -0
  598. omnibase_infra/runtime/registry/mixin_message_type_query.py +326 -0
  599. omnibase_infra/runtime/registry/mixin_message_type_registration.py +354 -0
  600. omnibase_infra/runtime/registry/registry_event_bus_binding.py +268 -0
  601. omnibase_infra/runtime/registry/registry_message_type.py +542 -0
  602. omnibase_infra/runtime/registry/registry_protocol_binding.py +444 -0
  603. omnibase_infra/runtime/registry_compute.py +1143 -0
  604. omnibase_infra/runtime/registry_dispatcher.py +678 -0
  605. omnibase_infra/runtime/registry_policy.py +1502 -0
  606. omnibase_infra/runtime/runtime_scheduler.py +1070 -0
  607. omnibase_infra/runtime/secret_resolver.py +2110 -0
  608. omnibase_infra/runtime/security_metadata_validator.py +776 -0
  609. omnibase_infra/runtime/service_kernel.py +1573 -0
  610. omnibase_infra/runtime/service_message_dispatch_engine.py +1805 -0
  611. omnibase_infra/runtime/service_runtime_host_process.py +2260 -0
  612. omnibase_infra/runtime/util_container_wiring.py +1123 -0
  613. omnibase_infra/runtime/util_validation.py +314 -0
  614. omnibase_infra/runtime/util_version.py +98 -0
  615. omnibase_infra/runtime/util_wiring.py +566 -0
  616. omnibase_infra/schemas/schema_registration_projection.sql +320 -0
  617. omnibase_infra/services/__init__.py +68 -0
  618. omnibase_infra/services/corpus_capture.py +678 -0
  619. omnibase_infra/services/service_capability_query.py +945 -0
  620. omnibase_infra/services/service_health.py +897 -0
  621. omnibase_infra/services/service_node_selector.py +530 -0
  622. omnibase_infra/services/service_timeout_emitter.py +682 -0
  623. omnibase_infra/services/service_timeout_scanner.py +390 -0
  624. omnibase_infra/services/snapshot/__init__.py +31 -0
  625. omnibase_infra/services/snapshot/service_snapshot.py +647 -0
  626. omnibase_infra/services/snapshot/store_inmemory.py +637 -0
  627. omnibase_infra/services/snapshot/store_postgres.py +1279 -0
  628. omnibase_infra/shared/__init__.py +8 -0
  629. omnibase_infra/testing/__init__.py +10 -0
  630. omnibase_infra/testing/utils.py +23 -0
  631. omnibase_infra/types/__init__.py +48 -0
  632. omnibase_infra/types/type_cache_info.py +49 -0
  633. omnibase_infra/types/type_dsn.py +173 -0
  634. omnibase_infra/types/type_infra_aliases.py +60 -0
  635. omnibase_infra/types/typed_dict/__init__.py +21 -0
  636. omnibase_infra/types/typed_dict/typed_dict_introspection_cache.py +128 -0
  637. omnibase_infra/types/typed_dict/typed_dict_performance_metrics_cache.py +140 -0
  638. omnibase_infra/types/typed_dict_capabilities.py +64 -0
  639. omnibase_infra/utils/__init__.py +89 -0
  640. omnibase_infra/utils/correlation.py +208 -0
  641. omnibase_infra/utils/util_datetime.py +372 -0
  642. omnibase_infra/utils/util_dsn_validation.py +333 -0
  643. omnibase_infra/utils/util_env_parsing.py +264 -0
  644. omnibase_infra/utils/util_error_sanitization.py +457 -0
  645. omnibase_infra/utils/util_pydantic_validators.py +477 -0
  646. omnibase_infra/utils/util_semver.py +233 -0
  647. omnibase_infra/validation/__init__.py +307 -0
  648. omnibase_infra/validation/enums/__init__.py +11 -0
  649. omnibase_infra/validation/enums/enum_contract_violation_severity.py +13 -0
  650. omnibase_infra/validation/infra_validators.py +1486 -0
  651. omnibase_infra/validation/linter_contract.py +907 -0
  652. omnibase_infra/validation/mixin_any_type_classification.py +120 -0
  653. omnibase_infra/validation/mixin_any_type_exemption.py +580 -0
  654. omnibase_infra/validation/mixin_any_type_reporting.py +106 -0
  655. omnibase_infra/validation/mixin_execution_shape_violation_checks.py +596 -0
  656. omnibase_infra/validation/mixin_node_archetype_detection.py +254 -0
  657. omnibase_infra/validation/models/__init__.py +15 -0
  658. omnibase_infra/validation/models/model_contract_lint_result.py +101 -0
  659. omnibase_infra/validation/models/model_contract_violation.py +41 -0
  660. omnibase_infra/validation/service_validation_aggregator.py +395 -0
  661. omnibase_infra/validation/validation_exemptions.yaml +1710 -0
  662. omnibase_infra/validation/validator_any_type.py +715 -0
  663. omnibase_infra/validation/validator_chain_propagation.py +839 -0
  664. omnibase_infra/validation/validator_execution_shape.py +465 -0
  665. omnibase_infra/validation/validator_localhandler.py +261 -0
  666. omnibase_infra/validation/validator_registration_security.py +410 -0
  667. omnibase_infra/validation/validator_routing_coverage.py +1020 -0
  668. omnibase_infra/validation/validator_runtime_shape.py +915 -0
  669. omnibase_infra/validation/validator_security.py +410 -0
  670. omnibase_infra/validation/validator_topic_category.py +1152 -0
  671. omnibase_infra-0.2.1.dist-info/METADATA +197 -0
  672. omnibase_infra-0.2.1.dist-info/RECORD +675 -0
  673. omnibase_infra-0.2.1.dist-info/WHEEL +4 -0
  674. omnibase_infra-0.2.1.dist-info/entry_points.txt +4 -0
  675. omnibase_infra-0.2.1.dist-info/licenses/LICENSE +21 -0
@@ -0,0 +1,655 @@
1
+ # SPDX-License-Identifier: MIT
2
+ # Copyright (c) 2025 OmniNode Team
3
+ """Coroutine-safe async circuit breaker mixin for infrastructure components.
4
+
5
+ This module provides a reusable circuit breaker implementation for infrastructure
6
+ components such as event buses, service adapters, HTTP clients, and database
7
+ connections. It implements the standard 3-state circuit breaker pattern with
8
+ coroutine-safe async operations.
9
+
10
+ Circuit Breaker States:
11
+ - CLOSED: Normal operation, requests allowed
12
+ - OPEN: Circuit tripped, requests blocked
13
+ - HALF_OPEN: Testing recovery, limited requests allowed
14
+
15
+ Features:
16
+ - Coroutine-safe state management using asyncio.Lock
17
+ - Automatic state transitions based on failure thresholds
18
+ - Time-based auto-reset with configurable timeout
19
+ - Infrastructure error integration (InfraUnavailableError)
20
+ - Correlation ID propagation for distributed tracing
21
+ - Configurable failure thresholds and reset timeouts
22
+
23
+ Usage:
24
+ ```python
25
+ from omnibase_infra.mixins import MixinAsyncCircuitBreaker
26
+ from omnibase_infra.enums import EnumInfraTransportType
27
+
28
+ class EventBusKafka(MixinAsyncCircuitBreaker):
29
+ def __init__(self, config):
30
+ # Initialize circuit breaker with configuration
31
+ self._init_circuit_breaker(
32
+ threshold=config.circuit_breaker_threshold,
33
+ reset_timeout=config.circuit_breaker_reset_timeout,
34
+ service_name=f"kafka.{config.environment}",
35
+ transport_type=EnumInfraTransportType.KAFKA,
36
+ )
37
+
38
+ async def publish(
39
+ self, topic: str, key: str, value: bytes, correlation_id: UUID | None = None
40
+ ) -> None:
41
+ # Check circuit before operation
42
+ async with self._circuit_breaker_lock:
43
+ await self._check_circuit_breaker(
44
+ operation="publish",
45
+ correlation_id=correlation_id,
46
+ )
47
+
48
+ try:
49
+ # Perform operation
50
+ await self._kafka_producer.send(topic, key, value)
51
+
52
+ # Record success
53
+ async with self._circuit_breaker_lock:
54
+ await self._reset_circuit_breaker()
55
+
56
+ except Exception:
57
+ # Record failure
58
+ async with self._circuit_breaker_lock:
59
+ await self._record_circuit_failure(
60
+ operation="publish",
61
+ correlation_id=correlation_id,
62
+ )
63
+ raise
64
+ ```
65
+
66
+ Concurrency Safety:
67
+ All circuit breaker methods require the caller to hold `_circuit_breaker_lock`
68
+ before invocation. This is documented in each method's docstring using:
69
+ "REQUIRES: self._circuit_breaker_lock must be held by caller."
70
+
71
+ Note: This mixin uses asyncio.Lock which provides coroutine-safe access,
72
+ not thread-safe access. For true multi-threaded usage, additional
73
+ synchronization (e.g., threading.Lock) would be required.
74
+
75
+ Example:
76
+ ```python
77
+ # Correct - lock held by caller
78
+ async with self._circuit_breaker_lock:
79
+ await self._check_circuit_breaker("operation")
80
+
81
+ # Incorrect - race condition between coroutines!
82
+ await self._check_circuit_breaker("operation")
83
+ ```
84
+
85
+ Integration Requirements:
86
+ Classes using this mixin must:
87
+ 1. Call `_init_circuit_breaker()` during initialization
88
+ 2. Use `async with self._circuit_breaker_lock` before calling circuit methods
89
+ 3. Pass appropriate operation name and correlation_id to circuit methods
90
+ 4. Handle InfraUnavailableError when circuit is open
91
+
92
+ See Also:
93
+ - docs/analysis/CIRCUIT_BREAKER_COMPARISON.md for design rationale
94
+ - src/omnibase_infra/event_bus/event_bus_kafka.py for reference implementation
95
+ """
96
+
97
+ from __future__ import annotations
98
+
99
+ import asyncio
100
+ import logging
101
+ import time
102
+ from uuid import UUID, uuid4
103
+
104
+ from omnibase_infra.enums import EnumCircuitState, EnumInfraTransportType
105
+ from omnibase_infra.errors import (
106
+ InfraUnavailableError,
107
+ ModelInfraErrorContext,
108
+ ProtocolConfigurationError,
109
+ )
110
+ from omnibase_infra.models.resilience import ModelCircuitBreakerConfig
111
+
112
+ logger = logging.getLogger(__name__)
113
+
114
+
115
+ class MixinAsyncCircuitBreaker:
116
+ """Coroutine-safe async circuit breaker mixin for infrastructure components.
117
+
118
+ Provides circuit breaker pattern implementation with:
119
+ - Coroutine-safe state management using asyncio.Lock
120
+ - Configurable failure thresholds and reset timeouts
121
+ - Automatic state transitions (CLOSED → OPEN → HALF_OPEN → CLOSED)
122
+ - Infrastructure error integration (InfraUnavailableError)
123
+ - Correlation ID propagation for distributed tracing
124
+
125
+ State Variables:
126
+ _circuit_breaker_failures: Failure counter (incremented on each failure)
127
+ _circuit_breaker_open: Circuit open/closed state (True = open)
128
+ _circuit_breaker_open_until: Timestamp for automatic reset
129
+ _circuit_breaker_lock: asyncio.Lock for coroutine-safe access
130
+
131
+ Configuration Variables (public attributes set by _init_circuit_breaker):
132
+ circuit_breaker_threshold: Max failures before opening (default: 5)
133
+ circuit_breaker_reset_timeout: Auto-reset timeout in seconds (default: 60.0)
134
+ service_name: Service identifier for error context
135
+
136
+ Concurrency Safety:
137
+ All circuit breaker methods MUST be called while holding
138
+ `_circuit_breaker_lock`. Callers are responsible for lock acquisition.
139
+ Note: asyncio.Lock protects against concurrent coroutine access,
140
+ not OS thread access. For multi-threaded scenarios, use threading.Lock.
141
+
142
+ ```python
143
+ async with self._circuit_breaker_lock:
144
+ await self._check_circuit_breaker("operation")
145
+ ```
146
+
147
+ Example:
148
+ ```python
149
+ class ConsulAdapter(MixinAsyncCircuitBreaker):
150
+ def __init__(self, config):
151
+ self._init_circuit_breaker(
152
+ threshold=5,
153
+ reset_timeout=30.0,
154
+ service_name="consul.dev",
155
+ transport_type=EnumInfraTransportType.CONSUL,
156
+ )
157
+
158
+ async def register_service(
159
+ self, service: str, correlation_id: UUID | None = None
160
+ ) -> None:
161
+ # Check circuit (coroutine-safe)
162
+ async with self._circuit_breaker_lock:
163
+ await self._check_circuit_breaker(
164
+ operation="register_service",
165
+ correlation_id=correlation_id,
166
+ )
167
+
168
+ try:
169
+ # Perform operation
170
+ await self._consul_client.register(service)
171
+
172
+ # Record success (coroutine-safe)
173
+ async with self._circuit_breaker_lock:
174
+ await self._reset_circuit_breaker()
175
+
176
+ except Exception:
177
+ # Record failure (coroutine-safe)
178
+ async with self._circuit_breaker_lock:
179
+ await self._record_circuit_failure(
180
+ operation="register_service",
181
+ correlation_id=correlation_id,
182
+ )
183
+ raise
184
+ ```
185
+ """
186
+
187
+ def _init_circuit_breaker(
188
+ self,
189
+ threshold: int = 5,
190
+ reset_timeout: float = 60.0,
191
+ service_name: str = "unknown",
192
+ transport_type: EnumInfraTransportType = EnumInfraTransportType.HTTP,
193
+ ) -> None:
194
+ """Initialize circuit breaker state and configuration.
195
+
196
+ Must be called during class initialization before any circuit breaker
197
+ operations are performed.
198
+
199
+ Args:
200
+ threshold: Maximum failures before opening circuit (default: 5)
201
+ reset_timeout: Seconds before automatic reset (default: 60.0)
202
+ service_name: Service identifier for error context (e.g., "kafka.dev")
203
+ transport_type: Transport type for error context (default: HTTP)
204
+
205
+ Raises:
206
+ ValueError: If threshold < 1 or reset_timeout < 0
207
+
208
+ Example:
209
+ ```python
210
+ class MyService(MixinAsyncCircuitBreaker):
211
+ def __init__(self, config):
212
+ self._init_circuit_breaker(
213
+ threshold=config.circuit_breaker_threshold,
214
+ reset_timeout=config.circuit_breaker_reset_timeout,
215
+ service_name=f"my-service.{config.environment}",
216
+ transport_type=EnumInfraTransportType.HTTP,
217
+ )
218
+ ```
219
+ """
220
+ # Validate parameters
221
+ if threshold < 1:
222
+ context = ModelInfraErrorContext.with_correlation(
223
+ transport_type=transport_type,
224
+ operation="init_circuit_breaker",
225
+ target_name=service_name,
226
+ )
227
+ raise ProtocolConfigurationError(
228
+ f"Circuit breaker threshold must be >= 1, got {threshold}",
229
+ context=context,
230
+ parameter="threshold",
231
+ value=threshold,
232
+ )
233
+ if reset_timeout < 0:
234
+ context = ModelInfraErrorContext.with_correlation(
235
+ transport_type=transport_type,
236
+ operation="init_circuit_breaker",
237
+ target_name=service_name,
238
+ )
239
+ raise ProtocolConfigurationError(
240
+ f"Circuit breaker reset_timeout must be >= 0, got {reset_timeout}",
241
+ context=context,
242
+ parameter="reset_timeout",
243
+ value=reset_timeout,
244
+ )
245
+
246
+ # State variables
247
+ self._circuit_breaker_failures = 0
248
+ self._circuit_breaker_open = False
249
+ self._circuit_breaker_open_until: float = 0.0
250
+
251
+ # Configuration
252
+ self.circuit_breaker_threshold = threshold
253
+ self.circuit_breaker_reset_timeout = reset_timeout
254
+ self.service_name = service_name
255
+ self._cb_transport_type = (
256
+ transport_type # Use private name to avoid property conflicts
257
+ )
258
+
259
+ # Coroutine-safety lock (asyncio.Lock for concurrent async access, not thread-safe)
260
+ self._circuit_breaker_lock = asyncio.Lock()
261
+
262
+ logger.debug(
263
+ f"Circuit breaker initialized for {service_name}",
264
+ extra={
265
+ "threshold": threshold,
266
+ "reset_timeout": reset_timeout,
267
+ "transport_type": transport_type.value,
268
+ },
269
+ )
270
+
271
+ def _init_circuit_breaker_from_config(
272
+ self,
273
+ config: ModelCircuitBreakerConfig,
274
+ ) -> None:
275
+ """Initialize circuit breaker from a configuration model.
276
+
277
+ This method provides an alternative initialization path using a
278
+ configuration model instead of individual parameters. This reduces
279
+ union types in calling code and follows ONEX patterns.
280
+
281
+ Args:
282
+ config: Configuration model containing all circuit breaker settings.
283
+ See ModelCircuitBreakerConfig for available options.
284
+
285
+ Raises:
286
+ ValueError: If config contains invalid values (validated by Pydantic).
287
+
288
+ Example:
289
+ ```python
290
+ from omnibase_infra.models.resilience import ModelCircuitBreakerConfig
291
+ from omnibase_infra.enums import EnumInfraTransportType
292
+
293
+ class EventBusKafka(MixinAsyncCircuitBreaker):
294
+ def __init__(self, environment: str):
295
+ config = ModelCircuitBreakerConfig(
296
+ threshold=5,
297
+ reset_timeout_seconds=60.0,
298
+ service_name=f"kafka.{environment}",
299
+ transport_type=EnumInfraTransportType.KAFKA,
300
+ )
301
+ self._init_circuit_breaker_from_config(config)
302
+ ```
303
+
304
+ See Also:
305
+ _init_circuit_breaker: Original initialization method with parameters.
306
+ ModelCircuitBreakerConfig: Configuration model with all options.
307
+ """
308
+ self._init_circuit_breaker(
309
+ threshold=config.threshold,
310
+ reset_timeout=config.reset_timeout_seconds,
311
+ service_name=config.service_name,
312
+ transport_type=config.transport_type,
313
+ )
314
+
315
+ async def _check_circuit_breaker(
316
+ self, operation: str, correlation_id: UUID | None = None
317
+ ) -> None:
318
+ """Check if circuit breaker allows operation.
319
+
320
+ Verifies circuit breaker state and raises InfraUnavailableError if
321
+ circuit is open. Automatically transitions from OPEN to HALF_OPEN
322
+ if reset timeout has elapsed.
323
+
324
+ Concurrency Safety:
325
+ REQUIRES: self._circuit_breaker_lock must be held by caller.
326
+
327
+ This method accesses shared state variables and MUST be called
328
+ while holding the lock to prevent race conditions between coroutines:
329
+
330
+ ```python
331
+ # Correct
332
+ async with self._circuit_breaker_lock:
333
+ await self._check_circuit_breaker("operation")
334
+
335
+ # Incorrect - race condition between coroutines!
336
+ await self._check_circuit_breaker("operation")
337
+ ```
338
+
339
+ Args:
340
+ operation: Operation name for error context (e.g., "publish", "register")
341
+ correlation_id: Optional correlation ID for distributed tracing.
342
+ If not provided, a new UUID will be generated.
343
+
344
+ Raises:
345
+ InfraUnavailableError: If circuit breaker is open and reset timeout
346
+ has not elapsed. Error includes:
347
+ - context.transport_type: Transport type from configuration
348
+ - context.operation: Operation name from parameter
349
+ - context.target_name: Service name from configuration
350
+ - context.correlation_id: Correlation ID (provided or generated)
351
+ - circuit_state: Current circuit state ("open")
352
+ - retry_after_seconds: Seconds remaining until auto-reset
353
+
354
+ Example:
355
+ ```python
356
+ async def perform_operation(
357
+ self, correlation_id: UUID | None = None
358
+ ) -> Result:
359
+ # Check circuit before operation (coroutine-safe)
360
+ async with self._circuit_breaker_lock:
361
+ await self._check_circuit_breaker(
362
+ operation="perform_operation",
363
+ correlation_id=correlation_id,
364
+ )
365
+
366
+ # Proceed with operation if circuit allows
367
+ result = await self._do_work()
368
+ return result
369
+ ```
370
+ """
371
+ # Verify lock is held (debug assertion)
372
+ if not self._circuit_breaker_lock.locked():
373
+ logger.error(
374
+ "Circuit breaker lock not held during state check",
375
+ extra={
376
+ "service": self.service_name,
377
+ "operation": operation,
378
+ },
379
+ )
380
+ # Still proceed but log the violation for debugging
381
+
382
+ current_time = time.time()
383
+
384
+ # Check if circuit is open (atomic read protected by caller's lock)
385
+ if self._circuit_breaker_open:
386
+ # Check if reset timeout has passed
387
+ if current_time >= self._circuit_breaker_open_until:
388
+ # Transition to HALF_OPEN (atomic write protected by caller's lock)
389
+ self._circuit_breaker_open = False
390
+ self._circuit_breaker_failures = 0
391
+ logger.info(
392
+ f"Circuit breaker transitioning to half-open for {self.service_name}",
393
+ extra={
394
+ "service": self.service_name,
395
+ "operation": operation,
396
+ },
397
+ )
398
+ else:
399
+ # Circuit still open - block request
400
+ retry_after = int(self._circuit_breaker_open_until - current_time)
401
+ context = ModelInfraErrorContext(
402
+ transport_type=self._cb_transport_type,
403
+ operation=operation,
404
+ target_name=self.service_name,
405
+ correlation_id=correlation_id if correlation_id else uuid4(),
406
+ )
407
+ raise InfraUnavailableError(
408
+ f"Circuit breaker is open - {self.service_name} temporarily unavailable",
409
+ context=context,
410
+ circuit_state="open",
411
+ retry_after_seconds=retry_after,
412
+ )
413
+
414
+ async def _record_circuit_failure(
415
+ self, operation: str, correlation_id: UUID | None = None
416
+ ) -> None:
417
+ """Record a circuit breaker failure and potentially open the circuit.
418
+
419
+ Increments the failure counter and opens the circuit if the threshold
420
+ is reached. When the circuit opens, it sets the reset timestamp for
421
+ automatic recovery.
422
+
423
+ Concurrency Safety:
424
+ REQUIRES: self._circuit_breaker_lock must be held by caller.
425
+
426
+ This method mutates shared state variables and MUST be called
427
+ while holding the lock to prevent race conditions between coroutines:
428
+
429
+ ```python
430
+ # Correct
431
+ async with self._circuit_breaker_lock:
432
+ await self._record_circuit_failure("operation")
433
+
434
+ # Incorrect - race condition between coroutines!
435
+ await self._record_circuit_failure("operation")
436
+ ```
437
+
438
+ Args:
439
+ operation: Operation name for logging context
440
+ correlation_id: Optional correlation ID for distributed tracing
441
+
442
+ State Transitions:
443
+ If failure count >= threshold:
444
+ CLOSED → OPEN
445
+ HALF_OPEN → OPEN
446
+
447
+ Side Effects:
448
+ - Increments _circuit_breaker_failures
449
+ - If threshold reached:
450
+ - Sets _circuit_breaker_open = True
451
+ - Sets _circuit_breaker_open_until = current_time + reset_timeout
452
+ - Logs warning message
453
+
454
+ Example:
455
+ ```python
456
+ async def perform_operation(
457
+ self, correlation_id: UUID | None = None
458
+ ) -> Result:
459
+ try:
460
+ result = await self._do_work()
461
+ return result
462
+ except Exception:
463
+ # Record failure on exception (coroutine-safe)
464
+ async with self._circuit_breaker_lock:
465
+ await self._record_circuit_failure(
466
+ operation="perform_operation",
467
+ correlation_id=correlation_id,
468
+ )
469
+ raise
470
+ ```
471
+ """
472
+ # Verify lock is held (debug assertion)
473
+ if not self._circuit_breaker_lock.locked():
474
+ logger.error(
475
+ "Circuit breaker lock not held during failure recording",
476
+ extra={
477
+ "service": self.service_name,
478
+ "operation": operation,
479
+ },
480
+ )
481
+ # Still proceed but log the violation for debugging
482
+
483
+ # Increment failure counter (atomic write protected by caller's lock)
484
+ self._circuit_breaker_failures += 1
485
+
486
+ # Check if threshold reached
487
+ if self._circuit_breaker_failures >= self.circuit_breaker_threshold:
488
+ # Transition to OPEN state (atomic write protected by caller's lock)
489
+ self._circuit_breaker_open = True
490
+ self._circuit_breaker_open_until = (
491
+ time.time() + self.circuit_breaker_reset_timeout
492
+ )
493
+
494
+ logger.warning(
495
+ f"Circuit breaker opened for {self.service_name} after {self._circuit_breaker_failures} failures",
496
+ extra={
497
+ "service": self.service_name,
498
+ "operation": operation,
499
+ "failure_count": self._circuit_breaker_failures,
500
+ "threshold": self.circuit_breaker_threshold,
501
+ "reset_timeout": self.circuit_breaker_reset_timeout,
502
+ "correlation_id": str(correlation_id) if correlation_id else None,
503
+ },
504
+ )
505
+
506
+ async def _reset_circuit_breaker(self) -> None:
507
+ """Reset circuit breaker to closed state.
508
+
509
+ Resets the failure counter and closes the circuit, allowing all
510
+ requests to proceed normally. Typically called after a successful
511
+ operation.
512
+
513
+ Concurrency Safety:
514
+ REQUIRES: self._circuit_breaker_lock must be held by caller.
515
+
516
+ This method mutates shared state variables and MUST be called
517
+ while holding the lock to prevent race conditions between coroutines:
518
+
519
+ ```python
520
+ # Correct
521
+ async with self._circuit_breaker_lock:
522
+ await self._reset_circuit_breaker()
523
+
524
+ # Incorrect - race condition between coroutines!
525
+ await self._reset_circuit_breaker()
526
+ ```
527
+
528
+ State Transitions:
529
+ OPEN → CLOSED
530
+ HALF_OPEN → CLOSED
531
+ CLOSED → CLOSED (idempotent)
532
+
533
+ Side Effects:
534
+ - Sets _circuit_breaker_open = False
535
+ - Sets _circuit_breaker_failures = 0
536
+ - Sets _circuit_breaker_open_until = 0.0
537
+ - Logs info message if circuit was not already closed
538
+
539
+ Example:
540
+ ```python
541
+ async def perform_operation(self):
542
+ try:
543
+ result = await self._do_work()
544
+
545
+ # Reset circuit on success (coroutine-safe)
546
+ async with self._circuit_breaker_lock:
547
+ await self._reset_circuit_breaker()
548
+
549
+ return result
550
+ except Exception:
551
+ async with self._circuit_breaker_lock:
552
+ await self._record_circuit_failure("perform_operation")
553
+ raise
554
+ ```
555
+ """
556
+ # Verify lock is held (debug assertion)
557
+ if not self._circuit_breaker_lock.locked():
558
+ logger.error(
559
+ "Circuit breaker lock not held during reset",
560
+ extra={
561
+ "service": self.service_name,
562
+ },
563
+ )
564
+ # Still proceed but log the violation for debugging
565
+
566
+ # Log state transition if circuit was open or had failures
567
+ if self._circuit_breaker_open or self._circuit_breaker_failures > 0:
568
+ previous_state = "open" if self._circuit_breaker_open else "closed"
569
+ logger.info(
570
+ f"Circuit breaker reset from {previous_state} to closed for {self.service_name}",
571
+ extra={
572
+ "service": self.service_name,
573
+ "previous_state": previous_state,
574
+ "previous_failures": self._circuit_breaker_failures,
575
+ },
576
+ )
577
+
578
+ # Reset state (atomic write protected by caller's lock)
579
+ self._circuit_breaker_open = False
580
+ self._circuit_breaker_failures = 0
581
+ self._circuit_breaker_open_until = 0.0
582
+
583
+ def _get_circuit_breaker_state(self) -> dict[str, object]:
584
+ """Return current circuit breaker state for introspection.
585
+
586
+ This method encapsulates circuit breaker internals for safe access
587
+ by subclasses implementing describe() or other introspection methods.
588
+ It provides a stable interface for reading circuit breaker state without
589
+ exposing internal attribute names.
590
+
591
+ Note:
592
+ This method does NOT require holding _circuit_breaker_lock because
593
+ it only performs reads for observability purposes. The state may be
594
+ slightly stale in concurrent scenarios, which is acceptable for
595
+ introspection use cases.
596
+
597
+ Returns:
598
+ dict containing:
599
+ - initialized: Whether circuit breaker has been initialized
600
+ - state: Current state ("closed", "open", or "half_open")
601
+ - failures: Current failure count
602
+ - threshold: Configured failure threshold
603
+ - reset_timeout_seconds: Configured reset timeout
604
+ - seconds_until_half_open: Seconds until half_open (only when open)
605
+
606
+ Example:
607
+ ```python
608
+ def describe(self) -> dict[str, object]:
609
+ circuit_breaker_info = self._get_circuit_breaker_state()
610
+ return {
611
+ "handler_type": self.handler_type.value,
612
+ "circuit_breaker": circuit_breaker_info,
613
+ }
614
+ ```
615
+ """
616
+ # Check if circuit breaker has been initialized by looking for key attributes
617
+ cb_initialized = hasattr(self, "_circuit_breaker_lock") and hasattr(
618
+ self, "circuit_breaker_threshold"
619
+ )
620
+
621
+ # Read state variables with safe defaults for uninitialized state
622
+ cb_open = getattr(self, "_circuit_breaker_open", False)
623
+ cb_open_until = getattr(self, "_circuit_breaker_open_until", 0.0)
624
+ cb_failures = getattr(self, "_circuit_breaker_failures", 0)
625
+ cb_threshold = getattr(self, "circuit_breaker_threshold", 5)
626
+ cb_reset_timeout = getattr(self, "circuit_breaker_reset_timeout", 60.0)
627
+
628
+ # Calculate state: closed, open, or half_open
629
+ current_time = time.time()
630
+ if cb_open:
631
+ if current_time >= cb_open_until:
632
+ cb_state = "half_open"
633
+ seconds_until_half_open: float | None = None
634
+ else:
635
+ cb_state = "open"
636
+ seconds_until_half_open = round(cb_open_until - current_time, 2)
637
+ else:
638
+ cb_state = "closed"
639
+ seconds_until_half_open = None
640
+
641
+ result: dict[str, object] = {
642
+ "initialized": cb_initialized,
643
+ "state": cb_state,
644
+ "failures": cb_failures,
645
+ "threshold": cb_threshold,
646
+ "reset_timeout_seconds": cb_reset_timeout,
647
+ }
648
+
649
+ if seconds_until_half_open is not None:
650
+ result["seconds_until_half_open"] = seconds_until_half_open
651
+
652
+ return result
653
+
654
+
655
+ __all__ = ["EnumCircuitState", "MixinAsyncCircuitBreaker", "ModelCircuitBreakerConfig"]