mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Added webui support for pushover
This commit is contained in:
@@ -26,10 +26,11 @@ $config_value = mres($_POST['config_value']);
|
|||||||
$config_extra = mres($_POST['config_extra']);
|
$config_extra = mres($_POST['config_extra']);
|
||||||
$config_room_id = mres($_POST['config_room_id']);
|
$config_room_id = mres($_POST['config_room_id']);
|
||||||
$config_from = mres($_POST['config_from']);
|
$config_from = mres($_POST['config_from']);
|
||||||
|
$config_userkey = mres($_POST['config_userkey']);
|
||||||
$status = 'error';
|
$status = 'error';
|
||||||
$message = 'Error with config';
|
$message = 'Error with config';
|
||||||
|
|
||||||
if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipchat') {
|
if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipchat' || $action == 'remove-pushover') {
|
||||||
$config_id = mres($_POST['config_id']);
|
$config_id = mres($_POST['config_id']);
|
||||||
if (empty($config_id)) {
|
if (empty($config_id)) {
|
||||||
$message = 'No config id passed';
|
$message = 'No config id passed';
|
||||||
@@ -39,6 +40,8 @@ if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipch
|
|||||||
dbDelete('config', "`config_name` LIKE 'alert.transports.slack.$config_id.%'");
|
dbDelete('config', "`config_name` LIKE 'alert.transports.slack.$config_id.%'");
|
||||||
} elseif ($action == 'remove-hipchat') {
|
} elseif ($action == 'remove-hipchat') {
|
||||||
dbDelete('config', "`config_name` LIKE 'alert.transports.hipchat.$config_id.%'");
|
dbDelete('config', "`config_name` LIKE 'alert.transports.hipchat.$config_id.%'");
|
||||||
|
} elseif ($action == 'remove-pushover') {
|
||||||
|
dbDelete('config', "`config_name` LIKE 'alert.transports.pushover.$config_id.%'");
|
||||||
}
|
}
|
||||||
$status = 'ok';
|
$status = 'ok';
|
||||||
$message = 'Config item removed';
|
$message = 'Config item removed';
|
||||||
@@ -73,8 +76,8 @@ if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipch
|
|||||||
$config_id = dbInsert(array('config_name' => 'alert.transports.hipchat.', 'config_value' => $config_value, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_value, 'config_descr'=>'Hipchat Transport'), 'config');
|
$config_id = dbInsert(array('config_name' => 'alert.transports.hipchat.', 'config_value' => $config_value, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_value, 'config_descr'=>'Hipchat Transport'), 'config');
|
||||||
if ($config_id > 0) {
|
if ($config_id > 0) {
|
||||||
dbUpdate(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.url'), 'config', 'config_id=?', array($config_id));
|
dbUpdate(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.url'), 'config', 'config_id=?', array($config_id));
|
||||||
dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.room_id', 'config_value' => $config_room_id, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_room_id, 'config_descr'=>'Hipchat URL'), 'config');
|
$additional_id['room_id'] = dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.room_id', 'config_value' => $config_room_id, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_room_id, 'config_descr'=>'Hipchat URL'), 'config');
|
||||||
dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.from', 'config_value' => $config_from, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_from, 'config_descr'=>'Hipchat From'), 'config');
|
$additional_id['from'] = dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.from', 'config_value' => $config_from, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_from, 'config_descr'=>'Hipchat From'), 'config');
|
||||||
$status = 'ok';
|
$status = 'ok';
|
||||||
$message = 'Config item created';
|
$message = 'Config item created';
|
||||||
$extras = explode('\n',$config_extra);
|
$extras = explode('\n',$config_extra);
|
||||||
@@ -88,6 +91,27 @@ if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipch
|
|||||||
$message = 'Could not create config item';
|
$message = 'Could not create config item';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} elseif ($action == 'add-pushover') {
|
||||||
|
if (empty($config_value) || empty($config_userkey)) {
|
||||||
|
$message = 'No pushover appkey or userkey provided';
|
||||||
|
} else {
|
||||||
|
$config_id = dbInsert(array('config_name' => 'alert.transports.pushover.', 'config_value' => $config_value, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_value, 'config_descr'=>'Pushover Transport'), 'config');
|
||||||
|
if ($config_id > 0) {
|
||||||
|
dbUpdate(array('config_name' => 'alert.transports.pushover.'.$config_id.'.appkey'), 'config', 'config_id=?', array($config_id));
|
||||||
|
$additional_id['userkey'] = dbInsert(array('config_name' => 'alert.transports.pushover.'.$config_id.'.userkey', 'config_value' => $config_userkey, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$config_userkey, 'config_descr'=>'Pushver Userkey'), 'config');
|
||||||
|
$status = 'ok';
|
||||||
|
$message = 'Config item created';
|
||||||
|
$extras = explode('\n',$config_extra);
|
||||||
|
foreach ($extras as $option) {
|
||||||
|
list($k,$v) = explode("=", $option,2);
|
||||||
|
if (!empty($k) || !empty($v)) {
|
||||||
|
dbInsert(array('config_name' => 'alert.transports.pushover.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => $config_group, 'config_sub_group' => $config_sub_group, 'config_default'=>$v, 'config_descr'=>'Pushover '.$v), 'config');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$message = 'Could not create config item';
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
if (empty($config_group) || empty($config_sub_group) || empty($config_name) || empty($config_value)) {
|
if (empty($config_group) || empty($config_sub_group) || empty($config_name) || empty($config_value)) {
|
||||||
@@ -104,5 +128,5 @@ if ($action == 'remove' || $action == 'remove-slack' || $action == 'remove-hipch
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$response = array('status'=>$status,'message'=>$message, 'config_id'=>$config_id);
|
$response = array('status'=>$status,'message'=>$message, 'config_id'=>$config_id, 'additional_id'=>$additional_id);
|
||||||
echo _json_encode($response);
|
echo _json_encode($response);
|
||||||
|
|||||||
@@ -33,15 +33,22 @@ if (!is_numeric($config_id)) {
|
|||||||
$db_id[] = dbInsert(array('config_name' => 'alert.transports.slack.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => 'alerting', 'config_sub_group' => 'transports', 'config_default'=>$v, 'config_descr'=>'Slack Transport'), 'config');
|
$db_id[] = dbInsert(array('config_name' => 'alert.transports.slack.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => 'alerting', 'config_sub_group' => 'transports', 'config_default'=>$v, 'config_descr'=>'Slack Transport'), 'config');
|
||||||
} elseif ($config_type == 'hipchat') {
|
} elseif ($config_type == 'hipchat') {
|
||||||
$db_id[] = dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => 'alerting', 'config_sub_group' => 'transports', 'config_default'=>$v, 'config_descr'=>'Hipchat Transport'), 'config');
|
$db_id[] = dbInsert(array('config_name' => 'alert.transports.hipchat.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => 'alerting', 'config_sub_group' => 'transports', 'config_default'=>$v, 'config_descr'=>'Hipchat Transport'), 'config');
|
||||||
|
} elseif ($config_type == 'pushover') {
|
||||||
|
$db_id[] = dbInsert(array('config_name' => 'alert.transports.pushover.'.$config_id.'.'.$k, 'config_value' => $v, 'config_group' => 'alerting', 'config_sub_group' => 'transports', 'config_default'=>$v, 'config_descr'=>'Pushover Transport'), 'config');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$db_inserts = implode(",",$db_id);
|
$db_inserts = implode(",",$db_id);
|
||||||
if (!empty($db_inserts)) {
|
if (!empty($db_inserts) || empty($_POST['config_value'])) {
|
||||||
|
if (empty($_POST['config_value'])) {
|
||||||
|
$db_inserts = 0;
|
||||||
|
}
|
||||||
if ($config_type == 'slack') {
|
if ($config_type == 'slack') {
|
||||||
dbDelete('config',"(`config_name` LIKE 'alert.transports.slack.$config_id.%' AND `config_name` != 'alert.transports.slack.$config_id.url' AND `config_id` NOT IN ($db_inserts))");
|
dbDelete('config',"(`config_name` LIKE 'alert.transports.slack.$config_id.%' AND `config_name` != 'alert.transports.slack.$config_id.url' AND `config_id` NOT IN ($db_inserts))");
|
||||||
} elseif ($config_type == 'hipchat') {
|
} elseif ($config_type == 'hipchat') {
|
||||||
dbDelete('config',"(`config_name` LIKE 'alert.transports.hipchat.$config_id.%' AND (`config_name` != 'alert.transports.hipchat.$config_id.url' AND `config_name` != 'alert.transports.hipchat.$config_id.room_id' AND `config_name` != 'alert.transports.hipchat.$config_id.from') AND `config_id` NOT IN ($db_inserts))");
|
dbDelete('config',"(`config_name` LIKE 'alert.transports.hipchat.$config_id.%' AND (`config_name` != 'alert.transports.hipchat.$config_id.url' AND `config_name` != 'alert.transports.hipchat.$config_id.room_id' AND `config_name` != 'alert.transports.hipchat.$config_id.from') AND `config_id` NOT IN ($db_inserts))");
|
||||||
|
} elseif ($config_type == 'pushover') {
|
||||||
|
dbDelete('config',"(`config_name` LIKE 'alert.transports.pushover.$config_id.%' AND (`config_name` != 'alert.transports.pushover.$config_id.appkey' AND `config_name` != 'alert.transports.pushover.$config_id.userkey') AND `config_id` NOT IN ($db_inserts))");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$message = 'Config item has been updated:';
|
$message = 'Config item has been updated:';
|
||||||
|
|||||||
@@ -113,6 +113,38 @@ $no_refresh = TRUE;
|
|||||||
</div>
|
</div>
|
||||||
<!-- End Hipchat Modal -->
|
<!-- End Hipchat Modal -->
|
||||||
|
|
||||||
|
<!-- Pushover Modal -->
|
||||||
|
<div class="modal fade" id="new-config-pushover" role="dialog" aria-hidden="true" title="Create new config item">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-body">
|
||||||
|
<form role="form" class="new_config_form">
|
||||||
|
<div class="form-group">
|
||||||
|
<span class="message"></span>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="pushover_value">Pushover Apikey</label>
|
||||||
|
<input type="text" class="form-control" name="pushover_value" id="pushover_value" placeholder="Enter the Pushover Apikey">
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="new_userkey">Room ID</label>
|
||||||
|
<input type="text" class="form-control" name="new_userkey" id="new_userkey" placeholder="Enter the Userkey">
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="pushover_extra">Pushover options (specify one per line key=value)</label>
|
||||||
|
<textarea class="form-control" name="pushover_extra" id="pushover_extra" placeholder="Enter the config options"></textarea>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button class="btn btn-success" id="submit-pushover">Add config</button>
|
||||||
|
<a href="#" class="btn" data-dismiss="modal">Cancel</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- End Pushover Modal -->
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
if (isset($_GET['error'])) {
|
if (isset($_GET['error'])) {
|
||||||
print_error('We had issues connecting to your Pager Duty account, please try again');
|
print_error('We had issues connecting to your Pager Duty account, please try again');
|
||||||
@@ -580,6 +612,85 @@ echo '
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="panel panel-default">
|
||||||
|
<div class="panel-heading">
|
||||||
|
<h4 class="panel-title">
|
||||||
|
<a data-toggle="collapse" data-parent="#accordion" href="#pushover_transport_expand">Pushover transport</a>
|
||||||
|
</h4>
|
||||||
|
</div>
|
||||||
|
<div id="pushover_transport_expand" class="panel-collapse collapse">
|
||||||
|
<div class="panel-body">
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<button class="btn btn-success btn-xs" type="button" name="new_config" id="new_config_item" data-toggle="modal" data-target="#new-config-pushover">Add Pushover config</button>
|
||||||
|
</div>
|
||||||
|
</div>';
|
||||||
|
$pushover_appkeys = get_config_like_name('alert.transports.pushover.%.appkey');
|
||||||
|
foreach ($pushover_appkeys as $pushover_appkey) {
|
||||||
|
unset($upd_pushover_extra);
|
||||||
|
$new_pushover_extra = array();
|
||||||
|
$pushover_extras = get_config_like_name('alert.transports.pushover.'.$pushover_appkey['config_id'].'.%');
|
||||||
|
$pushover_userkey = get_config_by_name('alert.transports.pushover.'.$pushover_appkey['config_id'].'.userkey');
|
||||||
|
foreach ($pushover_extras as $extra) {
|
||||||
|
$split_extra = explode('.',$extra['config_name']);
|
||||||
|
if ($split_extra[4] != 'appkey' && $split_extra[4] != 'userkey') {
|
||||||
|
$new_pushover_extra[] = $split_extra[4] . '=' . $extra['config_value'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$upd_pushover_extra = implode(PHP_EOL,$new_pushover_extra);
|
||||||
|
echo '<div id="'.$pushover_appkey['config_id'].'">
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<label for="pushover_appkey" class="col-sm-4 control-label">Pushover Appkey </label>
|
||||||
|
<div class="col-sm-4">
|
||||||
|
<input id="pushover_appkey" class="form-control" type="text" name="global-config-input" value="'.$pushover_appkey['config_value'].'" data-config_id="'.$pushover_appkey['config_id'].'">
|
||||||
|
<span class="glyphicon form-control-feedback" aria-hidden="true"></span>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-2">
|
||||||
|
<button type="button" class="btn btn-danger del-pushover-config" name="del-pushover-call" data-config_id="'.$pushover_appkey['config_id'].'"><i class="fa fa-minus"></i></button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<label for="pushover_userkey" class="col-sm-4 control-label">Userkey</label>
|
||||||
|
<div class="col-sm-4">
|
||||||
|
<input id="pushover_userkey" class="form-control" type="text" name="global-config-input" value="'.$pushover_userkey['config_value'].'" data-config_id="'.$pushover_userkey['config_id'].'">
|
||||||
|
<span class="glyphicon form-control-feedback" aria-hidden="true"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<div class="col-sm-offset-4 col-sm-4">
|
||||||
|
<textarea class="form-control" name="global-config-textarea" id="upd_pushover_extra" placeholder="Enter the config options" data-config_id="'.$pushover_appkey['config_id'].'" data-type="pushover">'.$upd_pushover_extra.'</textarea>
|
||||||
|
<span class="glyphicon form-control-feedback" aria-hidden="true"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>';
|
||||||
|
}
|
||||||
|
echo '<div id="pushover_appkey_template" class="hide">
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<label for="pushover_appkey" class="col-sm-4 control-label api-method">Pushover Appkey </label>
|
||||||
|
<div class="col-sm-4">
|
||||||
|
<input id="pushover_appkey" class="form-control" type="text" name="global-config-input" value="" data-config_id="">
|
||||||
|
<span class="glyphicon form-control-feedback" aria-hidden="true"></span>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-2">
|
||||||
|
<button type="button" class="btn btn-danger del-pushover-config" id="del-pushover-call" name="del-pushover-call" data-config_id=""><i class="fa fa-minus"></i></button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<label for="pushover_userkey" class="col-sm-4 control-label">Userkey</label>
|
||||||
|
<div class="col-sm-4">
|
||||||
|
<input id="global-config-userkey" class="form-control" type="text" name="global-config-input" value="" data-config_id="">
|
||||||
|
<span class="glyphicon form-control-feedback" aria-hidden="true"></span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group has-feedback">
|
||||||
|
<div class="col-sm-offset-4 col-sm-4">
|
||||||
|
<textarea class="form-control" name="global-config-textarea" id="upd_pushover_extra" placeholder="Enter the config options" data-config_id="" data-type="pushover"></textarea>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
';
|
';
|
||||||
@@ -710,6 +821,44 @@ echo '
|
|||||||
});
|
});
|
||||||
});// End Add Hipchat config
|
});// End Add Hipchat config
|
||||||
|
|
||||||
|
// Add Pushover config
|
||||||
|
pushoverIndex = 0;
|
||||||
|
$("button#submit-pushover").click(function(){
|
||||||
|
var config_value = $('#pushover_value').val();
|
||||||
|
var config_extra = $('#pushover_extra').val();
|
||||||
|
var config_userkey = $('#new_userkey').val();
|
||||||
|
$.ajax({
|
||||||
|
type: "POST",
|
||||||
|
url: "/ajax_form.php",
|
||||||
|
data: {type: "config-item", action: 'add-pushover', config_group: "alerting", config_sub_group: "transports", config_extra: config_extra, config_value: config_value, config_userkey: config_userkey},
|
||||||
|
dataType: "json",
|
||||||
|
success: function(data){
|
||||||
|
if (data.status == 'ok') {
|
||||||
|
pushoverIndex++;
|
||||||
|
var $template = $('#pushover_appkey_template'),
|
||||||
|
$clone = $template
|
||||||
|
.clone()
|
||||||
|
.removeClass('hide')
|
||||||
|
.attr('id',data.config_id)
|
||||||
|
.attr('pushover-appkey-index', pushoverIndex)
|
||||||
|
.insertBefore($template);
|
||||||
|
$clone.find('[id="pushover_appkey"]').attr('data-config_id',data.config_id);
|
||||||
|
$clone.find('[id="del-pushover-call"]').attr('data-config_id',data.config_id);
|
||||||
|
$clone.find('[name="global-config-input"]').attr('value', config_value);
|
||||||
|
$clone.find('[id="global-config-userkey"]').attr('value', config_userkey);
|
||||||
|
$clone.find('[id="global-config-userkey"]').attr('data-config_id',data.additional_id['userkey']);
|
||||||
|
$clone.find('[id="upd_pushover_extra"]').val(config_extra);
|
||||||
|
$clone.find('[id="upd_pushover_extra"]').attr('data-config_id',data.config_id);
|
||||||
|
$("#new-config-pushover").modal('hide');
|
||||||
|
} else {
|
||||||
|
$("#message").html('<div class="alert alert-info">' + data.message + '</div>');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function(){
|
||||||
|
$("#message").html('<div class="alert alert-info">Error creating config item</div>');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});// End Add Pushover config
|
||||||
|
|
||||||
// Delete api config
|
// Delete api config
|
||||||
$(document).on('click', 'button[name="del-api-call"]', function(event) {
|
$(document).on('click', 'button[name="del-api-call"]', function(event) {
|
||||||
@@ -774,6 +923,27 @@ echo '
|
|||||||
});
|
});
|
||||||
});// End delete hipchat config
|
});// End delete hipchat config
|
||||||
|
|
||||||
|
// Delete pushover config
|
||||||
|
$(document).on('click', 'button[name="del-pushover-call"]', function(event) {
|
||||||
|
var config_id = $(this).data('config_id');
|
||||||
|
$.ajax({
|
||||||
|
type: 'POST',
|
||||||
|
url: '/ajax_form.php',
|
||||||
|
data: {type: "config-item", action: 'remove-pushover', config_id: config_id},
|
||||||
|
dataType: "json",
|
||||||
|
success: function (data) {
|
||||||
|
if (data.status == 'ok') {
|
||||||
|
$("#"+config_id).remove();
|
||||||
|
} else {
|
||||||
|
$("#message").html('<div class="alert alert-info">' + data.message + '</div>');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function () {
|
||||||
|
$("#message").html('<div class="alert alert-info">An error occurred.</div>');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});// End delete pushover config
|
||||||
|
|
||||||
$("[name='global-config-check']").bootstrapSwitch('offColor','danger');
|
$("[name='global-config-check']").bootstrapSwitch('offColor','danger');
|
||||||
$('input[name="global-config-check"]').on('switchChange.bootstrapSwitch', function(event, state) {
|
$('input[name="global-config-check"]').on('switchChange.bootstrapSwitch', function(event, state) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
@@ -799,6 +969,7 @@ echo '
|
|||||||
var $this = $(this);
|
var $this = $(this);
|
||||||
var config_id = $this.data("config_id");
|
var config_id = $this.data("config_id");
|
||||||
var config_value = $this.val();
|
var config_value = $this.val();
|
||||||
|
alert(config_id + ' and ' + config_value)
|
||||||
$.ajax({
|
$.ajax({
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
url: '/ajax_form.php',
|
url: '/ajax_form.php',
|
||||||
|
|||||||
Reference in New Issue
Block a user