Fix form input highlights on initial load/ajax requests - add alert settings - slack integration
This commit is contained in:
parent
8a73d5bb5d
commit
e4c8faaa57
2
app.js
2
app.js
|
@ -33,6 +33,8 @@ app.use('/dhcp_config_save', require('./routes/dhcp_config_save'));
|
||||||
app.use('/dhcp_start_stop_restart', require('./routes/dhcp_start_stop_restart'));
|
app.use('/dhcp_start_stop_restart', require('./routes/dhcp_start_stop_restart'));
|
||||||
app.use('/api_examples', require('./routes/api_examples'));
|
app.use('/api_examples', require('./routes/api_examples'));
|
||||||
app.use('/glass_settings', require('./routes/glass_settings'));
|
app.use('/glass_settings', require('./routes/glass_settings'));
|
||||||
|
app.use('/glass_alerts', require('./routes/glass_alerts'));
|
||||||
|
app.use('/glass_alert_settings_save', require('./routes/glass_alert_settings_save'));
|
||||||
app.use('/glass_settings_save', require('./routes/glass_settings_save'));
|
app.use('/glass_settings_save', require('./routes/glass_settings_save'));
|
||||||
|
|
||||||
/* API Routes */
|
/* API Routes */
|
||||||
|
|
|
@ -2,6 +2,11 @@
|
||||||
"admin_user": "glassadmin",
|
"admin_user": "glassadmin",
|
||||||
"admin_password": "glassadmin",
|
"admin_password": "glassadmin",
|
||||||
"leases_file": "/var/lib/dhcp/dhcpd.leases",
|
"leases_file": "/var/lib/dhcp/dhcpd.leases",
|
||||||
"log_file": "/var/lib/dhcp.log",
|
"log_file": "/var/log/dhcp.log",
|
||||||
"config_file": "/etc/dhcp/dhcpd.conf"
|
"config_file": "/etc/dhcp/dhcpd.conf",
|
||||||
|
"shared_network_critical_threshold": 95,
|
||||||
|
"shared_network_warning_threshold": 80,
|
||||||
|
"lease_per_second_threshold": 0,
|
||||||
|
"slack_webhook_url": "",
|
||||||
|
"slack_alert_channel": ""
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ module.exports = {
|
||||||
return template.replace("[" + variable + "]", value);
|
return template.replace("[" + variable + "]", value);
|
||||||
},
|
},
|
||||||
form_body: function (id, inputs) {
|
form_body: function (id, inputs) {
|
||||||
return '<div class="form-group" id="' + id + '">' + inputs + '</div>';
|
return '<div id="' + id + '">' + inputs + '</div>';
|
||||||
},
|
},
|
||||||
form_input: function (title, input) {
|
form_input: function (title, input) {
|
||||||
return '<label>' + title + '</label><div class="form-group"><div class="form-line">' + input + '</div></div>';
|
return '<label>' + title + '</label><div class="form-group"><div class="form-line">' + input + '</div></div>';
|
||||||
|
|
|
@ -4,6 +4,45 @@
|
||||||
|
|
||||||
$( document ).ajaxComplete(function( event, request, settings ) {
|
$( document ).ajaxComplete(function( event, request, settings ) {
|
||||||
check_dashboard_active();
|
check_dashboard_active();
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Form input highlighting events
|
||||||
|
*/
|
||||||
|
|
||||||
|
//On focus event
|
||||||
|
$('.form-control').focus(function () {
|
||||||
|
$(this).parent().addClass('focused');
|
||||||
|
});
|
||||||
|
|
||||||
|
//On focusout event
|
||||||
|
$('.form-control').focusout(function () {
|
||||||
|
var $this = $(this);
|
||||||
|
if ($this.parents('.form-group').hasClass('form-float')) {
|
||||||
|
if ($this.val() == '') { $this.parents('.form-line').removeClass('focused'); }
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$this.parents('.form-line').removeClass('focused');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
//On label click
|
||||||
|
$('body').on('click', '.form-float .form-line .form-label', function () {
|
||||||
|
$(this).parent().find('input').focus();
|
||||||
|
});
|
||||||
|
|
||||||
|
//Not blank form
|
||||||
|
$('.form-control').each(function () {
|
||||||
|
if ($(this).val() !== '') {
|
||||||
|
$(this).parents('.form-line').addClass('focused');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.form-line').removeClass("focused");
|
||||||
|
});
|
||||||
|
|
||||||
|
$( document ).ready(function() {
|
||||||
|
$('.form-line').removeClass("focused");
|
||||||
});
|
});
|
||||||
|
|
||||||
function check_dashboard_active() {
|
function check_dashboard_active() {
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 5.5 KiB |
|
@ -0,0 +1,46 @@
|
||||||
|
<div id="alerts_config">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-12 col-md-12 col-sm-12 col-xs-12">
|
||||||
|
<div class="card">
|
||||||
|
<div class="header">
|
||||||
|
<h2>
|
||||||
|
Glass Alerts
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
<div class="body">
|
||||||
|
[c_content]
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-12 col-md-12 col-sm-12 col-xs-12">
|
||||||
|
<div class="card">
|
||||||
|
<div class="header">
|
||||||
|
<h2>
|
||||||
|
Notification Settings
|
||||||
|
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
<div class="body">
|
||||||
|
[n_content]
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="glass_alerts_result"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
[save_button]
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
function save_alarm_settings() {
|
||||||
|
glass_alert_settings = get_form_query_string("alerts_config");
|
||||||
|
|
||||||
|
$.post( "/glass_alert_settings_save", glass_alert_settings, function( data ) {
|
||||||
|
$( "#glass_alerts_result" ).html( data );
|
||||||
|
});
|
||||||
|
}
|
||||||
|
</script>
|
|
@ -203,9 +203,6 @@
|
||||||
<!-- Custom Js -->
|
<!-- Custom Js -->
|
||||||
<script src="assets/js/admin.js"></script>
|
<script src="assets/js/admin.js"></script>
|
||||||
|
|
||||||
<!-- Demo Js -->
|
|
||||||
<script src="assets/js/demo.js"></script>
|
|
||||||
|
|
||||||
<script src="assets/js/pjax.js"></script>
|
<script src="assets/js/pjax.js"></script>
|
||||||
|
|
||||||
<script src="assets/js/api-examples.js"></script>
|
<script src="assets/js/api-examples.js"></script>
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
/**
|
||||||
|
* Created by cmiles on 8/9/2017.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
|
||||||
|
router.post('/', function(req, res, next) {
|
||||||
|
var request = req.body;
|
||||||
|
var json_file = require('jsonfile');
|
||||||
|
var glass_config = json_file.readFileSync('config/glass_config.json');
|
||||||
|
|
||||||
|
glass_config.shared_network_critical_threshold = request.shared_network_critical_threshold;
|
||||||
|
glass_config.shared_network_warning_threshold = request.shared_network_warning_threshold;
|
||||||
|
glass_config.lease_per_second_threshold = request.lease_per_second_threshold;
|
||||||
|
glass_config.slack_webhook_url = request.slack_webhook_url;
|
||||||
|
glass_config.slack_alert_channel = request.slack_alert_channel;
|
||||||
|
|
||||||
|
json_file.writeFile('./config/glass_config.json', glass_config, {spaces: 2}, function(err) {
|
||||||
|
console.error(err);
|
||||||
|
});
|
||||||
|
|
||||||
|
res.send('<script type="text/javascript">notification(\'Saved Alert Settings!\')</script>');
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
|
@ -0,0 +1,55 @@
|
||||||
|
/**
|
||||||
|
* Created by cmiles on 8/9/2017.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var express = require('express');
|
||||||
|
var router = express.Router();
|
||||||
|
var fs = require('fs');
|
||||||
|
var template_render = require('../lib/render_template.js');
|
||||||
|
|
||||||
|
router.get('/', function(req, res, next) {
|
||||||
|
|
||||||
|
glass_settings_template = template_render.get_template("glass_alerts");
|
||||||
|
|
||||||
|
var json_file = require('jsonfile');
|
||||||
|
|
||||||
|
/* Read Config */
|
||||||
|
glass_config = json_file.readFileSync('config/glass_config.json');
|
||||||
|
|
||||||
|
/* Shared Network Alert Threshold (Critical) */
|
||||||
|
input = template_render.form_input('Shared Network Alert Threshold (Critical)', '<input type="input" class="form-control" id="shared_network_critical_threshold" placeholder="95%" value="' + glass_config.shared_network_critical_threshold + '">');
|
||||||
|
|
||||||
|
/* Shared Network Alert Threshold (Warning) */
|
||||||
|
input = input + template_render.form_input('Shared Network Alert Threshold (Warning)', '<input type="input" class="form-control" id="shared_network_warning_threshold" placeholder="80" value="' + glass_config.shared_network_warning_threshold + '">');
|
||||||
|
|
||||||
|
/* Leases Per Second Threshold */
|
||||||
|
input = input + template_render.form_input('Alert when Leases Per Second Reaches Below this Number', '<input type="input" class="form-control" id="lease_per_second_threshold" placeholder="0" value="' + glass_config.lease_per_second_threshold + '">');
|
||||||
|
|
||||||
|
// <div id="glass_settings_result"></div>
|
||||||
|
|
||||||
|
form_data = template_render.form_body("glass-alerts-form", input);
|
||||||
|
|
||||||
|
glass_settings_template = template_render.set_template_variable(glass_settings_template, "c_content", form_data);
|
||||||
|
|
||||||
|
/* Shared Network Alert Threshold (Critical) */
|
||||||
|
input = template_render.form_input('Slack Webhook URL <img src="images/slack-icon.png" style="height:25px; width: auto;"> ', '<input type="input" class="form-control" id="slack_webhook_url" placeholder="https://hooks.slack.com/services/xxx/xxx/xxx" value="' + glass_config.slack_webhook_url + '">');
|
||||||
|
|
||||||
|
/* Shared Network Alert Threshold (Warning) */
|
||||||
|
input = input + template_render.form_input('Slack Channel <img src="images/slack-icon.png" style="height:25px; width: auto;"> ', '<input type="input" class="form-control" id="slack_alert_channel" placeholder="#channel" value="' + glass_config.slack_alert_channel + '">');
|
||||||
|
|
||||||
|
// <div id="glass_settings_result"></div>
|
||||||
|
|
||||||
|
form_data = template_render.form_body("glass-notifications-form", input);
|
||||||
|
|
||||||
|
glass_settings_template = template_render.set_template_variable(glass_settings_template, "n_content", form_data);
|
||||||
|
|
||||||
|
glass_settings_template = template_render.set_template_variable(
|
||||||
|
glass_settings_template,
|
||||||
|
"save_button",
|
||||||
|
'<button type="button" class="btn btn-primary waves-effect" onclick="save_alarm_settings()"><i class="material-icons">add_alert</i> <span>Save Alarm Settings</span></button>'
|
||||||
|
);
|
||||||
|
|
||||||
|
res.send(template_render.get_index_template(glass_settings_template, req.url));
|
||||||
|
});
|
||||||
|
|
||||||
|
module.exports = router;
|
|
@ -9,8 +9,16 @@ router.post('/', function(req, res, next) {
|
||||||
var request = req.body;
|
var request = req.body;
|
||||||
var json_file = require('jsonfile');
|
var json_file = require('jsonfile');
|
||||||
|
|
||||||
json_file.writeFile('./config/glass_config.json', request, {spaces: 2}, function(err) {
|
var glass_config = json_file.readFileSync('config/glass_config.json');
|
||||||
console.error(err);
|
|
||||||
|
glass_config.admin_user = request.admin_user;
|
||||||
|
glass_config.admin_password = request.admin_password;
|
||||||
|
glass_config.leases_file = request.leases_file;
|
||||||
|
glass_config.log_file = request.log_file;
|
||||||
|
glass_config.config_file = request.config_file;
|
||||||
|
|
||||||
|
json_file.writeFile('./config/glass_config.json', glass_config, {spaces: 2}, function(err) {
|
||||||
|
console.error(err)
|
||||||
});
|
});
|
||||||
|
|
||||||
res.send('<script type="text/javascript">notification(\'Saved Config!\')</script>');
|
res.send('<script type="text/javascript">notification(\'Saved Config!\')</script>');
|
||||||
|
|
Loading…
Reference in New Issue