Hi Pawel,

Il 08/01/2025 09:57, kowa...@denic.de ha scritto:

[PK] This is all true, assuming there is always 100% match between the client and the server on the version. Note that here, because we version a specification not an implementation, we may face an unusual situation that the client may be ahead of the server. In this case if client depends on 0.8 functionality, it would not be fine with 0.4 response (missing fields added between 0.4 and 0.8). So, if the server eventually would ramp up 0.9 (not default yet) the client would not get 0.9 response which would be working for him, unless it makes 2-RTT flow and discovers 0.9 version, which it does not know (yet), but which may serve a compatible response for it.

The bottom line is, that the clients would either need the implement 2-RTT flow to get an optimum answer, or always support somehow the lowest version that may come from the server missing functionality that may have come from a better version.

This could be solved if the client would be able to make range version requests. For me it would be one of the reasons to bother with semantic versioning at all if machines could figure out on their own the best fit.

If it is not a goal and semantics behind versioning is just for humans, then I would return to my previous position that we shouldn't bother defining any semantics at all and let each extension define their own stuff how they like. It is a waste in my eyes to define and maintain strict rules for versioning with a new IANA registry and all processes around it.

[ML] At any time a client version of a given specification may be ahead of a server version and vice versa.

I wouldn't worry if the mismatch was due to a chain of backward compatible changes as the client can still process the response. Since we are talking about backward compatible versions, if the client is ahead of the server, all missing fields should be optional and the client would interpret their absence as a lack of information, vice versa, the client would ignore fields it doesn't recognize due to JSON being schemaless. Anyway, if both the client and the server supported the rdap-versioning spec, the client would get from the response the information about the version currently supported by the server. In a way, this is what happens when the client gets a redacted response. The only difference is that, if the server supports RFC 9537, the client can know that a missing field is not returned but supported.


If the mismatch is due to a breaking change, both clients and servers are expected to play their part in the transition process :

- The breaking version is supported as default by the client but not by the server

The client should previously check if that version is supported before asking the server for it or submitting a request anyway. If the new version is not supported, the client should be able to switch to the old version as long as all the servers it usually deals with are alligned to the new version. Please note that the client knows that it is asking for and expecting a version related to a breaking change with regard to the previous version.

-  The breaking version is supported as default by the server but not by the client

Similarly, the server should have previously planned a transition process to switch to that version to mitigate the risk of returning a breaking response. Such a transition should consist in first, announcing the sunrise of the new version, then serving the old version by default and the new version on request, finally returning the new version as default after giving appropriate time to all (or almost all of) the clients it deals with to switch to the new version. This is explained in the rdap-jscontact document.


Generally, this is expected to happen for every version upgrade but in case of mismatches due to non-breaking versions both clients and servers never risk to break interoperability.

I also think that since managing a transition process could be very cumbersome for both clients and servers depending on the scope of the breaking change, I think introducing a breaking version as the default should reset the sequence of non-breaking versions supported by both of them.

In conclusion, I do believe that the RTT-flow is needed to efficiently implement a possible transition process and the rdap-versioning spec is helpful in this respect.


Best,

Mario




--
Dott. Mario Loffredo
Senior Technologist
Technological Unit “Digital Innovation”
Institute of Informatics and Telematics (IIT)
National Research Council (CNR)
Address: Via G. Moruzzi 1, I-56124 PISA, Italy
Phone: +39.0503153497
Web: http://www.iit.cnr.it/mario.loffredo

_______________________________________________
regext mailing list -- regext@ietf.org
To unsubscribe send an email to regext-le...@ietf.org

Reply via email to