buz 2.13.1rc8__tar.gz → 2.13.1rc9__tar.gz
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.
- {buz-2.13.1rc8 → buz-2.13.1rc9}/PKG-INFO +1 -1
- {buz-2.13.1rc8 → buz-2.13.1rc9}/pyproject.toml +1 -1
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/kafka_event_sync_subscriber_executor.py +0 -5
- buz-2.13.1rc9/src/buz/kafka/domain/exceptions/not_all_partition_assigned_exception.py +8 -0
- buz-2.13.1rc9/src/buz/kafka/domain/exceptions/topic_not_found_exception.py +6 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/services/kafka_admin_client.py +14 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/kafka_python_admin_client.py +98 -5
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/kafka_python_admin_test_client.py +11 -2
- {buz-2.13.1rc8 → buz-2.13.1rc9}/LICENSE +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/README.md +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/base_command_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/command_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/command_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/base_handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/handle_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/self_process/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/self_process/self_process_command_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/command.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/more_than_one_command_handler_related_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/base_command_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/command_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/command_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/middleware/base_handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/middleware/handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/middleware/handle_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/self_process/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/self_process/self_process_command_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/synced_async/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/synced_async/synced_async_command_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/async_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/async_subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/async_worker.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/base_async_subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/base_subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/dead_letter_queue/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/dead_letter_queue/dlq_criteria.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/dead_letter_queue/dlq_record.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/dead_letter_queue/dlq_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/event.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/event_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/event_not_published_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/event_restore_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/subscribers_not_found_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/term_signal_interruption_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/worker_execution_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/base_buz_aiokafka_async_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/buz_aiokafka_async_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/buz_aiokafka_multi_threaded_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/buz_kafka_event_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/consume_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/consume_strategy/consume_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/consume_strategy/kafka_on_fail_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/consume_strategy/topic_and_subscription_group_per_subscriber_kafka_consumer_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/exceptions/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/exceptions/kafka_event_bus_config_not_valid_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/kafka_event_async_subscriber_executor.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/kafka_event_subscriber_executor.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/publish_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/publish_strategy/publish_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/publish_strategy/topic_per_event_kafka_publish_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/allowed_kombu_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/consume_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/consume_strategy/consume_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/consume_strategy/queue_per_subscriber_consume_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/kombu_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/kombu_event_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/publish_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/publish_strategy/fanout_exchange_per_event_publish_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/publish_strategy/publish_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/retry_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/retry_strategy/publish_retry_policy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/retry_strategy/simple_publish_retry_policy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/models/consuming_task.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/queue/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/meta_base_subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/meta_subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/async_consume_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/async_consume_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/base_consume_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/base_publish_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/consume_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/consume_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/exceptions/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/exceptions/event_already_in_progress_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/publish_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/publish_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/async_execution_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/async_self_process_execution_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/cyclic_iterator_execution_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/execution_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/self_process_execution_strategy.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/consume_retrier.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/consumed_event_retry.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/consumed_event_retry_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/max_retries_consume_retrier.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/max_retries_negative_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/reject_callback.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/subscriber.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/sync/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/sync/sync_event_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/event_to_outbox_record_translator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/fqn_to_event_mapper.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/deliverable_records_outbox_criteria_factory.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/outbox_criteria.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/outbox_criteria_factory.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/outbox_sorting_criteria.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_finder/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_finder/outbox_record_stream_finder.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_finder/polling_outbox_record_stream_finder.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_to_event_translator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/abstract_outbox_record_validator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/outbox_record_size_not_allowed_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/outbox_record_validation_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/outbox_record_validator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_validation/size_outbox_record_validator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/transactional_outbox_event_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/transactional_outbox_worker.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/worker.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/exceptions/not_valid_kafka_message_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/exceptions/topic_already_created_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/auto_create_topic_configuration.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/consumer_initial_offset_position.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/create_kafka_topic.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_connection_config.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_connection_credentials.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_connection_plain_text_credentials.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_connection_sasl_credentials.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_consumer_record.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_poll_record.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_supported_sasl_mechanisms.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/kafka_supported_security_protocols.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/services/kafka_admin_test_client.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/services/kafka_producer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/aiokafka_consumer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/rebalance/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/rebalance/kafka_callback_rebalancer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/translators/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/aiokafka/translators/consumer_initial_offset_position_translator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/cdc/cdc_message.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/byte_deserializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/bytes_to_message_deserializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/implementations/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/implementations/cdc/cdc_record_bytes_to_event_deserializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/implementations/cdc/not_valid_cdc_message_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/implementations/json_byte_deserializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/deserializers/implementations/json_bytes_to_message_deserializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/exception/consumer_interrupted_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/factories/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/factories/kafka_python_producer_factory.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/kafka_python_producer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/translators/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/kafka_python/translators/consumer_initial_offset_position_translator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/serializers/byte_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/serializers/implementations/cdc_record_bytes_to_event_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/serializers/implementations/json_byte_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/infrastructure/serializers/kafka_header_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/handler_fqn_not_found_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/locator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/message_fqn_not_found_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/pypendency/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/pypendency/container_locator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/pypendency/container_locator_resolution_configuration.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/pypendency/handler_not_found_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/pypendency/handler_not_registered_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/sync/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/sync/handler_already_registered_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/sync/handler_not_registered_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/locator/sync/instance_locator.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/message.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/middleware/middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/middleware/middleware_chain_builder.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/py.typed +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/base_query_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/middleware/base_handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/middleware/handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/middleware/handle_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/query_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/query_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/self_process/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/asynchronous/self_process/self_process_query_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/more_than_one_query_handler_related_exception.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/query.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/query_response.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/base_query_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/middleware/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/middleware/base_handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/middleware/handle_middleware.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/middleware/handle_middleware_chain_resolver.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/query_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/query_handler.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/self_process/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/self_process/self_process_query_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/synced_async/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/query/synchronous/synced_async/synced_async_query_bus.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/queue/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/queue/in_memory/in_memory_multiqueue_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/queue/in_memory/in_memory_queue_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/queue/multiqueue_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/queue/queue_repository.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/serializer/message_to_bytes_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/serializer/message_to_json_bytes_serializer.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/wrapper/__init__.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/wrapper/async_to_sync.py +0 -0
- {buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/wrapper/event_loop.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
[tool.poetry]
|
|
2
2
|
name = "buz"
|
|
3
|
-
version = "2.13.
|
|
3
|
+
version = "2.13.1rc9"
|
|
4
4
|
description = "Buz is a set of light, simple and extensible implementations of event, command and query buses."
|
|
5
5
|
readme = "README.md"
|
|
6
6
|
authors = ["Luis Pintado Lozano <luis.pintado.lozano@gmail.com>", "Gerardo Parra <gprauxiliar@gmail.com>"]
|
|
@@ -67,11 +67,6 @@ class KafkaEventSyncSubscriberExecutor(KafkaEventSubscriberExecutor):
|
|
|
67
67
|
self.__logger.error(
|
|
68
68
|
f'The message "{str(kafka_poll_record.value)}" is not valid, it will be consumed but not processed'
|
|
69
69
|
)
|
|
70
|
-
except Exception as exception:
|
|
71
|
-
if self.__on_fail_strategy == KafkaOnFailStrategy.CONSUME_ON_FAIL:
|
|
72
|
-
self.__logger.error(f"Error consuming event: {exception}")
|
|
73
|
-
return
|
|
74
|
-
raise exception
|
|
75
70
|
|
|
76
71
|
def __execution_callback(self, subscriber: Subscriber, message: KafkaConsumerRecord[Event]) -> None:
|
|
77
72
|
self.__consume_middleware_chain_resolver.resolve(
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
from __future__ import annotations
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class NotAllPartitionAssignedException(Exception):
|
|
5
|
+
def __init__(self, topic_name: str) -> None:
|
|
6
|
+
super().__init__(
|
|
7
|
+
f'Not all the partition were assigned for the topic "{topic_name}", please disconnect the rest of subscribers'
|
|
8
|
+
)
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
3
|
from abc import abstractmethod, ABC
|
|
4
|
+
from datetime import datetime
|
|
4
5
|
from typing import Sequence
|
|
5
6
|
|
|
6
7
|
from buz.kafka.domain.models.create_kafka_topic import CreateKafkaTopic
|
|
@@ -37,3 +38,16 @@ class KafkaAdminClient(ABC):
|
|
|
37
38
|
self,
|
|
38
39
|
) -> set[str]:
|
|
39
40
|
pass
|
|
41
|
+
|
|
42
|
+
# This function moves the following offset from the provided date
|
|
43
|
+
# if there are no messages with a date greater than the provided offset
|
|
44
|
+
# the offset will be moved to the end
|
|
45
|
+
@abstractmethod
|
|
46
|
+
def move_offsets_to_datetime(
|
|
47
|
+
self,
|
|
48
|
+
*,
|
|
49
|
+
consumer_group: str,
|
|
50
|
+
topic: str,
|
|
51
|
+
target_datetime: datetime,
|
|
52
|
+
) -> None:
|
|
53
|
+
pass
|
|
@@ -1,19 +1,30 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
+
from datetime import datetime
|
|
4
|
+
from logging import Logger
|
|
3
5
|
import re
|
|
4
|
-
from typing import Any, Callable, Sequence
|
|
6
|
+
from typing import Any, Callable, Optional, Sequence, cast
|
|
5
7
|
|
|
6
8
|
from cachetools import TTLCache
|
|
7
|
-
from kafka import KafkaClient
|
|
9
|
+
from kafka import KafkaClient, KafkaConsumer
|
|
8
10
|
from kafka.admin import KafkaAdminClient as KafkaPythonLibraryAdminClient, NewTopic
|
|
9
11
|
from kafka.errors import TopicAlreadyExistsError
|
|
12
|
+
from kafka.structs import TopicPartition, OffsetAndTimestamp
|
|
10
13
|
|
|
14
|
+
from buz.kafka.domain.exceptions.not_all_partition_assigned_exception import NotAllPartitionAssignedException
|
|
11
15
|
from buz.kafka.domain.exceptions.topic_already_created_exception import KafkaTopicsAlreadyCreatedException
|
|
16
|
+
from buz.kafka.domain.exceptions.topic_not_found_exception import TopicNotFoundException
|
|
17
|
+
from buz.kafka.domain.models.consumer_initial_offset_position import ConsumerInitialOffsetPosition
|
|
12
18
|
from buz.kafka.domain.models.create_kafka_topic import CreateKafkaTopic
|
|
13
19
|
from buz.kafka.domain.models.kafka_connection_config import KafkaConnectionConfig
|
|
14
20
|
from buz.kafka.domain.services.kafka_admin_client import KafkaAdminClient
|
|
15
21
|
|
|
22
|
+
from buz.kafka.infrastructure.kafka_python.translators.consumer_initial_offset_position_translator import (
|
|
23
|
+
KafkaPythonConsumerInitialOffsetPositionTranslator,
|
|
24
|
+
)
|
|
25
|
+
|
|
16
26
|
INTERNAL_KAFKA_TOPICS = {"__consumer_offsets", "_schema"}
|
|
27
|
+
TOPIC_CACHE_KEY = "topics"
|
|
17
28
|
|
|
18
29
|
|
|
19
30
|
class KafkaPythonAdminClient(KafkaAdminClient):
|
|
@@ -22,9 +33,11 @@ class KafkaPythonAdminClient(KafkaAdminClient):
|
|
|
22
33
|
def __init__(
|
|
23
34
|
self,
|
|
24
35
|
*,
|
|
36
|
+
logger: Logger,
|
|
25
37
|
config: KafkaConnectionConfig,
|
|
26
38
|
cache_ttl_seconds: int = 0,
|
|
27
39
|
):
|
|
40
|
+
self._logger = logger
|
|
28
41
|
self._config = config
|
|
29
42
|
self._config_in_library_format = self.__get_kafka_config_in_library_format(config)
|
|
30
43
|
self._kafka_admin = KafkaPythonLibraryAdminClient(**self._config_in_library_format)
|
|
@@ -75,14 +88,13 @@ class KafkaPythonAdminClient(KafkaAdminClient):
|
|
|
75
88
|
self,
|
|
76
89
|
topic: str,
|
|
77
90
|
) -> bool:
|
|
78
|
-
|
|
79
|
-
return topic in topics
|
|
91
|
+
return topic in self.get_topics()
|
|
80
92
|
|
|
81
93
|
def get_topics(
|
|
82
94
|
self,
|
|
83
95
|
) -> set[str]:
|
|
84
96
|
return self.__resolve_cached_property(
|
|
85
|
-
|
|
97
|
+
TOPIC_CACHE_KEY, lambda: set(self._kafka_admin.list_topics()) - INTERNAL_KAFKA_TOPICS
|
|
86
98
|
)
|
|
87
99
|
|
|
88
100
|
def __resolve_cached_property(self, property_key: str, callback: Callable) -> Any:
|
|
@@ -101,6 +113,10 @@ class KafkaPythonAdminClient(KafkaAdminClient):
|
|
|
101
113
|
self._kafka_admin.delete_topics(
|
|
102
114
|
topics=topics,
|
|
103
115
|
)
|
|
116
|
+
self.__remove_cache_property(TOPIC_CACHE_KEY)
|
|
117
|
+
|
|
118
|
+
def __remove_cache_property(self, property_key: str) -> None:
|
|
119
|
+
self.__ttl_cache.pop(property_key, None)
|
|
104
120
|
|
|
105
121
|
def delete_subscription_groups(
|
|
106
122
|
self,
|
|
@@ -119,3 +135,80 @@ class KafkaPythonAdminClient(KafkaAdminClient):
|
|
|
119
135
|
def _wait_for_cluster_update(self) -> None:
|
|
120
136
|
future = self._kafka_client.cluster.request_update()
|
|
121
137
|
self._kafka_client.poll(future=future)
|
|
138
|
+
|
|
139
|
+
def move_offsets_to_datetime(
|
|
140
|
+
self,
|
|
141
|
+
*,
|
|
142
|
+
consumer_group: str,
|
|
143
|
+
topic: str,
|
|
144
|
+
target_datetime: datetime,
|
|
145
|
+
) -> None:
|
|
146
|
+
consumer = KafkaConsumer(
|
|
147
|
+
group_id=consumer_group,
|
|
148
|
+
enable_auto_commit=False,
|
|
149
|
+
auto_offset_reset=KafkaPythonConsumerInitialOffsetPositionTranslator.to_kafka_supported_format(
|
|
150
|
+
ConsumerInitialOffsetPosition.BEGINNING
|
|
151
|
+
),
|
|
152
|
+
**self._config_in_library_format,
|
|
153
|
+
)
|
|
154
|
+
|
|
155
|
+
partitions = consumer.partitions_for_topic(topic)
|
|
156
|
+
|
|
157
|
+
if partitions is None:
|
|
158
|
+
raise TopicNotFoundException(topic)
|
|
159
|
+
|
|
160
|
+
topic_partitions = [TopicPartition(topic, p) for p in partitions]
|
|
161
|
+
consumer.subscribe(topics=[topic])
|
|
162
|
+
|
|
163
|
+
self.__force_partition_assignment(consumer)
|
|
164
|
+
|
|
165
|
+
# We need all the partitions in order to update the offsets
|
|
166
|
+
if len(consumer.assignment()) != len(topic_partitions):
|
|
167
|
+
raise NotAllPartitionAssignedException(topic)
|
|
168
|
+
|
|
169
|
+
offsets_for_date = self.__get_first_offset_after_date(
|
|
170
|
+
consumer=consumer,
|
|
171
|
+
topic_partitions=topic_partitions,
|
|
172
|
+
target_datetime=target_datetime,
|
|
173
|
+
)
|
|
174
|
+
|
|
175
|
+
end_offsets = consumer.end_offsets(topic_partitions)
|
|
176
|
+
|
|
177
|
+
if end_offsets is None or len(end_offsets.keys()) != len(topic_partitions):
|
|
178
|
+
raise Exception(f'There was an error extracting the end offsets of the topic "{topic}"')
|
|
179
|
+
|
|
180
|
+
for topic_partition in topic_partitions:
|
|
181
|
+
offset_and_timestamp = offsets_for_date.get(topic_partition)
|
|
182
|
+
if offset_and_timestamp:
|
|
183
|
+
self._logger.info(f'moving "{topic_partition}" to the offset "{offset_and_timestamp.offset}"')
|
|
184
|
+
consumer.seek(topic_partition, offset_and_timestamp.offset)
|
|
185
|
+
else:
|
|
186
|
+
self._logger.info(
|
|
187
|
+
f'moving "{topic_partition}" to the end of the topic because there are no messages later than "{target_datetime}"'
|
|
188
|
+
)
|
|
189
|
+
consumer.seek(topic_partition, end_offsets[topic_partition])
|
|
190
|
+
|
|
191
|
+
consumer.commit()
|
|
192
|
+
consumer.close()
|
|
193
|
+
|
|
194
|
+
def __get_first_offset_after_date(
|
|
195
|
+
self,
|
|
196
|
+
*,
|
|
197
|
+
consumer: KafkaConsumer,
|
|
198
|
+
topic_partitions: Sequence[TopicPartition],
|
|
199
|
+
target_datetime: datetime,
|
|
200
|
+
) -> dict[TopicPartition, Optional[OffsetAndTimestamp]]:
|
|
201
|
+
offset_for_times: dict[TopicPartition, Optional[int]] = {}
|
|
202
|
+
timestamp_ms = int(target_datetime.timestamp() * 1000)
|
|
203
|
+
|
|
204
|
+
for topic_partition in topic_partitions:
|
|
205
|
+
offset_for_times[topic_partition] = timestamp_ms
|
|
206
|
+
|
|
207
|
+
return cast(
|
|
208
|
+
dict[TopicPartition, Optional[OffsetAndTimestamp]],
|
|
209
|
+
consumer.offsets_for_times(offset_for_times),
|
|
210
|
+
)
|
|
211
|
+
|
|
212
|
+
# We are not to commit the new offset, but we need to execute a polling in order to start the partition assignment
|
|
213
|
+
def __force_partition_assignment(self, consumer: KafkaConsumer) -> None:
|
|
214
|
+
consumer.poll(max_records=1, timeout_ms=0)
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
from __future__ import annotations
|
|
2
2
|
|
|
3
|
+
from logging import Logger
|
|
3
4
|
from typing import Optional
|
|
4
5
|
|
|
5
6
|
from kafka import KafkaConsumer, KafkaProducer
|
|
@@ -22,8 +23,16 @@ CONSUMER_POLL_TIMEOUT_MS = 1000
|
|
|
22
23
|
|
|
23
24
|
|
|
24
25
|
class KafkaPythonAdminTestClient(KafkaPythonAdminClient, KafkaAdminTestClient):
|
|
25
|
-
def __init__(
|
|
26
|
-
|
|
26
|
+
def __init__(
|
|
27
|
+
self,
|
|
28
|
+
*,
|
|
29
|
+
logger: Logger,
|
|
30
|
+
config: KafkaConnectionConfig,
|
|
31
|
+
):
|
|
32
|
+
super().__init__(
|
|
33
|
+
config=config,
|
|
34
|
+
logger=logger,
|
|
35
|
+
)
|
|
27
36
|
|
|
28
37
|
def send_message_to_topic(
|
|
29
38
|
self,
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/base_handle_middleware.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/asynchronous/middleware/handle_middleware.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/more_than_one_command_handler_related_exception.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/middleware/base_handle_middleware.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/self_process/self_process_command_bus.py
RENAMED
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/command/synchronous/synced_async/synced_async_command_bus.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/exceptions/term_signal_interruption_exception.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/buz_kafka_event_bus.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/consume_strategy/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/exceptions/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/buz_kafka/publish_strategy/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/allowed_kombu_serializer.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/consume_strategy/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/publish_strategy/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/infrastructure/kombu/retry_strategy/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/async_consume_middleware_chain_resolver.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/consume_middleware_chain_resolver.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/middleware/publish_middleware_chain_resolver.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/execution_strategy/execution_strategy.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/consumed_event_retry_repository.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/max_retries_consume_retrier.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/strategies/retry/max_retries_negative_exception.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_criteria/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/outbox_record_finder/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/transactional_outbox_event_bus.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/event/transactional_outbox/transactional_outbox_worker.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/exceptions/not_valid_kafka_message_exception.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/exceptions/topic_already_created_exception.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/auto_create_topic_configuration.py
RENAMED
|
File without changes
|
{buz-2.13.1rc8 → buz-2.13.1rc9}/src/buz/kafka/domain/models/consumer_initial_offset_position.py
RENAMED
|
File without changes
|