[ SYSTEM ]: Linux srv.persadacompanies.com 4.18.0-553.56.1.el8_10.x86_64 #1 SMP Tue Jun 10 05:00:59 EDT 2025 x86_64
[ SERVER ]: Apache | PHP: 8.4.19
[ USER ]: persadamedika | IP: 45.64.1.108
GEFORCE FILE MANAGER
/
usr
/
lib64
/
python3.6
/
site-packages
/
setools
/
diff
/
UPLOAD:
NAME
SIZE
QUICK PERMS
ACTIONS
📁 __pycache__
SET
[ DEL ]
📄 __init__.py
3,222 B
SET
[ EDIT ]
|
[ DEL ]
📄 bool.py
2,898 B
SET
[ EDIT ]
|
[ DEL ]
📄 bounds.py
4,200 B
SET
[ EDIT ]
|
[ DEL ]
📄 commons.py
2,883 B
SET
[ EDIT ]
|
[ DEL ]
📄 conditional.py
1,717 B
SET
[ EDIT ]
|
[ DEL ]
📄 constraints.py
8,843 B
SET
[ EDIT ]
|
[ DEL ]
📄 context.py
1,934 B
SET
[ EDIT ]
|
[ DEL ]
📄 default.py
4,240 B
SET
[ EDIT ]
|
[ DEL ]
📄 descriptors.py
1,637 B
SET
[ EDIT ]
|
[ DEL ]
📄 difference.py
5,796 B
SET
[ EDIT ]
|
[ DEL ]
📄 fsuse.py
3,184 B
SET
[ EDIT ]
|
[ DEL ]
📄 genfscon.py
3,328 B
SET
[ EDIT ]
|
[ DEL ]
📄 ibendportcon.py
3,361 B
SET
[ EDIT ]
|
[ DEL ]
📄 ibpkeycon.py
3,367 B
SET
[ EDIT ]
|
[ DEL ]
📄 initsid.py
2,543 B
SET
[ EDIT ]
|
[ DEL ]
📄 mls.py
10,562 B
SET
[ EDIT ]
|
[ DEL ]
📄 mlsrules.py
4,916 B
SET
[ EDIT ]
|
[ DEL ]
📄 netifcon.py
3,798 B
SET
[ EDIT ]
|
[ DEL ]
📄 nodecon.py
3,289 B
SET
[ EDIT ]
|
[ DEL ]
📄 objclass.py
3,690 B
SET
[ EDIT ]
|
[ DEL ]
📄 polcap.py
1,742 B
SET
[ EDIT ]
|
[ DEL ]
📄 portcon.py
3,269 B
SET
[ EDIT ]
|
[ DEL ]
📄 properties.py
2,389 B
SET
[ EDIT ]
|
[ DEL ]
📄 rbacrules.py
6,579 B
SET
[ EDIT ]
|
[ DEL ]
📄 roles.py
3,275 B
SET
[ EDIT ]
|
[ DEL ]
📄 terules.py
24,282 B
SET
[ EDIT ]
|
[ DEL ]
📄 typeattr.py
3,354 B
SET
[ EDIT ]
|
[ DEL ]
📄 types.py
4,975 B
SET
[ EDIT ]
|
[ DEL ]
📄 users.py
5,532 B
SET
[ EDIT ]
|
[ DEL ]
DELETE SELECTED
[ CLOSE ]
EDIT: users.py
# Copyright 2016, Tresys Technology, LLC # Copyright 2018, Chris PeBenito <pebenito@ieee.org> # # This file is part of SETools. # # SETools is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as # published by the Free Software Foundation, either version 2.1 of # the License, or (at your option) any later version. # # SETools 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 Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with SETools. If not, see # <http://www.gnu.org/licenses/>. # from collections import defaultdict, namedtuple from ..exception import MLSDisabled from .descriptors import DiffResultDescriptor from .difference import Difference, SymbolWrapper from .mls import LevelWrapper, RangeWrapper from .roles import role_wrapper_factory modified_users_record = namedtuple("modified_user", ["added_roles", "removed_roles", "matched_roles", "added_level", "removed_level", "added_range", "removed_range"]) _users_cache = defaultdict(dict) def user_wrapper_factory(user): """ Wrap users from the specified policy. This caches results to prevent duplicate wrapper objects in memory. """ try: return _users_cache[user.policy][user] except KeyError: r = SymbolWrapper(user) _users_cache[user.policy][user] = r return r class UsersDifference(Difference): """Determine the difference in users between two policies.""" added_users = DiffResultDescriptor("diff_users") removed_users = DiffResultDescriptor("diff_users") modified_users = DiffResultDescriptor("diff_users") def diff_users(self): """Generate the difference in users between the policies.""" self.log.info( "Generating user differences from {0.left_policy} to {0.right_policy}".format(self)) self.added_users, self.removed_users, matched_users = self._set_diff( (user_wrapper_factory(r) for r in self.left_policy.users()), (user_wrapper_factory(r) for r in self.right_policy.users())) self.modified_users = dict() for left_user, right_user in matched_users: # Criteria for modified users # 1. change to role set, or # 2. change to default level, or # 3. change to range added_roles, removed_roles, matched_roles = self._set_diff( (role_wrapper_factory(r) for r in left_user.roles), (role_wrapper_factory(r) for r in right_user.roles)) # keep wrapped and unwrapped MLS objects here so there # are not several nested try blocks try: left_level_wrap = LevelWrapper(left_user.mls_level) left_range_wrap = RangeWrapper(left_user.mls_range) left_level = left_user.mls_level left_range = left_user.mls_range except MLSDisabled: left_level_wrap = None left_range_wrap = None left_level = "None (MLS Disabled)" left_range = "None (MLS Disabled)" try: right_level_wrap = LevelWrapper(right_user.mls_level) right_range_wrap = RangeWrapper(right_user.mls_range) right_level = right_user.mls_level right_range = right_user.mls_range except MLSDisabled: right_level_wrap = None right_range_wrap = None right_level = "None (MLS Disabled)" right_range = "None (MLS Disabled)" if left_level_wrap != right_level_wrap: added_level = right_level removed_level = left_level else: added_level = None removed_level = None if left_range_wrap != right_range_wrap: added_range = right_range removed_range = left_range else: added_range = None removed_range = None if added_roles or removed_roles or removed_level or removed_range: self.modified_users[left_user] = modified_users_record(added_roles, removed_roles, matched_roles, added_level, removed_level, added_range, removed_range) # # Internal functions # def _reset_diff(self): """Reset diff results on policy changes.""" self.log.debug("Resetting user differences") self.added_users = None self.removed_users = None self.modified_users = None