qontract-reconcile 0.10.2.dev7__py3-none-any.whl → 0.10.2.dev8__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.
- {qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/METADATA +1 -1
- {qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/RECORD +6 -6
- reconcile/external_resources/manager.py +4 -2
- reconcile/external_resources/metrics.py +22 -0
- {qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/WHEEL +0 -0
- {qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/entry_points.txt +0 -0
{qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/METADATA
RENAMED
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: qontract-reconcile
|
3
|
-
Version: 0.10.2.
|
3
|
+
Version: 0.10.2.dev8
|
4
4
|
Summary: Collection of tools to reconcile services with their desired state as defined in the app-interface DB.
|
5
5
|
Project-URL: homepage, https://github.com/app-sre/qontract-reconcile
|
6
6
|
Project-URL: repository, https://github.com/app-sre/qontract-reconcile
|
{qontract_reconcile-0.10.2.dev7.dist-info → qontract_reconcile-0.10.2.dev8.dist-info}/RECORD
RENAMED
@@ -199,9 +199,9 @@ reconcile/external_resources/aws.py,sha256=NSaOeHqFEcMaMxNjJwuQZosolgsJ8XRVvwkEE
|
|
199
199
|
reconcile/external_resources/factories.py,sha256=TyJMaijDfPIFYks9i6dhKN7nSR1BoCkoBs1iPExKpcE,5493
|
200
200
|
reconcile/external_resources/integration.py,sha256=gBVO5dE8JyZ3xYcYik-MTIp_18oU7_hpYc_oztyfElQ,6753
|
201
201
|
reconcile/external_resources/integration_secrets_sync.py,sha256=dX09O3r6KURziUYYfiki10orNjOGVma-XojhVqd0ww4,1667
|
202
|
-
reconcile/external_resources/manager.py,sha256=
|
202
|
+
reconcile/external_resources/manager.py,sha256=eVaaGCaKDkc897xt5cA5-B4yYuS9VWR-Z7Uom0uSsG0,15971
|
203
203
|
reconcile/external_resources/meta.py,sha256=noaytFzmShpzLA_ebGh7wuP45mOfHIOnnoUxivjDa1I,672
|
204
|
-
reconcile/external_resources/metrics.py,sha256=
|
204
|
+
reconcile/external_resources/metrics.py,sha256=KiBjMUaN_z0cSkF_7Ar_a8RiuiwVqjyMcVdISlxhzXE,3898
|
205
205
|
reconcile/external_resources/model.py,sha256=YJylbAhetN9szpLUFd9jFqxCRMvSWXVxSC9OMQNV-wg,11316
|
206
206
|
reconcile/external_resources/reconciler.py,sha256=K9QvbQCIOCuOHnPIxQE_P_jFtrkF3dGo8d_cCCh08Ys,8973
|
207
207
|
reconcile/external_resources/secrets_sync.py,sha256=H8JfI3JW1XEau1jqv15AhYg49mCZeHwZmqMzMv_6tFc,16344
|
@@ -766,7 +766,7 @@ tools/saas_promotion_state/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJ
|
|
766
766
|
tools/saas_promotion_state/saas_promotion_state.py,sha256=5LJ9rygZ304vxfsIuRfuxueoYRb72EZNKKITEcJ4Mtk,3908
|
767
767
|
tools/sre_checkpoints/__init__.py,sha256=CDaDaywJnmRCLyl_NCcvxi-Zc0hTi_3OdwKiFOyS39I,145
|
768
768
|
tools/sre_checkpoints/util.py,sha256=zEDbGr18ZeHNQwW8pUsr2JRjuXIPz--WAGJxZo9sv_Y,894
|
769
|
-
qontract_reconcile-0.10.2.
|
770
|
-
qontract_reconcile-0.10.2.
|
771
|
-
qontract_reconcile-0.10.2.
|
772
|
-
qontract_reconcile-0.10.2.
|
769
|
+
qontract_reconcile-0.10.2.dev8.dist-info/METADATA,sha256=Q7bA9-IZt-P1nmshnv22D4iHqrAq7N03KD5__iEgMyA,24664
|
770
|
+
qontract_reconcile-0.10.2.dev8.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
771
|
+
qontract_reconcile-0.10.2.dev8.dist-info/entry_points.txt,sha256=JniHZPadNOILPyfSl0LF2YSp3Db7K2_W2CN7i9f3Gos,540
|
772
|
+
qontract_reconcile-0.10.2.dev8.dist-info/RECORD,,
|
@@ -357,12 +357,14 @@ class ExternalResourcesManager:
|
|
357
357
|
if reconciliation_status.resource_status.needs_secret_sync:
|
358
358
|
to_sync_keys.add(r.key)
|
359
359
|
|
360
|
-
if self._resource_needs_reconciliation(
|
360
|
+
if is_reconciled := self._resource_needs_reconciliation(
|
361
|
+
reconciliation=r, state=state
|
362
|
+
):
|
361
363
|
self.reconciler.reconcile_resource(reconciliation=r)
|
362
364
|
self._set_resource_reconciliation_in_progress(r, state)
|
363
365
|
|
364
366
|
if spec := self.er_inventory.get(r.key):
|
365
|
-
publish_metrics(r, spec, reconciliation_status)
|
367
|
+
publish_metrics(r, spec, reconciliation_status, is_reconciled)
|
366
368
|
|
367
369
|
pending_sync_keys = self.state_mgr.get_keys_by_status(
|
368
370
|
ResourceStatus.PENDING_SECRET_SYNC
|
@@ -23,6 +23,14 @@ class ExternalResourcesBaseMetric(BaseModel):
|
|
23
23
|
job_name: str
|
24
24
|
|
25
25
|
|
26
|
+
class ExternalResourcesReconciliationsCounter(
|
27
|
+
ExternalResourcesBaseMetric, CounterMetric
|
28
|
+
):
|
29
|
+
@classmethod
|
30
|
+
def name(cls) -> str:
|
31
|
+
return "external_resources_reconciliations"
|
32
|
+
|
33
|
+
|
26
34
|
class ExternalResourcesReconcileErrorsCounter(
|
27
35
|
ExternalResourcesBaseMetric, CounterMetric
|
28
36
|
):
|
@@ -49,6 +57,7 @@ def publish_metrics(
|
|
49
57
|
r: Reconciliation,
|
50
58
|
spec: ExternalResourceSpec,
|
51
59
|
reconciliation_status: ReconciliationStatus,
|
60
|
+
is_reconciled: bool,
|
52
61
|
) -> None:
|
53
62
|
job_name = ReconciliationK8sJob(reconciliation=r).name()
|
54
63
|
|
@@ -93,3 +102,16 @@ def publish_metrics(
|
|
93
102
|
job_name=job_name,
|
94
103
|
)
|
95
104
|
)
|
105
|
+
|
106
|
+
if is_reconciled:
|
107
|
+
metrics.inc_counter(
|
108
|
+
ExternalResourcesReconciliationsCounter(
|
109
|
+
app=spec.namespace["app"]["name"],
|
110
|
+
environment=spec.namespace["environment"]["name"],
|
111
|
+
provision_provider=r.key.provision_provider,
|
112
|
+
provisioner_name=r.key.provisioner_name,
|
113
|
+
provider=r.key.provider,
|
114
|
+
identifier=r.key.identifier,
|
115
|
+
job_name=job_name,
|
116
|
+
)
|
117
|
+
)
|
File without changes
|
File without changes
|