From 8ef7afda46db6d39607485bfd21ea3027846e703 Mon Sep 17 00:00:00 2001 From: Jean-Louis Leroy Date: Tue, 19 Nov 2024 16:32:44 -0500 Subject: [PATCH 1/2] configurator.Cluster: add remove_domain Signed-off-by: Jean-Louis Leroy --- src/python/blazingmq/dev/configurator/__init__.py | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/python/blazingmq/dev/configurator/__init__.py b/src/python/blazingmq/dev/configurator/__init__.py index a5508ccab3..a82eb47833 100644 --- a/src/python/blazingmq/dev/configurator/__init__.py +++ b/src/python/blazingmq/dev/configurator/__init__.py @@ -227,6 +227,19 @@ def _add_domain(self, domain: "Domain") -> "Domain": return domain + def remove_domain(self, name: str) -> None: + """ + Remove a domain from the Cluster's map and all the domain's maps. + + The domain must exist in `Cluster.domains`. It can be missing from the + broker's domain maps. + """ + + del self.domains[name] + + for node in self.nodes.values(): + node.domains.pop(name, None) + class Cluster(AbstractCluster): def domain(self, parameters: mqbconf.Domain) -> "Domain": From 8cbe5311f575e9808b37c77b2898aa3d05847d97 Mon Sep 17 00:00:00 2001 From: Jean-Louis Leroy Date: Tue, 19 Nov 2024 16:54:44 -0500 Subject: [PATCH 2/2] re-generate Python schemas and tweaks Signed-off-by: Jean-Louis Leroy --- .../blazingmq/dev/it/tweaks/generated.py | 34 ++++++++++++ src/python/blazingmq/schemas/mqbcfg.py | 52 ++++++++++++++++++- 2 files changed, 85 insertions(+), 1 deletion(-) diff --git a/src/python/blazingmq/dev/it/tweaks/generated.py b/src/python/blazingmq/dev/it/tweaks/generated.py index 26a0ff5487..5a2a37e761 100644 --- a/src/python/blazingmq/dev/it/tweaks/generated.py +++ b/src/python/blazingmq/dev/it/tweaks/generated.py @@ -165,6 +165,34 @@ def __call__( syslog = Syslog() + class LogDump(metaclass=TweakMetaclass): + class RecordBufferSize(metaclass=TweakMetaclass): + + def __call__(self, value: int) -> Callable: ... + + record_buffer_size = RecordBufferSize() + + class RecordingLevel(metaclass=TweakMetaclass): + + def __call__(self, value: str) -> Callable: ... + + recording_level = RecordingLevel() + + class TriggerLevel(metaclass=TweakMetaclass): + + def __call__(self, value: str) -> Callable: ... + + trigger_level = TriggerLevel() + + def __call__( + self, + value: typing.Union[ + blazingmq.schemas.mqbcfg.LogDumpConfig, NoneType + ], + ) -> Callable: ... + + log_dump = LogDump() + def __call__( self, value: typing.Union[ @@ -769,6 +797,12 @@ def __call__(self, value: bool) -> Callable: ... advertise_subscriptions = AdvertiseSubscriptions() + class RouteCommandTimeoutMs(metaclass=TweakMetaclass): + + def __call__(self, value: int) -> Callable: ... + + route_command_timeout_ms = RouteCommandTimeoutMs() + def __call__( self, value: typing.Union[blazingmq.schemas.mqbcfg.AppConfig, NoneType] ) -> Callable: ... diff --git a/src/python/blazingmq/schemas/mqbcfg.py b/src/python/blazingmq/schemas/mqbcfg.py index 547c6cca02..1d34e6e76c 100644 --- a/src/python/blazingmq/schemas/mqbcfg.py +++ b/src/python/blazingmq/schemas/mqbcfg.py @@ -397,6 +397,37 @@ class Heartbeat: ) +@dataclass +class LogDumpConfig: + record_buffer_size: int = field( + default=32768, + metadata={ + "name": "recordBufferSize", + "type": "Element", + "namespace": "http://bloomberg.com/schemas/mqbcfg", + "required": True, + }, + ) + recording_level: str = field( + default="OFF", + metadata={ + "name": "recordingLevel", + "type": "Element", + "namespace": "http://bloomberg.com/schemas/mqbcfg", + "required": True, + }, + ) + trigger_level: str = field( + default="OFF", + metadata={ + "name": "triggerLevel", + "type": "Element", + "namespace": "http://bloomberg.com/schemas/mqbcfg", + "required": True, + }, + ) + + class MasterAssignmentAlgorithm(Enum): """Enumeration of the various algorithm's used for assigning a master to. @@ -1157,6 +1188,15 @@ class LogController: "required": True, }, ) + log_dump: Optional[LogDumpConfig] = field( + default=None, + metadata={ + "name": "logDump", + "type": "Element", + "namespace": "http://bloomberg.com/schemas/mqbcfg", + "required": True, + }, + ) @dataclass @@ -1855,7 +1895,8 @@ class AppConfig: plugins..............: configuration for the plugins msgPropertiesSupport.: information about if/how to advertise support for v2 message properties configureStream......: send new ConfigureStream instead of old ConfigureQueue - advertiseSubscriptions.: temporarily control use of ConfigureStream in SDK/> + advertiseSubscriptions.: temporarily control use of ConfigureStream in SDK + routeCommandTimeoutMs: maximum amount of time to wait for a routed command's response """ broker_instance_name: Optional[str] = field( @@ -2018,6 +2059,15 @@ class AppConfig: "required": True, }, ) + route_command_timeout_ms: int = field( + default=3000, + metadata={ + "name": "routeCommandTimeoutMs", + "type": "Element", + "namespace": "http://bloomberg.com/schemas/mqbcfg", + "required": True, + }, + ) @dataclass