OXIESEC PANEL
- Current Dir:
/
/
lib
/
python3.9
/
site-packages
/
rhn
Server IP: 2a02:4780:11:1594:0:ef5:22d7:a
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
10/22/2025 07:58:12 AM
rwxr-xr-x
📄
SSL.py
10.79 KB
12/07/2022 01:15:22 PM
rw-r--r--
📄
SmartIO.py
2.11 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
UserDictCase.py
2.96 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
__init__.py
132 bytes
02/19/2018 08:18:29 AM
rw-r--r--
📁
__pycache__
-
05/14/2024 12:06:29 PM
rwxr-xr-x
📁
actions
-
04/05/2025 03:57:15 AM
rwxr-xr-x
📄
connections.py
9.48 KB
12/07/2022 01:15:22 PM
rw-r--r--
📄
i18n.py
1.73 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
nonblocking.py
2.37 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
rhnLockfile.py
3.35 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
rpclib.py
23.68 KB
12/07/2022 01:15:24 PM
rw-r--r--
📄
tb.py
836 bytes
02/19/2018 08:18:29 AM
rw-r--r--
📄
transports.py
31.18 KB
12/07/2022 01:15:24 PM
rw-r--r--
Editing: UserDictCase.py
Close
# # Copyright (c) 2001--2016 Red Hat, Inc. # # This software is licensed to you under the GNU General Public License, # version 2 (GPLv2). There is NO WARRANTY for this software, express or # implied, including the implied warranties of MERCHANTABILITY or FITNESS # FOR A PARTICULAR PURPOSE. You should have received a copy of GPLv2 # along with this software; if not, see # http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt. # # Red Hat trademarks are not licensed under GPLv2. No permission is # granted to use or replicate Red Hat trademarks that are incorporated # in this software or its documentation. # # # This file implements a case insensitive dictionary on top of the # UserDict standard python class # try: # python2 from UserDict import UserDict from types import StringType except ImportError: # python3 from collections import UserDict StringType = bytes from functools import reduce # A dictionary with case insensitive keys class UserDictCase(UserDict): def __init__(self, data = None): self.kcase = {} UserDict.__init__(self, data) def __lower_string(self, key): """ Return the lower() of key if it is a string. """ if isinstance(key, StringType): return key.lower() else: return key # some methods used to make the class work as a dictionary def __setitem__(self, key, value): lkey = self.__lower_string(key) self.data[lkey] = value self.kcase[lkey] = key def __getitem__(self, key): key = self.__lower_string(key) return self.data[key] get = __getitem__ def __delitem__(self, key): key = self.__lower_string(key) del self.data[key] del self.kcase[key] def __contains__(self, key): key = self.__lower_string(key) return key in self.data def keys(self): return self.kcase.values() def items(self): return self.get_hash().items() def has_key(self, key): # obsoleted, left for compatibility with older python return key in self def clear(self): self.data.clear() self.kcase.clear() # return this data as a real hash def get_hash(self): return reduce(lambda a, t, hc=self.kcase: a.update({ hc[t[0]] : t[1]}) or a, self.data.items(), {}) # return the data for marshalling def __getstate__(self): return self.get_hash() # we need a setstate because of the __getstate__ presence screws up deepcopy def __setstate__(self, state): self.__init__(state) # get a dictionary out of this instance ({}.update doesn't get instances) def dict(self): return self.get_hash() def update(self, dict): for (k, v) in dict.items(): self[k] = v # Expose an iterator. This would normally fail if there is no iter() # function defined - but __iter__ will never be called on python 1.5.2 def __iter__(self): return iter(self.data)