]> andersk Git - zcommit.git/blame_incremental - zcommit.py
Added a README
[zcommit.git] / zcommit.py
... / ...
CommitLineData
1#!/usr/bin/python
2
3import cherrypy
4from flup.server.fcgi import WSGIServer
5import logging
6import json
7import os
8import subprocess
9import sys
10import traceback
11
12HERE = os.path.dirname(__file__)
13ZWRITE = os.path.join(HERE, 'bin', 'zsend')
14LOG_FILENAME = 'logs/zcommit.log'
15
16# Set up a specific logger with our desired output level
17logger = logging.getLogger(__name__)
18logger.setLevel(logging.DEBUG)
19
20# Add the log message handler to the logger
21handler = logging.FileHandler(LOG_FILENAME)
22logger.addHandler(handler)
23
24def zephyr(sender, klass, instance, zsig, msg):
25 # TODO: spoof the sender
26 logger.info("""About to send zephyr:
27sender: %(sender)s
28class: %(klass)s
29instance: %(instance)s
30zsig: %(zsig)s
31msg: %(msg)s""" % {'sender' : sender,
32 'klass' : klass,
33 'instance' : instance,
34 'zsig' : zsig,
35 'msg' : msg})
36 cmd = [ZWRITE, '-S', sender, '-c', klass, '-i', instance,
37 '-s', zsig, '-d', '-m', msg]
38 subprocess.check_call(cmd)
39
40class Application(object):
41 @cherrypy.expose
42 def index(self):
43 logger.debug('Hello world app reached')
44 return 'Hello world!'
45
46 class Github(object):
47 @cherrypy.expose
48 def default(self, *args, **query):
49 try:
50 return self._default(*args, **query)
51 except Exception, e:
52 logger.error('Caught exception %s:\n%s' % (e, traceback.format_exc()))
53 raise
54
55 def _default(self, *args, **query):
56 logger.info('A %s request with args: %r and query: %r' %
57 (cherrypy.request.method, args, query))
58 opts = {}
59 if len(args) % 2:
60 raise cherrypy.HTTPError(400, 'Invalid submission URL')
61 logger.debug('Passed validation')
62 for i in xrange(0, len(args), 2):
63 opts[args[i]] = args[i + 1]
64 logger.debug('Set opts')
65 if 'class' not in opts:
66 raise cherrypy.HTTPError(400, 'Must specify a zephyr class name')
67 logger.debug('Specified a class')
68 if cherrypy.request.method == 'POST':
69 logger.debug('About to load data')
70 payload = json.loads(query['payload'])
71 logger.debug('Loaded payload data')
72 zsig = payload['ref']
73 if 'zsig' in opts:
74 zsig = '%s: %s' % (opts['zsig'], zsig)
75 sender = opts.get('sender', 'daemon.zcommit')
76 logger.debug('Set zsig')
77 for c in reversed(payload['commits']):
78 inst = opts.get('instance', c['id'][:8])
79 actions = []
80 if c.get('added'):
81 actions.append('Added: %s\n' % '\n '.join(c['added']))
82 if c.get('removed'):
83 actions.append('Removed: %s\n' % '\n '.join(c['removed']))
84 if c.get('modified'):
85 actions.append('Modified: %s\n' % '\n '.join(c['modified']))
86 if not actions:
87 actions.append('Something weird happened... could not figure out what action to take')
88 info = {'name' : c['author']['name'],
89 'email' : c['author']['email'],
90 'message' : c['message'],
91 'timestamp' : c['timestamp'],
92 'actions' : '--\n'.join(actions)}
93
94 msg = """%(name)s <%(email)s> (%(timestamp)s)
95> %(message)s
96--
97%(actions)s""" % info
98 zephyr(sender, opts['class'], inst, zsig, msg)
99 msg = 'Thanks for posting!'
100 else:
101 msg = ('If you had sent a POST request to this URL, would have sent'
102 ' a zepyhr to -c %s' % opts['class'])
103 return msg
104
105 github = Github()
106
107def main():
108 app = cherrypy.tree.mount(Application(), '/zcommit')
109 cherrypy.server.unsubscribe()
110 cherrypy.engine.start()
111 try:
112 WSGIServer(app, environ={'SCRIPT_NAME' : '/zcommit'}).run()
113 finally:
114 cherrypy.engine.stop()
115
116if __name__ == '__main__':
117 sys.exit(main())
This page took 6.114953 seconds and 5 git commands to generate.