10637.3.1
by Guilherme Salgado
Use the default python version instead of a hard-coded version |
1 |
#!/usr/bin/python -uS
|
8687.15.22
by Karl Fogel
Add the copyright header block to the remaining .py files. |
2 |
#
|
13813.1.6
by Stuart Bishop
Revert reversion in launchpad/devel r13865 |
3 |
# Copyright 2009-2011 Canonical Ltd. This software is licensed under the
|
8687.15.22
by Karl Fogel
Add the copyright header block to the remaining .py files. |
4 |
# GNU Affero General Public License version 3 (see the file LICENSE).
|
5 |
||
7459.5.14
by Michael Hudson
move stuff out of script file, test it, including one that shows we haven't got |
6 |
# pylint: disable-msg=W0403
|
7459.5.2
by Michael Hudson
add somewhat working script |
7 |
|
7459.8.1
by Michael Hudson
so much so boring |
8 |
"""Script intended to run as a :prg: RewriteMap.
|
9 |
||
10 |
See http://httpd.apache.org/docs/2.2/mod/mod_rewrite.html#rewritemap for the
|
|
11 |
documentation of the very simple 'protocol' Apache uses to talk to us, and
|
|
8426.6.2
by Michael Hudson
a few more references in comments and docstrings |
12 |
lp.codehosting.rewrite.BranchRewriter for the logic of the rewritemap.
|
7459.8.1
by Michael Hudson
so much so boring |
13 |
"""
|
14 |
||
8971.10.1
by Michael Hudson
beef up the tests! |
15 |
import os |
7459.5.2
by Michael Hudson
add somewhat working script |
16 |
import sys |
8971.10.2
by Michael Hudson
version that does direct database access, no caching though! |
17 |
|
14027.3.2
by Jeroen Vermeulen
Merge devel, resolve conflicts. |
18 |
import _pythonpath |
19 |
||
8971.10.19
by Michael Hudson
autocommit is appropriate for us -- no long running transactions thanks! |
20 |
from canonical.config import config |
13813.1.6
by Stuart Bishop
Revert reversion in launchpad/devel r13865 |
21 |
from canonical.launchpad.interfaces.lpstorm import ISlaveStore |
22 |
from lp.code.model.branch import Branch |
|
8426.6.1
by Michael Hudson
bzr ls --versioned --recursive --kind=file | xargs sed -i -e 's,from canonical.codehosting,from lp.codehosting,' |
23 |
from lp.codehosting.rewrite import BranchRewriter |
14027.3.2
by Jeroen Vermeulen
Merge devel, resolve conflicts. |
24 |
from lp.services.log.loglevels import ( |
25 |
INFO, |
|
26 |
WARNING, |
|
27 |
)
|
|
8356.1.9
by Leonard Richardson
Renamed the base script module in scripts/, which module_rename.py didn't touch because it wasn't under lib/. |
28 |
from lp.services.scripts.base import LaunchpadScript |
7459.5.2
by Michael Hudson
add somewhat working script |
29 |
|
30 |
||
7459.5.14
by Michael Hudson
move stuff out of script file, test it, including one that shows we haven't got |
31 |
class BranchRewriteScript(LaunchpadScript): |
7459.5.7
by Michael Hudson
start using usual script infrastructure |
32 |
|
11300.2.51
by Stuart Bishop
Fix branch rewrite script stderr handling |
33 |
# By default, only emit WARNING and above messages to stderr, which
|
34 |
# will end up in the Apache error log.
|
|
35 |
loglevel = WARNING |
|
36 |
||
7459.8.1
by Michael Hudson
so much so boring |
37 |
def add_my_options(self): |
38 |
"""Make the logging go to a file by default.
|
|
39 |
||
40 |
Because this script is run by Apache, logging to stderr results in our
|
|
41 |
log output ending up in Apache's error.log, which is not so useful.
|
|
42 |
We hack the OptionParser to set the default (which will be applied;
|
|
43 |
Apache doesn't pass any arguments to the script it starts up) to a
|
|
44 |
value from the config.
|
|
45 |
"""
|
|
46 |
log_file_location = config.codehosting.rewrite_script_log_file |
|
8971.10.1
by Michael Hudson
beef up the tests! |
47 |
log_file_directory = os.path.dirname(log_file_location) |
48 |
if not os.path.isdir(log_file_directory): |
|
49 |
os.makedirs(log_file_directory) |
|
7459.8.1
by Michael Hudson
so much so boring |
50 |
self.parser.defaults['log_file'] = log_file_location |
11300.2.51
by Stuart Bishop
Fix branch rewrite script stderr handling |
51 |
self.parser.defaults['log_file_level'] = INFO |
7459.8.1
by Michael Hudson
so much so boring |
52 |
|
7459.5.7
by Michael Hudson
start using usual script infrastructure |
53 |
def main(self): |
8971.10.2
by Michael Hudson
version that does direct database access, no caching though! |
54 |
rewriter = BranchRewriter(self.logger) |
7459.5.11
by Michael Hudson
final (?) refactorings |
55 |
self.logger.debug("Starting up...") |
7459.5.7
by Michael Hudson
start using usual script infrastructure |
56 |
while True: |
57 |
try: |
|
7660.2.1
by Tim Penhey
Add a way for the function to return other than a KeyboardInterrupt. |
58 |
line = sys.stdin.readline() |
59 |
# Mod-rewrite always gives us a newline terminated string.
|
|
60 |
if line: |
|
8971.10.2
by Michael Hudson
version that does direct database access, no caching though! |
61 |
print rewriter.rewriteLine(line.strip()) |
7660.2.1
by Tim Penhey
Add a way for the function to return other than a KeyboardInterrupt. |
62 |
else: |
63 |
# Standard input has been closed, so die.
|
|
64 |
return
|
|
13813.3.3
by Stuart Bishop
Revert KeyboardInterrupt handling change |
65 |
except KeyboardInterrupt: |
66 |
sys.exit() |
|
13813.1.6
by Stuart Bishop
Revert reversion in launchpad/devel r13865 |
67 |
except Exception: |
7459.8.1
by Michael Hudson
so much so boring |
68 |
self.logger.exception('Exception occurred:') |
7459.5.9
by Michael Hudson
more misc. improvments |
69 |
print "NULL" |
13813.1.6
by Stuart Bishop
Revert reversion in launchpad/devel r13865 |
70 |
# The exception might have been a DisconnectionError or
|
71 |
# similar. Cleanup such as database reconnection will
|
|
72 |
# not happen until the transaction is rolled back.
|
|
73 |
# XXX StuartBishop 2011-08-31 bug=819282: We are
|
|
74 |
# explicitly rolling back the store here as a workaround
|
|
75 |
# instead of using transaction.abort()
|
|
76 |
try: |
|
77 |
ISlaveStore(Branch).rollback() |
|
78 |
except Exception: |
|
79 |
self.logger.exception('Exception occurred in rollback:') |
|
7459.5.7
by Michael Hudson
start using usual script infrastructure |
80 |
|
81 |
||
82 |
if __name__ == '__main__': |
|
8971.10.19
by Michael Hudson
autocommit is appropriate for us -- no long running transactions thanks! |
83 |
BranchRewriteScript("branch-rewrite", dbuser='branch-rewrite').run( |
14022.3.2
by William Grant
LaunchpadScript no longer uses initZopeless. |
84 |
isolation='autocommit') |