167
by Michael Hudson
make serve-branches.py executable |
1 |
#!/usr/bin/env python
|
183.2.1
by John Arbash Meinel
Add Copyright information to most files. |
2 |
# This program is free software; you can redistribute it and/or modify
|
3 |
# it under the terms of the GNU General Public License as published by
|
|
4 |
# the Free Software Foundation; either version 2 of the License, or
|
|
5 |
# (at your option) any later version.
|
|
6 |
#
|
|
7 |
# This program is distributed in the hope that it will be useful,
|
|
8 |
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
9 |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
10 |
# GNU General Public License for more details.
|
|
11 |
#
|
|
12 |
# You should have received a copy of the GNU General Public License
|
|
13 |
# along with this program; if not, write to the Free Software
|
|
14 |
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
15 |
||
16 |
"""Search for branches underneath a directory and serve them all."""
|
|
17 |
||
174
by Michael Hudson
misc logging improvements: |
18 |
import logging |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
19 |
import os |
165.1.4
by Michael Hudson
change serve-branches.py to be easier to document :) |
20 |
import sys |
21 |
||
270.1.1
by Michael Hudson
defer loading of plugins until after we've set up the logging |
22 |
from bzrlib.plugin import load_plugins |
23 |
||
165.1.4
by Michael Hudson
change serve-branches.py to be easier to document :) |
24 |
from paste import httpserver |
264
by Michael Hudson
error if you run serve-branches behind proxy when paste.deploy is not available |
25 |
from paste.httpexceptions import HTTPExceptionHandler, HTTPInternalServerError |
165.1.4
by Michael Hudson
change serve-branches.py to be easier to document :) |
26 |
from paste.translogger import TransLogger |
27 |
||
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
28 |
from loggerhead import __version__ |
29 |
from loggerhead.apps.filesystem import ( |
|
30 |
BranchesFromFileSystemRoot, UserBranchesFromFileSystemRoot) |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
31 |
from loggerhead.config import LoggerheadConfig |
219.1.2
by Guillermo Gonzalez
* update NEWS and serve-branches man page |
32 |
from loggerhead.util import Reloader |
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
33 |
from loggerhead.apps.error import ErrorHandlerApp |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
34 |
|
35 |
||
36 |
def main(args): |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
37 |
config = LoggerheadConfig() |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
38 |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
39 |
if config.get_option('show_version'): |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
40 |
print "loggerhead %s" % __version__ |
41 |
sys.exit(0) |
|
42 |
||
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
43 |
if config.arg_count > 1: |
44 |
config.print_help() |
|
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
45 |
sys.exit(1) |
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
46 |
elif config.arg_count == 1: |
321
by Michael Hudson
fix bug #353230, thanks Peter Bui |
47 |
path = config.get_arg(0) |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
48 |
else: |
49 |
path = '.' |
|
50 |
||
51 |
if not os.path.isdir(path): |
|
52 |
print "%s is not a directory" % path |
|
53 |
sys.exit(1) |
|
54 |
||
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
55 |
if config.get_option('trunk_dir') and not config.get_option('user_dirs'): |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
56 |
print "--trunk-dir is only valid with --user-dirs" |
57 |
sys.exit(1) |
|
217.2.1
by Michael Hudson
whitespace, style, typos |
58 |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
59 |
if config.get_option('reload'): |
219.1.2
by Guillermo Gonzalez
* update NEWS and serve-branches man page |
60 |
if Reloader.is_installed(): |
61 |
Reloader.install() |
|
219.1.1
by Guillermo Gonzalez
* added --reload option |
62 |
else: |
219.1.2
by Guillermo Gonzalez
* update NEWS and serve-branches man page |
63 |
return Reloader.restart_with_reloader() |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
64 |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
65 |
if config.get_option('user_dirs'): |
327
by Matt Nordhoff
Fix incorrect calls to config.get_option() (bug #361238) |
66 |
if not config.get_option('trunk_dir'): |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
67 |
print "You didn't specify a directory for the trunk directories." |
68 |
sys.exit(1) |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
69 |
app = UserBranchesFromFileSystemRoot( |
70 |
path, config.get_option('trunk_dir')) |
|
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
71 |
else: |
72 |
app = BranchesFromFileSystemRoot(path) |
|
217.2.1
by Michael Hudson
whitespace, style, typos |
73 |
|
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
74 |
# setup_logging()
|
75 |
logging.basicConfig() |
|
76 |
logging.getLogger('').setLevel(logging.DEBUG) |
|
77 |
logger = getattr(app, 'log', logging.getLogger('loggerhead')) |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
78 |
if config.get_option('log_folder'): |
79 |
logfile_path = os.path.join( |
|
327
by Matt Nordhoff
Fix incorrect calls to config.get_option() (bug #361238) |
80 |
config.get_option('log_folder'), 'serve-branches.log') |
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
81 |
else: |
82 |
logfile_path = 'serve-branches.log' |
|
83 |
logfile = logging.FileHandler(logfile_path, 'a') |
|
84 |
formatter = logging.Formatter('%(asctime)s %(levelname)-8s %(name)s:' |
|
85 |
' %(message)s') |
|
86 |
logfile.setFormatter(formatter) |
|
87 |
logfile.setLevel(logging.DEBUG) |
|
88 |
logger.addHandler(logfile) |
|
314.1.7
by Paul Hummer
Fixed logging for memory profiling |
89 |
|
315.1.5
by Paul Hummer
Fixed an issue where I seemed to have poo for brains at the time, and created memory profile logs ALL the time. |
90 |
if config.get_option('memory_profile'): |
91 |
memprofile = logging.getLogger('loggerhead-memprofile') |
|
92 |
memprofile.setLevel(logging.DEBUG) |
|
93 |
memprofile.addHandler(logging.FileHandler('loggerhead-memprofile')) |
|
314.1.7
by Paul Hummer
Fixed logging for memory profiling |
94 |
|
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
95 |
# setup_logging() #end
|
314.1.9
by Paul Hummer
Whitespace fix |
96 |
|
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
97 |
app = TransLogger(app, logger=logger) |
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
98 |
if config.get_option('profile'): |
232.1.7
by Robert Collins
Allow lsprofile data on requests to be gathered. |
99 |
from loggerhead.middleware.profile import LSProfMiddleware |
100 |
app = LSProfMiddleware(app) |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
101 |
if config.get_option('memory_profile'): |
314.1.6
by Paul Hummer
Added update method for memory profiling middleware. |
102 |
from loggerhead.middleware.profile import MemoryProfileMiddleware |
103 |
app = MemoryProfileMiddleware(app) |
|
217.1.4
by Guillermo Gonzalez
* new apps module: "error" and ErrorHandlerApp middleware |
104 |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
105 |
if not config.get_option('user_prefix'): |
215.1.2
by Martin Albisetti
Add --prefix option for hosts |
106 |
prefix = '/' |
107 |
else: |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
108 |
prefix = config.get_option('user_prefix') |
277
by Michael Hudson
* make example Apache stanza more correct with how PasteDeploy works |
109 |
if not prefix.startswith('/'): |
110 |
prefix = '/' + prefix |
|
215.1.2
by Martin Albisetti
Add --prefix option for hosts |
111 |
|
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
112 |
try: |
113 |
from paste.deploy.config import PrefixMiddleware |
|
114 |
except ImportError: |
|
264
by Michael Hudson
error if you run serve-branches behind proxy when paste.deploy is not available |
115 |
cant_proxy_correctly_message = ( |
116 |
'Unsupported configuration: PasteDeploy not available, but '
|
|
117 |
'loggerhead appears to be behind a proxy.') |
|
118 |
def check_not_proxied(app): |
|
119 |
def wrapped(environ, start_response): |
|
120 |
if 'HTTP_X_FORWARDED_SERVER' in environ: |
|
121 |
exc = HTTPInternalServerError() |
|
122 |
exc.explanation = cant_proxy_correctly_message |
|
123 |
raise exc |
|
124 |
return app(environ, start_response) |
|
125 |
return wrapped |
|
126 |
app = check_not_proxied(app) |
|
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
127 |
else: |
215.1.2
by Martin Albisetti
Add --prefix option for hosts |
128 |
app = PrefixMiddleware(app, prefix=prefix) |
217.2.1
by Michael Hudson
whitespace, style, typos |
129 |
|
266.2.13
by Michael Hudson
raise a 404 when passed an invalid revid |
130 |
app = HTTPExceptionHandler(app) |
264
by Michael Hudson
error if you run serve-branches behind proxy when paste.deploy is not available |
131 |
app = ErrorHandlerApp(app) |
132 |
||
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
133 |
if not config.get_option('user_port'): |
215.1.1
by Martin Albisetti
* Allow specifying a custom port |
134 |
port = '8080' |
135 |
else: |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
136 |
port = config.get_option('user_port') |
215.1.1
by Martin Albisetti
* Allow specifying a custom port |
137 |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
138 |
if not config.get_option('user_host'): |
215.1.1
by Martin Albisetti
* Allow specifying a custom port |
139 |
host = '0.0.0.0' |
140 |
else: |
|
315.1.3
by Paul Hummer
Moar integrations for the config codes! |
141 |
host = config.get_option('user_host') |
215.1.1
by Martin Albisetti
* Allow specifying a custom port |
142 |
|
270.1.1
by Michael Hudson
defer loading of plugins until after we've set up the logging |
143 |
load_plugins() |
144 |
||
215.1.1
by Martin Albisetti
* Allow specifying a custom port |
145 |
httpserver.serve(app, host=host, port=port) |
189.1.2
by Tim Penhey
Extend serve-branches to serve user dirs. |
146 |
|
147 |
||
148 |
if __name__ == "__main__": |
|
149 |
main(sys.argv) |