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
/
usr /
lib /
python3.6 /
site-packages /
salt /
utils /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
decorators
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
dockermod
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
openstack
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
pkg
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
validate
[ DIR ]
drwxr-xr-x
2022-10-11 05:09
__init__.py
237
B
-rw-r--r--
2022-05-16 09:16
aggregation.py
5.17
KB
-rw-r--r--
2022-05-16 09:16
args.py
19.86
KB
-rw-r--r--
2022-05-16 09:16
asynchronous.py
4.07
KB
-rw-r--r--
2022-05-16 09:16
atomicfile.py
5.33
KB
-rw-r--r--
2022-05-16 09:16
aws.py
19.38
KB
-rw-r--r--
2022-05-16 09:16
azurearm.py
11.38
KB
-rw-r--r--
2022-05-16 09:16
beacons.py
517
B
-rw-r--r--
2022-05-16 09:16
boto3_elasticsearch.py
3.73
KB
-rw-r--r--
2022-05-16 09:16
boto3mod.py
8.36
KB
-rw-r--r--
2022-05-16 09:16
boto_elb_tag.py
3.02
KB
-rw-r--r--
2022-05-16 09:16
botomod.py
7.98
KB
-rw-r--r--
2022-05-16 09:16
cache.py
9.81
KB
-rw-r--r--
2022-05-16 09:16
cloud.py
117.04
KB
-rw-r--r--
2022-05-16 09:16
color.py
2.72
KB
-rw-r--r--
2022-05-16 09:16
compat.py
1.81
KB
-rw-r--r--
2022-05-16 09:16
configcomparer.py
3.88
KB
-rw-r--r--
2022-05-16 09:16
configparser.py
10.82
KB
-rw-r--r--
2022-05-16 09:16
context.py
6.8
KB
-rw-r--r--
2022-05-16 09:16
crypt.py
4.71
KB
-rw-r--r--
2022-05-16 09:16
ctx.py
1.42
KB
-rw-r--r--
2022-05-16 09:16
data.py
49.28
KB
-rw-r--r--
2022-05-16 09:16
dateutils.py
2.31
KB
-rw-r--r--
2022-05-16 09:16
debug.py
4.19
KB
-rw-r--r--
2022-05-16 09:16
dictdiffer.py
14.16
KB
-rw-r--r--
2022-05-16 09:16
dicttrim.py
3.9
KB
-rw-r--r--
2022-05-16 09:16
dictupdate.py
11.33
KB
-rw-r--r--
2022-05-16 09:16
dns.py
35.17
KB
-rw-r--r--
2022-05-16 09:16
doc.py
2.25
KB
-rw-r--r--
2022-05-16 09:16
entrypoints.py
2.28
KB
-rw-r--r--
2022-05-16 09:16
environment.py
2.2
KB
-rw-r--r--
2022-05-16 09:16
error.py
1.18
KB
-rw-r--r--
2022-05-16 09:16
etcd_util.py
14.22
KB
-rw-r--r--
2022-05-16 09:16
event.py
52.3
KB
-rw-r--r--
2022-05-16 09:16
extend.py
8.87
KB
-rw-r--r--
2022-05-16 09:16
extmods.py
5.67
KB
-rw-r--r--
2022-05-16 09:16
filebuffer.py
3.15
KB
-rw-r--r--
2022-05-16 09:16
files.py
27.6
KB
-rw-r--r--
2022-05-16 09:16
find.py
22.09
KB
-rw-r--r--
2022-05-16 09:16
fsutils.py
3.29
KB
-rw-r--r--
2022-05-16 09:16
functools.py
5.02
KB
-rw-r--r--
2022-05-16 09:16
gitfs.py
124.49
KB
-rw-r--r--
2022-05-16 09:16
github.py
1.52
KB
-rw-r--r--
2022-05-16 09:16
gzip_util.py
2.86
KB
-rw-r--r--
2022-05-16 09:16
hashutils.py
5.91
KB
-rw-r--r--
2022-05-16 09:16
http.py
34.36
KB
-rw-r--r--
2022-05-16 09:16
iam.py
1.22
KB
-rw-r--r--
2022-05-16 09:16
icinga2.py
754
B
-rw-r--r--
2022-05-16 09:16
idem.py
1.22
KB
-rw-r--r--
2022-05-16 09:16
immutabletypes.py
2.46
KB
-rw-r--r--
2022-05-16 09:16
itertools.py
2.36
KB
-rw-r--r--
2022-05-16 09:16
jid.py
3
KB
-rw-r--r--
2022-05-16 09:16
jinja.py
31.54
KB
-rw-r--r--
2022-05-16 09:16
job.py
6.01
KB
-rw-r--r--
2022-05-16 09:16
json.py
3.78
KB
-rw-r--r--
2022-05-16 09:16
kickstart.py
41.04
KB
-rw-r--r--
2022-05-16 09:16
kinds.py
493
B
-rw-r--r--
2022-05-16 09:16
lazy.py
3.06
KB
-rw-r--r--
2022-05-16 09:16
listdiffer.py
10.9
KB
-rw-r--r--
2022-05-16 09:16
locales.py
2.06
KB
-rw-r--r--
2022-05-16 09:16
mac_utils.py
14.01
KB
-rw-r--r--
2022-05-16 09:16
mako.py
3.63
KB
-rw-r--r--
2022-05-16 09:16
master.py
29.57
KB
-rw-r--r--
2022-05-16 09:16
mattermost.py
1.77
KB
-rw-r--r--
2022-05-16 09:16
memcached.py
3.56
KB
-rw-r--r--
2022-05-16 09:16
migrations.py
1.46
KB
-rw-r--r--
2022-05-16 09:16
mine.py
3.68
KB
-rw-r--r--
2022-05-16 09:16
minion.py
4.13
KB
-rw-r--r--
2022-05-16 09:16
minions.py
43.4
KB
-rw-r--r--
2022-05-16 09:16
mount.py
1.15
KB
-rw-r--r--
2022-05-16 09:16
msazure.py
5.36
KB
-rw-r--r--
2022-05-16 09:16
msgpack.py
4.69
KB
-rw-r--r--
2022-05-16 09:16
nacl.py
13.58
KB
-rw-r--r--
2022-05-16 09:16
namecheap.py
4.32
KB
-rw-r--r--
2022-05-16 09:16
napalm.py
23.79
KB
-rw-r--r--
2022-05-16 09:16
nb_popen.py
7.24
KB
-rw-r--r--
2022-05-16 09:16
network.py
71.07
KB
-rw-r--r--
2022-05-16 09:16
nxos.py
12.94
KB
-rw-r--r--
2022-05-16 09:16
nxos_api.py
4
KB
-rw-r--r--
2022-05-16 09:16
odict.py
13.16
KB
-rw-r--r--
2022-05-16 09:16
oset.py
6.41
KB
-rw-r--r--
2022-05-16 09:16
pagerduty.py
3.03
KB
-rw-r--r--
2022-05-16 09:16
parsers.py
125.31
KB
-rw-r--r--
2022-05-16 09:16
path.py
10.78
KB
-rw-r--r--
2022-05-16 09:16
pbm.py
9.81
KB
-rw-r--r--
2022-05-16 09:16
platform.py
5.16
KB
-rw-r--r--
2022-05-16 09:16
powershell.py
4.15
KB
-rw-r--r--
2022-05-16 09:16
preseed.py
2.64
KB
-rw-r--r--
2022-05-16 09:16
process.py
43.34
KB
-rw-r--r--
2022-05-16 09:16
profile.py
3.21
KB
-rw-r--r--
2022-05-16 09:16
proxy.py
331
B
-rw-r--r--
2022-05-16 09:16
psutil_compat.py
3.65
KB
-rw-r--r--
2022-05-16 09:16
pushover.py
4.51
KB
-rw-r--r--
2022-05-16 09:16
pycrypto.py
5.39
KB
-rw-r--r--
2022-05-16 09:16
pydsl.py
13.74
KB
-rw-r--r--
2022-05-16 09:16
pyobjects.py
10.75
KB
-rw-r--r--
2022-05-16 09:16
reactor.py
19.09
KB
-rw-r--r--
2022-05-16 09:16
reclass.py
752
B
-rw-r--r--
2022-05-16 09:16
roster_matcher.py
3.55
KB
-rw-r--r--
2022-05-16 09:16
rsax931.py
8.07
KB
-rw-r--r--
2022-05-16 09:16
s3.py
8.78
KB
-rw-r--r--
2022-05-16 09:16
saltclass.py
14.27
KB
-rw-r--r--
2022-05-16 09:16
sanitizers.py
2.51
KB
-rw-r--r--
2022-05-16 09:16
schedule.py
70.67
KB
-rw-r--r--
2022-05-16 09:16
schema.py
54.26
KB
-rw-r--r--
2022-05-16 09:16
sdb.py
4.04
KB
-rw-r--r--
2022-05-16 09:16
slack.py
3.57
KB
-rw-r--r--
2022-05-16 09:16
smb.py
11.16
KB
-rw-r--r--
2022-05-16 09:16
smtp.py
3.27
KB
-rw-r--r--
2022-05-16 09:16
ssdp.py
14.75
KB
-rw-r--r--
2022-05-16 09:16
ssh.py
769
B
-rw-r--r--
2022-05-16 09:16
state.py
8.43
KB
-rw-r--r--
2022-05-16 09:16
stringio.py
355
B
-rw-r--r--
2022-05-16 09:16
stringutils.py
16.63
KB
-rw-r--r--
2022-05-16 09:16
systemd.py
5.51
KB
-rw-r--r--
2022-05-16 09:16
templates.py
23.92
KB
-rw-r--r--
2022-05-16 09:16
textformat.py
5.03
KB
-rw-r--r--
2022-05-16 09:16
thin.py
31.64
KB
-rw-r--r--
2022-05-16 09:16
timed_subprocess.py
4.06
KB
-rw-r--r--
2022-05-16 09:16
timeout.py
1.53
KB
-rw-r--r--
2022-05-16 09:16
timeutil.py
2.4
KB
-rw-r--r--
2022-05-16 09:16
url.py
4.96
KB
-rw-r--r--
2022-05-16 09:16
user.py
10.92
KB
-rw-r--r--
2022-05-16 09:16
value.py
247
B
-rw-r--r--
2022-05-16 09:16
vault.py
19.23
KB
-rw-r--r--
2022-05-16 09:16
verify.py
26.97
KB
-rw-r--r--
2022-05-16 09:16
versions.py
16.32
KB
-rw-r--r--
2022-05-16 09:16
virt.py
3.24
KB
-rw-r--r--
2022-05-16 09:16
virtualbox.py
22.43
KB
-rw-r--r--
2022-05-16 09:16
vmware.py
129.74
KB
-rw-r--r--
2022-05-16 09:16
vsan.py
17.18
KB
-rw-r--r--
2022-05-16 09:16
vt.py
30.25
KB
-rw-r--r--
2022-05-16 09:16
vt_helper.py
4.4
KB
-rw-r--r--
2022-05-16 09:16
win_chcp.py
3.7
KB
-rw-r--r--
2022-05-16 09:16
win_dacl.py
94.69
KB
-rw-r--r--
2022-05-16 09:16
win_dotnet.py
4.75
KB
-rw-r--r--
2022-05-16 09:16
win_functions.py
12.69
KB
-rw-r--r--
2022-05-16 09:16
win_lgpo_auditpol.py
8.48
KB
-rw-r--r--
2022-05-16 09:16
win_lgpo_netsh.py
17.87
KB
-rw-r--r--
2022-05-16 09:16
win_network.py
12.41
KB
-rw-r--r--
2022-05-16 09:16
win_osinfo.py
2.83
KB
-rw-r--r--
2022-05-16 09:16
win_pdh.py
13.85
KB
-rw-r--r--
2022-05-16 09:16
win_reg.py
30.05
KB
-rw-r--r--
2022-05-16 09:16
win_runas.py
10.55
KB
-rw-r--r--
2022-05-16 09:16
win_service.py
5.2
KB
-rw-r--r--
2022-05-16 09:16
win_system.py
14.47
KB
-rw-r--r--
2022-05-16 09:16
win_update.py
40.36
KB
-rw-r--r--
2022-05-16 09:16
winapi.py
818
B
-rw-r--r--
2022-05-16 09:16
xdg.py
316
B
-rw-r--r--
2022-05-16 09:16
xmlutil.py
13.91
KB
-rw-r--r--
2022-05-16 09:16
yaml.py
348
B
-rw-r--r--
2022-05-16 09:16
yamldumper.py
3.38
KB
-rw-r--r--
2022-05-16 09:16
yamlencoding.py
1.55
KB
-rw-r--r--
2022-05-16 09:16
yamlloader.py
6.21
KB
-rw-r--r--
2022-05-16 09:16
yamlloader_old.py
8.33
KB
-rw-r--r--
2022-05-16 09:16
yast.py
619
B
-rw-r--r--
2022-05-16 09:16
zeromq.py
1.65
KB
-rw-r--r--
2022-05-16 09:16
zfs.py
19.2
KB
-rw-r--r--
2022-05-16 09:16
Save
Rename
r""" Salt Util for getting system information with the Performance Data Helper (pdh). Counter information is gathered from current activity or log files. Usage: .. code-block:: python import salt.utils.win_pdh # Get a list of Counter objects salt.utils.win_pdh.list_objects() # Get a list of ``Processor`` instances salt.utils.win_pdh.list_instances('Processor') # Get a list of ``Processor`` counters salt.utils.win_pdh.list_counters('Processor') # Get the value of a single counter # \Processor(*)\% Processor Time salt.utils.win_pdh.get_counter('Processor', '*', '% Processor Time') # Get the values of multiple counters counter_list = [('Processor', '*', '% Processor Time'), ('System', None, 'Context Switches/sec'), ('Memory', None, 'Pages/sec'), ('Server Work Queues', '*', 'Queue Length')] salt.utils.win_pdh.get_counters(counter_list) # Get all counters for the Processor object salt.utils.win_pdh.get_all_counters('Processor') """ # https://docs.microsoft.com/en-us/windows/desktop/perfctrs/using-the-pdh-functions-to-consume-counter-data # https://www.cac.cornell.edu/wiki/index.php?title=Performance_Data_Helper_in_Python_with_win32pdh import logging import time import salt.utils.platform from salt.exceptions import CommandExecutionError try: import pywintypes import win32pdh HAS_WINDOWS_MODULES = True except ImportError: HAS_WINDOWS_MODULES = False log = logging.getLogger(__file__) # Define the virtual name __virtualname__ = "pdh" def __virtual__(): """ Only works on Windows systems with the PyWin32 """ if not salt.utils.platform.is_windows(): return False, "salt.utils.win_pdh: Requires Windows" if not HAS_WINDOWS_MODULES: return False, "salt.utils.win_pdh: Missing required modules" return __virtualname__ class Counter: """ Counter object Has enumerations and functions for working with counters """ # The dwType field from GetCounterInfo returns the following, or'ed. # These come from WinPerf.h PERF_SIZE_DWORD = 0x00000000 PERF_SIZE_LARGE = 0x00000100 PERF_SIZE_ZERO = 0x00000200 # for Zero Length fields PERF_SIZE_VARIABLE_LEN = 0x00000300 # length is in the CounterLength field of the Counter Definition structure # select one of the following values to indicate the counter field usage PERF_TYPE_NUMBER = 0x00000000 # a number (not a counter) PERF_TYPE_COUNTER = 0x00000400 # an increasing numeric value PERF_TYPE_TEXT = 0x00000800 # a text field PERF_TYPE_ZERO = 0x00000C00 # displays a zero # If the PERF_TYPE_NUMBER field was selected, then select one of the # following to describe the Number PERF_NUMBER_HEX = 0x00000000 # display as HEX value PERF_NUMBER_DECIMAL = 0x00010000 # display as a decimal integer PERF_NUMBER_DEC_1000 = 0x00020000 # display as a decimal/1000 # If the PERF_TYPE_COUNTER value was selected then select one of the # following to indicate the type of counter PERF_COUNTER_VALUE = 0x00000000 # display counter value PERF_COUNTER_RATE = 0x00010000 # divide ctr / delta time PERF_COUNTER_FRACTION = 0x00020000 # divide ctr / base PERF_COUNTER_BASE = 0x00030000 # base value used in fractions PERF_COUNTER_ELAPSED = 0x00040000 # subtract counter from current time PERF_COUNTER_QUEUE_LEN = 0x00050000 # Use Queue len processing func. PERF_COUNTER_HISTOGRAM = 0x00060000 # Counter begins or ends a histogram # If the PERF_TYPE_TEXT value was selected, then select one of the # following to indicate the type of TEXT data. PERF_TEXT_UNICODE = 0x00000000 # type of text in text field PERF_TEXT_ASCII = 0x00010000 # ASCII using the CodePage field # Timer SubTypes PERF_TIMER_TICK = 0x00000000 # use system perf. freq for base PERF_TIMER_100NS = 0x00100000 # use 100 NS timer time base units PERF_OBJECT_TIMER = 0x00200000 # use the object timer freq # Any types that have calculations performed can use one or more of the # following calculation modification flags listed here PERF_DELTA_COUNTER = 0x00400000 # compute difference first PERF_DELTA_BASE = 0x00800000 # compute base diff as well PERF_INVERSE_COUNTER = 0x01000000 # show as 1.00-value (assumes: PERF_MULTI_COUNTER = 0x02000000 # sum of multiple instances # Select one of the following values to indicate the display suffix (if any) PERF_DISPLAY_NO_SUFFIX = 0x00000000 # no suffix PERF_DISPLAY_PER_SEC = 0x10000000 # "/sec" PERF_DISPLAY_PERCENT = 0x20000000 # "%" PERF_DISPLAY_SECONDS = 0x30000000 # "secs" PERF_DISPLAY_NO_SHOW = 0x40000000 # value is not displayed def build_counter(obj, instance, instance_index, counter): r""" Makes a fully resolved counter path. Counter names are formatted like this: ``\Processor(*)\% Processor Time`` The above breaks down like this: obj = 'Processor' instance = '*' counter = '% Processor Time' Args: obj (str): The top level object instance (str): The instance of the object instance_index (int): The index of the instance. Can usually be 0 counter (str): The name of the counter Returns: Counter: A Counter object with the path if valid Raises: CommandExecutionError: If the path is invalid """ path = win32pdh.MakeCounterPath( (None, obj, instance, None, instance_index, counter), 0 ) if win32pdh.ValidatePath(path) == 0: return Counter(path, obj, instance, instance_index, counter) raise CommandExecutionError("Invalid counter specified: {}".format(path)) build_counter = staticmethod(build_counter) def __init__(self, path, obj, instance, index, counter): self.path = path self.obj = obj self.instance = instance self.index = index self.counter = counter self.handle = None self.info = None self.type = None def add_to_query(self, query): """ Add the current path to the query Args: query (obj): The handle to the query to add the counter """ self.handle = win32pdh.AddCounter(query, self.path) def get_info(self): """ Get information about the counter .. note:: GetCounterInfo sometimes crashes in the wrapper code. Fewer crashes if this is called after sampling data. """ if not self.info: ci = win32pdh.GetCounterInfo(self.handle, 0) self.info = { "type": ci[0], "version": ci[1], "scale": ci[2], "default_scale": ci[3], "user_data": ci[4], "query_user_data": ci[5], "full_path": ci[6], "machine_name": ci[7][0], "object_name": ci[7][1], "instance_name": ci[7][2], "parent_instance": ci[7][3], "instance_index": ci[7][4], "counter_name": ci[7][5], "explain_text": ci[8], } return self.info def value(self): """ Return the counter value Returns: long: The counter value """ (counter_type, value) = win32pdh.GetFormattedCounterValue( self.handle, win32pdh.PDH_FMT_DOUBLE ) self.type = counter_type return value def type_string(self): """ Returns the names of the flags that are set in the Type field It can be used to format the counter. """ type = self.get_info()["type"] type_list = [] for member in dir(self): if member.startswith("PERF_"): bit = getattr(self, member) if bit and bit & type: type_list.append(member[5:]) return type_list def __str__(self): return self.path def list_objects(): """ Get a list of available counter objects on the system Returns: list: A list of counter objects """ return sorted(win32pdh.EnumObjects(None, None, -1, 0)) def list_counters(obj): """ Get a list of counters available for the object Args: obj (str): The name of the counter object. You can get a list of valid names using the ``list_objects`` function Returns: list: A list of counters available to the passed object """ return win32pdh.EnumObjectItems(None, None, obj, -1, 0)[0] def list_instances(obj): """ Get a list of instances available for the object Args: obj (str): The name of the counter object. You can get a list of valid names using the ``list_objects`` function Returns: list: A list of instances available to the passed object """ return win32pdh.EnumObjectItems(None, None, obj, -1, 0)[1] def build_counter_list(counter_list): r""" Create a list of Counter objects to be used in the pdh query Args: counter_list (list): A list of tuples containing counter information. Each tuple should contain the object, instance, and counter name. For example, to get the ``% Processor Time`` counter for all Processors on the system (``\Processor(*)\% Processor Time``) you would pass a tuple like this: ``` counter_list = [('Processor', '*', '% Processor Time')] ``` If there is no ``instance`` for the counter, pass ``None`` Multiple counters can be passed like so: ``` counter_list = [('Processor', '*', '% Processor Time'), ('System', None, 'Context Switches/sec')] ``` .. note:: Invalid counters are ignored Returns: list: A list of Counter objects """ counters = [] index = 0 for obj, instance, counter_name in counter_list: try: counter = Counter.build_counter(obj, instance, index, counter_name) index += 1 counters.append(counter) except CommandExecutionError as exc: # Not a valid counter log.debug(exc.strerror) continue return counters def get_all_counters(obj, instance_list=None): """ Get the values for all counters available to a Counter object Args: obj (str): The name of the counter object. You can get a list of valid names using the ``list_objects`` function instance_list (list): A list of instances to return. Use this to narrow down the counters that are returned. .. note:: ``_Total`` is returned as ``*`` """ counters, instances_avail = win32pdh.EnumObjectItems(None, None, obj, -1, 0) if instance_list is None: instance_list = instances_avail if not isinstance(instance_list, list): instance_list = [instance_list] counter_list = [] for counter in counters: for instance in instance_list: instance = "*" if instance.lower() == "_total" else instance counter_list.append((obj, instance, counter)) else: # pylint: disable=useless-else-on-loop counter_list.append((obj, None, counter)) return get_counters(counter_list) if counter_list else {} def get_counters(counter_list): """ Get the values for the passes list of counters Args: counter_list (list): A list of counters to lookup Returns: dict: A dictionary of counters and their values """ if not isinstance(counter_list, list): raise CommandExecutionError("counter_list must be a list of tuples") try: # Start a Query instances query = win32pdh.OpenQuery() # Build the counters counters = build_counter_list(counter_list) # Add counters to the Query for counter in counters: counter.add_to_query(query) # https://docs.microsoft.com/en-us/windows/desktop/perfctrs/collecting-performance-data win32pdh.CollectQueryData(query) # The sleep here is required for counters that require more than 1 # reading time.sleep(1) win32pdh.CollectQueryData(query) ret = {} for counter in counters: try: ret.update({counter.path: counter.value()}) except pywintypes.error as exc: if exc.strerror == "No data to return.": # Some counters are not active and will throw an error if # there is no data to return continue else: raise except pywintypes.error as exc: if exc.strerror == "No data to return.": # Sometimess, win32pdh.CollectQueryData can err # so just ignore it return {} else: raise finally: win32pdh.CloseQuery(query) return ret def get_counter(obj, instance, counter): """ Get the value of a single counter Args: obj (str): The name of the counter object. You can get a list of valid names using the ``list_objects`` function instance (str): The counter instance you wish to return. Get a list of instances using the ``list_instances`` function .. note:: ``_Total`` is returned as ``*`` counter (str): The name of the counter. Get a list of counters using the ``list_counters`` function """ return get_counters([(obj, instance, counter)])