| Server IP : 213.136.93.164 / Your IP : 216.73.216.104 Web Server : Apache System : Linux m14200.contabo.net 5.14.0-611.54.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Wed May 6 18:03:03 EDT 2026 x86_64 User : ki692510 ( 1047) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /opt/imunify360/venv/lib/python3.11/site-packages/imav/simple_rpc/ |
Upload File : |
"""
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 3 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, see <https://www.gnu.org/licenses/>.
Copyright © 2019 Cloud Linux Software Inc.
This software is also available under ImunifyAV commercial license,
see <https://www.imunify360.com/legal/eula>
"""
from imav.rpc_tools.middleware import add_malicious_count
from defence360agent.contracts.config import UserType
from defence360agent.rpc_tools.middleware import max_count
from defence360agent.simple_rpc.schema import (
init_validator as init_base_validator,
)
def init_validator(schema_validator, validate_middleware, schema_paths):
imav_middleware = {
("malware", "ignore", "list"): [
# need for backward compatibility
# convert result -> tuple (max_items, items) ->
# dict {max_items:<int>, items:[...]}
(max_count, (UserType.ROOT, UserType.NON_ROOT))
],
("malware", "malicious", "list"): [
(add_malicious_count, (UserType.ROOT, UserType.NON_ROOT)),
(max_count, (UserType.ROOT, UserType.NON_ROOT)),
],
("malware", "history", "list"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT))
],
("malware", "user", "list"): [
(add_malicious_count, (UserType.ROOT, UserType.NON_ROOT)),
(max_count, (UserType.ROOT, UserType.NON_ROOT)),
],
("malware", "suspicious", "list"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT))
],
("malware", "on-demand", "list"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT))
],
("malware", "on-demand", "list-user"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT))
],
("vulnerabilities", "file", "list"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT)),
],
("vulnerabilities", "user", "list"): [
(max_count, (UserType.ROOT, UserType.NON_ROOT)),
],
}
validator, middleware, middleware_exclude = init_base_validator(
schema_validator, validate_middleware, schema_paths
)
middleware.update(imav_middleware)
return validator, middleware, middleware_exclude