Parent: [3abb2e] (diff)

Download this file

react.py    74 lines (62 with data), 2.9 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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import logging
logging.config.fileConfig("config/react_logging.conf", disable_existing_loggers=False)
from lamson.routing import route, route_like, stateless
from config.settings import relay
from lamson import view, queue
import os
import ming
import pylons
from pylons import c
from paste.deploy import appconfig
from allura.config.environment import load_environment
from allura import model as M
from allura.model import Project
from allura.lib.app_globals import Globals
class EmptyClass(object): pass
@route("(appmount)\\.(apploc)@(proj)\\.(host)", appmount=".*", apploc=".*", proj=".*")
@stateless
def REACTING(message, post_name=None, appmount=None, apploc=None, proj=None, host=None):
conf = appconfig('config:%s' % '../Allura/development.ini',relative_to=os.getcwd())
load_environment(conf.global_conf, conf.local_conf)
pylons.c._push_object(EmptyClass())
pylons.g._push_object(Globals())
ming.configure(**conf)
project_id = '/'.join(reversed(proj.split('.'))) + '/'
try:
valid = M.Project.query.get(_id=project_id, deleted=False)
except:
logging.debug('REACT: project "' + proj + '" does not exist as project or user')
else:
logging.debug('REACT: project "' + proj + '" exists with id:' + project_id)
try:
c.project = M.Project.query.get(_id=project_id, deleted=False)
except:
logging.debug('REACT: cannot initialize valid project')
else:
logging.debug('REACT: retrieved valid project with mount point:' + appmount)
try:
c.project.app_config(appmount)
c.app = c.project.app_instance(appmount)
tool_name=c.app.config.tool_name
except:
logging.debug('REACT: invalid mount point (' + appmount + ')')
else:
logging.debug('REACT: valid mount point (' + appmount + ') with tool_name:' + tool_name)
routing_key = tool_name + '.' + apploc
mailto = message.__getitem__('To')
mailfrom = message.__getitem__('From')
mailsubj = message.__getitem__('Subject')
mailbody = message.body()
logging.debug('REACT: *** TO *** = ' + mailto)
logging.debug('REACT: *** FROM *** = ' + mailfrom)
logging.debug('REACT: *** SUBJECT *** = ' + mailsubj)
logging.debug('REACT: *** CONTENT *** = ' + message.body())
try:
pylons.g.publish('audit', routing_key,
dict(to=mailto,fro=mailfrom,subject=mailsubj,body=mailbody),
serializer='yaml')
except:
logging.debug('REACT: unable to queue message in carrot')
else:
logging.debug('REACT: successfully queued message in carrot with key:' + routing_key)
return REACTING