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
						
					
					
				| <?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>
 |