forked from shaba/openuds
Added scheduled action to pool so we can remove "old assigned machines" with a programmed action
This commit is contained in:
parent
4cc4af5bd1
commit
835dc05e63
@ -60,6 +60,7 @@ from uds.models.calendar_action import (
|
||||
CALENDAR_ACTION_DEL_ALL_GROUPS,
|
||||
CALENDAR_ACTION_IGNORE_UNUSED,
|
||||
CALENDAR_ACTION_REMOVE_USERSERVICES,
|
||||
CALENDAR_ACTION_REMOVE_STUCK_USERSERVICES,
|
||||
)
|
||||
|
||||
from uds.core.managers import userServiceManager
|
||||
@ -685,6 +686,7 @@ class ServicesPools(ModelHandler):
|
||||
validActions += (
|
||||
CALENDAR_ACTION_IGNORE_UNUSED,
|
||||
CALENDAR_ACTION_REMOVE_USERSERVICES,
|
||||
CALENDAR_ACTION_REMOVE_STUCK_USERSERVICES,
|
||||
)
|
||||
return validActions
|
||||
|
||||
|
@ -111,8 +111,8 @@ class LogManager(metaclass=singleton.Singleton):
|
||||
if avoidDuplicates:
|
||||
try:
|
||||
lg = models.Log.objects.filter(
|
||||
owner_id=owner_id, owner_type=owner_type, level=level, source=source
|
||||
).order_by('-created', '-id')[0]
|
||||
owner_id=owner_id, owner_type=owner_type
|
||||
).order_by('-id')[0]
|
||||
if lg.data == message:
|
||||
# Do not log again, already logged
|
||||
return
|
||||
|
@ -139,7 +139,7 @@ CALENDAR_ACTION_DEL_ALL_TRANSPORTS: typing.Dict[str, typing.Any] = {
|
||||
'id': 'REMOVE_ALL_TRANSPORTS',
|
||||
'description': _('Remove all transports'),
|
||||
'params': (),
|
||||
}
|
||||
}
|
||||
CALENDAR_ACTION_ADD_GROUP: typing.Dict[str, typing.Any] = {
|
||||
'id': 'ADD_GROUP',
|
||||
'description': _('Add a group'),
|
||||
@ -158,7 +158,7 @@ CALENDAR_ACTION_DEL_ALL_GROUPS: typing.Dict[str, typing.Any] = {
|
||||
'id': 'REMOVE_ALL_GROUPS',
|
||||
'description': _('Remove all groups'),
|
||||
'params': (),
|
||||
}
|
||||
}
|
||||
CALENDAR_ACTION_IGNORE_UNUSED: typing.Dict[str, typing.Any] = {
|
||||
'id': 'IGNORE_UNUSED',
|
||||
'description': _('Sets the ignore unused'),
|
||||
@ -177,6 +177,21 @@ CALENDAR_ACTION_REMOVE_USERSERVICES: typing.Dict[str, typing.Any] = {
|
||||
'params': (),
|
||||
}
|
||||
|
||||
CALENDAR_ACTION_REMOVE_STUCK_USERSERVICES: typing.Dict[str, typing.Any] = {
|
||||
'id': 'STUCK_USERSERVICES',
|
||||
'description': _('Remove OLD assigned user services.'),
|
||||
'params': (
|
||||
{
|
||||
'type': 'numeric',
|
||||
'name': 'hours',
|
||||
'description': _(
|
||||
'Time in hours before considering the user service is OLD.'
|
||||
),
|
||||
'default': '72',
|
||||
},
|
||||
),
|
||||
}
|
||||
|
||||
|
||||
CALENDAR_ACTION_DICT: typing.Dict[str, typing.Dict] = {
|
||||
c['id']: c
|
||||
@ -194,6 +209,7 @@ CALENDAR_ACTION_DICT: typing.Dict[str, typing.Dict] = {
|
||||
CALENDAR_ACTION_DEL_ALL_GROUPS,
|
||||
CALENDAR_ACTION_IGNORE_UNUSED,
|
||||
CALENDAR_ACTION_REMOVE_USERSERVICES,
|
||||
CALENDAR_ACTION_REMOVE_STUCK_USERSERVICES,
|
||||
)
|
||||
}
|
||||
|
||||
@ -292,22 +308,22 @@ class CalendarAction(UUIDModel):
|
||||
|
||||
saveServicePool = save
|
||||
|
||||
def sizeVal() -> int:
|
||||
v = int(params['size'])
|
||||
def numVal(field: str) -> int:
|
||||
v = int(params[field])
|
||||
return v if v >= 0 else 0
|
||||
|
||||
executed = False
|
||||
if CALENDAR_ACTION_CACHE_L1['id'] == self.action:
|
||||
self.service_pool.cache_l1_srvs = sizeVal()
|
||||
self.service_pool.cache_l1_srvs = numVal('size')
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_CACHE_L2['id'] == self.action:
|
||||
self.service_pool.cache_l2_srvs = sizeVal()
|
||||
self.service_pool.cache_l2_srvs = numVal('size')
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_INITIAL['id'] == self.action:
|
||||
self.service_pool.initial_srvs = sizeVal()
|
||||
self.service_pool.initial_srvs = numVal('size')
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_MAX['id'] == self.action:
|
||||
self.service_pool.max_srvs = sizeVal()
|
||||
self.service_pool.max_srvs = numVal('size')
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_PUBLISH['id'] == self.action:
|
||||
self.service_pool.publish(changeLog='Scheduled publication action')
|
||||
@ -315,19 +331,36 @@ class CalendarAction(UUIDModel):
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_IGNORE_UNUSED['id'] == self.action:
|
||||
self.service_pool.ignores_unused = params['state'] in ('true', '1', True)
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_REMOVE_USERSERVICES['id'] == self.action:
|
||||
# 1.- Remove usable assigned services (Ignore "creating ones", just for created)
|
||||
for userService in self.service_pool.assignedUserServices().filter(
|
||||
state=state.State.USABLE
|
||||
):
|
||||
userService.remove()
|
||||
saveServicePool = False
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_REMOVE_STUCK_USERSERVICES['id'] == self.action:
|
||||
# 1.- Remove stuck assigned services (Ignore "creating ones", just for created)
|
||||
since = getSqlDatetime() - datetime.timedelta(hours=numVal('hours'))
|
||||
for userService in self.service_pool.assignedUserServices().filter(
|
||||
state_date__lt=since, state=state.State.USABLE
|
||||
):
|
||||
userService.remove()
|
||||
saveServicePool = False
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_DEL_ALL_TRANSPORTS['id'] == self.action:
|
||||
# 2.- Remove all transports
|
||||
self.service_pool.transports.all().delete()
|
||||
saveServicePool = False
|
||||
executed = True
|
||||
elif CALENDAR_ACTION_DEL_ALL_GROUPS['id'] == self.action:
|
||||
# 3.- Remove all groups
|
||||
self.service_pool.assignedGroups.all().detete()
|
||||
else:
|
||||
saveServicePool = False
|
||||
executed = True
|
||||
else: # Add/remove transport or group
|
||||
saveServicePool = False
|
||||
caTransports = (
|
||||
CALENDAR_ACTION_ADD_TRANSPORT['id'],
|
||||
CALENDAR_ACTION_DEL_TRANSPORT['id'],
|
||||
@ -348,7 +381,6 @@ class CalendarAction(UUIDModel):
|
||||
self.service_pool.log(
|
||||
'Scheduled action not executed because transport is not available anymore'
|
||||
)
|
||||
saveServicePool = False
|
||||
elif self.action in caGroups:
|
||||
try:
|
||||
auth, grp = params['group'].split('@')
|
||||
@ -362,7 +394,6 @@ class CalendarAction(UUIDModel):
|
||||
self.service_pool.log(
|
||||
'Scheduled action not executed because group is not available anymore'
|
||||
)
|
||||
saveServicePool = False
|
||||
|
||||
if executed:
|
||||
try:
|
||||
|
@ -712,7 +712,7 @@ class ServicePool(UUIDModel, TaggingMixin): # type: ignore
|
||||
clean(toDelete)
|
||||
|
||||
def __str__(self):
|
||||
return 'Deployed service {}({}) with {} as initial, {} as L1 cache, {} as L2 cache, {} as max'.format(
|
||||
return 'Service pool {}({}) with {} as initial, {} as L1 cache, {} as L2 cache, {} as max'.format(
|
||||
self.name,
|
||||
self.id,
|
||||
self.initial_srvs,
|
||||
|
Loading…
x
Reference in New Issue
Block a user