forked from samuelclay/NewsBlur
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathredis_raw_log_middleware.py
47 lines (42 loc) · 1.69 KB
/
redis_raw_log_middleware.py
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
from django.core.exceptions import MiddlewareNotUsed
from django.conf import settings
from django.db import connection
from redis.connection import Connection
from time import time
class SqldumpMiddleware(object):
def __init__(self):
if not settings.DEBUG:
raise MiddlewareNotUsed()
def process_view(self, request, callback, callback_args, callback_kwargs):
if settings.DEBUG:
# save old methods
self.orig_pack_command = \
Connection.pack_command
# instrument methods to record messages
Connection.pack_command = \
self._instrument(Connection.pack_command)
return None
def process_response(self, request, response):
if settings.DEBUG and hasattr(self, 'orig_pack_command'):
# remove instrumentation from redis
Connection.pack_command = \
self.orig_pack_command
return response
def _instrument(self, original_method):
def instrumented_method(*args, **kwargs):
message = self.process_message(*args, **kwargs)
if not message:
return original_method(*args, **kwargs)
start = time()
result = original_method(*args, **kwargs)
stop = time()
duration = stop - start
connection.queries.append({
'redis': message,
'time': '%.3f' % duration,
})
return result
return instrumented_method
def process_message(self, *args, **kwargs):
query = ' '.join([str(arg) for arg in args if not isinstance(arg, Connection)])
return { 'query': query, }