Statistics
| Branch: | Tag: | Revision:

root / astakos / middleware / log.py @ 64cd4730

History | View | Annotate | Download (2.1 kB)

1 64cd4730 Antony Chazapis
# Copyright 2011 GRNET S.A. All rights reserved.
2 64cd4730 Antony Chazapis
# 
3 64cd4730 Antony Chazapis
# Redistribution and use in source and binary forms, with or
4 64cd4730 Antony Chazapis
# without modification, are permitted provided that the following
5 64cd4730 Antony Chazapis
# conditions are met:
6 64cd4730 Antony Chazapis
# 
7 64cd4730 Antony Chazapis
#   1. Redistributions of source code must retain the above
8 64cd4730 Antony Chazapis
#      copyright notice, this list of conditions and the following
9 64cd4730 Antony Chazapis
#      disclaimer.
10 64cd4730 Antony Chazapis
# 
11 64cd4730 Antony Chazapis
#   2. Redistributions in binary form must reproduce the above
12 64cd4730 Antony Chazapis
#      copyright notice, this list of conditions and the following
13 64cd4730 Antony Chazapis
#      disclaimer in the documentation and/or other materials
14 64cd4730 Antony Chazapis
#      provided with the distribution.
15 64cd4730 Antony Chazapis
# 
16 64cd4730 Antony Chazapis
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 64cd4730 Antony Chazapis
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 64cd4730 Antony Chazapis
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 64cd4730 Antony Chazapis
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 64cd4730 Antony Chazapis
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 64cd4730 Antony Chazapis
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 64cd4730 Antony Chazapis
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 64cd4730 Antony Chazapis
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 64cd4730 Antony Chazapis
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 64cd4730 Antony Chazapis
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 64cd4730 Antony Chazapis
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 64cd4730 Antony Chazapis
# POSSIBILITY OF SUCH DAMAGE.
28 64cd4730 Antony Chazapis
# 
29 64cd4730 Antony Chazapis
# The views and conclusions contained in the software and
30 64cd4730 Antony Chazapis
# documentation are those of the authors and should not be
31 64cd4730 Antony Chazapis
# interpreted as representing official policies, either expressed
32 64cd4730 Antony Chazapis
# or implied, of GRNET S.A.
33 64cd4730 Antony Chazapis
34 64cd4730 Antony Chazapis
from django.conf import settings
35 64cd4730 Antony Chazapis
from django.core.exceptions import MiddlewareNotUsed
36 64cd4730 Antony Chazapis
37 64cd4730 Antony Chazapis
import logging
38 64cd4730 Antony Chazapis
39 64cd4730 Antony Chazapis
40 64cd4730 Antony Chazapis
class LoggingConfigMiddleware:
41 64cd4730 Antony Chazapis
    def __init__(self):
42 64cd4730 Antony Chazapis
        '''Initialise the logging setup from settings, called on first request.'''
43 64cd4730 Antony Chazapis
        args = {}
44 64cd4730 Antony Chazapis
        args['level'] = logging.DEBUG if getattr(settings, 'DEBUG', False) else logging.INFO
45 64cd4730 Antony Chazapis
        if settings.LOGFILE:
46 64cd4730 Antony Chazapis
            args['filename'] = settings.LOGFILE
47 64cd4730 Antony Chazapis
        args['format'] = '%(asctime)s [%(levelname)s] %(name)s %(message)s'
48 64cd4730 Antony Chazapis
        args['datefmt'] = '%Y-%m-%d %H:%M:%S'
49 64cd4730 Antony Chazapis
        logging.basicConfig(**args)
50 64cd4730 Antony Chazapis
        raise MiddlewareNotUsed('Logging setup only.')