omnibase_infra 0.2.6__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.
- omnibase_infra/__init__.py +101 -0
- omnibase_infra/adapters/adapter_onex_tool_execution.py +451 -0
- omnibase_infra/capabilities/__init__.py +15 -0
- omnibase_infra/capabilities/capability_inference_rules.py +211 -0
- omnibase_infra/capabilities/contract_capability_extractor.py +221 -0
- omnibase_infra/capabilities/intent_type_extractor.py +160 -0
- omnibase_infra/cli/__init__.py +1 -0
- omnibase_infra/cli/commands.py +216 -0
- omnibase_infra/clients/__init__.py +0 -0
- omnibase_infra/configs/widget_mapping.yaml +176 -0
- omnibase_infra/constants_topic_patterns.py +26 -0
- omnibase_infra/contracts/handlers/filesystem/handler_contract.yaml +264 -0
- omnibase_infra/contracts/handlers/mcp/handler_contract.yaml +141 -0
- omnibase_infra/decorators/__init__.py +29 -0
- omnibase_infra/decorators/allow_any.py +109 -0
- omnibase_infra/dlq/__init__.py +90 -0
- omnibase_infra/dlq/constants_dlq.py +57 -0
- omnibase_infra/dlq/models/__init__.py +26 -0
- omnibase_infra/dlq/models/enum_replay_status.py +37 -0
- omnibase_infra/dlq/models/model_dlq_replay_record.py +135 -0
- omnibase_infra/dlq/models/model_dlq_tracking_config.py +184 -0
- omnibase_infra/dlq/service_dlq_tracking.py +611 -0
- omnibase_infra/enums/__init__.py +132 -0
- omnibase_infra/enums/enum_any_type_violation.py +104 -0
- omnibase_infra/enums/enum_backend_type.py +27 -0
- omnibase_infra/enums/enum_capture_outcome.py +42 -0
- omnibase_infra/enums/enum_capture_state.py +88 -0
- omnibase_infra/enums/enum_chain_violation_type.py +119 -0
- omnibase_infra/enums/enum_circuit_state.py +51 -0
- omnibase_infra/enums/enum_confirmation_event_type.py +27 -0
- omnibase_infra/enums/enum_consumer_group_purpose.py +92 -0
- omnibase_infra/enums/enum_contract_type.py +84 -0
- omnibase_infra/enums/enum_dedupe_strategy.py +46 -0
- omnibase_infra/enums/enum_dispatch_status.py +191 -0
- omnibase_infra/enums/enum_environment.py +46 -0
- omnibase_infra/enums/enum_execution_shape_violation.py +103 -0
- omnibase_infra/enums/enum_handler_error_type.py +111 -0
- omnibase_infra/enums/enum_handler_loader_error.py +178 -0
- omnibase_infra/enums/enum_handler_source_mode.py +86 -0
- omnibase_infra/enums/enum_handler_source_type.py +87 -0
- omnibase_infra/enums/enum_handler_type.py +77 -0
- omnibase_infra/enums/enum_handler_type_category.py +61 -0
- omnibase_infra/enums/enum_infra_transport_type.py +73 -0
- omnibase_infra/enums/enum_introspection_reason.py +154 -0
- omnibase_infra/enums/enum_kafka_acks.py +99 -0
- omnibase_infra/enums/enum_message_category.py +213 -0
- omnibase_infra/enums/enum_node_archetype.py +74 -0
- omnibase_infra/enums/enum_node_output_type.py +185 -0
- omnibase_infra/enums/enum_non_retryable_error_category.py +224 -0
- omnibase_infra/enums/enum_policy_type.py +32 -0
- omnibase_infra/enums/enum_registration_state.py +261 -0
- omnibase_infra/enums/enum_registration_status.py +33 -0
- omnibase_infra/enums/enum_registry_response_status.py +28 -0
- omnibase_infra/enums/enum_response_status.py +26 -0
- omnibase_infra/enums/enum_retry_error_category.py +98 -0
- omnibase_infra/enums/enum_security_rule_id.py +103 -0
- omnibase_infra/enums/enum_selection_strategy.py +91 -0
- omnibase_infra/enums/enum_topic_standard.py +42 -0
- omnibase_infra/enums/enum_validation_severity.py +78 -0
- omnibase_infra/errors/__init__.py +160 -0
- omnibase_infra/errors/error_architecture_violation.py +152 -0
- omnibase_infra/errors/error_binding_resolution.py +128 -0
- omnibase_infra/errors/error_chain_propagation.py +188 -0
- omnibase_infra/errors/error_compute_registry.py +95 -0
- omnibase_infra/errors/error_consul.py +132 -0
- omnibase_infra/errors/error_container_wiring.py +243 -0
- omnibase_infra/errors/error_event_bus_registry.py +105 -0
- omnibase_infra/errors/error_infra.py +610 -0
- omnibase_infra/errors/error_message_type_registry.py +101 -0
- omnibase_infra/errors/error_policy_registry.py +115 -0
- omnibase_infra/errors/error_vault.py +123 -0
- omnibase_infra/event_bus/__init__.py +72 -0
- omnibase_infra/event_bus/configs/kafka_event_bus_config.yaml +84 -0
- omnibase_infra/event_bus/event_bus_inmemory.py +797 -0
- omnibase_infra/event_bus/event_bus_kafka.py +1716 -0
- omnibase_infra/event_bus/mixin_kafka_broadcast.py +180 -0
- omnibase_infra/event_bus/mixin_kafka_dlq.py +771 -0
- omnibase_infra/event_bus/models/__init__.py +29 -0
- omnibase_infra/event_bus/models/config/__init__.py +20 -0
- omnibase_infra/event_bus/models/config/model_kafka_event_bus_config.py +693 -0
- omnibase_infra/event_bus/models/model_dlq_event.py +206 -0
- omnibase_infra/event_bus/models/model_dlq_metrics.py +304 -0
- omnibase_infra/event_bus/models/model_event_headers.py +115 -0
- omnibase_infra/event_bus/models/model_event_message.py +60 -0
- omnibase_infra/event_bus/testing/__init__.py +26 -0
- omnibase_infra/event_bus/testing/adapter_protocol_event_publisher_inmemory.py +418 -0
- omnibase_infra/event_bus/testing/model_publisher_metrics.py +64 -0
- omnibase_infra/event_bus/topic_constants.py +376 -0
- omnibase_infra/handlers/__init__.py +82 -0
- omnibase_infra/handlers/filesystem/__init__.py +48 -0
- omnibase_infra/handlers/filesystem/enum_file_system_operation.py +35 -0
- omnibase_infra/handlers/filesystem/model_file_system_request.py +298 -0
- omnibase_infra/handlers/filesystem/model_file_system_result.py +166 -0
- omnibase_infra/handlers/handler_consul.py +795 -0
- omnibase_infra/handlers/handler_db.py +1046 -0
- omnibase_infra/handlers/handler_filesystem.py +1478 -0
- omnibase_infra/handlers/handler_graph.py +2015 -0
- omnibase_infra/handlers/handler_http.py +926 -0
- omnibase_infra/handlers/handler_intent.py +387 -0
- omnibase_infra/handlers/handler_manifest_persistence.contract.yaml +184 -0
- omnibase_infra/handlers/handler_manifest_persistence.py +1539 -0
- omnibase_infra/handlers/handler_mcp.py +1430 -0
- omnibase_infra/handlers/handler_qdrant.py +1076 -0
- omnibase_infra/handlers/handler_vault.py +428 -0
- omnibase_infra/handlers/mcp/__init__.py +19 -0
- omnibase_infra/handlers/mcp/adapter_onex_to_mcp.py +446 -0
- omnibase_infra/handlers/mcp/protocols.py +178 -0
- omnibase_infra/handlers/mcp/transport_streamable_http.py +352 -0
- omnibase_infra/handlers/mixins/__init__.py +47 -0
- omnibase_infra/handlers/mixins/mixin_consul_initialization.py +349 -0
- omnibase_infra/handlers/mixins/mixin_consul_kv.py +338 -0
- omnibase_infra/handlers/mixins/mixin_consul_service.py +542 -0
- omnibase_infra/handlers/mixins/mixin_consul_topic_index.py +585 -0
- omnibase_infra/handlers/mixins/mixin_vault_initialization.py +338 -0
- omnibase_infra/handlers/mixins/mixin_vault_retry.py +412 -0
- omnibase_infra/handlers/mixins/mixin_vault_secrets.py +450 -0
- omnibase_infra/handlers/mixins/mixin_vault_token.py +365 -0
- omnibase_infra/handlers/models/__init__.py +286 -0
- omnibase_infra/handlers/models/consul/__init__.py +81 -0
- omnibase_infra/handlers/models/consul/enum_consul_operation_type.py +57 -0
- omnibase_infra/handlers/models/consul/model_consul_deregister_payload.py +51 -0
- omnibase_infra/handlers/models/consul/model_consul_handler_config.py +153 -0
- omnibase_infra/handlers/models/consul/model_consul_handler_payload.py +89 -0
- omnibase_infra/handlers/models/consul/model_consul_kv_get_found_payload.py +55 -0
- omnibase_infra/handlers/models/consul/model_consul_kv_get_not_found_payload.py +49 -0
- omnibase_infra/handlers/models/consul/model_consul_kv_get_recurse_payload.py +50 -0
- omnibase_infra/handlers/models/consul/model_consul_kv_item.py +33 -0
- omnibase_infra/handlers/models/consul/model_consul_kv_put_payload.py +41 -0
- omnibase_infra/handlers/models/consul/model_consul_register_payload.py +53 -0
- omnibase_infra/handlers/models/consul/model_consul_retry_config.py +66 -0
- omnibase_infra/handlers/models/consul/model_payload_consul.py +66 -0
- omnibase_infra/handlers/models/consul/registry_payload_consul.py +214 -0
- omnibase_infra/handlers/models/graph/__init__.py +35 -0
- omnibase_infra/handlers/models/graph/enum_graph_operation_type.py +20 -0
- omnibase_infra/handlers/models/graph/model_graph_execute_payload.py +38 -0
- omnibase_infra/handlers/models/graph/model_graph_handler_config.py +54 -0
- omnibase_infra/handlers/models/graph/model_graph_handler_payload.py +44 -0
- omnibase_infra/handlers/models/graph/model_graph_query_payload.py +40 -0
- omnibase_infra/handlers/models/graph/model_graph_record.py +22 -0
- omnibase_infra/handlers/models/http/__init__.py +50 -0
- omnibase_infra/handlers/models/http/enum_http_operation_type.py +29 -0
- omnibase_infra/handlers/models/http/model_http_body_content.py +45 -0
- omnibase_infra/handlers/models/http/model_http_get_payload.py +88 -0
- omnibase_infra/handlers/models/http/model_http_handler_payload.py +90 -0
- omnibase_infra/handlers/models/http/model_http_post_payload.py +88 -0
- omnibase_infra/handlers/models/http/model_payload_http.py +66 -0
- omnibase_infra/handlers/models/http/registry_payload_http.py +212 -0
- omnibase_infra/handlers/models/mcp/__init__.py +23 -0
- omnibase_infra/handlers/models/mcp/enum_mcp_operation_type.py +24 -0
- omnibase_infra/handlers/models/mcp/model_mcp_handler_config.py +40 -0
- omnibase_infra/handlers/models/mcp/model_mcp_tool_call.py +32 -0
- omnibase_infra/handlers/models/mcp/model_mcp_tool_result.py +45 -0
- omnibase_infra/handlers/models/model_consul_handler_response.py +96 -0
- omnibase_infra/handlers/models/model_db_describe_response.py +83 -0
- omnibase_infra/handlers/models/model_db_query_payload.py +95 -0
- omnibase_infra/handlers/models/model_db_query_response.py +60 -0
- omnibase_infra/handlers/models/model_filesystem_config.py +98 -0
- omnibase_infra/handlers/models/model_filesystem_delete_payload.py +54 -0
- omnibase_infra/handlers/models/model_filesystem_delete_result.py +77 -0
- omnibase_infra/handlers/models/model_filesystem_directory_entry.py +75 -0
- omnibase_infra/handlers/models/model_filesystem_ensure_directory_payload.py +54 -0
- omnibase_infra/handlers/models/model_filesystem_ensure_directory_result.py +60 -0
- omnibase_infra/handlers/models/model_filesystem_list_directory_payload.py +60 -0
- omnibase_infra/handlers/models/model_filesystem_list_directory_result.py +68 -0
- omnibase_infra/handlers/models/model_filesystem_read_payload.py +62 -0
- omnibase_infra/handlers/models/model_filesystem_read_result.py +61 -0
- omnibase_infra/handlers/models/model_filesystem_write_payload.py +70 -0
- omnibase_infra/handlers/models/model_filesystem_write_result.py +55 -0
- omnibase_infra/handlers/models/model_graph_handler_response.py +98 -0
- omnibase_infra/handlers/models/model_handler_response.py +103 -0
- omnibase_infra/handlers/models/model_http_handler_response.py +101 -0
- omnibase_infra/handlers/models/model_manifest_metadata.py +75 -0
- omnibase_infra/handlers/models/model_manifest_persistence_config.py +62 -0
- omnibase_infra/handlers/models/model_manifest_query_payload.py +90 -0
- omnibase_infra/handlers/models/model_manifest_query_result.py +97 -0
- omnibase_infra/handlers/models/model_manifest_retrieve_payload.py +44 -0
- omnibase_infra/handlers/models/model_manifest_retrieve_result.py +98 -0
- omnibase_infra/handlers/models/model_manifest_store_payload.py +47 -0
- omnibase_infra/handlers/models/model_manifest_store_result.py +67 -0
- omnibase_infra/handlers/models/model_operation_context.py +187 -0
- omnibase_infra/handlers/models/model_qdrant_handler_response.py +98 -0
- omnibase_infra/handlers/models/model_retry_state.py +162 -0
- omnibase_infra/handlers/models/model_vault_handler_response.py +98 -0
- omnibase_infra/handlers/models/qdrant/__init__.py +44 -0
- omnibase_infra/handlers/models/qdrant/enum_qdrant_operation_type.py +26 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_collection_payload.py +42 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_delete_payload.py +36 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_handler_config.py +42 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_handler_payload.py +54 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_search_payload.py +42 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_search_result.py +30 -0
- omnibase_infra/handlers/models/qdrant/model_qdrant_upsert_payload.py +36 -0
- omnibase_infra/handlers/models/vault/__init__.py +69 -0
- omnibase_infra/handlers/models/vault/enum_vault_operation_type.py +35 -0
- omnibase_infra/handlers/models/vault/model_payload_vault.py +66 -0
- omnibase_infra/handlers/models/vault/model_vault_delete_payload.py +57 -0
- omnibase_infra/handlers/models/vault/model_vault_handler_config.py +148 -0
- omnibase_infra/handlers/models/vault/model_vault_handler_payload.py +101 -0
- omnibase_infra/handlers/models/vault/model_vault_list_payload.py +58 -0
- omnibase_infra/handlers/models/vault/model_vault_renew_token_payload.py +67 -0
- omnibase_infra/handlers/models/vault/model_vault_retry_config.py +66 -0
- omnibase_infra/handlers/models/vault/model_vault_secret_payload.py +106 -0
- omnibase_infra/handlers/models/vault/model_vault_write_payload.py +66 -0
- omnibase_infra/handlers/models/vault/registry_payload_vault.py +213 -0
- omnibase_infra/handlers/registration_storage/__init__.py +43 -0
- omnibase_infra/handlers/registration_storage/handler_registration_storage_mock.py +392 -0
- omnibase_infra/handlers/registration_storage/handler_registration_storage_postgres.py +922 -0
- omnibase_infra/handlers/registration_storage/models/__init__.py +23 -0
- omnibase_infra/handlers/registration_storage/models/model_delete_registration_request.py +58 -0
- omnibase_infra/handlers/registration_storage/models/model_update_registration_request.py +73 -0
- omnibase_infra/handlers/registration_storage/protocol_registration_persistence.py +191 -0
- omnibase_infra/handlers/service_discovery/__init__.py +43 -0
- omnibase_infra/handlers/service_discovery/handler_service_discovery_consul.py +1051 -0
- omnibase_infra/handlers/service_discovery/handler_service_discovery_mock.py +258 -0
- omnibase_infra/handlers/service_discovery/models/__init__.py +22 -0
- omnibase_infra/handlers/service_discovery/models/model_discovery_result.py +64 -0
- omnibase_infra/handlers/service_discovery/models/model_registration_result.py +138 -0
- omnibase_infra/handlers/service_discovery/models/model_service_info.py +109 -0
- omnibase_infra/handlers/service_discovery/protocol_discovery_operations.py +170 -0
- omnibase_infra/idempotency/__init__.py +94 -0
- omnibase_infra/idempotency/models/__init__.py +43 -0
- omnibase_infra/idempotency/models/model_idempotency_check_result.py +85 -0
- omnibase_infra/idempotency/models/model_idempotency_guard_config.py +130 -0
- omnibase_infra/idempotency/models/model_idempotency_record.py +86 -0
- omnibase_infra/idempotency/models/model_idempotency_store_health_check_result.py +81 -0
- omnibase_infra/idempotency/models/model_idempotency_store_metrics.py +140 -0
- omnibase_infra/idempotency/models/model_postgres_idempotency_store_config.py +299 -0
- omnibase_infra/idempotency/protocol_idempotency_store.py +184 -0
- omnibase_infra/idempotency/store_inmemory.py +265 -0
- omnibase_infra/idempotency/store_postgres.py +923 -0
- omnibase_infra/infrastructure/__init__.py +0 -0
- omnibase_infra/migrations/001_create_event_ledger.sql +166 -0
- omnibase_infra/migrations/001_drop_event_ledger.sql +18 -0
- omnibase_infra/mixins/__init__.py +71 -0
- omnibase_infra/mixins/mixin_async_circuit_breaker.py +656 -0
- omnibase_infra/mixins/mixin_dict_like_accessors.py +146 -0
- omnibase_infra/mixins/mixin_envelope_extraction.py +119 -0
- omnibase_infra/mixins/mixin_node_introspection.py +2670 -0
- omnibase_infra/mixins/mixin_retry_execution.py +386 -0
- omnibase_infra/mixins/protocol_circuit_breaker_aware.py +133 -0
- omnibase_infra/models/__init__.py +144 -0
- omnibase_infra/models/bindings/__init__.py +59 -0
- omnibase_infra/models/bindings/constants.py +144 -0
- omnibase_infra/models/bindings/model_binding_resolution_result.py +103 -0
- omnibase_infra/models/bindings/model_operation_binding.py +44 -0
- omnibase_infra/models/bindings/model_operation_bindings_subcontract.py +152 -0
- omnibase_infra/models/bindings/model_parsed_binding.py +52 -0
- omnibase_infra/models/corpus/__init__.py +17 -0
- omnibase_infra/models/corpus/model_capture_config.py +133 -0
- omnibase_infra/models/corpus/model_capture_result.py +86 -0
- omnibase_infra/models/discovery/__init__.py +42 -0
- omnibase_infra/models/discovery/model_dependency_spec.py +319 -0
- omnibase_infra/models/discovery/model_discovered_capabilities.py +50 -0
- omnibase_infra/models/discovery/model_introspection_config.py +330 -0
- omnibase_infra/models/discovery/model_introspection_performance_metrics.py +169 -0
- omnibase_infra/models/discovery/model_introspection_task_config.py +116 -0
- omnibase_infra/models/dispatch/__init__.py +155 -0
- omnibase_infra/models/dispatch/model_debug_trace_snapshot.py +114 -0
- omnibase_infra/models/dispatch/model_dispatch_context.py +439 -0
- omnibase_infra/models/dispatch/model_dispatch_error.py +336 -0
- omnibase_infra/models/dispatch/model_dispatch_log_context.py +400 -0
- omnibase_infra/models/dispatch/model_dispatch_metadata.py +228 -0
- omnibase_infra/models/dispatch/model_dispatch_metrics.py +496 -0
- omnibase_infra/models/dispatch/model_dispatch_outcome.py +317 -0
- omnibase_infra/models/dispatch/model_dispatch_outputs.py +231 -0
- omnibase_infra/models/dispatch/model_dispatch_result.py +436 -0
- omnibase_infra/models/dispatch/model_dispatch_route.py +279 -0
- omnibase_infra/models/dispatch/model_dispatcher_metrics.py +275 -0
- omnibase_infra/models/dispatch/model_dispatcher_registration.py +352 -0
- omnibase_infra/models/dispatch/model_materialized_dispatch.py +141 -0
- omnibase_infra/models/dispatch/model_parsed_topic.py +135 -0
- omnibase_infra/models/dispatch/model_topic_parser.py +725 -0
- omnibase_infra/models/dispatch/model_tracing_context.py +285 -0
- omnibase_infra/models/errors/__init__.py +45 -0
- omnibase_infra/models/errors/model_handler_validation_error.py +594 -0
- omnibase_infra/models/errors/model_infra_error_context.py +99 -0
- omnibase_infra/models/errors/model_message_type_registry_error_context.py +71 -0
- omnibase_infra/models/errors/model_timeout_error_context.py +110 -0
- omnibase_infra/models/handlers/__init__.py +80 -0
- omnibase_infra/models/handlers/model_bootstrap_handler_descriptor.py +162 -0
- omnibase_infra/models/handlers/model_contract_discovery_result.py +82 -0
- omnibase_infra/models/handlers/model_handler_descriptor.py +200 -0
- omnibase_infra/models/handlers/model_handler_identifier.py +215 -0
- omnibase_infra/models/handlers/model_handler_source_config.py +220 -0
- omnibase_infra/models/health/__init__.py +9 -0
- omnibase_infra/models/health/model_health_check_result.py +40 -0
- omnibase_infra/models/lifecycle/__init__.py +39 -0
- omnibase_infra/models/logging/__init__.py +51 -0
- omnibase_infra/models/logging/model_log_context.py +756 -0
- omnibase_infra/models/mcp/__init__.py +15 -0
- omnibase_infra/models/mcp/model_mcp_contract_config.py +80 -0
- omnibase_infra/models/mcp/model_mcp_server_config.py +67 -0
- omnibase_infra/models/mcp/model_mcp_tool_definition.py +73 -0
- omnibase_infra/models/mcp/model_mcp_tool_parameter.py +35 -0
- omnibase_infra/models/model_node_identity.py +126 -0
- omnibase_infra/models/model_retry_error_classification.py +78 -0
- omnibase_infra/models/projection/__init__.py +43 -0
- omnibase_infra/models/projection/model_capability_fields.py +112 -0
- omnibase_infra/models/projection/model_registration_projection.py +434 -0
- omnibase_infra/models/projection/model_registration_snapshot.py +322 -0
- omnibase_infra/models/projection/model_sequence_info.py +182 -0
- omnibase_infra/models/projection/model_snapshot_topic_config.py +591 -0
- omnibase_infra/models/projectors/__init__.py +41 -0
- omnibase_infra/models/projectors/model_projector_column.py +289 -0
- omnibase_infra/models/projectors/model_projector_discovery_result.py +65 -0
- omnibase_infra/models/projectors/model_projector_index.py +270 -0
- omnibase_infra/models/projectors/model_projector_schema.py +415 -0
- omnibase_infra/models/projectors/model_projector_validation_error.py +63 -0
- omnibase_infra/models/projectors/util_sql_identifiers.py +115 -0
- omnibase_infra/models/registration/__init__.py +68 -0
- omnibase_infra/models/registration/commands/__init__.py +15 -0
- omnibase_infra/models/registration/commands/model_node_registration_acked.py +108 -0
- omnibase_infra/models/registration/events/__init__.py +56 -0
- omnibase_infra/models/registration/events/model_node_became_active.py +103 -0
- omnibase_infra/models/registration/events/model_node_liveness_expired.py +103 -0
- omnibase_infra/models/registration/events/model_node_registration_accepted.py +98 -0
- omnibase_infra/models/registration/events/model_node_registration_ack_received.py +98 -0
- omnibase_infra/models/registration/events/model_node_registration_ack_timed_out.py +112 -0
- omnibase_infra/models/registration/events/model_node_registration_initiated.py +107 -0
- omnibase_infra/models/registration/events/model_node_registration_rejected.py +104 -0
- omnibase_infra/models/registration/model_event_bus_topic_entry.py +59 -0
- omnibase_infra/models/registration/model_introspection_metrics.py +253 -0
- omnibase_infra/models/registration/model_node_capabilities.py +190 -0
- omnibase_infra/models/registration/model_node_event_bus_config.py +99 -0
- omnibase_infra/models/registration/model_node_heartbeat_event.py +126 -0
- omnibase_infra/models/registration/model_node_introspection_event.py +195 -0
- omnibase_infra/models/registration/model_node_metadata.py +79 -0
- omnibase_infra/models/registration/model_node_registration.py +162 -0
- omnibase_infra/models/registration/model_node_registration_record.py +162 -0
- omnibase_infra/models/registry/__init__.py +29 -0
- omnibase_infra/models/registry/model_domain_constraint.py +202 -0
- omnibase_infra/models/registry/model_message_type_entry.py +271 -0
- omnibase_infra/models/resilience/__init__.py +9 -0
- omnibase_infra/models/resilience/model_circuit_breaker_config.py +227 -0
- omnibase_infra/models/routing/__init__.py +25 -0
- omnibase_infra/models/routing/model_routing_entry.py +52 -0
- omnibase_infra/models/routing/model_routing_subcontract.py +70 -0
- omnibase_infra/models/runtime/__init__.py +49 -0
- omnibase_infra/models/runtime/model_contract_security_config.py +41 -0
- omnibase_infra/models/runtime/model_discovery_error.py +81 -0
- omnibase_infra/models/runtime/model_discovery_result.py +162 -0
- omnibase_infra/models/runtime/model_discovery_warning.py +74 -0
- omnibase_infra/models/runtime/model_failed_plugin_load.py +63 -0
- omnibase_infra/models/runtime/model_handler_contract.py +296 -0
- omnibase_infra/models/runtime/model_loaded_handler.py +129 -0
- omnibase_infra/models/runtime/model_plugin_load_context.py +93 -0
- omnibase_infra/models/runtime/model_plugin_load_summary.py +124 -0
- omnibase_infra/models/security/__init__.py +50 -0
- omnibase_infra/models/security/classification_levels.py +99 -0
- omnibase_infra/models/security/model_environment_policy.py +145 -0
- omnibase_infra/models/security/model_handler_security_policy.py +107 -0
- omnibase_infra/models/security/model_security_error.py +81 -0
- omnibase_infra/models/security/model_security_validation_result.py +328 -0
- omnibase_infra/models/security/model_security_warning.py +67 -0
- omnibase_infra/models/snapshot/__init__.py +27 -0
- omnibase_infra/models/snapshot/model_field_change.py +65 -0
- omnibase_infra/models/snapshot/model_snapshot.py +270 -0
- omnibase_infra/models/snapshot/model_snapshot_diff.py +203 -0
- omnibase_infra/models/snapshot/model_subject_ref.py +81 -0
- omnibase_infra/models/types/__init__.py +71 -0
- omnibase_infra/models/validation/__init__.py +89 -0
- omnibase_infra/models/validation/model_any_type_validation_result.py +118 -0
- omnibase_infra/models/validation/model_any_type_violation.py +141 -0
- omnibase_infra/models/validation/model_category_match_result.py +345 -0
- omnibase_infra/models/validation/model_chain_violation.py +166 -0
- omnibase_infra/models/validation/model_coverage_metrics.py +316 -0
- omnibase_infra/models/validation/model_execution_shape_rule.py +159 -0
- omnibase_infra/models/validation/model_execution_shape_validation.py +208 -0
- omnibase_infra/models/validation/model_execution_shape_validation_result.py +294 -0
- omnibase_infra/models/validation/model_execution_shape_violation.py +122 -0
- omnibase_infra/models/validation/model_localhandler_validation_result.py +139 -0
- omnibase_infra/models/validation/model_localhandler_violation.py +100 -0
- omnibase_infra/models/validation/model_output_validation_params.py +74 -0
- omnibase_infra/models/validation/model_validate_and_raise_params.py +84 -0
- omnibase_infra/models/validation/model_validation_error_params.py +84 -0
- omnibase_infra/models/validation/model_validation_outcome.py +287 -0
- omnibase_infra/nodes/__init__.py +57 -0
- omnibase_infra/nodes/architecture_validator/__init__.py +79 -0
- omnibase_infra/nodes/architecture_validator/contract.yaml +252 -0
- omnibase_infra/nodes/architecture_validator/contract_architecture_validator.yaml +203 -0
- omnibase_infra/nodes/architecture_validator/mixins/__init__.py +16 -0
- omnibase_infra/nodes/architecture_validator/mixins/mixin_file_path_rule.py +92 -0
- omnibase_infra/nodes/architecture_validator/models/__init__.py +36 -0
- omnibase_infra/nodes/architecture_validator/models/model_architecture_validation_request.py +56 -0
- omnibase_infra/nodes/architecture_validator/models/model_architecture_validation_result.py +311 -0
- omnibase_infra/nodes/architecture_validator/models/model_architecture_violation.py +163 -0
- omnibase_infra/nodes/architecture_validator/models/model_rule_check_result.py +265 -0
- omnibase_infra/nodes/architecture_validator/models/model_validation_request.py +105 -0
- omnibase_infra/nodes/architecture_validator/models/model_validation_result.py +314 -0
- omnibase_infra/nodes/architecture_validator/node.py +262 -0
- omnibase_infra/nodes/architecture_validator/node_architecture_validator.py +383 -0
- omnibase_infra/nodes/architecture_validator/protocols/__init__.py +9 -0
- omnibase_infra/nodes/architecture_validator/protocols/protocol_architecture_rule.py +225 -0
- omnibase_infra/nodes/architecture_validator/registry/__init__.py +28 -0
- omnibase_infra/nodes/architecture_validator/registry/registry_infra_architecture_validator.py +106 -0
- omnibase_infra/nodes/architecture_validator/validators/__init__.py +104 -0
- omnibase_infra/nodes/architecture_validator/validators/validator_no_direct_dispatch.py +422 -0
- omnibase_infra/nodes/architecture_validator/validators/validator_no_handler_publishing.py +481 -0
- omnibase_infra/nodes/architecture_validator/validators/validator_no_orchestrator_fsm.py +491 -0
- omnibase_infra/nodes/contract_registry_reducer/__init__.py +29 -0
- omnibase_infra/nodes/contract_registry_reducer/contract.yaml +255 -0
- omnibase_infra/nodes/contract_registry_reducer/models/__init__.py +38 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_contract_registry_state.py +266 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_cleanup_topic_references.py +55 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_deactivate_contract.py +58 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_mark_stale.py +49 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_update_heartbeat.py +71 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_update_topic.py +66 -0
- omnibase_infra/nodes/contract_registry_reducer/models/model_payload_upsert_contract.py +92 -0
- omnibase_infra/nodes/contract_registry_reducer/node.py +121 -0
- omnibase_infra/nodes/contract_registry_reducer/reducer.py +784 -0
- omnibase_infra/nodes/contract_registry_reducer/registry/__init__.py +9 -0
- omnibase_infra/nodes/contract_registry_reducer/registry/registry_infra_contract_registry_reducer.py +101 -0
- omnibase_infra/nodes/effects/README.md +358 -0
- omnibase_infra/nodes/effects/__init__.py +26 -0
- omnibase_infra/nodes/effects/contract.yaml +167 -0
- omnibase_infra/nodes/effects/models/__init__.py +32 -0
- omnibase_infra/nodes/effects/models/model_backend_result.py +190 -0
- omnibase_infra/nodes/effects/models/model_effect_idempotency_config.py +92 -0
- omnibase_infra/nodes/effects/models/model_registry_request.py +132 -0
- omnibase_infra/nodes/effects/models/model_registry_response.py +263 -0
- omnibase_infra/nodes/effects/protocol_consul_client.py +89 -0
- omnibase_infra/nodes/effects/protocol_effect_idempotency_store.py +143 -0
- omnibase_infra/nodes/effects/protocol_postgres_adapter.py +96 -0
- omnibase_infra/nodes/effects/registry_effect.py +525 -0
- omnibase_infra/nodes/effects/store_effect_idempotency_inmemory.py +425 -0
- omnibase_infra/nodes/handlers/consul/contract.yaml +85 -0
- omnibase_infra/nodes/handlers/db/contract.yaml +72 -0
- omnibase_infra/nodes/handlers/graph/contract.yaml +127 -0
- omnibase_infra/nodes/handlers/http/contract.yaml +74 -0
- omnibase_infra/nodes/handlers/intent/contract.yaml +66 -0
- omnibase_infra/nodes/handlers/mcp/contract.yaml +69 -0
- omnibase_infra/nodes/handlers/vault/contract.yaml +91 -0
- omnibase_infra/nodes/node_intent_storage_effect/__init__.py +50 -0
- omnibase_infra/nodes/node_intent_storage_effect/contract.yaml +194 -0
- omnibase_infra/nodes/node_intent_storage_effect/models/__init__.py +24 -0
- omnibase_infra/nodes/node_intent_storage_effect/models/model_intent_storage_input.py +141 -0
- omnibase_infra/nodes/node_intent_storage_effect/models/model_intent_storage_output.py +130 -0
- omnibase_infra/nodes/node_intent_storage_effect/node.py +94 -0
- omnibase_infra/nodes/node_intent_storage_effect/registry/__init__.py +35 -0
- omnibase_infra/nodes/node_intent_storage_effect/registry/registry_infra_intent_storage.py +294 -0
- omnibase_infra/nodes/node_ledger_projection_compute/__init__.py +50 -0
- omnibase_infra/nodes/node_ledger_projection_compute/contract.yaml +104 -0
- omnibase_infra/nodes/node_ledger_projection_compute/node.py +284 -0
- omnibase_infra/nodes/node_ledger_projection_compute/registry/__init__.py +29 -0
- omnibase_infra/nodes/node_ledger_projection_compute/registry/registry_infra_ledger_projection.py +118 -0
- omnibase_infra/nodes/node_ledger_write_effect/__init__.py +82 -0
- omnibase_infra/nodes/node_ledger_write_effect/contract.yaml +200 -0
- omnibase_infra/nodes/node_ledger_write_effect/handlers/__init__.py +22 -0
- omnibase_infra/nodes/node_ledger_write_effect/handlers/handler_ledger_append.py +372 -0
- omnibase_infra/nodes/node_ledger_write_effect/handlers/handler_ledger_query.py +597 -0
- omnibase_infra/nodes/node_ledger_write_effect/models/__init__.py +31 -0
- omnibase_infra/nodes/node_ledger_write_effect/models/model_ledger_append_result.py +54 -0
- omnibase_infra/nodes/node_ledger_write_effect/models/model_ledger_entry.py +92 -0
- omnibase_infra/nodes/node_ledger_write_effect/models/model_ledger_query.py +53 -0
- omnibase_infra/nodes/node_ledger_write_effect/models/model_ledger_query_result.py +41 -0
- omnibase_infra/nodes/node_ledger_write_effect/node.py +89 -0
- omnibase_infra/nodes/node_ledger_write_effect/protocols/__init__.py +13 -0
- omnibase_infra/nodes/node_ledger_write_effect/protocols/protocol_ledger_persistence.py +127 -0
- omnibase_infra/nodes/node_ledger_write_effect/registry/__init__.py +9 -0
- omnibase_infra/nodes/node_ledger_write_effect/registry/registry_infra_ledger_write.py +121 -0
- omnibase_infra/nodes/node_registration_orchestrator/README.md +542 -0
- omnibase_infra/nodes/node_registration_orchestrator/__init__.py +120 -0
- omnibase_infra/nodes/node_registration_orchestrator/contract.yaml +482 -0
- omnibase_infra/nodes/node_registration_orchestrator/dispatchers/__init__.py +53 -0
- omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_node_introspected.py +376 -0
- omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_node_registration_acked.py +376 -0
- omnibase_infra/nodes/node_registration_orchestrator/dispatchers/dispatcher_runtime_tick.py +373 -0
- omnibase_infra/nodes/node_registration_orchestrator/handlers/__init__.py +62 -0
- omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_heartbeat.py +376 -0
- omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_introspected.py +694 -0
- omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_node_registration_acked.py +458 -0
- omnibase_infra/nodes/node_registration_orchestrator/handlers/handler_runtime_tick.py +364 -0
- omnibase_infra/nodes/node_registration_orchestrator/introspection_event_router.py +544 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/__init__.py +75 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_consul_intent_payload.py +194 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_consul_registration_intent.py +67 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_intent_execution_result.py +50 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_node_liveness_expired.py +107 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_config.py +67 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_input.py +41 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_orchestrator_output.py +166 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_postgres_intent_payload.py +235 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_postgres_upsert_intent.py +68 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_reducer_execution_result.py +384 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_reducer_state.py +60 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_registration_intent.py +177 -0
- omnibase_infra/nodes/node_registration_orchestrator/models/model_registry_intent.py +247 -0
- omnibase_infra/nodes/node_registration_orchestrator/node.py +195 -0
- omnibase_infra/nodes/node_registration_orchestrator/plugin.py +909 -0
- omnibase_infra/nodes/node_registration_orchestrator/protocols.py +439 -0
- omnibase_infra/nodes/node_registration_orchestrator/registry/__init__.py +41 -0
- omnibase_infra/nodes/node_registration_orchestrator/registry/registry_infra_node_registration_orchestrator.py +528 -0
- omnibase_infra/nodes/node_registration_orchestrator/timeout_coordinator.py +393 -0
- omnibase_infra/nodes/node_registration_orchestrator/wiring.py +743 -0
- omnibase_infra/nodes/node_registration_reducer/__init__.py +15 -0
- omnibase_infra/nodes/node_registration_reducer/contract.yaml +301 -0
- omnibase_infra/nodes/node_registration_reducer/models/__init__.py +38 -0
- omnibase_infra/nodes/node_registration_reducer/models/model_validation_result.py +113 -0
- omnibase_infra/nodes/node_registration_reducer/node.py +139 -0
- omnibase_infra/nodes/node_registration_reducer/registry/__init__.py +9 -0
- omnibase_infra/nodes/node_registration_reducer/registry/registry_infra_node_registration_reducer.py +79 -0
- omnibase_infra/nodes/node_registration_storage_effect/__init__.py +41 -0
- omnibase_infra/nodes/node_registration_storage_effect/contract.yaml +220 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/__init__.py +44 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_delete_result.py +132 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_registration_record.py +199 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_registration_update.py +155 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_health_check_details.py +123 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_health_check_result.py +117 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_query.py +100 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_storage_result.py +136 -0
- omnibase_infra/nodes/node_registration_storage_effect/models/model_upsert_result.py +127 -0
- omnibase_infra/nodes/node_registration_storage_effect/node.py +112 -0
- omnibase_infra/nodes/node_registration_storage_effect/protocols/__init__.py +22 -0
- omnibase_infra/nodes/node_registration_storage_effect/protocols/protocol_registration_persistence.py +333 -0
- omnibase_infra/nodes/node_registration_storage_effect/registry/__init__.py +23 -0
- omnibase_infra/nodes/node_registration_storage_effect/registry/registry_infra_registration_storage.py +215 -0
- omnibase_infra/nodes/node_registry_effect/__init__.py +85 -0
- omnibase_infra/nodes/node_registry_effect/contract.yaml +677 -0
- omnibase_infra/nodes/node_registry_effect/handlers/__init__.py +70 -0
- omnibase_infra/nodes/node_registry_effect/handlers/handler_consul_deregister.py +211 -0
- omnibase_infra/nodes/node_registry_effect/handlers/handler_consul_register.py +212 -0
- omnibase_infra/nodes/node_registry_effect/handlers/handler_partial_retry.py +417 -0
- omnibase_infra/nodes/node_registry_effect/handlers/handler_postgres_deactivate.py +215 -0
- omnibase_infra/nodes/node_registry_effect/handlers/handler_postgres_upsert.py +208 -0
- omnibase_infra/nodes/node_registry_effect/models/__init__.py +43 -0
- omnibase_infra/nodes/node_registry_effect/models/model_partial_retry_request.py +92 -0
- omnibase_infra/nodes/node_registry_effect/node.py +165 -0
- omnibase_infra/nodes/node_registry_effect/registry/__init__.py +27 -0
- omnibase_infra/nodes/node_registry_effect/registry/registry_infra_registry_effect.py +196 -0
- omnibase_infra/nodes/node_service_discovery_effect/__init__.py +111 -0
- omnibase_infra/nodes/node_service_discovery_effect/contract.yaml +246 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/__init__.py +67 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/enum_health_status.py +72 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/enum_service_discovery_operation.py +58 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_discovery_query.py +99 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_discovery_result.py +98 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_health_check_config.py +121 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_query_metadata.py +63 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_registration_result.py +130 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_service_discovery_health_check_details.py +111 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_service_discovery_health_check_result.py +119 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_service_info.py +106 -0
- omnibase_infra/nodes/node_service_discovery_effect/models/model_service_registration.py +121 -0
- omnibase_infra/nodes/node_service_discovery_effect/node.py +111 -0
- omnibase_infra/nodes/node_service_discovery_effect/protocols/__init__.py +14 -0
- omnibase_infra/nodes/node_service_discovery_effect/protocols/protocol_discovery_operations.py +279 -0
- omnibase_infra/nodes/node_service_discovery_effect/registry/__init__.py +13 -0
- omnibase_infra/nodes/node_service_discovery_effect/registry/registry_infra_service_discovery.py +222 -0
- omnibase_infra/nodes/reducers/__init__.py +30 -0
- omnibase_infra/nodes/reducers/models/__init__.py +37 -0
- omnibase_infra/nodes/reducers/models/model_payload_consul_register.py +87 -0
- omnibase_infra/nodes/reducers/models/model_payload_ledger_append.py +133 -0
- omnibase_infra/nodes/reducers/models/model_payload_postgres_upsert_registration.py +60 -0
- omnibase_infra/nodes/reducers/models/model_registration_confirmation.py +166 -0
- omnibase_infra/nodes/reducers/models/model_registration_state.py +433 -0
- omnibase_infra/nodes/reducers/registration_reducer.py +1138 -0
- omnibase_infra/observability/__init__.py +143 -0
- omnibase_infra/observability/constants_metrics.py +91 -0
- omnibase_infra/observability/factory_observability_sink.py +525 -0
- omnibase_infra/observability/handlers/__init__.py +118 -0
- omnibase_infra/observability/handlers/handler_logging_structured.py +967 -0
- omnibase_infra/observability/handlers/handler_metrics_prometheus.py +1120 -0
- omnibase_infra/observability/handlers/model_logging_handler_config.py +71 -0
- omnibase_infra/observability/handlers/model_logging_handler_response.py +77 -0
- omnibase_infra/observability/handlers/model_metrics_handler_config.py +172 -0
- omnibase_infra/observability/handlers/model_metrics_handler_payload.py +135 -0
- omnibase_infra/observability/handlers/model_metrics_handler_response.py +101 -0
- omnibase_infra/observability/hooks/__init__.py +74 -0
- omnibase_infra/observability/hooks/hook_observability.py +1223 -0
- omnibase_infra/observability/models/__init__.py +30 -0
- omnibase_infra/observability/models/enum_required_log_context_key.py +77 -0
- omnibase_infra/observability/models/model_buffered_log_entry.py +117 -0
- omnibase_infra/observability/models/model_logging_sink_config.py +73 -0
- omnibase_infra/observability/models/model_metrics_sink_config.py +156 -0
- omnibase_infra/observability/sinks/__init__.py +69 -0
- omnibase_infra/observability/sinks/sink_logging_structured.py +809 -0
- omnibase_infra/observability/sinks/sink_metrics_prometheus.py +710 -0
- omnibase_infra/plugins/__init__.py +27 -0
- omnibase_infra/plugins/examples/__init__.py +28 -0
- omnibase_infra/plugins/examples/plugin_json_normalizer.py +271 -0
- omnibase_infra/plugins/examples/plugin_json_normalizer_error_handling.py +210 -0
- omnibase_infra/plugins/models/__init__.py +21 -0
- omnibase_infra/plugins/models/model_plugin_context.py +76 -0
- omnibase_infra/plugins/models/model_plugin_input_data.py +58 -0
- omnibase_infra/plugins/models/model_plugin_output_data.py +62 -0
- omnibase_infra/plugins/plugin_compute_base.py +449 -0
- omnibase_infra/projectors/__init__.py +30 -0
- omnibase_infra/projectors/contracts/__init__.py +63 -0
- omnibase_infra/projectors/contracts/registration_projector.yaml +370 -0
- omnibase_infra/projectors/projection_reader_registration.py +1559 -0
- omnibase_infra/projectors/snapshot_publisher_registration.py +1329 -0
- omnibase_infra/protocols/__init__.py +104 -0
- omnibase_infra/protocols/protocol_capability_projection.py +253 -0
- omnibase_infra/protocols/protocol_capability_query.py +251 -0
- omnibase_infra/protocols/protocol_container_aware.py +200 -0
- omnibase_infra/protocols/protocol_dispatch_engine.py +152 -0
- omnibase_infra/protocols/protocol_event_bus_like.py +127 -0
- omnibase_infra/protocols/protocol_event_projector.py +96 -0
- omnibase_infra/protocols/protocol_idempotency_store.py +142 -0
- omnibase_infra/protocols/protocol_message_dispatcher.py +247 -0
- omnibase_infra/protocols/protocol_message_type_registry.py +306 -0
- omnibase_infra/protocols/protocol_plugin_compute.py +368 -0
- omnibase_infra/protocols/protocol_projector_schema_validator.py +82 -0
- omnibase_infra/protocols/protocol_registry_metrics.py +215 -0
- omnibase_infra/protocols/protocol_snapshot_publisher.py +396 -0
- omnibase_infra/protocols/protocol_snapshot_store.py +567 -0
- omnibase_infra/runtime/__init__.py +445 -0
- omnibase_infra/runtime/binding_config_resolver.py +2771 -0
- omnibase_infra/runtime/binding_resolver.py +753 -0
- omnibase_infra/runtime/chain_aware_dispatch.py +467 -0
- omnibase_infra/runtime/constants_notification.py +75 -0
- omnibase_infra/runtime/constants_security.py +70 -0
- omnibase_infra/runtime/contract_handler_discovery.py +587 -0
- omnibase_infra/runtime/contract_loaders/__init__.py +51 -0
- omnibase_infra/runtime/contract_loaders/handler_routing_loader.py +464 -0
- omnibase_infra/runtime/contract_loaders/operation_bindings_loader.py +789 -0
- omnibase_infra/runtime/dispatch_context_enforcer.py +427 -0
- omnibase_infra/runtime/emit_daemon/__init__.py +97 -0
- omnibase_infra/runtime/emit_daemon/cli.py +844 -0
- omnibase_infra/runtime/emit_daemon/client.py +811 -0
- omnibase_infra/runtime/emit_daemon/config.py +535 -0
- omnibase_infra/runtime/emit_daemon/daemon.py +812 -0
- omnibase_infra/runtime/emit_daemon/event_registry.py +477 -0
- omnibase_infra/runtime/emit_daemon/model_daemon_request.py +139 -0
- omnibase_infra/runtime/emit_daemon/model_daemon_response.py +191 -0
- omnibase_infra/runtime/emit_daemon/queue.py +618 -0
- omnibase_infra/runtime/enums/__init__.py +18 -0
- omnibase_infra/runtime/enums/enum_config_ref_scheme.py +33 -0
- omnibase_infra/runtime/enums/enum_scheduler_status.py +170 -0
- omnibase_infra/runtime/envelope_validator.py +179 -0
- omnibase_infra/runtime/event_bus_subcontract_wiring.py +466 -0
- omnibase_infra/runtime/handler_bootstrap_source.py +507 -0
- omnibase_infra/runtime/handler_contract_config_loader.py +603 -0
- omnibase_infra/runtime/handler_contract_source.py +750 -0
- omnibase_infra/runtime/handler_identity.py +81 -0
- omnibase_infra/runtime/handler_plugin_loader.py +2046 -0
- omnibase_infra/runtime/handler_registry.py +329 -0
- omnibase_infra/runtime/handler_source_resolver.py +367 -0
- omnibase_infra/runtime/invocation_security_enforcer.py +427 -0
- omnibase_infra/runtime/kafka_contract_source.py +984 -0
- omnibase_infra/runtime/kernel.py +40 -0
- omnibase_infra/runtime/mixin_policy_validation.py +522 -0
- omnibase_infra/runtime/mixin_semver_cache.py +402 -0
- omnibase_infra/runtime/mixins/__init__.py +24 -0
- omnibase_infra/runtime/mixins/mixin_projector_notification_publishing.py +566 -0
- omnibase_infra/runtime/mixins/mixin_projector_sql_operations.py +778 -0
- omnibase_infra/runtime/models/__init__.py +229 -0
- omnibase_infra/runtime/models/model_batch_lifecycle_result.py +217 -0
- omnibase_infra/runtime/models/model_binding_config.py +168 -0
- omnibase_infra/runtime/models/model_binding_config_cache_stats.py +135 -0
- omnibase_infra/runtime/models/model_binding_config_resolver_config.py +329 -0
- omnibase_infra/runtime/models/model_cached_secret.py +138 -0
- omnibase_infra/runtime/models/model_compute_key.py +138 -0
- omnibase_infra/runtime/models/model_compute_registration.py +97 -0
- omnibase_infra/runtime/models/model_config_cache_entry.py +61 -0
- omnibase_infra/runtime/models/model_config_ref.py +331 -0
- omnibase_infra/runtime/models/model_config_ref_parse_result.py +125 -0
- omnibase_infra/runtime/models/model_contract_load_result.py +224 -0
- omnibase_infra/runtime/models/model_domain_plugin_config.py +92 -0
- omnibase_infra/runtime/models/model_domain_plugin_result.py +270 -0
- omnibase_infra/runtime/models/model_duplicate_response.py +54 -0
- omnibase_infra/runtime/models/model_enabled_protocols_config.py +61 -0
- omnibase_infra/runtime/models/model_event_bus_config.py +54 -0
- omnibase_infra/runtime/models/model_failed_component.py +55 -0
- omnibase_infra/runtime/models/model_health_check_response.py +168 -0
- omnibase_infra/runtime/models/model_health_check_result.py +229 -0
- omnibase_infra/runtime/models/model_lifecycle_result.py +245 -0
- omnibase_infra/runtime/models/model_logging_config.py +42 -0
- omnibase_infra/runtime/models/model_optional_correlation_id.py +167 -0
- omnibase_infra/runtime/models/model_optional_string.py +94 -0
- omnibase_infra/runtime/models/model_optional_uuid.py +110 -0
- omnibase_infra/runtime/models/model_policy_context.py +100 -0
- omnibase_infra/runtime/models/model_policy_key.py +138 -0
- omnibase_infra/runtime/models/model_policy_registration.py +139 -0
- omnibase_infra/runtime/models/model_policy_result.py +103 -0
- omnibase_infra/runtime/models/model_policy_type_filter.py +157 -0
- omnibase_infra/runtime/models/model_projector_notification_config.py +171 -0
- omnibase_infra/runtime/models/model_projector_plugin_loader_config.py +47 -0
- omnibase_infra/runtime/models/model_protocol_registration_config.py +65 -0
- omnibase_infra/runtime/models/model_retry_policy.py +105 -0
- omnibase_infra/runtime/models/model_runtime_config.py +150 -0
- omnibase_infra/runtime/models/model_runtime_contract_config.py +268 -0
- omnibase_infra/runtime/models/model_runtime_scheduler_config.py +625 -0
- omnibase_infra/runtime/models/model_runtime_scheduler_metrics.py +233 -0
- omnibase_infra/runtime/models/model_runtime_tick.py +193 -0
- omnibase_infra/runtime/models/model_secret_cache_stats.py +82 -0
- omnibase_infra/runtime/models/model_secret_mapping.py +63 -0
- omnibase_infra/runtime/models/model_secret_resolver_config.py +107 -0
- omnibase_infra/runtime/models/model_secret_resolver_metrics.py +111 -0
- omnibase_infra/runtime/models/model_secret_source_info.py +72 -0
- omnibase_infra/runtime/models/model_secret_source_spec.py +66 -0
- omnibase_infra/runtime/models/model_security_config.py +109 -0
- omnibase_infra/runtime/models/model_shutdown_batch_result.py +75 -0
- omnibase_infra/runtime/models/model_shutdown_config.py +94 -0
- omnibase_infra/runtime/models/model_transition_notification_outbox_config.py +112 -0
- omnibase_infra/runtime/models/model_transition_notification_outbox_metrics.py +140 -0
- omnibase_infra/runtime/models/model_transition_notification_publisher_metrics.py +357 -0
- omnibase_infra/runtime/projector_plugin_loader.py +1462 -0
- omnibase_infra/runtime/projector_schema_manager.py +565 -0
- omnibase_infra/runtime/projector_shell.py +1330 -0
- omnibase_infra/runtime/protocol_contract_descriptor.py +92 -0
- omnibase_infra/runtime/protocol_contract_source.py +92 -0
- omnibase_infra/runtime/protocol_domain_plugin.py +474 -0
- omnibase_infra/runtime/protocol_handler_discovery.py +221 -0
- omnibase_infra/runtime/protocol_handler_plugin_loader.py +327 -0
- omnibase_infra/runtime/protocol_lifecycle_executor.py +435 -0
- omnibase_infra/runtime/protocol_policy.py +366 -0
- omnibase_infra/runtime/protocols/__init__.py +37 -0
- omnibase_infra/runtime/protocols/protocol_runtime_scheduler.py +468 -0
- omnibase_infra/runtime/publisher_topic_scoped.py +294 -0
- omnibase_infra/runtime/registry/__init__.py +93 -0
- omnibase_infra/runtime/registry/mixin_message_type_query.py +326 -0
- omnibase_infra/runtime/registry/mixin_message_type_registration.py +354 -0
- omnibase_infra/runtime/registry/registry_event_bus_binding.py +268 -0
- omnibase_infra/runtime/registry/registry_message_type.py +542 -0
- omnibase_infra/runtime/registry/registry_protocol_binding.py +445 -0
- omnibase_infra/runtime/registry_compute.py +1143 -0
- omnibase_infra/runtime/registry_contract_source.py +693 -0
- omnibase_infra/runtime/registry_dispatcher.py +678 -0
- omnibase_infra/runtime/registry_policy.py +1185 -0
- omnibase_infra/runtime/runtime_contract_config_loader.py +406 -0
- omnibase_infra/runtime/runtime_scheduler.py +1070 -0
- omnibase_infra/runtime/secret_resolver.py +2112 -0
- omnibase_infra/runtime/security_metadata_validator.py +776 -0
- omnibase_infra/runtime/service_kernel.py +1651 -0
- omnibase_infra/runtime/service_message_dispatch_engine.py +2350 -0
- omnibase_infra/runtime/service_runtime_host_process.py +3493 -0
- omnibase_infra/runtime/transition_notification_outbox.py +1190 -0
- omnibase_infra/runtime/transition_notification_publisher.py +765 -0
- omnibase_infra/runtime/util_container_wiring.py +1124 -0
- omnibase_infra/runtime/util_validation.py +314 -0
- omnibase_infra/runtime/util_version.py +98 -0
- omnibase_infra/runtime/util_wiring.py +723 -0
- omnibase_infra/schemas/schema_registration_projection.sql +320 -0
- omnibase_infra/schemas/schema_transition_notification_outbox.sql +245 -0
- omnibase_infra/services/__init__.py +89 -0
- omnibase_infra/services/corpus_capture.py +684 -0
- omnibase_infra/services/mcp/__init__.py +31 -0
- omnibase_infra/services/mcp/mcp_server_lifecycle.py +449 -0
- omnibase_infra/services/mcp/service_mcp_tool_discovery.py +411 -0
- omnibase_infra/services/mcp/service_mcp_tool_registry.py +329 -0
- omnibase_infra/services/mcp/service_mcp_tool_sync.py +565 -0
- omnibase_infra/services/registry_api/__init__.py +40 -0
- omnibase_infra/services/registry_api/main.py +261 -0
- omnibase_infra/services/registry_api/models/__init__.py +66 -0
- omnibase_infra/services/registry_api/models/model_capability_widget_mapping.py +38 -0
- omnibase_infra/services/registry_api/models/model_pagination_info.py +48 -0
- omnibase_infra/services/registry_api/models/model_registry_discovery_response.py +73 -0
- omnibase_infra/services/registry_api/models/model_registry_health_response.py +49 -0
- omnibase_infra/services/registry_api/models/model_registry_instance_view.py +88 -0
- omnibase_infra/services/registry_api/models/model_registry_node_view.py +88 -0
- omnibase_infra/services/registry_api/models/model_registry_summary.py +60 -0
- omnibase_infra/services/registry_api/models/model_response_list_instances.py +43 -0
- omnibase_infra/services/registry_api/models/model_response_list_nodes.py +51 -0
- omnibase_infra/services/registry_api/models/model_warning.py +49 -0
- omnibase_infra/services/registry_api/models/model_widget_defaults.py +28 -0
- omnibase_infra/services/registry_api/models/model_widget_mapping.py +51 -0
- omnibase_infra/services/registry_api/routes.py +371 -0
- omnibase_infra/services/registry_api/service.py +837 -0
- omnibase_infra/services/service_capability_query.py +945 -0
- omnibase_infra/services/service_health.py +898 -0
- omnibase_infra/services/service_node_selector.py +530 -0
- omnibase_infra/services/service_timeout_emitter.py +699 -0
- omnibase_infra/services/service_timeout_scanner.py +394 -0
- omnibase_infra/services/session/__init__.py +56 -0
- omnibase_infra/services/session/config_consumer.py +137 -0
- omnibase_infra/services/session/config_store.py +139 -0
- omnibase_infra/services/session/consumer.py +1007 -0
- omnibase_infra/services/session/protocol_session_aggregator.py +117 -0
- omnibase_infra/services/session/store.py +997 -0
- omnibase_infra/services/snapshot/__init__.py +31 -0
- omnibase_infra/services/snapshot/service_snapshot.py +647 -0
- omnibase_infra/services/snapshot/store_inmemory.py +637 -0
- omnibase_infra/services/snapshot/store_postgres.py +1279 -0
- omnibase_infra/shared/__init__.py +8 -0
- omnibase_infra/testing/__init__.py +10 -0
- omnibase_infra/testing/utils.py +23 -0
- omnibase_infra/topics/__init__.py +45 -0
- omnibase_infra/topics/platform_topic_suffixes.py +140 -0
- omnibase_infra/topics/util_topic_composition.py +95 -0
- omnibase_infra/types/__init__.py +48 -0
- omnibase_infra/types/type_cache_info.py +49 -0
- omnibase_infra/types/type_dsn.py +173 -0
- omnibase_infra/types/type_infra_aliases.py +60 -0
- omnibase_infra/types/typed_dict/__init__.py +29 -0
- omnibase_infra/types/typed_dict/typed_dict_envelope_build_params.py +115 -0
- omnibase_infra/types/typed_dict/typed_dict_introspection_cache.py +128 -0
- omnibase_infra/types/typed_dict/typed_dict_performance_metrics_cache.py +140 -0
- omnibase_infra/types/typed_dict_capabilities.py +64 -0
- omnibase_infra/utils/__init__.py +117 -0
- omnibase_infra/utils/correlation.py +208 -0
- omnibase_infra/utils/util_atomic_file.py +261 -0
- omnibase_infra/utils/util_consumer_group.py +232 -0
- omnibase_infra/utils/util_datetime.py +372 -0
- omnibase_infra/utils/util_db_transaction.py +239 -0
- omnibase_infra/utils/util_dsn_validation.py +333 -0
- omnibase_infra/utils/util_env_parsing.py +264 -0
- omnibase_infra/utils/util_error_sanitization.py +457 -0
- omnibase_infra/utils/util_pydantic_validators.py +477 -0
- omnibase_infra/utils/util_retry_optimistic.py +281 -0
- omnibase_infra/utils/util_semver.py +233 -0
- omnibase_infra/validation/__init__.py +307 -0
- omnibase_infra/validation/contracts/security.validation.yaml +114 -0
- omnibase_infra/validation/enums/__init__.py +11 -0
- omnibase_infra/validation/enums/enum_contract_violation_severity.py +13 -0
- omnibase_infra/validation/infra_validators.py +1514 -0
- omnibase_infra/validation/linter_contract.py +907 -0
- omnibase_infra/validation/mixin_any_type_classification.py +120 -0
- omnibase_infra/validation/mixin_any_type_exemption.py +580 -0
- omnibase_infra/validation/mixin_any_type_reporting.py +106 -0
- omnibase_infra/validation/mixin_execution_shape_violation_checks.py +596 -0
- omnibase_infra/validation/mixin_node_archetype_detection.py +254 -0
- omnibase_infra/validation/models/__init__.py +15 -0
- omnibase_infra/validation/models/model_contract_lint_result.py +101 -0
- omnibase_infra/validation/models/model_contract_violation.py +41 -0
- omnibase_infra/validation/service_validation_aggregator.py +395 -0
- omnibase_infra/validation/validation_exemptions.yaml +2033 -0
- omnibase_infra/validation/validator_any_type.py +715 -0
- omnibase_infra/validation/validator_chain_propagation.py +839 -0
- omnibase_infra/validation/validator_execution_shape.py +465 -0
- omnibase_infra/validation/validator_localhandler.py +261 -0
- omnibase_infra/validation/validator_registration_security.py +410 -0
- omnibase_infra/validation/validator_routing_coverage.py +1020 -0
- omnibase_infra/validation/validator_runtime_shape.py +915 -0
- omnibase_infra/validation/validator_security.py +513 -0
- omnibase_infra/validation/validator_topic_category.py +1152 -0
- omnibase_infra-0.2.6.dist-info/METADATA +197 -0
- omnibase_infra-0.2.6.dist-info/RECORD +833 -0
- omnibase_infra-0.2.6.dist-info/WHEEL +4 -0
- omnibase_infra-0.2.6.dist-info/entry_points.txt +5 -0
- omnibase_infra-0.2.6.dist-info/licenses/LICENSE +21 -0
|
@@ -0,0 +1,597 @@
|
|
|
1
|
+
# SPDX-License-Identifier: MIT
|
|
2
|
+
# Copyright (c) 2026 OmniNode Team
|
|
3
|
+
"""Handler for ledger query operations with internal routing.
|
|
4
|
+
|
|
5
|
+
This handler provides query operations for the event ledger, supporting
|
|
6
|
+
queries by correlation_id and time_range. Both operations share:
|
|
7
|
+
- Input validation and normalization
|
|
8
|
+
- DB connection/session lifecycle (via HandlerDb composition)
|
|
9
|
+
- Pagination and ordering rules
|
|
10
|
+
- Error mapping and handling
|
|
11
|
+
- Consistent response surface
|
|
12
|
+
|
|
13
|
+
The operation suffix drives internal routing to private query methods.
|
|
14
|
+
|
|
15
|
+
Design Decision - Single Handler with Internal Routing:
|
|
16
|
+
Two handlers looks "clean" until you realize you now have to duplicate:
|
|
17
|
+
validation, DB session wiring, paging defaults, error mapping, metrics,
|
|
18
|
+
tracing, and auth checks. That's the stuff that actually rots. The query
|
|
19
|
+
shape is the only thing that differs.
|
|
20
|
+
|
|
21
|
+
Only split into two handlers if the two modes diverge materially in
|
|
22
|
+
non-shared behavior (different indexes, different auth model, different
|
|
23
|
+
response shape, different pagination contract).
|
|
24
|
+
"""
|
|
25
|
+
|
|
26
|
+
from __future__ import annotations
|
|
27
|
+
|
|
28
|
+
import logging
|
|
29
|
+
from datetime import datetime
|
|
30
|
+
from typing import TYPE_CHECKING
|
|
31
|
+
from uuid import UUID, uuid4
|
|
32
|
+
|
|
33
|
+
from omnibase_core.models.dispatch import ModelHandlerOutput
|
|
34
|
+
from omnibase_infra.enums import (
|
|
35
|
+
EnumHandlerType,
|
|
36
|
+
EnumHandlerTypeCategory,
|
|
37
|
+
EnumInfraTransportType,
|
|
38
|
+
)
|
|
39
|
+
from omnibase_infra.errors import ModelInfraErrorContext, RuntimeHostError
|
|
40
|
+
from omnibase_infra.nodes.node_ledger_write_effect.models import (
|
|
41
|
+
ModelLedgerEntry,
|
|
42
|
+
ModelLedgerQuery,
|
|
43
|
+
ModelLedgerQueryResult,
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
if TYPE_CHECKING:
|
|
47
|
+
from omnibase_core.container import ModelONEXContainer
|
|
48
|
+
from omnibase_infra.handlers.handler_db import HandlerDb
|
|
49
|
+
|
|
50
|
+
logger = logging.getLogger(__name__)
|
|
51
|
+
|
|
52
|
+
# Handler ID for ModelHandlerOutput
|
|
53
|
+
HANDLER_ID_LEDGER_QUERY: str = "ledger-query-handler"
|
|
54
|
+
|
|
55
|
+
# Default pagination limits
|
|
56
|
+
_DEFAULT_LIMIT: int = 100
|
|
57
|
+
_MAX_LIMIT: int = 10000
|
|
58
|
+
|
|
59
|
+
# SQL for correlation_id queries
|
|
60
|
+
# Uses partial index idx_event_ledger_correlation_id
|
|
61
|
+
_SQL_QUERY_BY_CORRELATION_ID = """
|
|
62
|
+
SELECT
|
|
63
|
+
ledger_entry_id,
|
|
64
|
+
topic,
|
|
65
|
+
partition,
|
|
66
|
+
kafka_offset,
|
|
67
|
+
encode(event_key, 'base64') as event_key,
|
|
68
|
+
encode(event_value, 'base64') as event_value,
|
|
69
|
+
onex_headers,
|
|
70
|
+
envelope_id,
|
|
71
|
+
correlation_id,
|
|
72
|
+
event_type,
|
|
73
|
+
source,
|
|
74
|
+
event_timestamp,
|
|
75
|
+
ledger_written_at
|
|
76
|
+
FROM event_ledger
|
|
77
|
+
WHERE correlation_id = $1
|
|
78
|
+
ORDER BY COALESCE(event_timestamp, ledger_written_at) DESC
|
|
79
|
+
LIMIT $2
|
|
80
|
+
OFFSET $3
|
|
81
|
+
"""
|
|
82
|
+
|
|
83
|
+
# SQL for counting correlation_id matches (for pagination metadata)
|
|
84
|
+
_SQL_COUNT_BY_CORRELATION_ID = """
|
|
85
|
+
SELECT COUNT(*) as total
|
|
86
|
+
FROM event_ledger
|
|
87
|
+
WHERE correlation_id = $1
|
|
88
|
+
"""
|
|
89
|
+
|
|
90
|
+
# SQL for time range queries
|
|
91
|
+
# Uses index idx_event_ledger_topic_timestamp for topic-scoped queries
|
|
92
|
+
# Falls back to idx_event_ledger_event_timestamp for unscoped queries
|
|
93
|
+
_SQL_QUERY_BY_TIME_RANGE_BASE = """
|
|
94
|
+
SELECT
|
|
95
|
+
ledger_entry_id,
|
|
96
|
+
topic,
|
|
97
|
+
partition,
|
|
98
|
+
kafka_offset,
|
|
99
|
+
encode(event_key, 'base64') as event_key,
|
|
100
|
+
encode(event_value, 'base64') as event_value,
|
|
101
|
+
onex_headers,
|
|
102
|
+
envelope_id,
|
|
103
|
+
correlation_id,
|
|
104
|
+
event_type,
|
|
105
|
+
source,
|
|
106
|
+
event_timestamp,
|
|
107
|
+
ledger_written_at
|
|
108
|
+
FROM event_ledger
|
|
109
|
+
WHERE COALESCE(event_timestamp, ledger_written_at) >= $1
|
|
110
|
+
AND COALESCE(event_timestamp, ledger_written_at) < $2
|
|
111
|
+
"""
|
|
112
|
+
|
|
113
|
+
_SQL_COUNT_BY_TIME_RANGE_BASE = """
|
|
114
|
+
SELECT COUNT(*) as total
|
|
115
|
+
FROM event_ledger
|
|
116
|
+
WHERE COALESCE(event_timestamp, ledger_written_at) >= $1
|
|
117
|
+
AND COALESCE(event_timestamp, ledger_written_at) < $2
|
|
118
|
+
"""
|
|
119
|
+
|
|
120
|
+
|
|
121
|
+
class HandlerLedgerQuery:
|
|
122
|
+
"""Handler for querying events from the audit ledger.
|
|
123
|
+
|
|
124
|
+
This handler implements query operations for ProtocolLedgerPersistence,
|
|
125
|
+
composing with HandlerDb for PostgreSQL operations. It provides:
|
|
126
|
+
|
|
127
|
+
- Query by correlation_id (distributed tracing)
|
|
128
|
+
- Query by time_range (replay, audit, debugging)
|
|
129
|
+
- Optional filters by event_type and topic
|
|
130
|
+
- Pagination with limit/offset
|
|
131
|
+
- Consistent response surface via ModelLedgerQueryResult
|
|
132
|
+
|
|
133
|
+
Internal Routing:
|
|
134
|
+
Based on the operation field in the envelope:
|
|
135
|
+
- "ledger.query" with correlation_id → _query_by_correlation_id()
|
|
136
|
+
- "ledger.query" with start_time/end_time → _query_by_time_range()
|
|
137
|
+
- Or use the explicit typed methods directly
|
|
138
|
+
|
|
139
|
+
Attributes:
|
|
140
|
+
handler_type: EnumHandlerType.INFRA_HANDLER
|
|
141
|
+
handler_category: EnumHandlerTypeCategory.EFFECT
|
|
142
|
+
|
|
143
|
+
Example:
|
|
144
|
+
>>> handler = HandlerLedgerQuery(container, db_handler)
|
|
145
|
+
>>> await handler.initialize({})
|
|
146
|
+
>>> # Query by correlation_id
|
|
147
|
+
>>> entries = await handler.query_by_correlation_id(corr_id, limit=50)
|
|
148
|
+
>>> # Query by time range
|
|
149
|
+
>>> entries = await handler.query_by_time_range(start, end, event_type="NodeRegistered")
|
|
150
|
+
"""
|
|
151
|
+
|
|
152
|
+
def __init__(
|
|
153
|
+
self,
|
|
154
|
+
container: ModelONEXContainer,
|
|
155
|
+
db_handler: HandlerDb,
|
|
156
|
+
) -> None:
|
|
157
|
+
"""Initialize the ledger query handler.
|
|
158
|
+
|
|
159
|
+
Args:
|
|
160
|
+
container: ONEX dependency injection container.
|
|
161
|
+
db_handler: Initialized HandlerDb instance for PostgreSQL operations.
|
|
162
|
+
"""
|
|
163
|
+
self._container = container
|
|
164
|
+
self._db_handler = db_handler
|
|
165
|
+
self._initialized: bool = False
|
|
166
|
+
|
|
167
|
+
@property
|
|
168
|
+
def handler_type(self) -> EnumHandlerType:
|
|
169
|
+
"""Return the architectural role of this handler."""
|
|
170
|
+
return EnumHandlerType.INFRA_HANDLER
|
|
171
|
+
|
|
172
|
+
@property
|
|
173
|
+
def handler_category(self) -> EnumHandlerTypeCategory:
|
|
174
|
+
"""Return the behavioral classification of this handler."""
|
|
175
|
+
return EnumHandlerTypeCategory.EFFECT
|
|
176
|
+
|
|
177
|
+
async def initialize(self, config: dict[str, object]) -> None:
|
|
178
|
+
"""Initialize the handler.
|
|
179
|
+
|
|
180
|
+
Args:
|
|
181
|
+
config: Configuration dict (currently unused).
|
|
182
|
+
|
|
183
|
+
Raises:
|
|
184
|
+
RuntimeHostError: If HandlerDb is not initialized.
|
|
185
|
+
"""
|
|
186
|
+
if not getattr(self._db_handler, "_initialized", False):
|
|
187
|
+
ctx = ModelInfraErrorContext.with_correlation(
|
|
188
|
+
transport_type=EnumInfraTransportType.DATABASE,
|
|
189
|
+
operation="initialize",
|
|
190
|
+
)
|
|
191
|
+
raise RuntimeHostError(
|
|
192
|
+
"HandlerDb must be initialized before HandlerLedgerQuery",
|
|
193
|
+
context=ctx,
|
|
194
|
+
)
|
|
195
|
+
|
|
196
|
+
self._initialized = True
|
|
197
|
+
logger.info(
|
|
198
|
+
"%s initialized successfully",
|
|
199
|
+
self.__class__.__name__,
|
|
200
|
+
extra={"handler": self.__class__.__name__},
|
|
201
|
+
)
|
|
202
|
+
|
|
203
|
+
async def shutdown(self) -> None:
|
|
204
|
+
"""Shutdown the handler."""
|
|
205
|
+
self._initialized = False
|
|
206
|
+
logger.info("HandlerLedgerQuery shutdown complete")
|
|
207
|
+
|
|
208
|
+
# =========================================================================
|
|
209
|
+
# Public Query Methods (Typed Interface)
|
|
210
|
+
# =========================================================================
|
|
211
|
+
|
|
212
|
+
async def query_by_correlation_id(
|
|
213
|
+
self,
|
|
214
|
+
correlation_id: UUID,
|
|
215
|
+
limit: int = _DEFAULT_LIMIT,
|
|
216
|
+
offset: int = 0,
|
|
217
|
+
) -> list[ModelLedgerEntry]:
|
|
218
|
+
"""Query ledger entries by correlation ID.
|
|
219
|
+
|
|
220
|
+
Args:
|
|
221
|
+
correlation_id: The correlation ID to search for.
|
|
222
|
+
limit: Maximum entries to return (default: 100, max: 10000).
|
|
223
|
+
offset: Number of entries to skip for pagination.
|
|
224
|
+
|
|
225
|
+
Returns:
|
|
226
|
+
List of ModelLedgerEntry matching the correlation ID.
|
|
227
|
+
"""
|
|
228
|
+
self._ensure_initialized("ledger.query.by_correlation_id")
|
|
229
|
+
limit = self._normalize_limit(limit)
|
|
230
|
+
|
|
231
|
+
# Execute query via HandlerDb
|
|
232
|
+
rows = await self._execute_query(
|
|
233
|
+
sql=_SQL_QUERY_BY_CORRELATION_ID,
|
|
234
|
+
parameters=[str(correlation_id), limit, offset],
|
|
235
|
+
operation="ledger.query.by_correlation_id",
|
|
236
|
+
correlation_id=correlation_id,
|
|
237
|
+
)
|
|
238
|
+
|
|
239
|
+
return [self._row_to_entry(row) for row in rows]
|
|
240
|
+
|
|
241
|
+
async def query_by_time_range(
|
|
242
|
+
self,
|
|
243
|
+
start: datetime,
|
|
244
|
+
end: datetime,
|
|
245
|
+
correlation_id: UUID | None = None,
|
|
246
|
+
event_type: str | None = None,
|
|
247
|
+
topic: str | None = None,
|
|
248
|
+
limit: int = _DEFAULT_LIMIT,
|
|
249
|
+
offset: int = 0,
|
|
250
|
+
) -> list[ModelLedgerEntry]:
|
|
251
|
+
"""Query ledger entries within a time range.
|
|
252
|
+
|
|
253
|
+
Args:
|
|
254
|
+
start: Start of time range (inclusive).
|
|
255
|
+
end: End of time range (exclusive).
|
|
256
|
+
correlation_id: Correlation ID for distributed tracing (auto-generated if None).
|
|
257
|
+
event_type: Optional filter by event type.
|
|
258
|
+
topic: Optional filter by Kafka topic.
|
|
259
|
+
limit: Maximum entries to return (default: 100, max: 10000).
|
|
260
|
+
offset: Number of entries to skip for pagination.
|
|
261
|
+
|
|
262
|
+
Returns:
|
|
263
|
+
List of ModelLedgerEntry within the time range.
|
|
264
|
+
"""
|
|
265
|
+
self._ensure_initialized("ledger.query.by_time_range")
|
|
266
|
+
limit = self._normalize_limit(limit)
|
|
267
|
+
# Auto-generate correlation_id if not provided
|
|
268
|
+
effective_correlation_id = (
|
|
269
|
+
correlation_id if correlation_id is not None else uuid4()
|
|
270
|
+
)
|
|
271
|
+
|
|
272
|
+
# Build query model for SQL generation
|
|
273
|
+
query_params = ModelLedgerQuery(
|
|
274
|
+
start_time=start,
|
|
275
|
+
end_time=end,
|
|
276
|
+
event_type=event_type,
|
|
277
|
+
topic=topic,
|
|
278
|
+
limit=limit,
|
|
279
|
+
offset=offset,
|
|
280
|
+
)
|
|
281
|
+
|
|
282
|
+
# Build dynamic SQL with optional filters
|
|
283
|
+
sql, _count_sql, parameters = self._build_time_range_query(query_params)
|
|
284
|
+
|
|
285
|
+
# Execute query via HandlerDb
|
|
286
|
+
rows = await self._execute_query(
|
|
287
|
+
sql=sql,
|
|
288
|
+
parameters=parameters,
|
|
289
|
+
operation="ledger.query.by_time_range",
|
|
290
|
+
correlation_id=effective_correlation_id,
|
|
291
|
+
)
|
|
292
|
+
|
|
293
|
+
return [self._row_to_entry(row) for row in rows]
|
|
294
|
+
|
|
295
|
+
async def query(
|
|
296
|
+
self,
|
|
297
|
+
query: ModelLedgerQuery,
|
|
298
|
+
correlation_id: UUID,
|
|
299
|
+
) -> ModelLedgerQueryResult:
|
|
300
|
+
"""Execute a query using the ModelLedgerQuery parameters.
|
|
301
|
+
|
|
302
|
+
Routes to the appropriate private method based on query parameters.
|
|
303
|
+
|
|
304
|
+
Args:
|
|
305
|
+
query: Query parameters model.
|
|
306
|
+
correlation_id: Correlation ID for distributed tracing.
|
|
307
|
+
|
|
308
|
+
Returns:
|
|
309
|
+
ModelLedgerQueryResult with entries, total_count, and has_more.
|
|
310
|
+
"""
|
|
311
|
+
self._ensure_initialized("ledger.query")
|
|
312
|
+
|
|
313
|
+
# Route based on query parameters
|
|
314
|
+
if query.correlation_id is not None:
|
|
315
|
+
entries = await self.query_by_correlation_id(
|
|
316
|
+
correlation_id=query.correlation_id,
|
|
317
|
+
limit=query.limit,
|
|
318
|
+
offset=query.offset,
|
|
319
|
+
)
|
|
320
|
+
total_count = await self._count_by_correlation_id(query.correlation_id)
|
|
321
|
+
elif query.start_time is not None and query.end_time is not None:
|
|
322
|
+
entries = await self.query_by_time_range(
|
|
323
|
+
start=query.start_time,
|
|
324
|
+
end=query.end_time,
|
|
325
|
+
correlation_id=correlation_id,
|
|
326
|
+
event_type=query.event_type,
|
|
327
|
+
topic=query.topic,
|
|
328
|
+
limit=query.limit,
|
|
329
|
+
offset=query.offset,
|
|
330
|
+
)
|
|
331
|
+
total_count = await self._count_by_time_range(
|
|
332
|
+
start=query.start_time,
|
|
333
|
+
end=query.end_time,
|
|
334
|
+
correlation_id=correlation_id,
|
|
335
|
+
event_type=query.event_type,
|
|
336
|
+
topic=query.topic,
|
|
337
|
+
)
|
|
338
|
+
else:
|
|
339
|
+
# No specific query criteria - would return all events
|
|
340
|
+
# This is likely an error or needs explicit "get all" operation
|
|
341
|
+
ctx = ModelInfraErrorContext.with_correlation(
|
|
342
|
+
correlation_id=correlation_id,
|
|
343
|
+
transport_type=EnumInfraTransportType.DATABASE,
|
|
344
|
+
operation="ledger.query",
|
|
345
|
+
)
|
|
346
|
+
raise RuntimeHostError(
|
|
347
|
+
"Query must specify either correlation_id or time range (start_time + end_time)",
|
|
348
|
+
context=ctx,
|
|
349
|
+
)
|
|
350
|
+
|
|
351
|
+
has_more = query.offset + len(entries) < total_count
|
|
352
|
+
|
|
353
|
+
return ModelLedgerQueryResult(
|
|
354
|
+
entries=entries,
|
|
355
|
+
total_count=total_count,
|
|
356
|
+
has_more=has_more,
|
|
357
|
+
query=query,
|
|
358
|
+
)
|
|
359
|
+
|
|
360
|
+
# =========================================================================
|
|
361
|
+
# Envelope-Based Interface (ProtocolHandler)
|
|
362
|
+
# =========================================================================
|
|
363
|
+
|
|
364
|
+
async def execute(
|
|
365
|
+
self,
|
|
366
|
+
envelope: dict[str, object],
|
|
367
|
+
) -> ModelHandlerOutput[ModelLedgerQueryResult]:
|
|
368
|
+
"""Execute ledger query from envelope.
|
|
369
|
+
|
|
370
|
+
Args:
|
|
371
|
+
envelope: Request envelope containing:
|
|
372
|
+
- operation: "ledger.query"
|
|
373
|
+
- payload: ModelLedgerQuery as dict
|
|
374
|
+
- correlation_id: Optional correlation ID
|
|
375
|
+
|
|
376
|
+
Returns:
|
|
377
|
+
ModelHandlerOutput wrapping ModelLedgerQueryResult.
|
|
378
|
+
"""
|
|
379
|
+
correlation_id_raw = envelope.get("correlation_id")
|
|
380
|
+
correlation_id = (
|
|
381
|
+
UUID(str(correlation_id_raw)) if correlation_id_raw else uuid4()
|
|
382
|
+
)
|
|
383
|
+
input_envelope_id = uuid4()
|
|
384
|
+
|
|
385
|
+
payload_raw = envelope.get("payload")
|
|
386
|
+
if not isinstance(payload_raw, dict):
|
|
387
|
+
ctx = ModelInfraErrorContext.with_correlation(
|
|
388
|
+
correlation_id=correlation_id,
|
|
389
|
+
transport_type=EnumInfraTransportType.DATABASE,
|
|
390
|
+
operation="ledger.query",
|
|
391
|
+
)
|
|
392
|
+
raise RuntimeHostError(
|
|
393
|
+
"Missing or invalid 'payload' in envelope",
|
|
394
|
+
context=ctx,
|
|
395
|
+
)
|
|
396
|
+
|
|
397
|
+
# Parse payload into typed model
|
|
398
|
+
query = ModelLedgerQuery.model_validate(payload_raw)
|
|
399
|
+
|
|
400
|
+
# Execute query
|
|
401
|
+
result = await self.query(query, correlation_id=correlation_id)
|
|
402
|
+
|
|
403
|
+
return ModelHandlerOutput.for_compute(
|
|
404
|
+
input_envelope_id=input_envelope_id,
|
|
405
|
+
correlation_id=correlation_id,
|
|
406
|
+
handler_id=HANDLER_ID_LEDGER_QUERY,
|
|
407
|
+
result=result,
|
|
408
|
+
)
|
|
409
|
+
|
|
410
|
+
# =========================================================================
|
|
411
|
+
# Private Helpers
|
|
412
|
+
# =========================================================================
|
|
413
|
+
|
|
414
|
+
def _ensure_initialized(self, operation: str) -> None:
|
|
415
|
+
"""Ensure handler is initialized."""
|
|
416
|
+
if not self._initialized:
|
|
417
|
+
ctx = ModelInfraErrorContext.with_correlation(
|
|
418
|
+
transport_type=EnumInfraTransportType.DATABASE,
|
|
419
|
+
operation=operation,
|
|
420
|
+
)
|
|
421
|
+
raise RuntimeHostError(
|
|
422
|
+
"HandlerLedgerQuery not initialized. Call initialize() first.",
|
|
423
|
+
context=ctx,
|
|
424
|
+
)
|
|
425
|
+
|
|
426
|
+
def _normalize_limit(self, limit: int) -> int:
|
|
427
|
+
"""Normalize limit to valid range."""
|
|
428
|
+
if limit < 1:
|
|
429
|
+
return _DEFAULT_LIMIT
|
|
430
|
+
if limit > _MAX_LIMIT:
|
|
431
|
+
return _MAX_LIMIT
|
|
432
|
+
return limit
|
|
433
|
+
|
|
434
|
+
async def _execute_query(
|
|
435
|
+
self,
|
|
436
|
+
sql: str,
|
|
437
|
+
parameters: list[object],
|
|
438
|
+
operation: str,
|
|
439
|
+
correlation_id: UUID,
|
|
440
|
+
) -> list[dict[str, object]]:
|
|
441
|
+
"""Execute a query via HandlerDb and return rows."""
|
|
442
|
+
envelope: dict[str, object] = {
|
|
443
|
+
"operation": "db.query",
|
|
444
|
+
"payload": {
|
|
445
|
+
"sql": sql,
|
|
446
|
+
"parameters": parameters,
|
|
447
|
+
},
|
|
448
|
+
"correlation_id": str(correlation_id),
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
db_result = await self._db_handler.execute(envelope)
|
|
452
|
+
if db_result.result is None:
|
|
453
|
+
return []
|
|
454
|
+
return db_result.result.payload.rows
|
|
455
|
+
|
|
456
|
+
async def _count_by_correlation_id(self, correlation_id: UUID) -> int:
|
|
457
|
+
"""Get total count for correlation_id query."""
|
|
458
|
+
rows = await self._execute_query(
|
|
459
|
+
sql=_SQL_COUNT_BY_CORRELATION_ID,
|
|
460
|
+
parameters=[str(correlation_id)],
|
|
461
|
+
operation="ledger.query.count",
|
|
462
|
+
correlation_id=correlation_id,
|
|
463
|
+
)
|
|
464
|
+
if rows and rows[0].get("total") is not None:
|
|
465
|
+
return int(str(rows[0]["total"]))
|
|
466
|
+
return 0
|
|
467
|
+
|
|
468
|
+
async def _count_by_time_range(
|
|
469
|
+
self,
|
|
470
|
+
start: datetime,
|
|
471
|
+
end: datetime,
|
|
472
|
+
correlation_id: UUID,
|
|
473
|
+
event_type: str | None = None,
|
|
474
|
+
topic: str | None = None,
|
|
475
|
+
) -> int:
|
|
476
|
+
"""Get total count for time_range query."""
|
|
477
|
+
query_params = ModelLedgerQuery(
|
|
478
|
+
start_time=start,
|
|
479
|
+
end_time=end,
|
|
480
|
+
event_type=event_type,
|
|
481
|
+
topic=topic,
|
|
482
|
+
limit=1,
|
|
483
|
+
offset=0,
|
|
484
|
+
)
|
|
485
|
+
_, count_sql, parameters = self._build_time_range_query(
|
|
486
|
+
query_params, count_only=True
|
|
487
|
+
)
|
|
488
|
+
|
|
489
|
+
rows = await self._execute_query(
|
|
490
|
+
sql=count_sql,
|
|
491
|
+
parameters=parameters,
|
|
492
|
+
operation="ledger.query.count",
|
|
493
|
+
correlation_id=correlation_id,
|
|
494
|
+
)
|
|
495
|
+
if rows and rows[0].get("total") is not None:
|
|
496
|
+
return int(str(rows[0]["total"]))
|
|
497
|
+
return 0
|
|
498
|
+
|
|
499
|
+
def _build_time_range_query(
|
|
500
|
+
self,
|
|
501
|
+
query: ModelLedgerQuery,
|
|
502
|
+
count_only: bool = False,
|
|
503
|
+
) -> tuple[str, str, list[object]]:
|
|
504
|
+
"""Build dynamic SQL for time range query with optional filters.
|
|
505
|
+
|
|
506
|
+
Args:
|
|
507
|
+
query: Query parameters including start_time, end_time, filters, pagination.
|
|
508
|
+
count_only: If True, don't add limit/offset to parameters.
|
|
509
|
+
|
|
510
|
+
Returns:
|
|
511
|
+
Tuple of (query_sql, count_sql, parameters).
|
|
512
|
+
"""
|
|
513
|
+
# Start with base parameters (start_time and end_time are required for this path)
|
|
514
|
+
parameters: list[object] = [query.start_time, query.end_time]
|
|
515
|
+
param_index = 3 # $1 and $2 are start/end
|
|
516
|
+
|
|
517
|
+
# Build WHERE clause additions
|
|
518
|
+
where_additions: list[str] = []
|
|
519
|
+
|
|
520
|
+
if query.event_type is not None:
|
|
521
|
+
where_additions.append(f"AND event_type = ${param_index}")
|
|
522
|
+
parameters.append(query.event_type)
|
|
523
|
+
param_index += 1
|
|
524
|
+
|
|
525
|
+
if query.topic is not None:
|
|
526
|
+
where_additions.append(f"AND topic = ${param_index}")
|
|
527
|
+
parameters.append(query.topic)
|
|
528
|
+
param_index += 1
|
|
529
|
+
|
|
530
|
+
# Build final SQL
|
|
531
|
+
where_clause = " ".join(where_additions)
|
|
532
|
+
|
|
533
|
+
# Query SQL with ordering and pagination
|
|
534
|
+
query_sql = (
|
|
535
|
+
_SQL_QUERY_BY_TIME_RANGE_BASE
|
|
536
|
+
+ where_clause
|
|
537
|
+
+ f"""
|
|
538
|
+
ORDER BY COALESCE(event_timestamp, ledger_written_at) DESC
|
|
539
|
+
LIMIT ${param_index}
|
|
540
|
+
OFFSET ${param_index + 1}
|
|
541
|
+
"""
|
|
542
|
+
)
|
|
543
|
+
|
|
544
|
+
# Count SQL without ordering/pagination
|
|
545
|
+
count_sql = _SQL_COUNT_BY_TIME_RANGE_BASE + where_clause
|
|
546
|
+
|
|
547
|
+
if not count_only:
|
|
548
|
+
parameters.extend([query.limit, query.offset])
|
|
549
|
+
|
|
550
|
+
return query_sql, count_sql, parameters
|
|
551
|
+
|
|
552
|
+
def _row_to_entry(self, row: dict[str, object]) -> ModelLedgerEntry:
|
|
553
|
+
"""Convert a database row to ModelLedgerEntry.
|
|
554
|
+
|
|
555
|
+
The row comes from HandlerDb which returns dict[str, object].
|
|
556
|
+
event_key and event_value are already base64-encoded via SQL encode().
|
|
557
|
+
|
|
558
|
+
Raises:
|
|
559
|
+
RuntimeHostError: If ledger_written_at is not a datetime (data corruption).
|
|
560
|
+
"""
|
|
561
|
+
# Extract ledger_written_at which is guaranteed to exist
|
|
562
|
+
ledger_written_at_raw = row["ledger_written_at"]
|
|
563
|
+
if not isinstance(ledger_written_at_raw, datetime):
|
|
564
|
+
# This should never happen for valid ledger entries - indicates data corruption
|
|
565
|
+
ctx = ModelInfraErrorContext.with_correlation(
|
|
566
|
+
transport_type=EnumInfraTransportType.DATABASE,
|
|
567
|
+
operation="ledger.query.row_to_entry",
|
|
568
|
+
)
|
|
569
|
+
raise RuntimeHostError(
|
|
570
|
+
f"Data integrity error: ledger_written_at must be datetime, got {type(ledger_written_at_raw).__name__}",
|
|
571
|
+
context=ctx,
|
|
572
|
+
)
|
|
573
|
+
|
|
574
|
+
return ModelLedgerEntry(
|
|
575
|
+
ledger_entry_id=UUID(str(row["ledger_entry_id"])),
|
|
576
|
+
topic=str(row["topic"]),
|
|
577
|
+
partition=int(str(row["partition"])),
|
|
578
|
+
kafka_offset=int(str(row["kafka_offset"])),
|
|
579
|
+
event_key=str(row["event_key"]) if row["event_key"] else None,
|
|
580
|
+
event_value=str(row["event_value"]),
|
|
581
|
+
onex_headers=row["onex_headers"]
|
|
582
|
+
if isinstance(row["onex_headers"], dict)
|
|
583
|
+
else {},
|
|
584
|
+
envelope_id=UUID(str(row["envelope_id"])) if row["envelope_id"] else None,
|
|
585
|
+
correlation_id=UUID(str(row["correlation_id"]))
|
|
586
|
+
if row["correlation_id"]
|
|
587
|
+
else None,
|
|
588
|
+
event_type=str(row["event_type"]) if row["event_type"] else None,
|
|
589
|
+
source=str(row["source"]) if row["source"] else None,
|
|
590
|
+
event_timestamp=row["event_timestamp"]
|
|
591
|
+
if isinstance(row["event_timestamp"], datetime)
|
|
592
|
+
else None,
|
|
593
|
+
ledger_written_at=ledger_written_at_raw,
|
|
594
|
+
)
|
|
595
|
+
|
|
596
|
+
|
|
597
|
+
__all__ = ["HandlerLedgerQuery"]
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"""Ledger write effect node models.
|
|
2
|
+
|
|
3
|
+
This package contains Pydantic models for the ledger write effect node,
|
|
4
|
+
which handles persistent storage of events to the event ledger.
|
|
5
|
+
|
|
6
|
+
Models:
|
|
7
|
+
ModelLedgerEntry: Single ledger entry representing one event
|
|
8
|
+
ModelLedgerAppendResult: Result of a ledger write operation
|
|
9
|
+
ModelLedgerQuery: Query parameters for ledger searches
|
|
10
|
+
ModelLedgerQueryResult: Result of a ledger query operation
|
|
11
|
+
"""
|
|
12
|
+
|
|
13
|
+
from omnibase_infra.nodes.node_ledger_write_effect.models.model_ledger_append_result import (
|
|
14
|
+
ModelLedgerAppendResult,
|
|
15
|
+
)
|
|
16
|
+
from omnibase_infra.nodes.node_ledger_write_effect.models.model_ledger_entry import (
|
|
17
|
+
ModelLedgerEntry,
|
|
18
|
+
)
|
|
19
|
+
from omnibase_infra.nodes.node_ledger_write_effect.models.model_ledger_query import (
|
|
20
|
+
ModelLedgerQuery,
|
|
21
|
+
)
|
|
22
|
+
from omnibase_infra.nodes.node_ledger_write_effect.models.model_ledger_query_result import (
|
|
23
|
+
ModelLedgerQueryResult,
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
__all__ = [
|
|
27
|
+
"ModelLedgerAppendResult",
|
|
28
|
+
"ModelLedgerEntry",
|
|
29
|
+
"ModelLedgerQuery",
|
|
30
|
+
"ModelLedgerQueryResult",
|
|
31
|
+
]
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"""Ledger append result model for write operation outcomes.
|
|
2
|
+
|
|
3
|
+
This module defines the result structure returned after attempting
|
|
4
|
+
to append an event to the ledger.
|
|
5
|
+
"""
|
|
6
|
+
|
|
7
|
+
from uuid import UUID
|
|
8
|
+
|
|
9
|
+
from pydantic import BaseModel, ConfigDict, Field
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
class ModelLedgerAppendResult(BaseModel):
|
|
13
|
+
"""Result of a ledger append operation.
|
|
14
|
+
|
|
15
|
+
This model captures the outcome of attempting to write an event
|
|
16
|
+
to the ledger, including handling of duplicate detection via
|
|
17
|
+
the (topic, partition, kafka_offset) unique constraint.
|
|
18
|
+
|
|
19
|
+
The duplicate flag indicates when ON CONFLICT DO NOTHING was
|
|
20
|
+
triggered, meaning the event was already in the ledger. This
|
|
21
|
+
is not an error condition - it enables idempotent replay.
|
|
22
|
+
"""
|
|
23
|
+
|
|
24
|
+
model_config = ConfigDict(frozen=True, extra="forbid")
|
|
25
|
+
|
|
26
|
+
success: bool = Field(
|
|
27
|
+
...,
|
|
28
|
+
description="Whether the append operation completed without error",
|
|
29
|
+
)
|
|
30
|
+
ledger_entry_id: UUID | None = Field(
|
|
31
|
+
default=None,
|
|
32
|
+
description="ID of the created entry, None if duplicate",
|
|
33
|
+
)
|
|
34
|
+
duplicate: bool = Field(
|
|
35
|
+
default=False,
|
|
36
|
+
description="True if ON CONFLICT DO NOTHING matched existing entry",
|
|
37
|
+
)
|
|
38
|
+
|
|
39
|
+
# Kafka position that was attempted
|
|
40
|
+
topic: str = Field(
|
|
41
|
+
...,
|
|
42
|
+
min_length=1,
|
|
43
|
+
description="Kafka topic of the event",
|
|
44
|
+
)
|
|
45
|
+
partition: int = Field(
|
|
46
|
+
...,
|
|
47
|
+
ge=0,
|
|
48
|
+
description="Kafka partition number",
|
|
49
|
+
)
|
|
50
|
+
kafka_offset: int = Field(
|
|
51
|
+
...,
|
|
52
|
+
ge=0,
|
|
53
|
+
description="Kafka offset within the partition",
|
|
54
|
+
)
|