1
0
mirror of https://github.com/dkmstr/openuds.git synced 2025-01-25 06:03:51 +03:00

Merged 2.0 fixes

This commit is contained in:
Adolfo Gómez García 2016-09-27 15:52:47 +02:00
commit 7fc9adae8b
4 changed files with 21 additions and 3 deletions

View File

@ -37,9 +37,12 @@ from uds.core.services import types as serviceTypes
from uds.core.util.State import State
from uds.core.util.stats.events import addEvent, ET_LOGIN, ET_LOGOUT
from uds.core.util import log
from uds.core.util.Config import GlobalConfig
from uds.core import Module
__updated__ = '2016-09-16'
import six
__updated__ = '2016-09-19'
STORAGE_KEY = 'osmk'
@ -202,6 +205,9 @@ class OSManager(Module):
log.useLog('login', uniqueId, serviceIp, userName, knownUserIP, fullUserName)
counter = int(userService.getProperty('loginsCounter', '0')) + 1
userService.setProperty(six.text_type(counter))
if save:
userService.save()
@ -212,6 +218,15 @@ class OSManager(Module):
- Sets service in use
- Invokes userLoggedIn for user service instance
'''
counter = int(userService.getProperty('loginsCounter', '0'))
if counter > 0:
counter -= 1
userService.setProperty(six.text_type(counter))
if GlobalConfig.EXCLUSIVE_LOGOUT.getBool(True) is True:
if counter > 0:
return
uniqueId = userService.unique_id
userService.setInUse(False)
si = userService.getInstance()

View File

@ -296,6 +296,9 @@ class GlobalConfig(object):
# If there is a proxy in front of us
BEHIND_PROXY = Config.section(SECURITY_SECTION).value('Behind a proxy', '0', type=Config.BOOLEAN_FIELD)
# If we use new logout mechanics
EXCLUSIVE_LOGOUT = Config.section(SECURITY_SECTION).value('Exclusive Logout', '0', type=Config.BOOLEAN_FIELD)
# Clusters related vars
# Maximum desired CPU Load. If cpu is over this value, a migration of a service is "desirable"

View File

@ -164,7 +164,7 @@ class LinuxOsManager(osmanagers.OSManager):
ret = "{0}\t{1}\t{2}".format(ip, hostname, 0 if deadLine is None else deadLine)
elif msg == "logout":
self.loggedOut(userService, data, False)
if self._onLogout == 'remove':
if userService.in_use == False and self._onLogout == 'remove':
doRemove = True
elif msg == "ip":
# This ocurss on main loop inside machine, so userService is usable

View File

@ -177,7 +177,7 @@ class WindowsOsManager(osmanagers.OSManager):
ret = "{0}\t{1}".format(ip, hostname)
elif msg == "logoff" or msg == 'logout':
self.loggedOut(userService, data, False)
if self._onLogout == 'remove':
if userService.in_use == False and self._onLogout == 'remove':
doRemove = True
elif msg == "ip":
# This ocurss on main loop inside machine, so userService is usable