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.
474 lines
13 KiB
474 lines
13 KiB
<?php declare(strict_types = 0);
|
|
/*
|
|
** 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
|
|
*/
|
|
?>
|
|
|
|
// Initialized massupdate form tabs.
|
|
$('#tabs').tabs();
|
|
|
|
$('#tabs').on('tabsactivate', (event, ui) => {
|
|
$('#tabs').resize();
|
|
});
|
|
|
|
// Host groups.
|
|
<?php if (CWebUser::getType() == USER_TYPE_SUPER_ADMIN): ?>
|
|
(() => {
|
|
const groups_elem = document.querySelector('#groups-div');
|
|
|
|
if (groups_elem === null) {
|
|
return false;
|
|
}
|
|
|
|
const obj = groups_elem.tagName === 'SPAN' ? groups_elem.originalObject : groups_elem;
|
|
const $groups_ms = $(groups_elem).find('#groups_');
|
|
|
|
$groups_ms.on('change', (e) => {
|
|
$groups_ms.multiSelect('setDisabledEntries',
|
|
[... document.querySelectorAll('[name^="groups["]')].map((input) => input.value)
|
|
);
|
|
});
|
|
|
|
[... obj.querySelectorAll('input[name=mass_update_groups]')].map((elem) => {
|
|
elem.addEventListener('change', (e) => {
|
|
const action_value = e.currentTarget.value;
|
|
|
|
$groups_ms.multiSelect('modify', {
|
|
'addNew': (action_value == <?= ZBX_ACTION_ADD ?> || action_value == <?= ZBX_ACTION_REPLACE ?>)
|
|
});
|
|
})
|
|
});
|
|
})();
|
|
<?php endif ?>
|
|
|
|
// Macros.
|
|
(() => {
|
|
const macros_elem = document.querySelector('#macros-div');
|
|
if (!macros_elem) {
|
|
return false;
|
|
}
|
|
|
|
let obj = macros_elem
|
|
if (macros_elem.tagName === 'SPAN') {
|
|
obj = macros_elem.originalObject;
|
|
}
|
|
|
|
$(obj.querySelector('#tbl_macros')).dynamicRows({template: '#macro-row-tmpl', allow_empty: true});
|
|
$(obj.querySelector('#tbl_macros'))
|
|
.on('afteradd.dynamicRows', () => {
|
|
$('.macro-input-group', $(obj.querySelector('#tbl_macros'))).macroValue();
|
|
$('.<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>', $(obj.querySelector('#tbl_macros'))).textareaFlexible();
|
|
obj.querySelector('#macro_add').scrollIntoView({block: 'nearest'});
|
|
});
|
|
|
|
$(obj.querySelector('#tbl_macros'))
|
|
.find('.macro-input-group')
|
|
.macroValue();
|
|
|
|
$(obj.querySelector('#tbl_macros'))
|
|
.on('change keydown', '.<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>.macro', function(event) {
|
|
if (event.type === 'change' || event.which === 13) {
|
|
$(this)
|
|
.val($(this).val().replace(/([^:]+)/, (value) => value.toUpperCase('$1')))
|
|
.textareaFlexible();
|
|
}
|
|
});
|
|
|
|
$(obj.querySelector('#tbl_macros'))
|
|
.find('.<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>')
|
|
.textareaFlexible();
|
|
|
|
$(obj.querySelector('#tbl_macros'))
|
|
.on('resize', '.<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>', () => {
|
|
$(window).resize();
|
|
});
|
|
})();
|
|
|
|
// Tags.
|
|
(() => {
|
|
const tags_elem = document.querySelector('#tags-div');
|
|
if (!tags_elem) {
|
|
return false;
|
|
}
|
|
|
|
let obj = tags_elem
|
|
if (tags_elem.tagName === 'SPAN') {
|
|
obj = tags_elem.originalObject;
|
|
}
|
|
|
|
$(obj.querySelector('.tags-table')).dynamicRows({template: '#tag-row-tmpl', allow_empty: true});
|
|
$(obj.querySelector('.tags-table'))
|
|
.on('click', 'button.element-table-add', () => {
|
|
$('.tags-table .<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>').textareaFlexible();
|
|
})
|
|
.on('resize', '.<?= ZBX_STYLE_TEXTAREA_FLEXIBLE ?>', () => {
|
|
$(window).resize();
|
|
});
|
|
})();
|
|
|
|
// Linked templates.
|
|
(() => {
|
|
const template_visible = document.querySelector('#linked-templates-div');
|
|
|
|
if (!template_visible) {
|
|
return false;
|
|
}
|
|
|
|
const obj = template_visible.tagName === 'SPAN' ? template_visible.originalObject : template_visible;
|
|
const mass_action_tpls = obj.querySelector('#mass_action_tpls');
|
|
|
|
if (mass_action_tpls === null) {
|
|
return false;
|
|
}
|
|
|
|
const $template_ms = $(template_visible).find('#templates_, #linked_templates_');
|
|
|
|
$template_ms.on('change', (e) => {
|
|
$template_ms.multiSelect('setDisabledEntries',
|
|
[... template_visible.querySelectorAll('[name^="templates["], [name^="linked_templates["]')]
|
|
.map((input) => input.value)
|
|
);
|
|
});
|
|
|
|
mass_action_tpls.addEventListener('change', (e) => {
|
|
const action = obj.querySelector('input[name="mass_action_tpls"]:checked').value;
|
|
|
|
obj.querySelector('#mass_clear_tpls').disabled = (action === '<?= ZBX_ACTION_ADD ?>');
|
|
});
|
|
|
|
mass_action_tpls.dispatchEvent(new CustomEvent('change', {}));
|
|
})();
|
|
|
|
// Inventory mode.
|
|
(() => {
|
|
const inventory = document.querySelector('#inventoryFormList');
|
|
if (!inventory) {
|
|
return false;
|
|
}
|
|
|
|
let obj = inventory;
|
|
if (inventory.tagName === 'SPAN') {
|
|
obj = inventory.originalObject;
|
|
}
|
|
|
|
const cb = (event) => {
|
|
const value = event.currentTarget.value;
|
|
|
|
$('.formrow-inventory').toggle(value !== '<?php echo HOST_INVENTORY_DISABLED; ?>');
|
|
|
|
// Update popup size.
|
|
$('#tabs').resize();
|
|
};
|
|
|
|
[...obj.querySelectorAll('[name=inventory_mode]')].map((elem) => elem.addEventListener('change', cb));
|
|
|
|
document
|
|
.querySelector('#visible_inventory_mode')
|
|
.addEventListener('click',
|
|
() => cb({
|
|
currentTarget: {
|
|
value: (!document.querySelector('#visible_inventory_mode:checked'))
|
|
? '<?php echo HOST_INVENTORY_DISABLED; ?>'
|
|
: document
|
|
.querySelector('[name=inventory_mode]:checked')
|
|
.value
|
|
}
|
|
})
|
|
);
|
|
|
|
obj
|
|
.querySelector('[name=inventory_mode]')
|
|
.dispatchEvent(new CustomEvent('change', {}));
|
|
})();
|
|
|
|
// Encryption.
|
|
(() => {
|
|
const encryption = document.querySelector('#encryption_div');
|
|
if (!encryption) {
|
|
return false;
|
|
}
|
|
|
|
let obj = encryption;
|
|
if (encryption.tagName === 'SPAN') {
|
|
obj = encryption.originalObject;
|
|
}
|
|
|
|
[...obj.querySelectorAll('#tls_connect, #tls_in_psk, #tls_in_cert')].map(
|
|
(elem) => elem.addEventListener('change', (event) => {
|
|
// If certificate is selected or checked.
|
|
if (obj.querySelector('input[name=tls_connect]:checked').value == <?= HOST_ENCRYPTION_CERTIFICATE ?>
|
|
|| obj.querySelector('#tls_in_cert').checked) {
|
|
obj
|
|
.querySelector('#tls_issuer')
|
|
.closest('li')
|
|
.style
|
|
.display = '';
|
|
obj
|
|
.querySelector('#tls_subject')
|
|
.closest('li')
|
|
.style
|
|
.display = '';
|
|
}
|
|
else {
|
|
obj
|
|
.querySelector('#tls_issuer')
|
|
.closest('li')
|
|
.style
|
|
.display = 'none';
|
|
obj
|
|
.querySelector('#tls_subject')
|
|
.closest('li')
|
|
.style
|
|
.display = 'none';
|
|
}
|
|
|
|
// If PSK is selected or checked.
|
|
if (obj.querySelector('input[name=tls_connect]:checked').value == <?= HOST_ENCRYPTION_PSK ?>
|
|
|| obj.querySelector('#tls_in_psk').checked) {
|
|
obj
|
|
.querySelector('#tls_psk')
|
|
.closest('li')
|
|
.style
|
|
.display = '';
|
|
obj
|
|
.querySelector('#tls_psk_identity')
|
|
.closest('li')
|
|
.style
|
|
.display = '';
|
|
}
|
|
else {
|
|
obj
|
|
.querySelector('#tls_psk')
|
|
.closest('li')
|
|
.style
|
|
.display = 'none';
|
|
obj
|
|
.querySelector('#tls_psk_identity')
|
|
.closest('li')
|
|
.style
|
|
.display = 'none';
|
|
}
|
|
})
|
|
);
|
|
|
|
// Refresh field visibility on document load.
|
|
const tls_accept = document.querySelector('#tls_accept');
|
|
if (tls_accept) {
|
|
if ((tls_accept.value & <?= HOST_ENCRYPTION_NONE ?>) == <?= HOST_ENCRYPTION_NONE ?>) {
|
|
obj.querySelector('#tls_in_none').checked = true;
|
|
}
|
|
if ((tls_accept.value & <?= HOST_ENCRYPTION_PSK ?>) == <?= HOST_ENCRYPTION_PSK ?>) {
|
|
obj.querySelector('#tls_in_psk').checked = true;
|
|
}
|
|
if ((tls_accept.value & <?= HOST_ENCRYPTION_CERTIFICATE ?>) == <?= HOST_ENCRYPTION_CERTIFICATE ?>) {
|
|
obj.querySelector('#tls_in_cert').checked = true;
|
|
}
|
|
}
|
|
|
|
obj
|
|
.querySelector('#tls_connect')
|
|
.dispatchEvent(new CustomEvent('change', {}));
|
|
})();
|
|
|
|
// Value maps.
|
|
(() => {
|
|
const valuemap = document.querySelector('#valuemap-div');
|
|
|
|
if (!valuemap) {
|
|
return false;
|
|
}
|
|
|
|
let obj = valuemap;
|
|
if (valuemap.tagName === 'SPAN') {
|
|
obj = valuemap.originalObject;
|
|
}
|
|
|
|
obj.querySelectorAll('[name=valuemap_massupdate]').forEach((elem) => elem.addEventListener('click',
|
|
(event) => toggleVisible(obj, event.currentTarget.value)
|
|
));
|
|
obj.querySelectorAll('.js-element-table-addfrom').forEach(elm => elm.addEventListener('click',
|
|
(event) => openAddfromPopup(event.target)
|
|
));
|
|
|
|
$('#valuemap-rename-table').dynamicRows({
|
|
template: '#valuemap-rename-row-tmpl',
|
|
allow_empty: true,
|
|
row: '.form_row',
|
|
rows: [{from: '', to: ''}]
|
|
});
|
|
|
|
let overlay = overlays_stack.end();
|
|
|
|
$(overlay.$dialogue||document).on('remove', () => {
|
|
$(document).off('add.popup', processAddfromPopup);
|
|
});
|
|
$(document).on('add.popup', processAddfromPopup);
|
|
|
|
function processAddfromPopup(ev, data) {
|
|
let value = data.values[0];
|
|
|
|
if (data.parentId === null) {
|
|
new AddValueMap({
|
|
name: value.name,
|
|
mappings: value.mappings
|
|
});
|
|
}
|
|
}
|
|
|
|
function openAddfromPopup(element) {
|
|
let disable_names = [];
|
|
let valuemap_table = element.closest('table');
|
|
|
|
valuemap_table.querySelectorAll('[name$="[name]"]').forEach((element) => disable_names.push(element.value));
|
|
|
|
PopUp('popup.generic', {
|
|
srctbl: element.dataset.context === 'host' ? 'valuemaps' : 'template_valuemaps',
|
|
srcfld1: 'valuemapid',
|
|
context: element.dataset.context,
|
|
disable_names: disable_names,
|
|
editable: true
|
|
}, {dialogue_class: 'modal-popup-generic', trigger_element: element});
|
|
}
|
|
|
|
function toggleVisible(obj, data_type) {
|
|
obj.querySelectorAll('[data-type]').forEach((elm) => {
|
|
elm.style.display = (elm.getAttribute('data-type').split(',').indexOf(data_type) != -1) ? '' : 'none';
|
|
});
|
|
$(window).resize();
|
|
}
|
|
|
|
toggleVisible(obj, obj.querySelector('[name=valuemap_massupdate]:checked').value);
|
|
})();
|
|
|
|
if (!CR && !GK) {
|
|
$("textarea[maxlength]").bind("paste contextmenu change keydown keypress keyup", function() {
|
|
var elem = $(this);
|
|
if (elem.val().length > elem.attr("maxlength")) {
|
|
elem.val(elem.val().substr(0, elem.attr("maxlength")));
|
|
}
|
|
});
|
|
}
|
|
|
|
function submitPopup(overlay) {
|
|
const form = document.querySelector('#massupdate-form');
|
|
const action = form.querySelector('#action').value;
|
|
const location_url = form.querySelector('#location_url').value;
|
|
let macros_removeall_warning = (form.querySelector('#visible_macros:checked')
|
|
&& form.querySelector('[name="mass_update_macros"][value="<?= ZBX_ACTION_REMOVE_ALL ?>"]:checked')
|
|
&& (form.querySelector('#macros_remove_all').checked === false)
|
|
);
|
|
let valuemaps_removeall_warning = (form.querySelector('#visible_valuemaps:checked')
|
|
&& form.querySelector('[name="valuemap_massupdate"][value="<?= ZBX_ACTION_REMOVE_ALL ?>"]:checked')
|
|
&& (form.querySelector('#valuemap_remove_all').checked === false)
|
|
);
|
|
let warning_message = '';
|
|
|
|
if (macros_removeall_warning) {
|
|
warning_message = <?= json_encode(_('Please confirm that you want to remove all macros.')) ?>;
|
|
}
|
|
else if (valuemaps_removeall_warning) {
|
|
warning_message = <?= json_encode(_('Please confirm that you want to remove all value mappings.')) ?>;
|
|
}
|
|
|
|
if (warning_message !== '') {
|
|
overlayDialogue({
|
|
'title': <?= json_encode(_('Warning')) ?>,
|
|
'type': 'popup',
|
|
'class': 'position-middle',
|
|
'content': $('<span>').text(warning_message),
|
|
'buttons': [
|
|
{
|
|
'title': <?= json_encode(_('Ok')) ?>,
|
|
'focused': true,
|
|
'action': () => {}
|
|
}
|
|
]
|
|
}, overlay);
|
|
|
|
overlay.unsetLoading();
|
|
return false;
|
|
}
|
|
|
|
if (form.querySelector('#visible_valuemaps:checked')) {
|
|
$(form).trimValues(['[name^="valuemap_rename["]']);
|
|
}
|
|
|
|
if (form.querySelector('#visible_tags:checked')) {
|
|
$(form).trimValues(['[name^="tags"][name$="[tag]"]', '[name^="tags"][name$="[value]"]']);
|
|
}
|
|
|
|
if (action == 'popup.massupdate.host') {
|
|
// Depending on checkboxes, create a value for hidden field 'tls_accept'.
|
|
let tls_accept = 0x00;
|
|
|
|
if (form.querySelector('#tls_in_none') && form.querySelector('#tls_in_none').checked) {
|
|
tls_accept |= <?= HOST_ENCRYPTION_NONE ?>;
|
|
}
|
|
if (form.querySelector('#tls_in_psk') && form.querySelector('#tls_in_psk').checked) {
|
|
tls_accept |= <?= HOST_ENCRYPTION_PSK ?>;
|
|
}
|
|
if (form.querySelector('#tls_in_cert') && form.querySelector('#tls_in_cert').checked) {
|
|
tls_accept |= <?= HOST_ENCRYPTION_CERTIFICATE ?>;
|
|
}
|
|
|
|
form.querySelector('#tls_accept').value = tls_accept;
|
|
}
|
|
|
|
// Remove error message.
|
|
overlay.$dialogue.find('.<?= ZBX_STYLE_MSG_BAD ?>').remove();
|
|
|
|
const url = new Curl('zabbix.php');
|
|
url.setArgument('action', action);
|
|
url.setArgument('output', 'ajax');
|
|
|
|
fetch(url.getUrl(), {
|
|
method: 'post',
|
|
headers: {'Content-Type': 'application/x-www-form-urlencoded;charset=UTF-8'},
|
|
body: $(form).serialize()
|
|
})
|
|
.then((response) => response.json())
|
|
.then((response) => {
|
|
if ('script_inline' in response) {
|
|
$('head').append(response.script_inline);
|
|
}
|
|
|
|
if ('error' in response) {
|
|
overlay.unsetLoading();
|
|
|
|
const message_box = makeMessageBox('bad', response.error.messages, response.error.title);
|
|
|
|
message_box.insertBefore(form);
|
|
}
|
|
else {
|
|
postMessageOk(response.title);
|
|
|
|
if ('messages' in response) {
|
|
postMessageDetails('success', response.messages);
|
|
}
|
|
|
|
overlayDialogueDestroy(overlay.dialogueid);
|
|
location.href = location_url;
|
|
}
|
|
});
|
|
}
|