| Current File : /home/mmdealscpanel/yummmdeals.com/utils.tar |
__init__.py 0000644 00000000000 15051664264 0006654 0 ustar 00 nettool.py 0000644 00000013106 15051664264 0006614 0 ustar 00 __all__ = ["ethcard"]
import tuned.logs
from subprocess import *
import re
log = tuned.logs.get()
class Nettool:
_advertise_values = { # [ half, full ]
10 : [ 0x001, 0x002 ],
100 : [ 0x004, 0x008 ],
1000 : [ 0x010, 0x020 ],
2500 : [ 0, 0x8000 ],
10000 : [ 0, 0x1000 ],
"auto" : 0x03F
}
_disabled = False
def __init__(self, interface):
self._interface = interface;
self.update()
log.debug("%s: speed %s, full duplex %s, autoneg %s, link %s" % (interface, self.speed, self.full_duplex, self.autoneg, self.link))
log.debug("%s: supports: autoneg %s, modes %s" % (interface, self.supported_autoneg, self.supported_modes))
log.debug("%s: advertises: autoneg %s, modes %s" % (interface, self.advertised_autoneg, self.advertised_modes))
# def __del__(self):
# if self.supported_autoneg:
# self._set_advertise(self._advertise_values["auto"])
def _clean_status(self):
self.speed = 0
self.full_duplex = False
self.autoneg = False
self.link = False
self.supported_modes = []
self.supported_autoneg = False
self.advertised_modes = []
self.advertised_autoneg = False
def _calculate_mode(self, modes):
mode = 0;
for m in modes:
mode += self._advertise_values[m[0]][ 1 if m[1] else 0 ]
return mode
def _set_autonegotiation(self, enable):
if self.autoneg == enable:
return True
if not self.supported_autoneg:
return False
return 0 == call(["ethtool", "-s", self._interface, "autoneg", "on" if enable else "off"], close_fds=True)
def _set_advertise(self, value):
if not self._set_autonegotiation(True):
return False
return 0 == call(["ethtool", "-s", self._interface, "advertise", "0x%03x" % value], close_fds=True)
def get_max_speed(self):
max = 0
for mode in self.supported_modes:
if mode[0] > max: max = mode[0]
if max > 0:
return max
else:
return 1000
def set_max_speed(self):
if self._disabled or not self.supported_autoneg:
return False
#if self._set_advertise(self._calculateMode(self.supported_modes)):
if self._set_advertise(self._advertise_values["auto"]):
self.update()
return True
else:
return False
def set_speed(self, speed):
if self._disabled or not self.supported_autoneg:
return False
mode = 0
for am in self._advertise_values:
if am == "auto": continue
if am <= speed:
mode += self._advertise_values[am][0];
mode += self._advertise_values[am][1];
effective_mode = mode & self._calculate_mode(self.supported_modes)
log.debug("%s: set_speed(%d) - effective_mode 0x%03x" % (self._interface, speed, effective_mode))
if self._set_advertise(effective_mode):
self.update()
return True
else:
return False
def update(self):
if self._disabled:
return
# run ethtool and preprocess output
p_ethtool = Popen(["ethtool", self._interface], \
stdout=PIPE, stderr=PIPE, close_fds=True, \
universal_newlines = True)
p_filter = Popen(["sed", r"s/^\s*//;s/:\s*/:\n/g"], \
stdin=p_ethtool.stdout, stdout=PIPE, \
universal_newlines = True, \
close_fds=True)
output = p_filter.communicate()[0]
errors = p_ethtool.communicate()[1]
if errors != "":
log.warning("%s: some errors were reported by 'ethtool'" % self._interface)
log.debug("%s: %s" % (self._interface, errors.replace("\n", r"\n")))
self._clean_status()
self._disabled = True
return
# parses output - kind of FSM
self._clean_status()
re_speed = re.compile(r"(\d+)")
re_mode = re.compile(r"(\d+)baseT/(Half|Full)")
state = "wait"
for line in output.split("\n"):
if line.endswith(":"):
section = line[:-1]
if section == "Speed": state = "speed"
elif section == "Duplex": state = "duplex"
elif section == "Auto-negotiation": state = "autoneg"
elif section == "Link detected": state = "link"
elif section == "Supported link modes": state = "supported_modes"
elif section == "Supports auto-negotiation": state = "supported_autoneg"
elif section == "Advertised link modes": state = "advertised_modes"
elif section == "Advertised auto-negotiation": state = "advertised_autoneg"
else: state = "wait"
del section
elif state == "speed":
# Try to determine speed. If it fails, assume 1gbit ethernet
try:
self.speed = re_speed.match(line).group(1)
except:
self.speed = 1000
state = "wait"
elif state == "duplex":
self.full_duplex = line == "Full"
state = "wait"
elif state == "autoneg":
self.autoneg = (line == "yes" or line == "on")
state = "wait"
elif state == "link":
self.link = line == "yes"
state = "wait"
elif state == "supported_modes":
# Try to determine supported modes. If it fails, assume 1gibt ethernet fullduplex works
try:
for m in line.split():
(s, d) = re_mode.match(m).group(1,2)
self.supported_modes.append( (int(s), d == "Full") )
del m,s,d
except:
self.supported_modes.append((1000, True))
elif state == "supported_autoneg":
self.supported_autoneg = line == "Yes"
state = "wait"
elif state == "advertised_modes":
# Try to determine advertised modes. If it fails, assume 1gibt ethernet fullduplex works
try:
if line != "Not reported":
for m in line.split():
(s, d) = re_mode.match(m).group(1,2)
self.advertised_modes.append( (int(s), d == "Full") )
del m,s,d
except:
self.advertised_modes.append((1000, True))
elif state == "advertised_autoneg":
self.advertised_autoneg = line == "Yes"
state = "wait"
def ethcard(interface):
if not interface in ethcard.list:
ethcard.list[interface] = Nettool(interface)
return ethcard.list[interface]
ethcard.list = {}
polkit.py 0000644 00000002630 15051664264 0006432 0 ustar 00 import dbus
import tuned.logs
log = tuned.logs.get()
class polkit():
def __init__(self):
self._bus = dbus.SystemBus()
self._proxy = self._bus.get_object('org.freedesktop.PolicyKit1', '/org/freedesktop/PolicyKit1/Authority', follow_name_owner_changes = True)
self._authority = dbus.Interface(self._proxy, dbus_interface='org.freedesktop.PolicyKit1.Authority')
def check_authorization(self, sender, action_id):
"""Check authorization, return codes:
1 - authorized
2 - polkit error, but authorized with fallback method
0 - unauthorized
-1 - polkit error and unauthorized by the fallback method
-2 - polkit error and unable to use the fallback method
"""
if sender is None or action_id is None:
return False
details = {}
flags = 1 # AllowUserInteraction flag
cancellation_id = "" # No cancellation id
subject = ("system-bus-name", {"name" : sender})
try:
ret = self._authority.CheckAuthorization(subject, action_id, details, flags, cancellation_id)[0]
except (dbus.exceptions.DBusException, ValueError) as e:
log.error("error querying polkit: %s" % e)
# No polkit or polkit error, fallback to always allow root
try:
uid = self._bus.get_unix_user(sender)
except dbus.exceptions.DBusException as e:
log.error("error using fallback authorization method: %s" % e)
return -2
if uid == 0:
return 2
else:
return -1
return 1 if ret else 0
__pycache__/commands.cpython-36.opt-1.pyc 0000644 00000037457 15051664264 0014173 0 ustar 00 3
`��g�@ � @ sr d dl Z d dlZd dlZd dlZd dlZd dlZd dljZd dl Z d dl
T d dlmZ ej
j� ZG dd� d�ZdS )� N)�*)�TunedExceptionc @ s� e Zd Zdbdd�Zdd� Zdd� Zdd � Zd
d� Zdd
� Zdcdd�Z dddd�Z
dd� Zdd� Zdd� Z
dedd�Zdfdd�Zdgd d!�Zdhd#d$�Zdid%d&�Zdjd'd(�Zdkd)d*�Zdld+d,�Zd-d.� Zd/d0� Zdmd1d2�Zd3d4� Zd5d6� Zdnd7d8�Zddi g dfd9d:�Zdod;d<�Zd=d>� Zd?d@� ZdAdB� Z dpdDdE�Z!dFdG� Z"dHdI� Z#dJdK� Z$dLdM� Z%dqdNdO�Z&dPdQ� Z'dRdS� Z(dTdU� Z)dVdW� Z*dXdY� Z+dZd[� Z,d\d]� Z-d^d_� Z.d`da� Z/dS )r�commandsTc C s
|| _ d S )N)�_logging)�selfZlogging� r �/usr/lib/python3.6/commands.py�__init__ s zcommands.__init__c C s | j rtj|� d S )N)r �log�error)r �msgr r r �_error s zcommands._errorc C s | j rtj|� d S )N)r r
�debug)r r r r r �_debug s zcommands._debugc C s. t |�j� j� }ddddddddd�j||�S )N�1�0)�YZYES�TZTRUE�NZNO�FZFALSE)�str�upper�strip�get)r �value�vr r r �get_bool s zcommands.get_boolc C s t jddt|��j� S )Nz\s+� )�re�subr r )r �sr r r � remove_ws s zcommands.remove_wsc C s t jdd|�S )Nz^"(.*)"$z\1)r r )r r r r r �unquote"