Added log for all initial loggable objects

Added removing logs at object destroy (models)
This commit is contained in:
Adolfo Gómez 2013-01-31 14:24:29 +00:00
parent a1f72833a4
commit a740207b8e
3 changed files with 98 additions and 30 deletions

View File

@ -1,5 +1,4 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# #
# Copyright (c) 2013 Virtual Cable S.L. # Copyright (c) 2013 Virtual Cable S.L.
# All rights reserved. # All rights reserved.
@ -31,6 +30,15 @@
@author: Adolfo Gómez, dkmaster at dkmon dot com @author: Adolfo Gómez, dkmaster at dkmon dot com
''' '''
from uds.models import UserService
from uds.models import DeployedServicePublication
from uds.models import DeployedService
from uds.models import Service
from uds.models import Provider
from uds.models import User
from uds.models import Group
from uds.models import Authenticator
from uds.models import Log from uds.models import Log
from uds.core.util import log from uds.core.util import log
from uds.core.util.Config import GlobalConfig from uds.core.util.Config import GlobalConfig
@ -40,6 +48,18 @@ logger = logging.getLogger(__name__)
OT_USERSERVICE, OT_PUBLICATION, OT_DEPLOYED_SERVICE, OT_SERVICE, OT_PROVIDER, OT_USER, OT_GROUP, OT_AUTHENTICATOR = xrange(8) OT_USERSERVICE, OT_PUBLICATION, OT_DEPLOYED_SERVICE, OT_SERVICE, OT_PROVIDER, OT_USER, OT_GROUP, OT_AUTHENTICATOR = xrange(8)
# Dict for translations
transDict = {
UserService : OT_USERSERVICE,
DeployedServicePublication : OT_PUBLICATION,
DeployedService : OT_DEPLOYED_SERVICE,
Service : OT_SERVICE,
Provider : OT_PROVIDER,
User : OT_USER,
Group : OT_GROUP,
Authenticator : OT_AUTHENTICATOR
}
class LogManager(object): class LogManager(object):
''' '''
Manager for logging (at database) events Manager for logging (at database) events
@ -54,31 +74,36 @@ class LogManager(object):
if LogManager._manager == None: if LogManager._manager == None:
LogManager._manager = LogManager() LogManager._manager = LogManager()
return LogManager._manager return LogManager._manager
def __log(self, owner_type, owner_id, level, message, source):
# User Service log section
def __logUserService(self, userService, level, message, source):
''' '''
Logs a message associated to an user service Logs a message associated to owner
''' '''
from uds.models import getSqlDatetime from uds.models import getSqlDatetime
qs = Log.objects.filter(owner_id = owner_id, owner_type = owner_type)
qs = Log.objects.filter(owner_id = userService.id, owner_type = OT_USERSERVICE)
# First, ensure we do not have more than requested logs, and we can put one more log item # First, ensure we do not have more than requested logs, and we can put one more log item
if qs.count() >= GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt(): if qs.count() >= GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt():
for i in qs.order_by('-created',)[GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt()-1:]: i.delete() for i in qs.order_by('-created',)[GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt()-1:]: i.delete()
# now, we add new log # now, we add new log
Log.objects.create(owner_type = OT_USERSERVICE, owner_id = userService.id, created = getSqlDatetime(), source = source, level = level, data = message) Log.objects.create(owner_type = owner_type, owner_id = owner_id, created = getSqlDatetime(), source = source, level = level, data = message)
def __getUserServiceLogs(self, userService, limit):
def __getLogs(self, owner_type, owner_id, limit):
''' '''
Get all logs associated with an user service, ordered by date Get all logs associated with an user service, ordered by date
''' '''
qs = Log.objects.filter(owner_id = userService.id, owner_type = OT_USERSERVICE) qs = Log.objects.filter(owner_id = owner_id, owner_type = owner_type)
return [{'date': x.created, 'level': x.level, 'source': x.source, 'message': x.data} for x in qs.order_by('created')][:limit] return [{'date': x.created, 'level': x.level, 'source': x.source, 'message': x.data} for x in reversed(qs.order_by('-created')[:limit])]
def __clearLogs(self, owner_type, owner_id):
'''
Clears all logs related to user service
'''
Log.objects.filter(owner_id = owner_id, owner_type = owner_type).delete()
def doLog(self, wichObject, level, message, source = log.UNKNOWN): def doLog(self, wichObject, level, message, source = log.UNKNOWN):
''' '''
@ -86,21 +111,39 @@ class LogManager(object):
If the object provided do not accepts associated loggin, it simply ignores the request If the object provided do not accepts associated loggin, it simply ignores the request
''' '''
from uds.models import UserService
if type(level) is not int: if type(level) is not int:
level = log.logLevelFromStr(level) level = log.logLevelFromStr(level)
if type(wichObject) is UserService: owner_type = transDict.get(type(wichObject), None)
self.__logUserService(wichObject, level, message, source) if owner_type is not None:
self.__log(owner_type, wichObject.id, level, message, source)
else: else:
logger.debug('Requested doLog for a type of object not covered: {0}'.format(wichObject)) logger.debug('Requested doLog for a type of object not covered: {0}'.format(wichObject))
def getLogs(self, wichObject, limit = GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt()): def getLogs(self, wichObject, limit = GlobalConfig.MAX_LOGS_PER_ELEMENT.getInt()):
from uds.models import UserService '''
Get the logs associated with "wichObject", limiting to "limit" (default is GlobalConfig.MAX_LOGS_PER_ELEMENT)
'''
if type(wichObject) is UserService: owner_type = transDict.get(type(wichObject), None)
return self.__getUserServiceLogs(wichObject, limit)
if owner_type is not None:
return self.__getLogs(owner_type, wichObject.id, limit)
else: else:
logger.debug('Requested getLogs for a type of object not covered: {0}'.format(wichObject)) logger.debug('Requested getLogs for a type of object not covered: {0}'.format(wichObject))
return []
def clearLogs(self, wichObject):
'''
Clears all logs related to wichObject
Used mainly at object database removal (parent object)
'''
owner_type = transDict.get(type(wichObject), None)
if owner_type is not None:
self.__clearLogs(owner_type, wichObject.id)
else:
logger.debug('Requested clearLogs for a type of object not covered: {0}'.format(wichObject))

View File

@ -40,6 +40,7 @@ from uds.core.util.State import State
from uds.core.util import log from uds.core.util import log
from uds.core.services.Exceptions import InvalidServiceException from uds.core.services.Exceptions import InvalidServiceException
from datetime import datetime, timedelta from datetime import datetime, timedelta
from uds.core.managers import logManager
import logging import logging
@ -128,7 +129,7 @@ class Provider(models.Model):
return services.factory().lookup(self.data_type) return services.factory().lookup(self.data_type)
def __unicode__(self): def __unicode__(self):
return "{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id) return u"{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id)
@staticmethod @staticmethod
def beforeDelete(sender, **kwargs): def beforeDelete(sender, **kwargs):
@ -146,6 +147,9 @@ class Provider(models.Model):
s = toDelete.getInstance() s = toDelete.getInstance()
s.destroy() s.destroy()
s.env().clearRelatedData() s.env().clearRelatedData()
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Before delete service provider '.format(toDelete)) logger.debug('Before delete service provider '.format(toDelete))
@ -215,7 +219,7 @@ class Service(models.Model):
return self.provider.getType().getServiceByType(self.data_type) return self.provider.getType().getServiceByType(self.data_type)
def __unicode__(self): def __unicode__(self):
return "{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id) return u"{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id)
@staticmethod @staticmethod
def beforeDelete(sender, **kwargs): def beforeDelete(sender, **kwargs):
@ -234,6 +238,9 @@ class Service(models.Model):
s.destroy() s.destroy()
s.env().clearRelatedData() s.env().clearRelatedData()
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Before delete service '.format(toDelete)) logger.debug('Before delete service '.format(toDelete))
#: Connects a pre deletion signal to Service #: Connects a pre deletion signal to Service
@ -302,7 +309,7 @@ class OSManager(models.Model):
def __unicode__(self): def __unicode__(self):
return "{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id) return u"{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id)
def remove(self): def remove(self):
''' '''
@ -590,7 +597,7 @@ class Authenticator(models.Model):
return falseIfNotExists return falseIfNotExists
def __unicode__(self): def __unicode__(self):
return "{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id) return u"{0} of type {1} (id:{2})".format(self.name, self.data_type, self.id)
@staticmethod @staticmethod
def all(): def all():
@ -616,6 +623,9 @@ class Authenticator(models.Model):
s.destroy() s.destroy()
s.env().clearRelatedData() s.env().clearRelatedData()
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Before delete auth '.format(toDelete)) logger.debug('Before delete auth '.format(toDelete))
# Connects a pre deletion signal to Authenticator # Connects a pre deletion signal to Authenticator
@ -701,7 +711,7 @@ class User(models.Model):
return self.getManager().logout(self.name) return self.getManager().logout(self.name)
def __unicode__(self): def __unicode__(self):
return "User {0} from auth {1}".format(self.name, self.manager.name) return u"User {0} from auth {1}".format(self.name, self.manager.name)
@staticmethod @staticmethod
@ -720,6 +730,9 @@ class User(models.Model):
# be removed # be removed
toDelete.getManager().removeUser(toDelete.name) toDelete.getManager().removeUser(toDelete.name)
# Remove related logs
logManager().clearLogs(toDelete)
# Removes all user services assigned to this user (unassign it and mark for removal) # Removes all user services assigned to this user (unassign it and mark for removal)
for us in toDelete.userServices.all(): for us in toDelete.userServices.all():
us.assignToUser(None) us.assignToUser(None)
@ -756,7 +769,7 @@ class Group(models.Model):
return self.manager.getInstance() return self.manager.getInstance()
def __unicode__(self): def __unicode__(self):
return "Group {0} from auth {1}".format(self.name, self.manager.name) return u"Group {0} from auth {1}".format(self.name, self.manager.name)
@staticmethod @staticmethod
def beforeDelete(sender, **kwargs): def beforeDelete(sender, **kwargs):
@ -774,6 +787,8 @@ class Group(models.Model):
# be removed # be removed
toDelete.getManager().removeGroup(toDelete.name) toDelete.getManager().removeGroup(toDelete.name)
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Deleted group {0}'.format(toDelete)) logger.debug('Deleted group {0}'.format(toDelete))
@ -1013,10 +1028,13 @@ class DeployedService(models.Model):
toDelete = kwargs['instance'] toDelete = kwargs['instance']
toDelete.getEnvironment().clearRelatedData() toDelete.getEnvironment().clearRelatedData()
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Deleting Deployed Service {0}'.format(toDelete)) logger.debug('Deleting Deployed Service {0}'.format(toDelete))
def __unicode__(self): def __unicode__(self):
return "Deployed service {0}({1}) with {2} as initial, {3} as L1 cache, {4} as L2 cache, {5} as max".format( return u"Deployed service {0}({1}) with {2} as initial, {3} as L1 cache, {4} as L2 cache, {5} as max".format(
self.name, self.id, self.initial_srvs, self.cache_l1_srvs, self.cache_l2_srvs, self.max_srvs) self.name, self.id, self.initial_srvs, self.cache_l1_srvs, self.cache_l2_srvs, self.max_srvs)
@ -1143,9 +1161,13 @@ class DeployedServicePublication(models.Model):
toDelete = kwargs['instance'] toDelete = kwargs['instance']
toDelete.getEnvironment().clearRelatedData() toDelete.getEnvironment().clearRelatedData()
# Destroy method is invoked directly by PublicationManager, # Delete method is invoked directly by PublicationManager,
# Destroying a publication is not obligatory an 1 step action. # Destroying a publication is not obligatory an 1 step action.
# It's handled as "publish", and as so, it # It's handled as "publish", and as so, it can be a multi-step process
# Clears related logs
logManager().clearLogs(toDelete)
logger.debug('Deleted publication {0}'.format(toDelete)) logger.debug('Deleted publication {0}'.format(toDelete))
@ -1498,6 +1520,9 @@ class UserService(models.Model):
toDelete = kwargs['instance'] toDelete = kwargs['instance']
toDelete.getEnvironment().clearRelatedData() toDelete.getEnvironment().clearRelatedData()
# Clear related logs to this user service
logManager().clearLogs(toDelete)
# TODO: Check if this invokation goes here # TODO: Check if this invokation goes here
#toDelete.getInstance() #toDelete.getInstance()

View File

@ -158,7 +158,7 @@ def login(username, password, idAuth, locale, request):
logger.info("Validating user {0} with authenticator {1} with locale {2}".format(username, idAuth, locale)) logger.info("Validating user {0} with authenticator {1} with locale {2}".format(username, idAuth, locale))
activate(locale) activate(locale)
if idAuth == ADMIN_AUTH: if idAuth == ADMIN_AUTH:
if GlobalConfig.SUPER_USER_LOGIN.get() == username and GlobalConfig.SUPER_USER_PASS.get(True) == password: if GlobalConfig.SUPER_USER_LOGIN.get(True) == username and GlobalConfig.SUPER_USER_PASS.get(True) == password:
return makeCredentials(idAuth, username, locale, True) return makeCredentials(idAuth, username, locale, True)
else: else:
raise AuthException(_('Invalid credentials')) raise AuthException(_('Invalid credentials'))