On Wed, Jul 31, 2024 at 03:40:13PM +0200, Christian Couder wrote: > diff --git a/Documentation/gitprotocol-v2.txt b/Documentation/gitprotocol-v2.txt > index 414bc625d5..4d8d3839c4 100644 > --- a/Documentation/gitprotocol-v2.txt > +++ b/Documentation/gitprotocol-v2.txt > @@ -781,6 +781,43 @@ retrieving the header from a bundle at the indicated URI, and thus > save themselves and the server(s) the request(s) needed to inspect the > headers of that bundle or bundles. > > +promisor-remote=<pr-infos> > +~~~~~~~~~~~~~~~~~~~~~~~~~~ > + > +The server may advertise some promisor remotes it is using, if it's OK > +for the server that a client uses them too. In this case <pr-infos> > +should be of the form: > + > + pr-infos = pr-info | pr-infos ";" pr-info > + > + pr-info = "name=" pr-name | "name=" pr-name "," "url=" pr-url > + > +where `pr-name` is the name of a promisor remote, and `pr-url` the > +urlencoded URL of that promisor remote. > + > +In this case a client wanting to use one or more promisor remotes the > +server advertised should reply with "promisor-remote=<pr-names>" where > +<pr-names> should be of the form: > + > + pr-names = pr-name | pr-names ";" pr-name > + > +where `pr-name` is the name of a promisor remote the server > +advertised. > + > +If the server prefers a client not to use any promisor remote the > +server uses, or if the server doesn't use any promisor remote, it > +should only advertise "promisor-remote" without any value or "=" sign > +after it. > + > +In this case, or if the client doesn't want to use any promisor remote > +the server advertised, the client should reply only "promisor-remote" > +without any value or "=" sign after it. Why does the client have to advertise anything if they don't want to use any of the promisor remotes? > +The "promisor.advertise" and "promisor.acceptFromServer" configuration > +options can be used on the server and client side respectively to > +control what they advertise or accept respectively. See the > +documentation of these configuration options for more information. One thing I'm not totally clear on is the consequence of this capability. What is the expected consequence if the client accepts one of the promisor remotes? What is the consequence if the client accepts none? In the former case I'd expect that the server is free to omit objects, but that isn't made explicit anywhere, I think. Also, is there any mechanism that tells the client exactly which objects have been omitted? In the latter case I assume that the result will be a full clone, that is the server fetched any objects it didn't have from the promisor? Or does the server side continue to only honor whatever the client has provided as object filters, but signals to the client that it shall please contact somebody else when backfilling those promised objects? Patrick
Attachment:
signature.asc
Description: PGP signature