Hot-keys on this page

r m x p   toggle line displays

j k   next/prev highlighted chunk

0   (zero) top of page

1   (one) first highlighted chunk

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

# vim: tabstop=4 shiftwidth=4 softtabstop=4 

 

# Copyright 2013 OpenStack LLC 

# 

# Licensed under the Apache License, Version 2.0 (the "License"); you may 

# not use this file except in compliance with the License. You may obtain 

# a copy of the License at 

# 

#      http://www.apache.org/licenses/LICENSE-2.0 

# 

# Unless required by applicable law or agreed to in writing, software 

# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 

# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 

# License for the specific language governing permissions and limitations 

# under the License. 

 

import webob 

import webob.dec 

 

from keystone.common import logging 

from keystone.common import wsgi 

from keystone import config 

from keystone.openstack.common import timeutils 

 

 

CONF = config.CONF 

LOG = logging.getLogger('access') 

APACHE_TIME_FORMAT = '%d/%b/%Y:%H:%M:%S' 

APACHE_LOG_FORMAT = ( 

    '%(remote_addr)s - %(remote_user)s [%(datetime)s] "%(method)s %(url)s ' 

    '%(http_version)s" %(status)s %(content_length)s') 

 

 

class AccessLogMiddleware(wsgi.Middleware): 

    """Writes an access log to INFO.""" 

 

    @webob.dec.wsgify 

    def __call__(self, request): 

        data = { 

            'remote_addr': request.remote_addr, 

            'remote_user': request.remote_user or '-', 

            'method': request.method, 

            'url': request.url, 

            'http_version': request.http_version, 

            'status': 500, 

            'content_length': '-'} 

 

        try: 

            response = request.get_response(self.application) 

            data['status'] = response.status_int 

            data['content_length'] = len(response.body) or '-' 

        finally: 

            # must be calculated *after* the application has been called 

            now = timeutils.utcnow() 

 

            # timeutils may not return UTC, so we can't hardcode +0000 

            data['datetime'] = '%s %s' % (now.strftime(APACHE_TIME_FORMAT), 

                                          now.strftime('%z') or '+0000') 

 

            LOG.info(APACHE_LOG_FORMAT % data) 

        return response