mirror of
https://github.com/valitydev/wazuh-kibana-app.git
synced 2024-11-06 18:05:20 +00:00
212 lines
8.1 KiB
JavaScript
212 lines
8.1 KiB
JavaScript
let app = require('ui/modules').get('app/wazuh', []);
|
|
|
|
app.controller('rulesController', function ($scope, $rootScope, Rules,RulesAutoComplete, errorHandler) {
|
|
$scope.setRulesTab = tab => $rootScope.globalsubmenuNavItem2 = tab;
|
|
|
|
//Initialization
|
|
$scope.loading = true;
|
|
$scope.rules = Rules;
|
|
$scope.rulesAutoComplete = RulesAutoComplete;
|
|
$scope.setRulesTab('rules');
|
|
$rootScope.tabVisualizations = { ruleset: 4 };
|
|
$scope.analizeRules = async search => {
|
|
try {
|
|
$scope.rulesAutoComplete.filters = [];
|
|
|
|
if(search.startsWith('group:') && search.split('group:')[1].trim()) {
|
|
await $scope.rulesAutoComplete.addFilter('group',search.split('group:')[1].trim());
|
|
} else if(search.startsWith('level:') && search.split('level:')[1].trim()) {
|
|
await $scope.rulesAutoComplete.addFilter('level',search.split('level:')[1].trim());
|
|
} else if(search.startsWith('pci:') && search.split('pci:')[1].trim()) {
|
|
await $scope.rulesAutoComplete.addFilter('pci',search.split('pci:')[1].trim());
|
|
} else if(search.startsWith('file:') && search.split('file:')[1].trim()) {
|
|
await $scope.rulesAutoComplete.addFilter('file',search.split('file:')[1].trim());
|
|
} else {
|
|
await $scope.rulesAutoComplete.addFilter('search',search);
|
|
}
|
|
|
|
if(!$scope.$$phase) $scope.$digest();
|
|
return $scope.rulesAutoComplete.items;
|
|
} catch (error){
|
|
errorHandler.handle(error,'Ruleset');
|
|
if(!$rootScope.$$phase) $rootScope.$digest();
|
|
}
|
|
}
|
|
|
|
$scope.checkEnter = search => {
|
|
$scope.searchTerm = '';
|
|
angular.element(document.querySelector('#autocomplete')).blur();
|
|
if(search.startsWith('group:') && search.split('group:')[1].trim()) {
|
|
$scope.rules.addFilter('group',search.split('group:')[1].trim());
|
|
} else if(search.startsWith('level:') && search.split('level:')[1].trim()) {
|
|
$scope.rules.addFilter('level',search.split('level:')[1].trim());
|
|
} else if(search.startsWith('pci:') && search.split('pci:')[1].trim()) {
|
|
$scope.rules.addFilter('pci',search.split('pci:')[1].trim());
|
|
} else if(search.startsWith('file:') && search.split('file:')[1].trim()) {
|
|
$scope.rules.addFilter('file',search.split('file:')[1].trim());
|
|
} else {
|
|
$scope.rules.addFilter('search',search.trim());
|
|
}
|
|
};
|
|
|
|
|
|
const load = async () => {
|
|
try {
|
|
await Promise.all([
|
|
$scope.rules.nextPage(),
|
|
$scope.rulesAutoComplete.nextPage()
|
|
]);
|
|
$scope.loading = false;
|
|
if(!$scope.$$phase) $scope.$digest();
|
|
return;
|
|
} catch (error) {
|
|
errorHandler.handle('Unexpected exception loading controller','Ruleset');
|
|
if(!$rootScope.$$phase) $rootScope.$digest();
|
|
}
|
|
}
|
|
|
|
//Load
|
|
load();
|
|
|
|
let timesOpened = 0;
|
|
let lastName = false;
|
|
$scope.closeOther = rule => {
|
|
const item = rule.id ? rule.id : rule;
|
|
if(item !== lastName){
|
|
lastName = item;
|
|
timesOpened = 0;
|
|
}
|
|
timesOpened++;
|
|
$scope.activeItem = (timesOpened <= 1) ? item : false;
|
|
if(timesOpened > 1) timesOpened = 0;
|
|
return true;
|
|
}
|
|
|
|
//Destroy
|
|
$scope.$on('$destroy', () => {
|
|
$scope.rules.reset();
|
|
if($rootScope.ownHandlers){
|
|
for(let h of $rootScope.ownHandlers){
|
|
h._scope.$destroy();
|
|
}
|
|
}
|
|
$rootScope.ownHandlers = [];
|
|
});
|
|
});
|
|
|
|
app.controller('decodersController', function ($scope, $rootScope, $sce, Decoders,DecodersAutoComplete, errorHandler) {
|
|
$scope.setRulesTab = tab => $rootScope.globalsubmenuNavItem2 = tab;
|
|
|
|
//Initialization
|
|
$scope.loading = true;
|
|
$scope.decoders = Decoders;
|
|
$scope.decodersAutoComplete = DecodersAutoComplete;
|
|
$scope.typeFilter = "all";
|
|
$scope.setRulesTab('decoders');
|
|
$rootScope.tabVisualizations = { ruleset: 1 };
|
|
const colors = [
|
|
'#3F6833', '#967302', '#2F575E', '#99440A', '#58140C', '#052B51', '#511749', '#3F2B5B', //6
|
|
'#508642', '#CCA300', '#447EBC', '#C15C17', '#890F02', '#0A437C', '#6D1F62', '#584477', //2
|
|
'#629E51', '#E5AC0E', '#64B0C8', '#E0752D', '#BF1B00', '#0A50A1', '#962D82', '#614D93', //4
|
|
'#7EB26D', '#EAB839', '#6ED0E0', '#EF843C', '#E24D42', '#1F78C1', '#BA43A9', '#705DA0', // Normal
|
|
'#9AC48A', '#F2C96D', '#65C5DB', '#F9934E', '#EA6460', '#5195CE', '#D683CE', '#806EB7', //5
|
|
'#B7DBAB', '#F4D598', '#70DBED', '#F9BA8F', '#F29191', '#82B5D8', '#E5A8E2', '#AEA2E0', //3
|
|
'#E0F9D7', '#FCEACA', '#CFFAFF', '#F9E2D2', '#FCE2DE', '#BADFF4', '#F9D9F9', '#DEDAF7' //7
|
|
];
|
|
|
|
|
|
let timesOpened = 0;
|
|
let lastName = false;
|
|
$scope.closeOther = name => {
|
|
if(name !== lastName){
|
|
lastName = name;
|
|
timesOpened = 0;
|
|
}
|
|
timesOpened++;
|
|
$scope.activeItem = (timesOpened <= 1) ? name : false;
|
|
if(timesOpened > 1) timesOpened = 0;
|
|
return true;
|
|
}
|
|
|
|
$scope.colorRegex = regex => {
|
|
regex = regex.toString();
|
|
let valuesArray = regex.match(/\(((?!<\/span>).)*?\)(?!<\/span>)/gmi);
|
|
let coloredString = regex;
|
|
for (let i = 0, len = valuesArray.length; i < len; i++) {
|
|
coloredString = coloredString.replace(/\(((?!<\/span>).)*?\)(?!<\/span>)/mi, '<span style="color: ' + colors[i] + ' ">' + valuesArray[i] + '</span>');
|
|
}
|
|
return $sce.trustAsHtml(coloredString);
|
|
};
|
|
|
|
$scope.colorOrder = order => {
|
|
order = order.toString();
|
|
let valuesArray = order.split(',');
|
|
let coloredString = order;
|
|
for (let i = 0, len = valuesArray.length; i < len; i++) {
|
|
coloredString = coloredString.replace(valuesArray[i], '<span style="color: ' + colors[i] + ' ">' + valuesArray[i] + '</span>');
|
|
}
|
|
return $sce.trustAsHtml(coloredString);
|
|
};
|
|
|
|
|
|
$scope.checkEnter = search => {
|
|
$scope.searchTerm = '';
|
|
angular.element(document.querySelector('#autocomplete')).blur();
|
|
if(search.startsWith('path:') && search.split('path:')[1].trim()) {
|
|
$scope.decoders.addFilter('path',search.split('path:')[1].trim());
|
|
} else if(search.startsWith('file:') && search.split('file:')[1].trim()) {
|
|
$scope.decoders.addFilter('file',search.split('file:')[1].trim());
|
|
} else {
|
|
$scope.decoders.addFilter('search',search.trim());
|
|
}
|
|
};
|
|
|
|
$scope.analizeDecoders = async search => {
|
|
try {
|
|
$scope.decodersAutoComplete.filters = [];
|
|
|
|
if(search.startsWith('path:') && search.split('path:')[1].trim()) {
|
|
await $scope.decodersAutoComplete.addFilter('path',search.split('path:')[1].trim());
|
|
} else if(search.startsWith('file:') && search.split('file:')[1].trim()) {
|
|
await $scope.decodersAutoComplete.addFilter('file',search.split('file:')[1].trim());
|
|
} else {
|
|
await $scope.decodersAutoComplete.addFilter('search',search);
|
|
}
|
|
|
|
if(!$scope.$$phase) $scope.$digest();
|
|
return $scope.decodersAutoComplete.items;
|
|
} catch (error){
|
|
errorHandler.handle(error,'Ruleset');
|
|
if(!$rootScope.$$phase) $rootScope.$digest();
|
|
}
|
|
}
|
|
|
|
const load = async () => {
|
|
try {
|
|
await Promise.all([
|
|
$scope.decoders.nextPage(),
|
|
$scope.decodersAutoComplete.nextPage()
|
|
]);
|
|
$scope.loading = false;
|
|
if(!$scope.$$phase) $scope.$digest();
|
|
return;
|
|
} catch (error) {
|
|
errorHandler.handle('Unexpected exception loading controller','Ruleset');
|
|
if(!$rootScope.$$phase) $rootScope.$digest();
|
|
}
|
|
}
|
|
|
|
//Load
|
|
load();
|
|
|
|
//Destroy
|
|
$scope.$on("$destroy", () => {
|
|
$scope.decoders.reset();
|
|
if($rootScope.ownHandlers){
|
|
for(let h of $rootScope.ownHandlers){
|
|
h._scope.$destroy();
|
|
}
|
|
}
|
|
$rootScope.ownHandlers = [];
|
|
});
|
|
}); |