Parent: [f015bc] (diff)

Child: [0f2f3a] (diff)

Download this file

stats.py    57 lines (49 with data), 1.8 kB

 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
import logging
from collections import defaultdict
from datetime import datetime, time
import ming
from .session import main_doc_session
log = logging.getLogger(__name__)
class Stats(ming.Document):
class __mongometa__:
session = main_doc_session
name='stats'
class CPA(ming.Document):
class __mongometa__:
session = main_doc_session
name='content_production_activities'
indexes = [
'type', 'class_name', 'project_id', 'project_shortname', 'app_config_id', 'when', 'tool_name' ]
@classmethod
def post(cls, type, obj):
d = dict(
type=type,
class_name='%s.%s' % (
obj.__class__.__module__,
obj.__class__.__name__),
project_id=None,
project_shortname='',
app_config_id=obj.app_config_id,
tool_name='',
mount_point='',
when=datetime.utcnow())
if obj.app_config:
d.update(
project_id=obj.app_config.project_id,
project_shortname=obj.app_config.project.shortname,
tool_name=obj.app_config.tool_name,
mount_point=obj.app_config.options.mount_point)
doc = cls.make(d)
doc.m.insert()
@classmethod
def stats(cls, since=None):
result = defaultdict(lambda:dict(create=0, modify=0, delete=0))
if since:
q = dict(when={'$gt':datetime.combine(since, time.min)})
else:
q = {}
for doc in cls.m.find(q).sort([('tool_name', 1), ('class_name', 1)]):
result[doc.tool_name, doc.class_name][doc.type] += 1
result = sorted(result.iteritems())
return [ dict(v, tool_name=k[0], class_name=k[1])
for k,v in result]