t3301: test proper exit response to no-value notes.displayRef.
[git] / t / lib-httpd / apache.conf
1 ServerName dummy
2 PidFile httpd.pid
3 DocumentRoot www
4 LogFormat "%h %l %u %t \"%r\" %>s %b" common
5 CustomLog access.log common
6 ErrorLog error.log
7 <IfModule !mod_log_config.c>
8         LoadModule log_config_module modules/mod_log_config.so
9 </IfModule>
10 <IfModule !mod_alias.c>
11         LoadModule alias_module modules/mod_alias.so
12 </IfModule>
13 <IfModule !mod_cgi.c>
14         LoadModule cgi_module modules/mod_cgi.so
15 </IfModule>
16 <IfModule !mod_env.c>
17         LoadModule env_module modules/mod_env.so
18 </IfModule>
19 <IfModule !mod_rewrite.c>
20         LoadModule rewrite_module modules/mod_rewrite.so
21 </IFModule>
22 <IfModule !mod_version.c>
23         LoadModule version_module modules/mod_version.so
24 </IfModule>
25 <IfModule !mod_headers.c>
26         LoadModule headers_module modules/mod_headers.so
27 </IfModule>
28 <IfModule !mod_setenvif.c>
29         LoadModule setenvif_module modules/mod_setenvif.so
30 </IfModule>
31
32 <IfVersion < 2.4>
33 LockFile accept.lock
34 </IfVersion>
35
36 <IfVersion < 2.1>
37 <IfModule !mod_auth.c>
38         LoadModule auth_module modules/mod_auth.so
39 </IfModule>
40 </IfVersion>
41
42 <IfVersion >= 2.1>
43 <IfModule !mod_auth_basic.c>
44         LoadModule auth_basic_module modules/mod_auth_basic.so
45 </IfModule>
46 <IfModule !mod_authn_file.c>
47         LoadModule authn_file_module modules/mod_authn_file.so
48 </IfModule>
49 <IfModule !mod_authz_user.c>
50         LoadModule authz_user_module modules/mod_authz_user.so
51 </IfModule>
52 <IfModule !mod_authz_host.c>
53         LoadModule authz_host_module modules/mod_authz_host.so
54 </IfModule>
55 </IfVersion>
56
57 <IfVersion >= 2.4>
58 <IfModule !mod_authn_core.c>
59         LoadModule authn_core_module modules/mod_authn_core.so
60 </IfModule>
61 <IfModule !mod_authz_core.c>
62         LoadModule authz_core_module modules/mod_authz_core.so
63 </IfModule>
64 <IfModule !mod_access_compat.c>
65         LoadModule access_compat_module modules/mod_access_compat.so
66 </IfModule>
67 <IfModule !mod_mpm_prefork.c>
68         LoadModule mpm_prefork_module modules/mod_mpm_prefork.so
69 </IfModule>
70 <IfModule !mod_unixd.c>
71         LoadModule unixd_module modules/mod_unixd.so
72 </IfModule>
73 </IfVersion>
74
75 PassEnv GIT_VALGRIND
76 PassEnv GIT_VALGRIND_OPTIONS
77 PassEnv GNUPGHOME
78 PassEnv ASAN_OPTIONS
79 PassEnv LSAN_OPTIONS
80 PassEnv GIT_TRACE
81 PassEnv GIT_CONFIG_NOSYSTEM
82 PassEnv GIT_TEST_SIDEBAND_ALL
83
84 SetEnvIf Git-Protocol ".*" GIT_PROTOCOL=$0
85
86 Alias /dumb/ www/
87 Alias /auth/dumb/ www/auth/dumb/
88
89 <LocationMatch /smart/>
90         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
91         SetEnv GIT_HTTP_EXPORT_ALL
92 </LocationMatch>
93 <LocationMatch /smart_noexport/>
94         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
95 </LocationMatch>
96 <LocationMatch /smart_custom_env/>
97         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
98         SetEnv GIT_HTTP_EXPORT_ALL
99         SetEnv GIT_COMMITTER_NAME "Custom User"
100         SetEnv GIT_COMMITTER_EMAIL custom@example.com
101 </LocationMatch>
102 <LocationMatch /smart_namespace/>
103         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
104         SetEnv GIT_HTTP_EXPORT_ALL
105         SetEnv GIT_NAMESPACE ns
106 </LocationMatch>
107 <LocationMatch /smart_cookies/>
108         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
109         SetEnv GIT_HTTP_EXPORT_ALL
110         Header set Set-Cookie name=value
111 </LocationMatch>
112 <LocationMatch /smart_headers/>
113         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
114         SetEnv GIT_HTTP_EXPORT_ALL
115 </LocationMatch>
116 <LocationMatch /one_time_sed/>
117         SetEnv GIT_EXEC_PATH ${GIT_EXEC_PATH}
118         SetEnv GIT_HTTP_EXPORT_ALL
119 </LocationMatch>
120 ScriptAliasMatch /error_git_upload_pack/(.*)/git-upload-pack error.sh/
121 ScriptAliasMatch /smart_*[^/]*/(.*) ${GIT_EXEC_PATH}/git-http-backend/$1
122 ScriptAlias /broken_smart/ broken-smart-http.sh/
123 ScriptAlias /error_smart/ error-smart-http.sh/
124 ScriptAlias /error/ error.sh/
125 ScriptAliasMatch /one_time_sed/(.*) apply-one-time-sed.sh/$1
126 <Directory ${GIT_EXEC_PATH}>
127         Options FollowSymlinks
128 </Directory>
129 <Files broken-smart-http.sh>
130         Options ExecCGI
131 </Files>
132 <Files error-smart-http.sh>
133         Options ExecCGI
134 </Files>
135 <Files error.sh>
136   Options ExecCGI
137 </Files>
138 <Files apply-one-time-sed.sh>
139         Options ExecCGI
140 </Files>
141 <Files ${GIT_EXEC_PATH}/git-http-backend>
142         Options ExecCGI
143 </Files>
144
145 RewriteEngine on
146 RewriteRule ^/dumb-redir/(.*)$ /dumb/$1 [R=301]
147 RewriteRule ^/smart-redir-perm/(.*)$ /smart/$1 [R=301]
148 RewriteRule ^/smart-redir-temp/(.*)$ /smart/$1 [R=302]
149 RewriteRule ^/smart-redir-auth/(.*)$ /auth/smart/$1 [R=301]
150 RewriteRule ^/smart-redir-limited/(.*)/info/refs$ /smart/$1/info/refs [R=301]
151 RewriteRule ^/ftp-redir/(.*)$ ftp://localhost:1000/$1 [R=302]
152
153 RewriteRule ^/loop-redir/x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-x-(.*) /$1 [R=302]
154 RewriteRule ^/loop-redir/(.*)$ /loop-redir/x-$1 [R=302]
155
156 # redir-to/502/x?y -> really-redir-to?path=502/x&qs=y which returns 502
157 # redir-to/x?y -> really-redir-to?path=x&qs=y -> x?y
158 RewriteCond %{QUERY_STRING} ^(.*)$
159 RewriteRule ^/redir-to/(.*)$ /really-redir-to?path=$1&qs=%1 [R=302]
160 RewriteCond %{QUERY_STRING} ^path=502/(.*)&qs=(.*)$
161 RewriteRule ^/really-redir-to$ - [R=502,L]
162 RewriteCond %{QUERY_STRING} ^path=(.*)&qs=(.*)$
163 RewriteRule ^/really-redir-to$ /%1?%2 [R=302]
164
165 # The first rule issues a client-side redirect to something
166 # that _doesn't_ look like a git repo. The second rule is a
167 # server-side rewrite, so that it turns out the odd-looking
168 # thing _is_ a git repo. The "[PT]" tells Apache to match
169 # the usual ScriptAlias rules for /smart.
170 RewriteRule ^/insane-redir/(.*)$ /intern-redir/$1/foo [R=301]
171 RewriteRule ^/intern-redir/(.*)/foo$ /smart/$1 [PT]
172
173 # Serve info/refs internally without redirecting, but
174 # issue a redirect for any object requests.
175 RewriteRule ^/redir-objects/(.*/info/refs)$ /dumb/$1 [PT]
176 RewriteRule ^/redir-objects/(.*/objects/.*)$ /dumb/$1 [R=301]
177
178 # Apache 2.2 does not understand <RequireAll>, so we use RewriteCond.
179 # And as RewriteCond does not allow testing for non-matches, we match
180 # the desired case first (one has abra, two has cadabra), and let it
181 # pass by marking the RewriteRule as [L], "last rule, do not process
182 # any other matching RewriteRules after this"), and then have another
183 # RewriteRule that matches all other cases and lets them fail via '[F]',
184 # "fail the request".
185 RewriteCond %{HTTP:x-magic-one} =abra
186 RewriteCond %{HTTP:x-magic-two} =cadabra
187 RewriteRule ^/smart_headers/.* - [L]
188 RewriteRule ^/smart_headers/.* - [F]
189
190 <IfDefine SSL>
191 LoadModule ssl_module modules/mod_ssl.so
192
193 SSLCertificateFile httpd.pem
194 SSLCertificateKeyFile httpd.pem
195 SSLRandomSeed startup file:/dev/urandom 512
196 SSLRandomSeed connect file:/dev/urandom 512
197 SSLSessionCache none
198 SSLMutex file:ssl_mutex
199 SSLEngine On
200 </IfDefine>
201
202 <Location /auth/>
203         AuthType Basic
204         AuthName "git-auth"
205         AuthUserFile passwd
206         Require valid-user
207 </Location>
208
209 <LocationMatch "^/auth-push/.*/git-receive-pack$">
210         AuthType Basic
211         AuthName "git-auth"
212         AuthUserFile passwd
213         Require valid-user
214 </LocationMatch>
215
216 <LocationMatch "^/auth-fetch/.*/git-upload-pack$">
217         AuthType Basic
218         AuthName "git-auth"
219         AuthUserFile passwd
220         Require valid-user
221 </LocationMatch>
222
223 RewriteCond %{QUERY_STRING} service=git-receive-pack [OR]
224 RewriteCond %{REQUEST_URI} /git-receive-pack$
225 RewriteRule ^/half-auth-complete/ - [E=AUTHREQUIRED:yes]
226
227 <Location /half-auth-complete/>
228   Order Deny,Allow
229   Deny from env=AUTHREQUIRED
230
231   AuthType Basic
232   AuthName "Git Access"
233   AuthUserFile passwd
234   Require valid-user
235   Satisfy Any
236 </Location>
237
238 <IfDefine DAV>
239         LoadModule dav_module modules/mod_dav.so
240         LoadModule dav_fs_module modules/mod_dav_fs.so
241
242         DAVLockDB DAVLock
243         <Location /dumb/>
244                 Dav on
245         </Location>
246         <Location /auth/dumb>
247                 Dav on
248         </Location>
249 </IfDefine>
250
251 <IfDefine SVN>
252         LoadModule dav_svn_module modules/mod_dav_svn.so
253
254         <Location /${LIB_HTTPD_SVN}>
255                 DAV svn
256                 SVNPath "${LIB_HTTPD_SVNPATH}"
257         </Location>
258 </IfDefine>