facts: Add graph for facts endpoint.

This commit is contained in:
Spencer Krum
2013-08-28 16:12:19 -07:00
committed by Daniele Sluijters
parent e71f30ab50
commit 23af033cbb
4 changed files with 1798 additions and 1 deletions

View File

@@ -184,9 +184,12 @@ def facts():
def fact(fact):
"""Fetches the specific fact from PuppetDB and displays its value per
node for which this fact is known."""
# we can only consume the generator once, lists can be doubly consumed
# om nom nom
localfacts = [ f for f in yield_or_stop(puppetdb.facts(name=fact)) ]
return Response(stream_with_context(stream_template('fact.html',
name=fact,
facts=yield_or_stop(puppetdb.facts(name=fact)))))
facts=localfacts)))
@app.route('/query', methods=('GET', 'POST'))
def query():

1770
puppetboard/static/js/Chart.js vendored Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -27,6 +27,29 @@
</tbody>
</table>
{%- endmacro %}
{% macro facts_graph(facts, autofocus=False, condensed=False, show_node=False, margin_top=20, margin_bottom=20) -%}
<script src="{{url_for('static', filename='js/Chart.js')}}"></script>
<canvas id="factChart" width="400" height="400"></canvas>
<script type="text/javascript">
var data = [
{% set color_list = ["#F38630", "#E0E4CC", "#69D2E7", "#D11151", "#787BE3", "#B59370", "#B30202"] %}
{% for fact in facts|groupby('value') %}
{
label: "{{ fact.grouper }}",
color: "{{ color_list|random }}",
value: {{ fact.list|length }}
},
{% endfor %}
{
value: 0,
color: "#000000"
}
]
var ctx = document.getElementById("factChart").getContext("2d");
var myNewChart = new Chart(ctx).Pie(data);
new Chart(ctx).Pie(data);
</script>
{%- endmacro %}
{% macro reports_table(reports, nodename, condensed=False, hash_truncate=False, show_conf_col=True, show_agent_col=True, show_host_col=True) -%}
<div class="alert alert-info">

View File

@@ -2,5 +2,6 @@
{% import '_macros.html' as macros %}
{% block content %}
<h1>{{name}}</h1>
{{macros.facts_graph(facts, autofocus=True, show_node=True, margin_bottom=10)}}
{{macros.facts_table(facts, autofocus=True, show_node=True, margin_bottom=10)}}
{% endblock content %}