blob: f978cf2111716dd4ba09a16fc7179d635032c9ff [file] [log] [blame]
from collections import OrderedDict
def parse_buckets(agg_key, buckets, metric=None, labels=None):
if metric is None:
metric = []
if labels is None:
labels = OrderedDict()
result = []
for index, bucket in enumerate(buckets):
labels_next = labels.copy()
if 'key' in bucket.keys():
bucket_key = str(bucket['key'])
if agg_key in labels_next.keys():
labels_next[agg_key] = labels_next[agg_key] + [bucket_key]
else:
labels_next[agg_key] = [bucket_key]
del bucket['key']
else:
bucket_key = 'filter_' + str(index)
if agg_key in labels_next.keys():
labels_next[agg_key] = labels_next[agg_key] + [bucket_key]
else:
labels_next[agg_key] = [bucket_key]
result.extend(parse_agg(bucket_key, bucket, metric=metric, labels=labels_next))
return result
def parse_buckets_fixed(agg_key, buckets, metric=None, labels=None):
if metric is None:
metric = []
if labels is None:
labels = OrderedDict()
result = []
for bucket_key, bucket in buckets.items():
labels_next = labels.copy()
if agg_key in labels_next.keys():
labels_next[agg_key] = labels_next[agg_key] + [bucket_key]
else:
labels_next[agg_key] = [bucket_key]
result.extend(parse_agg(bucket_key, bucket, metric=metric, labels=labels_next))
return result
def parse_agg(agg_key, agg, metric=None, labels=None):
if metric is None:
metric = []
if labels is None:
labels = OrderedDict()
result = []
for key, value in agg.items():
if key == 'buckets' and isinstance(value, list):
result.extend(parse_buckets(agg_key, value, metric=metric, labels=labels))
elif key == 'buckets' and isinstance(value, dict):
result.extend(parse_buckets_fixed(agg_key, value, metric=metric, labels=labels))
elif isinstance(value, dict):
result.extend(parse_agg(key, value, metric=metric + [key], labels=labels))
else:
result.append((metric + [key], labels, value))
return result
def parse_response(response, metric=None):
if metric is None:
metric = []
result = []
if not response['timed_out']:
hits_total = response['hits']['total']
if isinstance(hits_total, dict):
hits_total = hits_total.get('value', 0)
result.append((metric + ['hits'], {}, hits_total))
result.append((metric + ['took', 'milliseconds'], {}, response['took']))
if 'aggregations' in response.keys():
for key, value in response['aggregations'].items():
result.extend(parse_agg(key, value, metric=metric + [key]))
return result