1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-11 05:17:55 +03:00

Linux actor seems to start working, a bit to go anyway to finish debian

package (fix init scripts, create a couple of shell scripts to "easy"
management, etc..)
This commit is contained in:
Adolfo Gómez García 2014-11-18 20:16:45 +01:00
parent 15ef761d47
commit dca366b334
16 changed files with 73 additions and 45 deletions

View File

@ -26,8 +26,8 @@ case "$1" in
echo "[uds]" > /etc/udsactor/udsactor.cfg echo "[uds]" > /etc/udsactor/udsactor.cfg
echo "host = $host" >> /etc/udsactor/udsactor.cfg echo "host = $host" >> /etc/udsactor/udsactor.cfg
echo "logLevel = 20000" >> /etc/udsactor/udsactor.cfg echo "logLevel = 30000" >> /etc/udsactor/udsactor.cfg
echo "ssl = ssl" >> /etc/udsactor/udsactor.cfg echo "ssl = $ssl" >> /etc/udsactor/udsactor.cfg
echo "masterKey = $masterKey" >> /etc/udsactor/udsactor.cfg echo "masterKey = $masterKey" >> /etc/udsactor/udsactor.cfg
fi fi

View File

@ -2,7 +2,7 @@ Package: udsactor
Version: 1.7.0 Version: 1.7.0
Architecture: all Architecture: all
Maintainer: Adolfo Gómez García <agomez@virtualcable.es> Maintainer: Adolfo Gómez García <agomez@virtualcable.es>
Installed-Size: 205 Installed-Size: 206
Depends: python-requests (>= 0.8.2), python-qt4 (>= 4.9), python-six (>= 1.1), python (>= 2.7), debconf (>= 0.5) | debconf-2.0 Depends: python-requests (>= 0.8.2), python-qt4 (>= 4.9), python-six (>= 1.1), python (>= 2.7), debconf (>= 0.5) | debconf-2.0
Section: admin Section: admin
Priority: optional Priority: optional

View File

@ -5,22 +5,22 @@ fc4e41285d388d33b5f149ebe4b93236 usr/share/doc/udsactor/readme.txt
86020414868d2ede37e76a911aa211c5 usr/share/pyshared/UDSActor/UDSActorConfig.py 86020414868d2ede37e76a911aa211c5 usr/share/pyshared/UDSActor/UDSActorConfig.py
b14dee09070d95cac6321a13442f15b8 usr/share/pyshared/UDSActor/UDSActorUser.py b14dee09070d95cac6321a13442f15b8 usr/share/pyshared/UDSActor/UDSActorUser.py
db1be7dd5fec00a3c31587fe8ce8e56f usr/share/pyshared/UDSActor/setup_dialog_ui.py db1be7dd5fec00a3c31587fe8ce8e56f usr/share/pyshared/UDSActor/setup_dialog_ui.py
d677aa5ec15d9497b654a04f3d671958 usr/share/pyshared/UDSActor/udsactor/REST.py 5317be4587c15ce790bfa55399f4d601 usr/share/pyshared/UDSActor/udsactor/REST.py
68b329da9893e34099c7d8ad5cb9c940 usr/share/pyshared/UDSActor/udsactor/__init__.py 68b329da9893e34099c7d8ad5cb9c940 usr/share/pyshared/UDSActor/udsactor/__init__.py
976710a766859591a543eebdf351537b usr/share/pyshared/UDSActor/udsactor/certs.py 976710a766859591a543eebdf351537b usr/share/pyshared/UDSActor/udsactor/certs.py
bcfca2062d45ec44b77b1e65d611bcc1 usr/share/pyshared/UDSActor/udsactor/httpserver.py bcfca2062d45ec44b77b1e65d611bcc1 usr/share/pyshared/UDSActor/udsactor/httpserver.py
0350137ae586a7babe54a75e68fa1fe7 usr/share/pyshared/UDSActor/udsactor/ipc.py 0350137ae586a7babe54a75e68fa1fe7 usr/share/pyshared/UDSActor/udsactor/ipc.py
73082793d61ef3ce40736de43c9b3314 usr/share/pyshared/UDSActor/udsactor/linux/UDSActorService.py 6b7afab1321512cf7884df70f86041e8 usr/share/pyshared/UDSActor/udsactor/linux/UDSActorService.py
3ef55d64ebda86651c3d882c5c649389 usr/share/pyshared/UDSActor/udsactor/linux/__init__.py 3ef55d64ebda86651c3d882c5c649389 usr/share/pyshared/UDSActor/udsactor/linux/__init__.py
fee6ea5f27ec7aa294c2c0741b22c5e6 usr/share/pyshared/UDSActor/udsactor/linux/daemon.py 7322c53041ef99b982a6bbdb9d510c70 usr/share/pyshared/UDSActor/udsactor/linux/daemon.py
c599495230cbd3f6495ba4a6edc169d9 usr/share/pyshared/UDSActor/udsactor/linux/log.py c599495230cbd3f6495ba4a6edc169d9 usr/share/pyshared/UDSActor/udsactor/linux/log.py
49dccc874df32d0dbeaf7ffcbc9cc176 usr/share/pyshared/UDSActor/udsactor/linux/operations.py fe28aef338eacc56f8e76a33ac33ac2a usr/share/pyshared/UDSActor/udsactor/linux/operations.py
1234f7f854901dc53a6d67105e72404d usr/share/pyshared/UDSActor/udsactor/linux/renamer/__init__.py 1234f7f854901dc53a6d67105e72404d usr/share/pyshared/UDSActor/udsactor/linux/renamer/__init__.py
e958b3a317d41f350a412992f5016e4d usr/share/pyshared/UDSActor/udsactor/linux/renamer/debian.py e958b3a317d41f350a412992f5016e4d usr/share/pyshared/UDSActor/udsactor/linux/renamer/debian.py
93e6a3d18c34fda4a42d96b42407e52b usr/share/pyshared/UDSActor/udsactor/linux/store.py 93e6a3d18c34fda4a42d96b42407e52b usr/share/pyshared/UDSActor/udsactor/linux/store.py
28b691cb635888d496598bedf184cdb0 usr/share/pyshared/UDSActor/udsactor/log.py 3351055d556c481e7fb61b132ab96f90 usr/share/pyshared/UDSActor/udsactor/log.py
9bfbf09895f4319c4a5ebef858ff9faa usr/share/pyshared/UDSActor/udsactor/operations.py 9bfbf09895f4319c4a5ebef858ff9faa usr/share/pyshared/UDSActor/udsactor/operations.py
d284d7b4f544b0d7efe27188e843a783 usr/share/pyshared/UDSActor/udsactor/service.py 8f5c4a4db6d42dbd2effd760f960b598 usr/share/pyshared/UDSActor/udsactor/service.py
c88b37b89a88734788e23b2f71a7fcd5 usr/share/pyshared/UDSActor/udsactor/store.py c88b37b89a88734788e23b2f71a7fcd5 usr/share/pyshared/UDSActor/udsactor/store.py
68b513e35d67d3e783947ec35b60cfa7 usr/share/pyshared/UDSActor/udsactor/utils.py 68b513e35d67d3e783947ec35b60cfa7 usr/share/pyshared/UDSActor/udsactor/utils.py
517440806336069b121ea587ec0ed80f usr/share/pyshared/UDSActor/udsactor/windows/SENS.py 517440806336069b121ea587ec0ed80f usr/share/pyshared/UDSActor/udsactor/windows/SENS.py

View File

@ -26,8 +26,8 @@ case "$1" in
echo "[uds]" > /etc/udsactor/udsactor.cfg echo "[uds]" > /etc/udsactor/udsactor.cfg
echo "host = $host" >> /etc/udsactor/udsactor.cfg echo "host = $host" >> /etc/udsactor/udsactor.cfg
echo "logLevel = 20000" >> /etc/udsactor/udsactor.cfg echo "logLevel = 30000" >> /etc/udsactor/udsactor.cfg
echo "ssl = ssl" >> /etc/udsactor/udsactor.cfg echo "ssl = $ssl" >> /etc/udsactor/udsactor.cfg
echo "masterKey = $masterKey" >> /etc/udsactor/udsactor.cfg echo "masterKey = $masterKey" >> /etc/udsactor/udsactor.cfg
fi fi

View File

@ -119,6 +119,7 @@ class Api(object):
self.useSSL = ssl self.useSSL = ssl
self.scrambledResponses = scrambledResponses self.scrambledResponses = scrambledResponses
self.uuid = None self.uuid = None
self.mac = None
self.url = "{}://{}/rest/actor/".format(('http', 'https')[ssl], self.host) self.url = "{}://{}/rest/actor/".format(('http', 'https')[ssl], self.host)
self.secretKey = six.text_type(uuid.uuid4()) self.secretKey = six.text_type(uuid.uuid4())
self.newerRequestLib = 'verify' in requests.sessions.Session.__attrs__ self.newerRequestLib = 'verify' in requests.sessions.Session.__attrs__

View File

@ -119,8 +119,8 @@ def usage():
if __name__ == '__main__': if __name__ == '__main__':
initCfg() initCfg()
if len(sys.argv) == 3: if len(sys.argv) == 3:
client = None
try: try:
client = ipc.ClientIPC(IPC_PORT) client = ipc.ClientIPC(IPC_PORT)
client.start() client.start()
@ -135,7 +135,8 @@ if __name__ == '__main__':
except Exception as e: except Exception as e:
logger.error(e) logger.error(e)
finally: finally:
client.stop() if client is not None:
client.stop()
usage() usage()
logger.debug('Executing actor') logger.debug('Executing actor')

View File

@ -35,7 +35,7 @@ import sys
import os import os
import time import time
import atexit import atexit
from udsactor.log import logger
from signal import SIGTERM from signal import SIGTERM
@ -64,7 +64,8 @@ class Daemon:
# exit first parent # exit first parent
sys.exit(0) sys.exit(0)
except OSError as e: except OSError as e:
sys.stderr.write("fork #1 failed: {} ({})\n".format(e.errno, e.strerror)) logger.error("fork #1 error: {}".format(e))
sys.stderr.write("fork #1 failed: {}\n".format(e))
sys.exit(1) sys.exit(1)
# decouple from parent environment # decouple from parent environment
@ -79,7 +80,8 @@ class Daemon:
# exit from second parent # exit from second parent
sys.exit(0) sys.exit(0)
except OSError as e: except OSError as e:
sys.stderr.write("fork #2 failed: {} ({})\n".format(e.errno, e.strerror)) logger.error("fork #2 error: {}".format(e))
sys.stderr.write("fork #2 failed: {}\n".format(e))
sys.exit(1) sys.exit(1)
# redirect standard file descriptors # redirect standard file descriptors
@ -105,22 +107,27 @@ class Daemon:
""" """
Start the daemon Start the daemon
""" """
logger.debug('Starting daemon')
# Check for a pidfile to see if the daemon already runs # Check for a pidfile to see if the daemon already runs
try: try:
pf = file(self.pidfile, 'r') pf = open(self.pidfile, 'r')
pid = int(pf.read().strip()) pid = int(pf.read().strip())
pf.close() pf.close()
except IOError: except IOError:
pid = None pid = None
if pid: if pid:
message = "pidfile %s already exist. Daemon already running?\n" message = "pidfile {} already exist. Daemon already running?\n".format(pid)
sys.stderr.write(message % self.pidfile) logger.error(message)
sys.stderr.write(message)
sys.exit(1) sys.exit(1)
# Start the daemon # Start the daemon
self.daemonize() self.daemonize()
self.run() try:
self.run()
except Exception as e:
logger.error('Exception running process: {}'.format(e))
def stop(self): def stop(self):
""" """
@ -135,7 +142,9 @@ class Daemon:
pid = None pid = None
if pid is None: if pid is None:
sys.stderr.write("pidfile {} does not exist. Daemon not running?\n".format(self.pidfile)) message = "pidfile {} does not exist. Daemon not running?\n".format(self.pidfile)
logger.error(message)
sys.stderr.write(message)
return # not an error in a restart return # not an error in a restart
# Try killing the daemon process # Try killing the daemon process

View File

@ -52,7 +52,7 @@ def _getMacAddr(ifname):
ifname = ifname.encode('utf-8') # If unicode, convert to bytes (or str in python 2.7) ifname = ifname.encode('utf-8') # If unicode, convert to bytes (or str in python 2.7)
try: try:
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
info = bytearray(fcntl.ioctl(s.fileno(), 0x8927, struct.pack('256s', ifname[:15]))) info = bytearray(fcntl.ioctl(s.fileno(), 0x8927, struct.pack(str('256s'), ifname[:15])))
return six.text_type(''.join(['%02x:' % char for char in info[18:24]])[:-1]) return six.text_type(''.join(['%02x:' % char for char in info[18:24]])[:-1])
except Exception: except Exception:
return None return None
@ -72,7 +72,7 @@ def _getIpAddr(ifname):
return six.text_type(socket.inet_ntoa(fcntl.ioctl( return six.text_type(socket.inet_ntoa(fcntl.ioctl(
s.fileno(), s.fileno(),
0x8915, # SIOCGIFADDR 0x8915, # SIOCGIFADDR
struct.pack('256s', ifname[:15]) struct.pack(str('256s'), ifname[:15])
)[20:24])) )[20:24]))
except Exception: except Exception:
return None return None
@ -93,10 +93,10 @@ def _getInterfaces():
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
names = array.array(str('B'), b'\0' * space) names = array.array(str('B'), b'\0' * space)
outbytes = struct.unpack('iL', fcntl.ioctl( outbytes = struct.unpack(str('iL'), fcntl.ioctl(
s.fileno(), s.fileno(),
0x8912, # SIOCGIFCONF 0x8912, # SIOCGIFCONF
struct.pack('iL', space, names.buffer_info()[0]) struct.pack(str('iL'), space, names.buffer_info()[0])
))[0] ))[0]
namestr = names.tostring() namestr = names.tostring()
# return namestr, outbytes # return namestr, outbytes
@ -118,7 +118,8 @@ def getComputerName():
def getNetworkInfo(): def getNetworkInfo():
for ifname in _getInterfaces(): for ifname in _getInterfaces():
ip, mac = _getIpAndMac(ifname) ip, mac = _getIpAndMac(ifname)
yield utils.Bunch(name=ifname, mac=mac, ip=ip) if mac != '00:00:00:00:00:00': # Skips local interfaces
yield utils.Bunch(name=ifname, mac=mac, ip=ip)
def getDomainName(): def getDomainName():

View File

@ -50,7 +50,7 @@ class Logger(object):
self.remoteLogger = None self.remoteLogger = None
def setLevel(self, level): def setLevel(self, level):
self.logLevel = level self.logLevel = int(level) # Ensures level is an integer or fails
self.logger.log(INFO, 'Setting LogLevel to {}'.format(level)) self.logger.log(INFO, 'Setting LogLevel to {}'.format(level))
def setRemoteLogger(self, remoteLogger): def setRemoteLogger(self, remoteLogger):

View File

@ -116,7 +116,7 @@ class CommonService(object):
# Right now, we thing that the interface connected to broker is # Right now, we thing that the interface connected to broker is
# the interface that broker will know, let's see how this works # the interface that broker will know, let's see how this works
logger.fatal('This host is not managed by UDS Broker (ids: {})'.format(ids)) logger.fatal('This host is not managed by UDS Broker (ids: {})'.format(ids))
return False return False # On unmanaged hosts, there is no reason right now to continue running
except Exception as e: except Exception as e:
logger.debug('Exception caugh: {}, retrying'.format(exceptionToMessage(e))) logger.debug('Exception caugh: {}, retrying'.format(exceptionToMessage(e)))
# Any other error is expectable and recoverable, so let's wait a bit and retry again # Any other error is expectable and recoverable, so let's wait a bit and retry again
@ -185,6 +185,8 @@ class CommonService(object):
return True return True
def checkIpsChanged(self): def checkIpsChanged(self):
if self.api.uuid is None:
return # Not connected
netInfo = tuple(operations.getNetworkInfo()) netInfo = tuple(operations.getNetworkInfo())
for i in netInfo: for i in netInfo:
# If at least one ip has changed # If at least one ip has changed

View File

@ -119,6 +119,7 @@ class Api(object):
self.useSSL = ssl self.useSSL = ssl
self.scrambledResponses = scrambledResponses self.scrambledResponses = scrambledResponses
self.uuid = None self.uuid = None
self.mac = None
self.url = "{}://{}/rest/actor/".format(('http', 'https')[ssl], self.host) self.url = "{}://{}/rest/actor/".format(('http', 'https')[ssl], self.host)
self.secretKey = six.text_type(uuid.uuid4()) self.secretKey = six.text_type(uuid.uuid4())
self.newerRequestLib = 'verify' in requests.sessions.Session.__attrs__ self.newerRequestLib = 'verify' in requests.sessions.Session.__attrs__

View File

@ -119,8 +119,8 @@ def usage():
if __name__ == '__main__': if __name__ == '__main__':
initCfg() initCfg()
if len(sys.argv) == 3: if len(sys.argv) == 3:
client = None
try: try:
client = ipc.ClientIPC(IPC_PORT) client = ipc.ClientIPC(IPC_PORT)
client.start() client.start()
@ -135,7 +135,8 @@ if __name__ == '__main__':
except Exception as e: except Exception as e:
logger.error(e) logger.error(e)
finally: finally:
client.stop() if client is not None:
client.stop()
usage() usage()
logger.debug('Executing actor') logger.debug('Executing actor')

View File

@ -35,7 +35,7 @@ import sys
import os import os
import time import time
import atexit import atexit
from udsactor.log import logger
from signal import SIGTERM from signal import SIGTERM
@ -64,7 +64,8 @@ class Daemon:
# exit first parent # exit first parent
sys.exit(0) sys.exit(0)
except OSError as e: except OSError as e:
sys.stderr.write("fork #1 failed: {} ({})\n".format(e.errno, e.strerror)) logger.error("fork #1 error: {}".format(e))
sys.stderr.write("fork #1 failed: {}\n".format(e))
sys.exit(1) sys.exit(1)
# decouple from parent environment # decouple from parent environment
@ -79,7 +80,8 @@ class Daemon:
# exit from second parent # exit from second parent
sys.exit(0) sys.exit(0)
except OSError as e: except OSError as e:
sys.stderr.write("fork #2 failed: {} ({})\n".format(e.errno, e.strerror)) logger.error("fork #2 error: {}".format(e))
sys.stderr.write("fork #2 failed: {}\n".format(e))
sys.exit(1) sys.exit(1)
# redirect standard file descriptors # redirect standard file descriptors
@ -105,22 +107,27 @@ class Daemon:
""" """
Start the daemon Start the daemon
""" """
logger.debug('Starting daemon')
# Check for a pidfile to see if the daemon already runs # Check for a pidfile to see if the daemon already runs
try: try:
pf = file(self.pidfile, 'r') pf = open(self.pidfile, 'r')
pid = int(pf.read().strip()) pid = int(pf.read().strip())
pf.close() pf.close()
except IOError: except IOError:
pid = None pid = None
if pid: if pid:
message = "pidfile %s already exist. Daemon already running?\n" message = "pidfile {} already exist. Daemon already running?\n".format(pid)
sys.stderr.write(message % self.pidfile) logger.error(message)
sys.stderr.write(message)
sys.exit(1) sys.exit(1)
# Start the daemon # Start the daemon
self.daemonize() self.daemonize()
self.run() try:
self.run()
except Exception as e:
logger.error('Exception running process: {}'.format(e))
def stop(self): def stop(self):
""" """
@ -135,7 +142,9 @@ class Daemon:
pid = None pid = None
if pid is None: if pid is None:
sys.stderr.write("pidfile {} does not exist. Daemon not running?\n".format(self.pidfile)) message = "pidfile {} does not exist. Daemon not running?\n".format(self.pidfile)
logger.error(message)
sys.stderr.write(message)
return # not an error in a restart return # not an error in a restart
# Try killing the daemon process # Try killing the daemon process

View File

@ -52,7 +52,7 @@ def _getMacAddr(ifname):
ifname = ifname.encode('utf-8') # If unicode, convert to bytes (or str in python 2.7) ifname = ifname.encode('utf-8') # If unicode, convert to bytes (or str in python 2.7)
try: try:
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
info = bytearray(fcntl.ioctl(s.fileno(), 0x8927, struct.pack('256s', ifname[:15]))) info = bytearray(fcntl.ioctl(s.fileno(), 0x8927, struct.pack(str('256s'), ifname[:15])))
return six.text_type(''.join(['%02x:' % char for char in info[18:24]])[:-1]) return six.text_type(''.join(['%02x:' % char for char in info[18:24]])[:-1])
except Exception: except Exception:
return None return None
@ -72,7 +72,7 @@ def _getIpAddr(ifname):
return six.text_type(socket.inet_ntoa(fcntl.ioctl( return six.text_type(socket.inet_ntoa(fcntl.ioctl(
s.fileno(), s.fileno(),
0x8915, # SIOCGIFADDR 0x8915, # SIOCGIFADDR
struct.pack('256s', ifname[:15]) struct.pack(str('256s'), ifname[:15])
)[20:24])) )[20:24]))
except Exception: except Exception:
return None return None
@ -93,10 +93,10 @@ def _getInterfaces():
s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
names = array.array(str('B'), b'\0' * space) names = array.array(str('B'), b'\0' * space)
outbytes = struct.unpack('iL', fcntl.ioctl( outbytes = struct.unpack(str('iL'), fcntl.ioctl(
s.fileno(), s.fileno(),
0x8912, # SIOCGIFCONF 0x8912, # SIOCGIFCONF
struct.pack('iL', space, names.buffer_info()[0]) struct.pack(str('iL'), space, names.buffer_info()[0])
))[0] ))[0]
namestr = names.tostring() namestr = names.tostring()
# return namestr, outbytes # return namestr, outbytes
@ -118,7 +118,8 @@ def getComputerName():
def getNetworkInfo(): def getNetworkInfo():
for ifname in _getInterfaces(): for ifname in _getInterfaces():
ip, mac = _getIpAndMac(ifname) ip, mac = _getIpAndMac(ifname)
yield utils.Bunch(name=ifname, mac=mac, ip=ip) if mac != '00:00:00:00:00:00': # Skips local interfaces
yield utils.Bunch(name=ifname, mac=mac, ip=ip)
def getDomainName(): def getDomainName():

View File

@ -50,7 +50,7 @@ class Logger(object):
self.remoteLogger = None self.remoteLogger = None
def setLevel(self, level): def setLevel(self, level):
self.logLevel = level self.logLevel = int(level) # Ensures level is an integer or fails
self.logger.log(INFO, 'Setting LogLevel to {}'.format(level)) self.logger.log(INFO, 'Setting LogLevel to {}'.format(level))
def setRemoteLogger(self, remoteLogger): def setRemoteLogger(self, remoteLogger):

View File

@ -116,7 +116,7 @@ class CommonService(object):
# Right now, we thing that the interface connected to broker is # Right now, we thing that the interface connected to broker is
# the interface that broker will know, let's see how this works # the interface that broker will know, let's see how this works
logger.fatal('This host is not managed by UDS Broker (ids: {})'.format(ids)) logger.fatal('This host is not managed by UDS Broker (ids: {})'.format(ids))
return False return False # On unmanaged hosts, there is no reason right now to continue running
except Exception as e: except Exception as e:
logger.debug('Exception caugh: {}, retrying'.format(exceptionToMessage(e))) logger.debug('Exception caugh: {}, retrying'.format(exceptionToMessage(e)))
# Any other error is expectable and recoverable, so let's wait a bit and retry again # Any other error is expectable and recoverable, so let's wait a bit and retry again
@ -185,6 +185,8 @@ class CommonService(object):
return True return True
def checkIpsChanged(self): def checkIpsChanged(self):
if self.api.uuid is None:
return # Not connected
netInfo = tuple(operations.getNetworkInfo()) netInfo = tuple(operations.getNetworkInfo())
for i in netInfo: for i in netInfo:
# If at least one ip has changed # If at least one ip has changed