aboutsummaryrefslogtreecommitdiff
path: root/.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py
diff options
context:
space:
mode:
authorS. Solomon Darnell2025-03-28 21:52:21 -0500
committerS. Solomon Darnell2025-03-28 21:52:21 -0500
commit4a52a71956a8d46fcb7294ac71734504bb09bcc2 (patch)
treeee3dc5af3b6313e921cd920906356f5d4febc4ed /.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py
parentcc961e04ba734dd72309fb548a2f97d67d578813 (diff)
downloadgn-ai-4a52a71956a8d46fcb7294ac71734504bb09bcc2.tar.gz
two version of R2R are hereHEADmaster
Diffstat (limited to '.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py')
-rw-r--r--.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py72
1 files changed, 72 insertions, 0 deletions
diff --git a/.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py b/.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py
new file mode 100644
index 00000000..26f3109f
--- /dev/null
+++ b/.venv/lib/python3.12/site-packages/prometheus_client/openmetrics/exposition.py
@@ -0,0 +1,72 @@
+#!/usr/bin/env python
+
+
+from ..utils import floatToGoString
+
+CONTENT_TYPE_LATEST = 'application/openmetrics-text; version=1.0.0; charset=utf-8'
+"""Content type of the latest OpenMetrics text format"""
+
+
+def _is_valid_exemplar_metric(metric, sample):
+ if metric.type == 'counter' and sample.name.endswith('_total'):
+ return True
+ if metric.type in ('histogram', 'gaugehistogram') and sample.name.endswith('_bucket'):
+ return True
+ return False
+
+
+def generate_latest(registry):
+ '''Returns the metrics from the registry in latest text format as a string.'''
+ output = []
+ for metric in registry.collect():
+ try:
+ mname = metric.name
+ output.append('# HELP {} {}\n'.format(
+ mname, metric.documentation.replace('\\', r'\\').replace('\n', r'\n').replace('"', r'\"')))
+ output.append(f'# TYPE {mname} {metric.type}\n')
+ if metric.unit:
+ output.append(f'# UNIT {mname} {metric.unit}\n')
+ for s in metric.samples:
+ if s.labels:
+ labelstr = '{{{0}}}'.format(','.join(
+ ['{}="{}"'.format(
+ k, v.replace('\\', r'\\').replace('\n', r'\n').replace('"', r'\"'))
+ for k, v in sorted(s.labels.items())]))
+ else:
+ labelstr = ''
+ if s.exemplar:
+ if not _is_valid_exemplar_metric(metric, s):
+ raise ValueError(f"Metric {metric.name} has exemplars, but is not a histogram bucket or counter")
+ labels = '{{{0}}}'.format(','.join(
+ ['{}="{}"'.format(
+ k, v.replace('\\', r'\\').replace('\n', r'\n').replace('"', r'\"'))
+ for k, v in sorted(s.exemplar.labels.items())]))
+ if s.exemplar.timestamp is not None:
+ exemplarstr = ' # {} {} {}'.format(
+ labels,
+ floatToGoString(s.exemplar.value),
+ s.exemplar.timestamp,
+ )
+ else:
+ exemplarstr = ' # {} {}'.format(
+ labels,
+ floatToGoString(s.exemplar.value),
+ )
+ else:
+ exemplarstr = ''
+ timestamp = ''
+ if s.timestamp is not None:
+ timestamp = f' {s.timestamp}'
+ output.append('{}{} {}{}{}\n'.format(
+ s.name,
+ labelstr,
+ floatToGoString(s.value),
+ timestamp,
+ exemplarstr,
+ ))
+ except Exception as exception:
+ exception.args = (exception.args or ('',)) + (metric,)
+ raise
+
+ output.append('# EOF\n')
+ return ''.join(output).encode('utf-8')