Linux server.edchosting.com 4.18.0-553.79.1.lve.el7h.x86_64 #1 SMP Wed Oct 15 16:34:46 UTC 2025 x86_64
LiteSpeed
Server IP : 75.98.162.185 & Your IP : 216.73.216.163
Domains :
Cant Read [ /etc/named.conf ]
User : goons4good
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
lib /
python2.7 /
site-packages /
ipalib /
Delete
Unzip
Name
Size
Permission
Date
Action
install
[ DIR ]
drwxr-xr-x
2023-06-15 03:41
__init__.py
34.04
KB
-rw-r--r--
2020-04-02 03:45
__init__.pyc
33.6
KB
-rw-r--r--
2023-06-13 03:24
__init__.pyo
33.55
KB
-rw-r--r--
2023-06-13 03:24
aci.py
10.07
KB
-rw-r--r--
2020-04-02 03:45
aci.pyc
9.01
KB
-rw-r--r--
2023-06-13 03:24
aci.pyo
8.91
KB
-rw-r--r--
2023-06-13 03:24
backend.py
4.65
KB
-rw-r--r--
2020-04-02 03:45
backend.pyc
5.19
KB
-rw-r--r--
2023-06-13 03:24
backend.pyo
5.14
KB
-rw-r--r--
2023-06-13 03:24
base.py
15.78
KB
-rw-r--r--
2020-04-02 03:45
base.pyc
16.78
KB
-rw-r--r--
2023-06-13 03:24
base.pyo
16.37
KB
-rw-r--r--
2023-06-13 03:24
capabilities.py
2.35
KB
-rw-r--r--
2020-04-02 03:45
capabilities.pyc
1.2
KB
-rw-r--r--
2023-06-13 03:24
capabilities.pyo
1.2
KB
-rw-r--r--
2023-06-13 03:24
cli.py
49.37
KB
-rw-r--r--
2020-04-02 03:45
cli.pyc
47.63
KB
-rw-r--r--
2023-06-13 03:24
cli.pyo
47.11
KB
-rw-r--r--
2023-06-13 03:24
config.py
24.04
KB
-rw-r--r--
2020-04-02 03:45
config.pyc
21.55
KB
-rw-r--r--
2023-06-13 03:24
config.pyo
21.5
KB
-rw-r--r--
2023-06-13 03:24
constants.py
13.38
KB
-rw-r--r--
2020-04-02 03:45
constants.pyc
9.28
KB
-rw-r--r--
2023-06-13 03:24
constants.pyo
9.28
KB
-rw-r--r--
2023-06-13 03:24
crud.py
12.29
KB
-rw-r--r--
2020-04-02 03:45
crud.pyc
12.39
KB
-rw-r--r--
2023-06-13 03:24
crud.pyo
12.39
KB
-rw-r--r--
2023-06-13 03:24
dns.py
3.47
KB
-rw-r--r--
2020-04-02 03:45
dns.pyc
3.37
KB
-rw-r--r--
2023-06-13 03:24
dns.pyo
3.37
KB
-rw-r--r--
2023-06-13 03:24
errors.py
48.82
KB
-rw-r--r--
2023-06-13 03:19
errors.pyc
67.76
KB
-rw-r--r--
2023-06-13 03:24
errors.pyo
67.63
KB
-rw-r--r--
2023-06-13 03:24
frontend.py
51.64
KB
-rw-r--r--
2020-04-02 03:45
frontend.pyc
51.96
KB
-rw-r--r--
2023-06-13 03:24
frontend.pyo
51.7
KB
-rw-r--r--
2023-06-13 03:24
krb_utils.py
6.17
KB
-rw-r--r--
2020-04-02 03:45
krb_utils.pyc
5.85
KB
-rw-r--r--
2023-06-13 03:24
krb_utils.pyo
5.85
KB
-rw-r--r--
2023-06-13 03:24
messages.py
14.38
KB
-rw-r--r--
2020-04-02 03:45
messages.pyc
18.85
KB
-rw-r--r--
2023-06-13 03:24
messages.pyo
18.74
KB
-rw-r--r--
2023-06-13 03:24
misc.py
3.51
KB
-rw-r--r--
2020-04-02 03:45
misc.pyc
3.66
KB
-rw-r--r--
2023-06-13 03:24
misc.pyo
3.66
KB
-rw-r--r--
2023-06-13 03:24
output.py
7.06
KB
-rw-r--r--
2020-04-02 03:45
output.pyc
6.74
KB
-rw-r--r--
2023-06-13 03:24
output.pyo
6.7
KB
-rw-r--r--
2023-06-13 03:24
parameters.py
72.42
KB
-rw-r--r--
2020-04-02 03:45
parameters.pyc
73.99
KB
-rw-r--r--
2023-06-13 03:24
parameters.pyo
73.12
KB
-rw-r--r--
2023-06-13 03:24
pkcs10.py
219
B
-rw-r--r--
2020-04-02 03:45
pkcs10.pyc
408
B
-rw-r--r--
2023-06-13 03:24
pkcs10.pyo
408
B
-rw-r--r--
2023-06-13 03:24
plugable.py
26.03
KB
-rw-r--r--
2023-06-13 03:19
plugable.pyc
26.96
KB
-rw-r--r--
2023-06-13 03:24
plugable.pyo
26.76
KB
-rw-r--r--
2023-06-13 03:24
request.py
2.13
KB
-rw-r--r--
2020-04-02 03:45
request.pyc
1.96
KB
-rw-r--r--
2023-06-13 03:24
request.pyo
1.96
KB
-rw-r--r--
2023-06-13 03:24
rpc.py
46.48
KB
-rw-r--r--
2020-04-02 03:45
rpc.pyc
40.12
KB
-rw-r--r--
2023-06-13 03:24
rpc.pyo
39.89
KB
-rw-r--r--
2023-06-13 03:24
text.py
18.55
KB
-rw-r--r--
2020-04-02 03:45
text.pyc
21.18
KB
-rw-r--r--
2023-06-13 03:24
text.pyo
21.14
KB
-rw-r--r--
2023-06-13 03:24
util.py
39.57
KB
-rw-r--r--
2020-04-02 03:45
util.pyc
41.25
KB
-rw-r--r--
2023-06-13 03:24
util.pyo
41.08
KB
-rw-r--r--
2023-06-13 03:24
x509.py
20.57
KB
-rw-r--r--
2020-04-02 03:45
x509.pyc
25.51
KB
-rw-r--r--
2023-06-13 03:24
x509.pyo
25.51
KB
-rw-r--r--
2023-06-13 03:24
Save
Rename
# Authors: # Rob Crittenden <rcritten@redhat.com> # # Copyright (C) 2008 Red Hat # see file 'COPYING' for use and warranty information # # 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 <http://www.gnu.org/licenses/>. import shlex import re import six # The Python re module doesn't do nested parenthesis # Break the ACI into 3 pieces: target, name, permissions/bind_rules ACIPat = re.compile(r'\(version\s+3.0\s*;\s*ac[li]\s+\"([^\"]*)\"\s*;\s*([^;]*);\s*\)', re.UNICODE) # Break the permissions/bind_rules out PermPat = re.compile(r'(\w+)\s*\(([^()]*)\)\s*(.*)', re.UNICODE) # Break the bind rule out BindPat = re.compile(r'\(?([a-zA-Z0-9;\.]+)\s*(\!?=)\s*\"(.*)\"\)?', re.UNICODE) ACTIONS = ["allow", "deny"] PERMISSIONS = ["read", "write", "add", "delete", "search", "compare", "selfwrite", "proxy", "all"] class ACI(object): """ Holds the basic data for an ACI entry, as stored in the cn=accounts entry in LDAP. Has methods to parse an ACI string and export to an ACI String. """ __hash__ = None def __init__(self,acistr=None): self.name = None self.source_group = None self.dest_group = None self.orig_acistr = acistr self.target = {} self.action = "allow" self.permissions = ["write"] self.bindrule = {} if acistr is not None: self._parse_acistr(acistr) def __getitem__(self,key): """Fake getting attributes by key for sorting""" if key == 0: return self.name if key == 1: return self.source_group if key == 2: return self.dest_group raise TypeError("Unknown key value %s" % key) def __repr__(self): """An alias for export_to_string()""" return self.export_to_string() def export_to_string(self): """Output a Directory Server-compatible ACI string""" self.validate() aci = "" for t, v in sorted(self.target.items()): op = v['operator'] if type(v['expression']) in (tuple, list): target = "" for l in v['expression']: target = target + l + " || " target = target[:-4] aci = aci + "(%s %s \"%s\")" % (t, op, target) else: aci = aci + "(%s %s \"%s\")" % (t, op, v['expression']) aci = aci + "(version 3.0;acl \"%s\";%s (%s) %s %s \"%s\"" % (self.name, self.action, ",".join(self.permissions), self.bindrule['keyword'], self.bindrule['operator'], self.bindrule['expression']) + ";)" return aci def _remove_quotes(self, s): # Remove leading and trailing quotes if s.startswith('"'): s = s[1:] if s.endswith('"'): s = s[:-1] return s def _parse_target(self, aci): if six.PY2: aci = aci.encode('utf-8') lexer = shlex.shlex(aci) lexer.wordchars = lexer.wordchars + "." var = False op = "=" for token in lexer: # We should have the form (a = b)(a = b)... if token == "(": var = next(lexer).strip() operator = next(lexer) if operator not in ("=", "!="): # Peek at the next char before giving up operator = operator + next(lexer) if operator not in ("=", "!="): raise SyntaxError("No operator in target, got '%s'" % operator) op = operator val = next(lexer).strip() val = self._remove_quotes(val) end = next(lexer) if end != ")": raise SyntaxError('No end parenthesis in target, got %s' % end) if var == 'targetattr': # Make a string of the form attr || attr || ... into a list t = re.split('[^a-zA-Z0-9;\*]+', val) self.target[var] = {} self.target[var]['operator'] = op self.target[var]['expression'] = t else: self.target[var] = {} self.target[var]['operator'] = op self.target[var]['expression'] = val def _parse_acistr(self, acistr): vstart = acistr.find('version 3.0') if vstart < 0: raise SyntaxError("malformed ACI, unable to find version %s" % acistr) acimatch = ACIPat.match(acistr[vstart-1:]) if not acimatch or len(acimatch.groups()) < 2: raise SyntaxError("malformed ACI, match for version and bind rule failed %s" % acistr) self._parse_target(acistr[:vstart-1]) self.name = acimatch.group(1) bindperms = PermPat.match(acimatch.group(2)) if not bindperms or len(bindperms.groups()) < 3: raise SyntaxError("malformed ACI, permissions match failed %s" % acistr) self.action = bindperms.group(1) self.permissions = bindperms.group(2).replace(' ','').split(',') self.set_bindrule(bindperms.group(3)) def validate(self): """Do some basic verification that this will produce a valid LDAP ACI. returns True if valid """ if type(self.permissions) not in (tuple, list): raise SyntaxError("permissions must be a list") for p in self.permissions: if p.lower() not in PERMISSIONS: raise SyntaxError("invalid permission: '%s'" % p) if not self.name: raise SyntaxError("name must be set") if not isinstance(self.name, six.string_types): raise SyntaxError("name must be a string") if not isinstance(self.target, dict) or len(self.target) == 0: raise SyntaxError("target must be a non-empty dictionary") if not isinstance(self.bindrule, dict): raise SyntaxError("bindrule must be a dictionary") if not self.bindrule.get('operator') or not self.bindrule.get('keyword') or not self.bindrule.get('expression'): raise SyntaxError("bindrule is missing a component") return True def set_target_filter(self, filter, operator="="): self.target['targetfilter'] = {} if not filter.startswith("("): filter = "(" + filter + ")" self.target['targetfilter']['expression'] = filter self.target['targetfilter']['operator'] = operator def set_target_attr(self, attr, operator="="): if not attr: if 'targetattr' in self.target: del self.target['targetattr'] return if type(attr) not in (tuple, list): attr = [attr] self.target['targetattr'] = {} self.target['targetattr']['expression'] = attr self.target['targetattr']['operator'] = operator def set_target(self, target, operator="="): assert target.startswith("ldap:///") self.target['target'] = {} self.target['target']['expression'] = target self.target['target']['operator'] = operator def set_bindrule(self, bindrule): if bindrule.startswith('(') != bindrule.endswith(')'): raise SyntaxError("non-matching parentheses in bindrule") match = BindPat.match(bindrule) if not match or len(match.groups()) < 3: raise SyntaxError("malformed bind rule") self.set_bindrule_keyword(match.group(1)) self.set_bindrule_operator(match.group(2)) self.set_bindrule_expression(match.group(3).replace('"','')) def set_bindrule_keyword(self, keyword): self.bindrule['keyword'] = keyword def set_bindrule_operator(self, operator): self.bindrule['operator'] = operator def set_bindrule_expression(self, expression): self.bindrule['expression'] = expression def isequal(self, b): """ Compare the current ACI to another one to see if they are the same. returns True if equal, False if not. """ assert isinstance(b, ACI) try: if self.name.lower() != b.name.lower(): return False if set(self.permissions) != set(b.permissions): return False if self.bindrule.get('keyword') != b.bindrule.get('keyword'): return False if self.bindrule.get('operator') != b.bindrule.get('operator'): return False if self.bindrule.get('expression') != b.bindrule.get('expression'): return False if self.target.get('targetfilter',{}).get('expression') != b.target.get('targetfilter',{}).get('expression'): return False if self.target.get('targetfilter',{}).get('operator') != b.target.get('targetfilter',{}).get('operator'): return False if set(self.target.get('targetattr', {}).get('expression', ())) != set(b.target.get('targetattr',{}).get('expression', ())): return False if self.target.get('targetattr',{}).get('operator') != b.target.get('targetattr',{}).get('operator'): return False if self.target.get('target',{}).get('expression') != b.target.get('target',{}).get('expression'): return False if self.target.get('target',{}).get('operator') != b.target.get('target',{}).get('operator'): return False except Exception: # If anything throws up then they are not equal return False # We got this far so lets declare them the same return True __eq__ = isequal def __ne__(self, b): return not self == b