From 81e216131bba394ce0a9c964fbf868ae65600163 Mon Sep 17 00:00:00 2001 From: Luca Bello Date: Mon, 19 Feb 2024 10:16:58 +0100 Subject: [PATCH 1/3] fix race condition in privkey generation --- lib/charms/observability_libs/v1/cert_handler.py | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/charms/observability_libs/v1/cert_handler.py b/lib/charms/observability_libs/v1/cert_handler.py index 83c506a..f5d1290 100644 --- a/lib/charms/observability_libs/v1/cert_handler.py +++ b/lib/charms/observability_libs/v1/cert_handler.py @@ -211,6 +211,7 @@ def _on_config_changed(self, _): if not relation: return + self._generate_privkey() self._generate_csr(renew=True) def _generate_csr( From 16af94af1cc51ff9661700ee6aaf4d2817ddf127 Mon Sep 17 00:00:00 2001 From: Luca Bello Date: Mon, 19 Feb 2024 10:26:25 +0100 Subject: [PATCH 2/3] fix static checks in other libs --- .../v0/kubernetes_compute_resources_patch.py | 8 ++++---- .../observability_libs/v0/metrics_endpoint_discovery.py | 4 ++-- lib/charms/observability_libs/v1/cert_handler.py | 2 +- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py b/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py index a6ad4df..024599c 100644 --- a/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py +++ b/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py @@ -133,7 +133,7 @@ def setUp(self, *unused): # Increment this PATCH version before using `charmcraft publish-lib` or reset # to 0 if you are raising the major API version -LIBPATCH = 6 +LIBPATCH = 7 _Decimal = Union[Decimal, float, str, int] # types that are potentially convertible to Decimal @@ -364,7 +364,7 @@ def is_patched(self, resource_reqs: ResourceRequirements) -> bool: Returns: bool: A boolean indicating if the service patch has been applied. """ - return equals_canonically(self.get_templated(), resource_reqs) + return equals_canonically(self.get_templated(), resource_reqs) # pyright: ignore def get_templated(self) -> Optional[ResourceRequirements]: """Returns the resource limits specified in the StatefulSet template.""" @@ -397,8 +397,8 @@ def is_ready(self, pod_name, resource_reqs: ResourceRequirements): self.get_templated(), self.get_actual(pod_name), ) - return self.is_patched(resource_reqs) and equals_canonically( - resource_reqs, self.get_actual(pod_name) + return self.is_patched(resource_reqs) and equals_canonically( # pyright: ignore + resource_reqs, self.get_actual(pod_name) # pyright: ignore ) def apply(self, resource_reqs: ResourceRequirements) -> None: diff --git a/lib/charms/observability_libs/v0/metrics_endpoint_discovery.py b/lib/charms/observability_libs/v0/metrics_endpoint_discovery.py index 7864ef9..d77962e 100644 --- a/lib/charms/observability_libs/v0/metrics_endpoint_discovery.py +++ b/lib/charms/observability_libs/v0/metrics_endpoint_discovery.py @@ -62,7 +62,7 @@ def _on_endpoints_change(self, event): # Increment this PATCH version before using `charmcraft publish-lib` or reset # to 0 if you are raising the major API version -LIBPATCH = 6 +LIBPATCH = 7 # File path where metrics endpoint change data is written for exchange # between the discovery process and the materialised event. @@ -215,7 +215,7 @@ def main(): target_ports = [] for c in filter(lambda c: c.ports is not None, entity.spec.containers): # pyright: ignore - for p in filter(lambda p: p.name == "metrics", c.ports): + for p in filter(lambda p: p.name == "metrics", c.ports): # pyright: ignore target_ports.append("*:{}".format(p.containerPort)) payload = { diff --git a/lib/charms/observability_libs/v1/cert_handler.py b/lib/charms/observability_libs/v1/cert_handler.py index f5d1290..37e143a 100644 --- a/lib/charms/observability_libs/v1/cert_handler.py +++ b/lib/charms/observability_libs/v1/cert_handler.py @@ -66,7 +66,7 @@ LIBID = "b5cd5cd580f3428fa5f59a8876dcbe6a" LIBAPI = 1 -LIBPATCH = 1 +LIBPATCH = 2 def is_ip_address(value: str) -> bool: From 4a0272928c08fb3854a679afba4cd683cca62aa3 Mon Sep 17 00:00:00 2001 From: Luca Bello Date: Mon, 19 Feb 2024 10:26:50 +0100 Subject: [PATCH 3/3] tox fmt --- .../observability_libs/v0/kubernetes_compute_resources_patch.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py b/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py index 024599c..2ab8a22 100644 --- a/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py +++ b/lib/charms/observability_libs/v0/kubernetes_compute_resources_patch.py @@ -398,7 +398,7 @@ def is_ready(self, pod_name, resource_reqs: ResourceRequirements): self.get_actual(pod_name), ) return self.is_patched(resource_reqs) and equals_canonically( # pyright: ignore - resource_reqs, self.get_actual(pod_name) # pyright: ignore + resource_reqs, self.get_actual(pod_name) # pyright: ignore ) def apply(self, resource_reqs: ResourceRequirements) -> None: