import logging
from django.utils.timezone import now
from rest_framework import status

db_logger = logging.getLogger('db')
class LoggingMixin(object):
    

    # log only when one of the following methods is being performed
    allowed_logging_methods = ('post', 'put', 'patch', 'delete')
    def finalize_response(self, request, response, *args, **kwargs):
        # regular finalize response
        response = super().finalize_response(request, response, *args, **kwargs)
        # do not log, if method not found
        if request.method.lower() not in self.allowed_logging_methods:
            return response
        status_code = response.status_code
        log_kwargs = {
            'view': self.get_view_name(),
            'action': self.action,
            'method': request.method.lower(),
            'status_code': status_code,
            'request_path': request.path,
        }
        if status.is_server_error(status_code):
            db_logger.error('error', extra=log_kwargs)
        elif status.is_client_error(status_code):
            db_logger.warning('warning', extra=log_kwargs)
        else:
            db_logger.info('info', extra=log_kwargs)
        return response