Mercurial

view contrib/win32/hgwebdir_wsgi.py @ 13072:8c6b7a5f38c4

merge with stable
author Matt Mackall <mpm@selenic.com>
date Wed, 01 Dec 2010 18:47:40 -0600
parents 36715cd6ee3d
children a2aa75118837
line source
1 # An example WSGI script for IIS/isapi-wsgi to export multiple hgweb repos
2 # Copyright 2010 Sune Foldager <cryo@cyanite.org>
3 #
4 # This software may be used and distributed according to the terms of the
5 # GNU General Public License version 2 or any later version.
6 #
7 # Requirements:
8 # - Python 2.6
9 # - PyWin32 build 214 or newer
10 # - Mercurial installed from source (python setup.py install)
11 # - IIS 7
12 #
13 # Earlier versions will in general work as well, but the PyWin32 version is
14 # necessary for win32traceutil to work correctly.
15 #
16 #
17 # Installation and use:
18 #
19 # - Download the isapi-wsgi source and run python setup.py install:
20 # http://code.google.com/p/isapi-wsgi/
21 #
22 # - Run this script (i.e. python hgwebdir_wsgi.py) to get a shim dll. The
23 # shim is identical for all scripts, so you can just copy and rename one
24 # from an earlier run, if you wish.
25 #
26 # - Setup an IIS application where your hgwebdir is to be served from.
27 # On 64-bit systems, make sure it's assigned a 32-bit app pool.
28 #
29 # - In the application, setup a wildcard script handler mapping of type
30 # IpsapiModule with the shim dll as its executable. This file MUST reside
31 # in the same directory as the shim. Remove all other handlers, if you wish.
32 #
33 # - Make sure the ISAPI and CGI restrictions (configured globally on the
34 # web server) includes the shim dll, to allow it to run.
35 #
36 # - Adjust the configuration variables below to match your needs.
37 #
39 # Configuration file location
40 hgweb_config = r'c:\src\iis\hg\hgweb.config'
42 # Global settings for IIS path translation
43 path_strip = 0 # Strip this many path elements off (when using url rewrite)
44 path_prefix = 1 # This many path elements are prefixes (depends on the
45 # virtual path of the IIS application).
47 import sys
49 # Adjust python path if this is not a system-wide install
50 #sys.path.insert(0, r'c:\path\to\python\lib')
52 # Enable tracing. Run 'python -m win32traceutil' to debug
53 if hasattr(sys, 'isapidllhandle'):
54 import win32traceutil
56 # To serve pages in local charset instead of UTF-8, remove the two lines below
57 import os
58 os.environ['HGENCODING'] = 'UTF-8'
61 import isapi_wsgi
62 from mercurial import demandimport; demandimport.enable()
63 from mercurial.hgweb.hgwebdir_mod import hgwebdir
65 # Example tweak: Replace isapi_wsgi's handler to provide better error message
66 # Other stuff could also be done here, like logging errors etc.
67 class WsgiHandler(isapi_wsgi.IsapiWsgiHandler):
68 error_status = '500 Internal Server Error' # less silly error message
70 isapi_wsgi.IsapiWsgiHandler = WsgiHandler
72 # Only create the hgwebdir instance once
73 application = hgwebdir(hgweb_config)
75 def handler(environ, start_response):
77 # Translate IIS's weird URLs
78 url = environ['SCRIPT_NAME'] + environ['PATH_INFO']
79 paths = url[1:].split('/')[path_strip:]
80 script_name = '/' + '/'.join(paths[:path_prefix])
81 path_info = '/'.join(paths[path_prefix:])
82 if path_info:
83 path_info = '/' + path_info
84 environ['SCRIPT_NAME'] = script_name
85 environ['PATH_INFO'] = path_info
87 return application(environ, start_response)
89 def __ExtensionFactory__():
90 return isapi_wsgi.ISAPISimpleHandler(handler)
92 if __name__=='__main__':
93 from isapi.install import *
94 params = ISAPIParameters()
95 HandleCommandLine(params)