##// END OF EJS Templates
wireprotov2: advertise redirect targets in capabilities...
Gregory Szorc -
r40059:10cf8b11 default
parent child Browse files
Show More
This diff has been collapsed as it changes many lines, (601 lines changed) Show them Hide them
@@ -0,0 +1,601 b''
1 $ . $TESTDIR/wireprotohelpers.sh
2
3 $ hg init server
4 $ enablehttpv2 server
5 $ cd server
6 $ cat >> .hg/hgrc << EOF
7 > [extensions]
8 > simplecache = $TESTDIR/wireprotosimplecache.py
9 > EOF
10
11 $ echo a0 > a
12 $ echo b0 > b
13 $ hg -q commit -A -m 'commit 0'
14 $ echo a1 > a
15 $ hg commit -m 'commit 1'
16
17 $ hg --debug debugindex -m
18 rev linkrev nodeid p1 p2
19 0 0 992f4779029a3df8d0666d00bb924f69634e2641 0000000000000000000000000000000000000000 0000000000000000000000000000000000000000
20 1 1 a988fb43583e871d1ed5750ee074c6d840bbbfc8 992f4779029a3df8d0666d00bb924f69634e2641 0000000000000000000000000000000000000000
21
22 $ hg --config simplecache.redirectsfile=redirects.py serve -p $HGPORT -d --pid-file hg.pid -E error.log
23 $ cat hg.pid > $DAEMON_PIDS
24
25 $ cat > redirects.py << EOF
26 > [
27 > {
28 > b'name': b'target-a',
29 > b'protocol': b'http',
30 > b'snirequired': False,
31 > b'tlsversions': [b'1.2', b'1.3'],
32 > b'uris': [b'http://example.com/'],
33 > },
34 > ]
35 > EOF
36
37 Redirect targets advertised when configured
38
39 $ sendhttpv2peerhandshake << EOF
40 > command capabilities
41 > EOF
42 creating http peer for wire protocol version 2
43 s> GET /?cmd=capabilities HTTP/1.1\r\n
44 s> Accept-Encoding: identity\r\n
45 s> vary: X-HgProto-1,X-HgUpgrade-1\r\n
46 s> x-hgproto-1: cbor\r\n
47 s> x-hgupgrade-1: exp-http-v2-0002\r\n
48 s> accept: application/mercurial-0.1\r\n
49 s> host: $LOCALIP:$HGPORT\r\n (glob)
50 s> user-agent: Mercurial debugwireproto\r\n
51 s> \r\n
52 s> makefile('rb', None)
53 s> HTTP/1.1 200 OK\r\n
54 s> Server: testing stub value\r\n
55 s> Date: $HTTP_DATE$\r\n
56 s> Content-Type: application/mercurial-cbor\r\n
57 s> Content-Length: 1970\r\n
58 s> \r\n
59 s> \xa3GapibaseDapi/Dapis\xa1Pexp-http-v2-0002\xa6Hcommands\xaaIbranchmap\xa2Dargs\xa0Kpermissions\x81DpullLcapabilities\xa2Dargs\xa0Kpermissions\x81DpullMchangesetdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x84IbookmarksGparentsEphaseHrevisionInoderange\xa3Gdefault\xf6Hrequired\xf4DtypeDlistEnodes\xa3Gdefault\xf6Hrequired\xf4DtypeDlistJnodesdepth\xa3Gdefault\xf6Hrequired\xf4DtypeCintKpermissions\x81DpullHfiledata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDpath\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullEheads\xa2Dargs\xa1Jpubliconly\xa3Gdefault\xf4Hrequired\xf4DtypeDboolKpermissions\x81DpullEknown\xa2Dargs\xa1Enodes\xa3Gdefault\x80Hrequired\xf4DtypeDlistKpermissions\x81DpullHlistkeys\xa2Dargs\xa1Inamespace\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullFlookup\xa2Dargs\xa1Ckey\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullLmanifestdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDtree\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullGpushkey\xa2Dargs\xa4Ckey\xa2Hrequired\xf5DtypeEbytesInamespace\xa2Hrequired\xf5DtypeEbytesCnew\xa2Hrequired\xf5DtypeEbytesCold\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpushKcompression\x82\xa1DnameDzstd\xa1DnameDzlibQframingmediatypes\x81X&application/mercurial-exp-framing-0005Rpathfilterprefixes\xd9\x01\x02\x82Epath:Lrootfilesin:Nrawrepoformats\x82LgeneraldeltaHrevlogv1Hredirect\xa2Fhashes\x82Fsha256Dsha1Gtargets\x81\xa5DnameHtarget-aHprotocolDhttpKsnirequired\xf4Ktlsversions\x82C1.2C1.3Duris\x81Shttp://example.com/Nv1capabilitiesY\x01\xd8batch branchmap $USUAL_BUNDLE2_CAPS$ changegroupsubset compression=$BUNDLE2_COMPRESSIONS$ getbundle httpheader=1024 httpmediatype=0.1rx,0.1tx,0.2tx known lookup pushkey streamreqs=generaldelta,revlogv1 unbundle=HG10GZ,HG10BZ,HG10UN unbundlehash
60 sending capabilities command
61 s> POST /api/exp-http-v2-0002/ro/capabilities HTTP/1.1\r\n
62 s> Accept-Encoding: identity\r\n
63 s> accept: application/mercurial-exp-framing-0005\r\n
64 s> content-type: application/mercurial-exp-framing-0005\r\n
65 s> content-length: 27\r\n
66 s> host: $LOCALIP:$HGPORT\r\n (glob)
67 s> user-agent: Mercurial debugwireproto\r\n
68 s> \r\n
69 s> \x13\x00\x00\x01\x00\x01\x01\x11\xa1DnameLcapabilities
70 s> makefile('rb', None)
71 s> HTTP/1.1 200 OK\r\n
72 s> Server: testing stub value\r\n
73 s> Date: $HTTP_DATE$\r\n
74 s> Content-Type: application/mercurial-exp-framing-0005\r\n
75 s> Transfer-Encoding: chunked\r\n
76 s> \r\n
77 s> 13\r\n
78 s> \x0b\x00\x00\x01\x00\x02\x011
79 s> \xa1FstatusBok
80 s> \r\n
81 received frame(size=11; request=1; stream=2; streamflags=stream-begin; type=command-response; flags=continuation)
82 s> 5ab\r\n
83 s> \xa3\x05\x00\x01\x00\x02\x001
84 s> \xa6Hcommands\xaaIbranchmap\xa2Dargs\xa0Kpermissions\x81DpullLcapabilities\xa2Dargs\xa0Kpermissions\x81DpullMchangesetdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x84IbookmarksGparentsEphaseHrevisionInoderange\xa3Gdefault\xf6Hrequired\xf4DtypeDlistEnodes\xa3Gdefault\xf6Hrequired\xf4DtypeDlistJnodesdepth\xa3Gdefault\xf6Hrequired\xf4DtypeCintKpermissions\x81DpullHfiledata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDpath\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullEheads\xa2Dargs\xa1Jpubliconly\xa3Gdefault\xf4Hrequired\xf4DtypeDboolKpermissions\x81DpullEknown\xa2Dargs\xa1Enodes\xa3Gdefault\x80Hrequired\xf4DtypeDlistKpermissions\x81DpullHlistkeys\xa2Dargs\xa1Inamespace\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullFlookup\xa2Dargs\xa1Ckey\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullLmanifestdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDtree\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullGpushkey\xa2Dargs\xa4Ckey\xa2Hrequired\xf5DtypeEbytesInamespace\xa2Hrequired\xf5DtypeEbytesCnew\xa2Hrequired\xf5DtypeEbytesCold\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpushKcompression\x82\xa1DnameDzstd\xa1DnameDzlibQframingmediatypes\x81X&application/mercurial-exp-framing-0005Rpathfilterprefixes\xd9\x01\x02\x82Epath:Lrootfilesin:Nrawrepoformats\x82LgeneraldeltaHrevlogv1Hredirect\xa2Fhashes\x82Fsha256Dsha1Gtargets\x81\xa5DnameHtarget-aHprotocolDhttpKsnirequired\xf4Ktlsversions\x82C1.2C1.3Duris\x81Shttp://example.com/
85 s> \r\n
86 received frame(size=1443; request=1; stream=2; streamflags=; type=command-response; flags=continuation)
87 s> 8\r\n
88 s> \x00\x00\x00\x01\x00\x02\x002
89 s> \r\n
90 s> 0\r\n
91 s> \r\n
92 received frame(size=0; request=1; stream=2; streamflags=; type=command-response; flags=eos)
93 response: gen[
94 {
95 b'commands': {
96 b'branchmap': {
97 b'args': {},
98 b'permissions': [
99 b'pull'
100 ]
101 },
102 b'capabilities': {
103 b'args': {},
104 b'permissions': [
105 b'pull'
106 ]
107 },
108 b'changesetdata': {
109 b'args': {
110 b'fields': {
111 b'default': set([]),
112 b'required': False,
113 b'type': b'set',
114 b'validvalues': set([
115 b'bookmarks',
116 b'parents',
117 b'phase',
118 b'revision'
119 ])
120 },
121 b'noderange': {
122 b'default': None,
123 b'required': False,
124 b'type': b'list'
125 },
126 b'nodes': {
127 b'default': None,
128 b'required': False,
129 b'type': b'list'
130 },
131 b'nodesdepth': {
132 b'default': None,
133 b'required': False,
134 b'type': b'int'
135 }
136 },
137 b'permissions': [
138 b'pull'
139 ]
140 },
141 b'filedata': {
142 b'args': {
143 b'fields': {
144 b'default': set([]),
145 b'required': False,
146 b'type': b'set',
147 b'validvalues': set([
148 b'parents',
149 b'revision'
150 ])
151 },
152 b'haveparents': {
153 b'default': False,
154 b'required': False,
155 b'type': b'bool'
156 },
157 b'nodes': {
158 b'required': True,
159 b'type': b'list'
160 },
161 b'path': {
162 b'required': True,
163 b'type': b'bytes'
164 }
165 },
166 b'permissions': [
167 b'pull'
168 ]
169 },
170 b'heads': {
171 b'args': {
172 b'publiconly': {
173 b'default': False,
174 b'required': False,
175 b'type': b'bool'
176 }
177 },
178 b'permissions': [
179 b'pull'
180 ]
181 },
182 b'known': {
183 b'args': {
184 b'nodes': {
185 b'default': [],
186 b'required': False,
187 b'type': b'list'
188 }
189 },
190 b'permissions': [
191 b'pull'
192 ]
193 },
194 b'listkeys': {
195 b'args': {
196 b'namespace': {
197 b'required': True,
198 b'type': b'bytes'
199 }
200 },
201 b'permissions': [
202 b'pull'
203 ]
204 },
205 b'lookup': {
206 b'args': {
207 b'key': {
208 b'required': True,
209 b'type': b'bytes'
210 }
211 },
212 b'permissions': [
213 b'pull'
214 ]
215 },
216 b'manifestdata': {
217 b'args': {
218 b'fields': {
219 b'default': set([]),
220 b'required': False,
221 b'type': b'set',
222 b'validvalues': set([
223 b'parents',
224 b'revision'
225 ])
226 },
227 b'haveparents': {
228 b'default': False,
229 b'required': False,
230 b'type': b'bool'
231 },
232 b'nodes': {
233 b'required': True,
234 b'type': b'list'
235 },
236 b'tree': {
237 b'required': True,
238 b'type': b'bytes'
239 }
240 },
241 b'permissions': [
242 b'pull'
243 ]
244 },
245 b'pushkey': {
246 b'args': {
247 b'key': {
248 b'required': True,
249 b'type': b'bytes'
250 },
251 b'namespace': {
252 b'required': True,
253 b'type': b'bytes'
254 },
255 b'new': {
256 b'required': True,
257 b'type': b'bytes'
258 },
259 b'old': {
260 b'required': True,
261 b'type': b'bytes'
262 }
263 },
264 b'permissions': [
265 b'push'
266 ]
267 }
268 },
269 b'compression': [
270 {
271 b'name': b'zstd'
272 },
273 {
274 b'name': b'zlib'
275 }
276 ],
277 b'framingmediatypes': [
278 b'application/mercurial-exp-framing-0005'
279 ],
280 b'pathfilterprefixes': set([
281 b'path:',
282 b'rootfilesin:'
283 ]),
284 b'rawrepoformats': [
285 b'generaldelta',
286 b'revlogv1'
287 ],
288 b'redirect': {
289 b'hashes': [
290 b'sha256',
291 b'sha1'
292 ],
293 b'targets': [
294 {
295 b'name': b'target-a',
296 b'protocol': b'http',
297 b'snirequired': False,
298 b'tlsversions': [
299 b'1.2',
300 b'1.3'
301 ],
302 b'uris': [
303 b'http://example.com/'
304 ]
305 }
306 ]
307 }
308 }
309 ]
310
311 $ cat > redirects.py << EOF
312 > [
313 > {
314 > b'name': b'target-a',
315 > b'protocol': b'http',
316 > b'uris': [b'http://example.com/'],
317 > },
318 > {
319 > b'name': b'target-b',
320 > b'protocol': b'unknown',
321 > b'uris': [b'unknown://example.com/'],
322 > },
323 > ]
324 > EOF
325
326 $ sendhttpv2peerhandshake << EOF
327 > command capabilities
328 > EOF
329 creating http peer for wire protocol version 2
330 s> GET /?cmd=capabilities HTTP/1.1\r\n
331 s> Accept-Encoding: identity\r\n
332 s> vary: X-HgProto-1,X-HgUpgrade-1\r\n
333 s> x-hgproto-1: cbor\r\n
334 s> x-hgupgrade-1: exp-http-v2-0002\r\n
335 s> accept: application/mercurial-0.1\r\n
336 s> host: $LOCALIP:$HGPORT\r\n (glob)
337 s> user-agent: Mercurial debugwireproto\r\n
338 s> \r\n
339 s> makefile('rb', None)
340 s> HTTP/1.1 200 OK\r\n
341 s> Server: testing stub value\r\n
342 s> Date: $HTTP_DATE$\r\n
343 s> Content-Type: application/mercurial-cbor\r\n
344 s> Content-Length: 1997\r\n
345 s> \r\n
346 s> \xa3GapibaseDapi/Dapis\xa1Pexp-http-v2-0002\xa6Hcommands\xaaIbranchmap\xa2Dargs\xa0Kpermissions\x81DpullLcapabilities\xa2Dargs\xa0Kpermissions\x81DpullMchangesetdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x84IbookmarksGparentsEphaseHrevisionInoderange\xa3Gdefault\xf6Hrequired\xf4DtypeDlistEnodes\xa3Gdefault\xf6Hrequired\xf4DtypeDlistJnodesdepth\xa3Gdefault\xf6Hrequired\xf4DtypeCintKpermissions\x81DpullHfiledata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDpath\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullEheads\xa2Dargs\xa1Jpubliconly\xa3Gdefault\xf4Hrequired\xf4DtypeDboolKpermissions\x81DpullEknown\xa2Dargs\xa1Enodes\xa3Gdefault\x80Hrequired\xf4DtypeDlistKpermissions\x81DpullHlistkeys\xa2Dargs\xa1Inamespace\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullFlookup\xa2Dargs\xa1Ckey\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullLmanifestdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDtree\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullGpushkey\xa2Dargs\xa4Ckey\xa2Hrequired\xf5DtypeEbytesInamespace\xa2Hrequired\xf5DtypeEbytesCnew\xa2Hrequired\xf5DtypeEbytesCold\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpushKcompression\x82\xa1DnameDzstd\xa1DnameDzlibQframingmediatypes\x81X&application/mercurial-exp-framing-0005Rpathfilterprefixes\xd9\x01\x02\x82Epath:Lrootfilesin:Nrawrepoformats\x82LgeneraldeltaHrevlogv1Hredirect\xa2Fhashes\x82Fsha256Dsha1Gtargets\x82\xa3DnameHtarget-aHprotocolDhttpDuris\x81Shttp://example.com/\xa3DnameHtarget-bHprotocolGunknownDuris\x81Vunknown://example.com/Nv1capabilitiesY\x01\xd8batch branchmap $USUAL_BUNDLE2_CAPS$ changegroupsubset compression=$BUNDLE2_COMPRESSIONS$ getbundle httpheader=1024 httpmediatype=0.1rx,0.1tx,0.2tx known lookup pushkey streamreqs=generaldelta,revlogv1 unbundle=HG10GZ,HG10BZ,HG10UN unbundlehash
347 sending capabilities command
348 s> POST /api/exp-http-v2-0002/ro/capabilities HTTP/1.1\r\n
349 s> Accept-Encoding: identity\r\n
350 s> accept: application/mercurial-exp-framing-0005\r\n
351 s> content-type: application/mercurial-exp-framing-0005\r\n
352 s> content-length: 27\r\n
353 s> host: $LOCALIP:$HGPORT\r\n (glob)
354 s> user-agent: Mercurial debugwireproto\r\n
355 s> \r\n
356 s> \x13\x00\x00\x01\x00\x01\x01\x11\xa1DnameLcapabilities
357 s> makefile('rb', None)
358 s> HTTP/1.1 200 OK\r\n
359 s> Server: testing stub value\r\n
360 s> Date: $HTTP_DATE$\r\n
361 s> Content-Type: application/mercurial-exp-framing-0005\r\n
362 s> Transfer-Encoding: chunked\r\n
363 s> \r\n
364 s> 13\r\n
365 s> \x0b\x00\x00\x01\x00\x02\x011
366 s> \xa1FstatusBok
367 s> \r\n
368 received frame(size=11; request=1; stream=2; streamflags=stream-begin; type=command-response; flags=continuation)
369 s> 5c6\r\n
370 s> \xbe\x05\x00\x01\x00\x02\x001
371 s> \xa6Hcommands\xaaIbranchmap\xa2Dargs\xa0Kpermissions\x81DpullLcapabilities\xa2Dargs\xa0Kpermissions\x81DpullMchangesetdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x84IbookmarksGparentsEphaseHrevisionInoderange\xa3Gdefault\xf6Hrequired\xf4DtypeDlistEnodes\xa3Gdefault\xf6Hrequired\xf4DtypeDlistJnodesdepth\xa3Gdefault\xf6Hrequired\xf4DtypeCintKpermissions\x81DpullHfiledata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDpath\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullEheads\xa2Dargs\xa1Jpubliconly\xa3Gdefault\xf4Hrequired\xf4DtypeDboolKpermissions\x81DpullEknown\xa2Dargs\xa1Enodes\xa3Gdefault\x80Hrequired\xf4DtypeDlistKpermissions\x81DpullHlistkeys\xa2Dargs\xa1Inamespace\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullFlookup\xa2Dargs\xa1Ckey\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullLmanifestdata\xa2Dargs\xa4Ffields\xa4Gdefault\xd9\x01\x02\x80Hrequired\xf4DtypeCsetKvalidvalues\xd9\x01\x02\x82GparentsHrevisionKhaveparents\xa3Gdefault\xf4Hrequired\xf4DtypeDboolEnodes\xa2Hrequired\xf5DtypeDlistDtree\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpullGpushkey\xa2Dargs\xa4Ckey\xa2Hrequired\xf5DtypeEbytesInamespace\xa2Hrequired\xf5DtypeEbytesCnew\xa2Hrequired\xf5DtypeEbytesCold\xa2Hrequired\xf5DtypeEbytesKpermissions\x81DpushKcompression\x82\xa1DnameDzstd\xa1DnameDzlibQframingmediatypes\x81X&application/mercurial-exp-framing-0005Rpathfilterprefixes\xd9\x01\x02\x82Epath:Lrootfilesin:Nrawrepoformats\x82LgeneraldeltaHrevlogv1Hredirect\xa2Fhashes\x82Fsha256Dsha1Gtargets\x82\xa3DnameHtarget-aHprotocolDhttpDuris\x81Shttp://example.com/\xa3DnameHtarget-bHprotocolGunknownDuris\x81Vunknown://example.com/
372 s> \r\n
373 received frame(size=1470; request=1; stream=2; streamflags=; type=command-response; flags=continuation)
374 s> 8\r\n
375 s> \x00\x00\x00\x01\x00\x02\x002
376 s> \r\n
377 s> 0\r\n
378 s> \r\n
379 received frame(size=0; request=1; stream=2; streamflags=; type=command-response; flags=eos)
380 response: gen[
381 {
382 b'commands': {
383 b'branchmap': {
384 b'args': {},
385 b'permissions': [
386 b'pull'
387 ]
388 },
389 b'capabilities': {
390 b'args': {},
391 b'permissions': [
392 b'pull'
393 ]
394 },
395 b'changesetdata': {
396 b'args': {
397 b'fields': {
398 b'default': set([]),
399 b'required': False,
400 b'type': b'set',
401 b'validvalues': set([
402 b'bookmarks',
403 b'parents',
404 b'phase',
405 b'revision'
406 ])
407 },
408 b'noderange': {
409 b'default': None,
410 b'required': False,
411 b'type': b'list'
412 },
413 b'nodes': {
414 b'default': None,
415 b'required': False,
416 b'type': b'list'
417 },
418 b'nodesdepth': {
419 b'default': None,
420 b'required': False,
421 b'type': b'int'
422 }
423 },
424 b'permissions': [
425 b'pull'
426 ]
427 },
428 b'filedata': {
429 b'args': {
430 b'fields': {
431 b'default': set([]),
432 b'required': False,
433 b'type': b'set',
434 b'validvalues': set([
435 b'parents',
436 b'revision'
437 ])
438 },
439 b'haveparents': {
440 b'default': False,
441 b'required': False,
442 b'type': b'bool'
443 },
444 b'nodes': {
445 b'required': True,
446 b'type': b'list'
447 },
448 b'path': {
449 b'required': True,
450 b'type': b'bytes'
451 }
452 },
453 b'permissions': [
454 b'pull'
455 ]
456 },
457 b'heads': {
458 b'args': {
459 b'publiconly': {
460 b'default': False,
461 b'required': False,
462 b'type': b'bool'
463 }
464 },
465 b'permissions': [
466 b'pull'
467 ]
468 },
469 b'known': {
470 b'args': {
471 b'nodes': {
472 b'default': [],
473 b'required': False,
474 b'type': b'list'
475 }
476 },
477 b'permissions': [
478 b'pull'
479 ]
480 },
481 b'listkeys': {
482 b'args': {
483 b'namespace': {
484 b'required': True,
485 b'type': b'bytes'
486 }
487 },
488 b'permissions': [
489 b'pull'
490 ]
491 },
492 b'lookup': {
493 b'args': {
494 b'key': {
495 b'required': True,
496 b'type': b'bytes'
497 }
498 },
499 b'permissions': [
500 b'pull'
501 ]
502 },
503 b'manifestdata': {
504 b'args': {
505 b'fields': {
506 b'default': set([]),
507 b'required': False,
508 b'type': b'set',
509 b'validvalues': set([
510 b'parents',
511 b'revision'
512 ])
513 },
514 b'haveparents': {
515 b'default': False,
516 b'required': False,
517 b'type': b'bool'
518 },
519 b'nodes': {
520 b'required': True,
521 b'type': b'list'
522 },
523 b'tree': {
524 b'required': True,
525 b'type': b'bytes'
526 }
527 },
528 b'permissions': [
529 b'pull'
530 ]
531 },
532 b'pushkey': {
533 b'args': {
534 b'key': {
535 b'required': True,
536 b'type': b'bytes'
537 },
538 b'namespace': {
539 b'required': True,
540 b'type': b'bytes'
541 },
542 b'new': {
543 b'required': True,
544 b'type': b'bytes'
545 },
546 b'old': {
547 b'required': True,
548 b'type': b'bytes'
549 }
550 },
551 b'permissions': [
552 b'push'
553 ]
554 }
555 },
556 b'compression': [
557 {
558 b'name': b'zstd'
559 },
560 {
561 b'name': b'zlib'
562 }
563 ],
564 b'framingmediatypes': [
565 b'application/mercurial-exp-framing-0005'
566 ],
567 b'pathfilterprefixes': set([
568 b'path:',
569 b'rootfilesin:'
570 ]),
571 b'rawrepoformats': [
572 b'generaldelta',
573 b'revlogv1'
574 ],
575 b'redirect': {
576 b'hashes': [
577 b'sha256',
578 b'sha1'
579 ],
580 b'targets': [
581 {
582 b'name': b'target-a',
583 b'protocol': b'http',
584 b'uris': [
585 b'http://example.com/'
586 ]
587 },
588 {
589 b'name': b'target-b',
590 b'protocol': b'unknown',
591 b'uris': [
592 b'unknown://example.com/'
593 ]
594 }
595 ]
596 }
597 }
598 ]
599
600 $ cat error.log
601 $ killdaemons.py
@@ -517,8 +517,66 b' def _capabilitiesv2(repo, proto):'
517 517 caps['rawrepoformats'] = sorted(repo.requirements &
518 518 repo.supportedformats)
519 519
520 targets = getadvertisedredirecttargets(repo, proto)
521 if targets:
522 caps[b'redirect'] = {
523 b'targets': [],
524 b'hashes': [b'sha256', b'sha1'],
525 }
526
527 for target in targets:
528 entry = {
529 b'name': target['name'],
530 b'protocol': target['protocol'],
531 b'uris': target['uris'],
532 }
533
534 for key in ('snirequired', 'tlsversions'):
535 if key in target:
536 entry[key] = target[key]
537
538 caps[b'redirect'][b'targets'].append(entry)
539
520 540 return proto.addcapabilities(repo, caps)
521 541
542 def getadvertisedredirecttargets(repo, proto):
543 """Obtain a list of content redirect targets.
544
545 Returns a list containing potential redirect targets that will be
546 advertised in capabilities data. Each dict MUST have the following
547 keys:
548
549 name
550 The name of this redirect target. This is the identifier clients use
551 to refer to a target. It is transferred as part of every command
552 request.
553
554 protocol
555 Network protocol used by this target. Typically this is the string
556 in front of the ``://`` in a URL. e.g. ``https``.
557
558 uris
559 List of representative URIs for this target. Clients can use the
560 URIs to test parsing for compatibility or for ordering preference
561 for which target to use.
562
563 The following optional keys are recognized:
564
565 snirequired
566 Bool indicating if Server Name Indication (SNI) is required to
567 connect to this target.
568
569 tlsversions
570 List of bytes indicating which TLS versions are supported by this
571 target.
572
573 By default, clients reflect the target order advertised by servers
574 and servers will use the first client-advertised target when picking
575 a redirect target. So targets should be advertised in the order the
576 server prefers they be used.
577 """
578 return []
579
522 580 def wireprotocommand(name, args=None, permission='push', cachekeyfn=None):
523 581 """Decorator to declare a wire protocol command.
524 582
@@ -17,6 +17,7 b' from mercurial import ('
17 17 )
18 18 from mercurial.utils import (
19 19 interfaceutil,
20 stringutil,
20 21 )
21 22
22 23 CACHE = None
@@ -26,6 +27,8 b' configitem = registrar.configitem(config'
26 27
27 28 configitem('simplecache', 'cacheobjects',
28 29 default=False)
30 configitem('simplecache', 'redirectsfile',
31 default=None)
29 32
30 33 @interfaceutil.implementer(repository.iwireprotocolcommandcacher)
31 34 class memorycacher(object):
@@ -91,6 +94,19 b' class memorycacher(object):'
91 94 def makeresponsecacher(orig, repo, proto, command, args, objencoderfn):
92 95 return memorycacher(repo.ui, command, objencoderfn)
93 96
97 def loadredirecttargets(ui):
98 path = ui.config('simplecache', 'redirectsfile')
99 if not path:
100 return []
101
102 with open(path, 'rb') as fh:
103 s = fh.read()
104
105 return stringutil.evalpythonliteral(s)
106
107 def getadvertisedredirecttargets(orig, repo, proto):
108 return loadredirecttargets(repo.ui)
109
94 110 def extsetup(ui):
95 111 global CACHE
96 112
@@ -98,3 +114,5 b' def extsetup(ui):'
98 114
99 115 extensions.wrapfunction(wireprotov2server, 'makeresponsecacher',
100 116 makeresponsecacher)
117 extensions.wrapfunction(wireprotov2server, 'getadvertisedredirecttargets',
118 getadvertisedredirecttargets)
General Comments 0
You need to be logged in to leave comments. Login now