You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
395 lines
12 KiB
395 lines
12 KiB
1 year ago
|
<?php
|
||
|
/*
|
||
|
** Zabbix
|
||
|
** Copyright (C) 2001-2023 Zabbix SIA
|
||
|
**
|
||
|
** This program is free software; you can redistribute it and/or modify
|
||
|
** it under the terms of the GNU General Public License as published by
|
||
|
** the Free Software Foundation; either version 2 of the License, or
|
||
|
** (at your option) any later version.
|
||
|
**
|
||
|
** This program is distributed in the hope that it will be useful,
|
||
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
** GNU General Public License for more details.
|
||
|
**
|
||
|
** You should have received a copy of the GNU General Public License
|
||
|
** along with this program; if not, write to the Free Software
|
||
|
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
**/
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @var CView $this
|
||
|
*/
|
||
|
?>
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
|
||
|
jQuery(function($) {
|
||
|
let $form = $('form[name="user_group_form"]'),
|
||
|
$new_group_right_table = $form.find('table#new-group-right-table'),
|
||
|
$new_templategroup_right_table = $form.find('table#new-templategroup-right-table'),
|
||
|
$group_right_table_container = $form.find('table#group-right-table').parent(),
|
||
|
$templategroup_right_table_container = $form.find('table#templategroup-right-table').parent(),
|
||
|
$new_tag_filter_table = $form.find('table#new-tag-filter-table'),
|
||
|
$tag_filter_table_container = $form.find('table#tag-filter-table').parent(),
|
||
|
$ms_tag_filter_groups = $new_tag_filter_table.find('.multiselect'),
|
||
|
$ms_group_right_groups = $new_group_right_table.find('.multiselect'),
|
||
|
$ms_templategroup_right_groups = $new_templategroup_right_table.find('.multiselect'),
|
||
|
$userdirectory = $form.find('[name="userdirectoryid"]'),
|
||
|
$gui_access = $form.find('[name="gui_access"]'),
|
||
|
timeoutid_new_group_right,
|
||
|
timeoutid_new_templategroup_right,
|
||
|
timeoutid_new_tag_filter,
|
||
|
xhr_new_group_right,
|
||
|
xhr_new_templategroup_right,
|
||
|
xhr_new_tag_filter;
|
||
|
|
||
|
$gui_access.on('change', onFrontendAccessChange);
|
||
|
onFrontendAccessChange.apply($gui_access);
|
||
|
|
||
|
$form.submit(function() {
|
||
|
$form.trimValues(['#name']);
|
||
|
});
|
||
|
|
||
|
/**
|
||
|
* Handle "Frontend access" selector change.
|
||
|
*/
|
||
|
function onFrontendAccessChange() {
|
||
|
let gui_access = $(this).val();
|
||
|
|
||
|
if (gui_access == <?= GROUP_GUI_ACCESS_INTERNAL ?> || gui_access == <?= GROUP_GUI_ACCESS_DISABLED ?>) {
|
||
|
$userdirectory.attr('disabled', 'disabled');
|
||
|
}
|
||
|
else {
|
||
|
$userdirectory.removeAttr('disabled');
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects tag filter form data.
|
||
|
*
|
||
|
* @return {object}
|
||
|
*/
|
||
|
function collectTagFilterFormData() {
|
||
|
var data = {
|
||
|
new_tag_filter: {groupids: []},
|
||
|
tag_filters: []
|
||
|
};
|
||
|
|
||
|
$ms_tag_filter_groups.multiSelect('getData').forEach(function(ms_item) {
|
||
|
data.new_tag_filter.groupids.push(ms_item.id);
|
||
|
});
|
||
|
|
||
|
data.new_tag_filter.include_subgroups = $new_tag_filter_table
|
||
|
.find('[name="new_tag_filter[include_subgroups]"]').prop('checked') ? '1' : '0';
|
||
|
|
||
|
data.new_tag_filter.tag = $new_tag_filter_table.find('[name="new_tag_filter[tag]"]').val();
|
||
|
data.new_tag_filter.value = $new_tag_filter_table.find('[name="new_tag_filter[value]"]').val();
|
||
|
|
||
|
$tag_filter_table_container.find('[name="tag_filter"]').each(function(i, node) {
|
||
|
data.tag_filters.push(JSON.parse(node.value));
|
||
|
});
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects host group right form data.
|
||
|
*
|
||
|
* @return {object}
|
||
|
*/
|
||
|
function collectGroupRightFormData() {
|
||
|
var data = {
|
||
|
new_group_right: {groupids: []},
|
||
|
group_rights: {}
|
||
|
};
|
||
|
|
||
|
$ms_group_right_groups.multiSelect('getData').forEach(function(ms_item) {
|
||
|
data.new_group_right.groupids.push(ms_item.id);
|
||
|
});
|
||
|
|
||
|
data.new_group_right.include_subgroups = $new_group_right_table
|
||
|
.find('[name="new_group_right[include_subgroups]"]').prop('checked') ? '1' : '0';
|
||
|
|
||
|
data.new_group_right.permission = $new_group_right_table
|
||
|
.find('[name="new_group_right[permission]"]').filter(':checked').val();
|
||
|
|
||
|
data.group_rights = $.extend.apply({},
|
||
|
$group_right_table_container.find('[name="group_right"]').map(function(i, node) {
|
||
|
var obj = JSON.parse(node.value),
|
||
|
permission = jQuery(node).parent().find('input[type="radio"]').filter(':checked').val();
|
||
|
|
||
|
if (typeof permission !== 'undefined') {
|
||
|
obj[Object.keys(obj)[0]].permission = permission;
|
||
|
}
|
||
|
return obj;
|
||
|
})
|
||
|
);
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects template group right form data.
|
||
|
*
|
||
|
* @return {object}
|
||
|
*/
|
||
|
function collectTemplategroupRightFormData() {
|
||
|
let data = {
|
||
|
new_templategroup_right: {groupids: []},
|
||
|
templategroup_rights: {}
|
||
|
};
|
||
|
|
||
|
$ms_templategroup_right_groups.multiSelect('getData').forEach(function(ms_item) {
|
||
|
data.new_templategroup_right.groupids.push(ms_item.id);
|
||
|
});
|
||
|
|
||
|
data.new_templategroup_right.include_subgroups = $new_templategroup_right_table
|
||
|
.find('[name="new_templategroup_right[include_subgroups]"]').prop('checked') ? '1' : '0';
|
||
|
|
||
|
data.new_templategroup_right.permission = $new_templategroup_right_table
|
||
|
.find('[name="new_templategroup_right[permission]"]').filter(':checked').val();
|
||
|
|
||
|
data.templategroup_rights = $.extend.apply({},
|
||
|
$templategroup_right_table_container.find('[name="templategroup_right"]').map(function(i, node) {
|
||
|
let obj = JSON.parse(node.value),
|
||
|
permission = jQuery(node).parent().find('input[type="radio"]').filter(':checked').val();
|
||
|
|
||
|
if (typeof permission !== 'undefined') {
|
||
|
obj[Object.keys(obj)[0]].permission = permission;
|
||
|
}
|
||
|
|
||
|
return obj;
|
||
|
})
|
||
|
);
|
||
|
|
||
|
return data;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* During long request, shows indicator and disables form elements.
|
||
|
*/
|
||
|
function disableNewGroupRightForm() {
|
||
|
timeoutid_new_group_right = setTimeout(function() {
|
||
|
$ms_group_right_groups.multiSelect('disable');
|
||
|
$new_group_right_table.find('button, [name^="new_group_right"]').prop('disabled', true);
|
||
|
$group_right_table_container.find('input[type="radio"]').prop('disabled', true);
|
||
|
}, 150);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* During long request, shows indicator and disables form elements.
|
||
|
*/
|
||
|
function disableNewTemplateGroupRightForm() {
|
||
|
timeoutid_new_templategroup_right = setTimeout(function() {
|
||
|
$ms_templategroup_right_groups.multiSelect('disable');
|
||
|
$new_templategroup_right_table.find('button, [name^="new_templategroup_right"]').prop('disabled', true);
|
||
|
$templategroup_right_table_container.find('input[type="radio"]').prop('disabled', true);
|
||
|
}, 150);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* During long request, shows indicator and disables form elements.
|
||
|
*/
|
||
|
function disableNewTagFilterForm() {
|
||
|
timeoutid_new_tag_filter = setTimeout(function() {
|
||
|
$ms_tag_filter_groups.multiSelect('disable');
|
||
|
$new_tag_filter_table.find('button, [name^="new_tag_filter"]').prop('disabled', true);
|
||
|
$tag_filter_table_container.find('button').prop('disabled', true);
|
||
|
}, 150);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Removes loading indicator and enables form elements.
|
||
|
*/
|
||
|
function enableNewGroupRightForm() {
|
||
|
clearTimeout(timeoutid_new_group_right);
|
||
|
$ms_group_right_groups.multiSelect('enable');
|
||
|
$new_group_right_table.find('button, [name^="new_group_right"]').prop('disabled', false);
|
||
|
$group_right_table_container.find('input[type="radio"]').prop('disabled', false);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Removes loading indicator and enables form elements.
|
||
|
*/
|
||
|
function enableNewTemplateGroupRightForm() {
|
||
|
clearTimeout(timeoutid_new_templategroup_right);
|
||
|
$ms_templategroup_right_groups.multiSelect('enable');
|
||
|
$new_templategroup_right_table.find('button, [name^="new_templategroup_right"]').prop('disabled', false);
|
||
|
$templategroup_right_table_container.find('input[type="radio"]').prop('disabled', false);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Removes loading indicator and enables form elements.
|
||
|
*/
|
||
|
function enableNewTagFilterForm() {
|
||
|
clearTimeout(timeoutid_new_tag_filter);
|
||
|
$ms_tag_filter_groups.multiSelect('enable');
|
||
|
$new_tag_filter_table.find('button, [name^="new_tag_filter"]').prop('disabled', false);
|
||
|
$tag_filter_table_container.find('button').prop('disabled', false);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Successful response handler.
|
||
|
*
|
||
|
* @param {string} html
|
||
|
*/
|
||
|
function respNewGroupRight(html) {
|
||
|
$ms_group_right_groups.multiSelect('clean');
|
||
|
$new_group_right_table.find('[name="new_group_right[tag]"]').val('');
|
||
|
$new_group_right_table.find('[name="new_group_right[value]"]').val('');
|
||
|
$group_right_table_container.html(html);
|
||
|
|
||
|
// Trigger event to update tab indicator.
|
||
|
document.dispatchEvent(new Event('tab-indicator-update'));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Successful response handler.
|
||
|
*
|
||
|
* @param {string} html
|
||
|
*/
|
||
|
function respNewTemplateGroupRight(html) {
|
||
|
$ms_templategroup_right_groups.multiSelect('clean');
|
||
|
$new_templategroup_right_table.find('[name="new_group_right[tag]"]').val('');
|
||
|
$new_templategroup_right_table.find('[name="new_group_right[value]"]').val('');
|
||
|
$templategroup_right_table_container.html(html);
|
||
|
|
||
|
// Trigger event to update tab indicator.
|
||
|
document.dispatchEvent(new Event('tab-indicator-update'));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Successful response handler.
|
||
|
*
|
||
|
* @param {string} html
|
||
|
*/
|
||
|
function respNewTagFilter(html) {
|
||
|
$ms_tag_filter_groups.multiSelect('clean');
|
||
|
$new_tag_filter_table.find('[name="new_tag_filter[tag]"]').val('');
|
||
|
$new_tag_filter_table.find('[name="new_tag_filter[value]"]').val('');
|
||
|
$tag_filter_table_container.html(html);
|
||
|
|
||
|
// Trigger event to update tab indicator.
|
||
|
document.dispatchEvent(new Event('tab-indicator-update'));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Response handler factory, dries up logic on how error response is recognized and handled.
|
||
|
*
|
||
|
* @param {callable} handle_data Successful response handler.
|
||
|
*
|
||
|
* @return {callable} Response handler.
|
||
|
*/
|
||
|
function respHandler(handle_data) {
|
||
|
return function(resp) {
|
||
|
clearMessages();
|
||
|
|
||
|
if ('error' in resp) {
|
||
|
const message_box = makeMessageBox('bad', resp.error.messages, resp.error.title);
|
||
|
|
||
|
addMessage(message_box);
|
||
|
}
|
||
|
else if ('messages' in resp) {
|
||
|
addMessage(resp.messages);
|
||
|
}
|
||
|
|
||
|
if (resp.body) {
|
||
|
var html = resp.body;
|
||
|
|
||
|
if (resp.debug) {
|
||
|
html += resp.debug;
|
||
|
}
|
||
|
|
||
|
handle_data(html);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects data, sends to controller for processing. On success, tag filter table is updated and form objects
|
||
|
* are removed from DOM. On failure error message is displayed. During request, loader is displayed.
|
||
|
*
|
||
|
* @param {string} action
|
||
|
*/
|
||
|
function submitNewTagFilter(action) {
|
||
|
var url = new Curl('zabbix.php'),
|
||
|
data = collectTagFilterFormData();
|
||
|
|
||
|
url.setArgument('action', action);
|
||
|
|
||
|
disableNewTagFilterForm();
|
||
|
|
||
|
xhr_new_tag_filter && xhr_new_tag_filter.abort();
|
||
|
xhr_new_tag_filter = $.post(url.getUrl(), data)
|
||
|
.always(enableNewTagFilterForm)
|
||
|
.done(respHandler(respNewTagFilter))
|
||
|
.fail(function() {});
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects template data, sends to controller for processing. On success, permissions table is updated and
|
||
|
* form objects are removed from DOM. On failure error message is displayed. During request, loader is
|
||
|
* displayed.
|
||
|
*
|
||
|
* @param {string} action
|
||
|
*/
|
||
|
function submitNewTemplateGroupRight(action) {
|
||
|
let url = new Curl('zabbix.php'),
|
||
|
data = collectTemplategroupRightFormData();
|
||
|
|
||
|
url.setArgument('action', action);
|
||
|
|
||
|
disableNewTemplateGroupRightForm();
|
||
|
|
||
|
xhr_new_templategroup_right && xhr_new_templategroup_right.abort();
|
||
|
xhr_new_templategroup_right = $.post(url.getUrl(), data)
|
||
|
.always(enableNewTemplateGroupRightForm)
|
||
|
.done(respHandler(respNewTemplateGroupRight))
|
||
|
.fail(function() {});
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Collects host data, sends to controller for processing. On success, permissions table is updated and form
|
||
|
* objects are removed from DOM. On failure error message is displayed. During request, loader is displayed.
|
||
|
*
|
||
|
* @param {string} action
|
||
|
*/
|
||
|
function submitNewGroupRight(action) {
|
||
|
let url = new Curl('zabbix.php'),
|
||
|
data = collectGroupRightFormData();
|
||
|
|
||
|
url.setArgument('action', action);
|
||
|
|
||
|
disableNewGroupRightForm();
|
||
|
|
||
|
xhr_new_group_right && xhr_new_group_right.abort();
|
||
|
xhr_new_group_right = $.post(url.getUrl(), data)
|
||
|
.always(enableNewGroupRightForm)
|
||
|
.done(respHandler(respNewGroupRight))
|
||
|
.fail(function() {});
|
||
|
}
|
||
|
|
||
|
function removeTagFilterRow($this) {
|
||
|
$this
|
||
|
.closest('tr')
|
||
|
.remove();
|
||
|
|
||
|
// Trigger event to update tab indicator.
|
||
|
document.dispatchEvent(new Event('tab-indicator-update'));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Public API.
|
||
|
*/
|
||
|
window.usergroups = {
|
||
|
submitNewGroupRight: submitNewGroupRight,
|
||
|
submitNewTemplateGroupRight: submitNewTemplateGroupRight,
|
||
|
submitNewTagFilter: submitNewTagFilter,
|
||
|
removeTagFilterRow: removeTagFilterRow
|
||
|
};
|
||
|
});
|
||
|
</script>
|