-
-
Notifications
You must be signed in to change notification settings - Fork 76
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: add AsyncAPI V3 compatible SQS binding definitions #261
base: master
Are you sure you want to change the base?
Conversation
@dpwdec hey, I noticed you introduced versioning for binding. The thing is that bindings atm should be aligned with spec, which means only the latest binding version should be in |
Whilst we are not extending |
I get your point. We had the same convo for Kafka binding. Afaik it was around v3 release date. Till today there were no complaints that people need updates to v2 bindings If we keep supporting v2, people are not motivated to move to v3. As org we do all we can to motivate to migrate, converters and other tools support it already, and supported them on release date. If in bindings we wanna go away from that model, then imho it could be a decision all binding owners agree with, so we are consistent. But my recommendation is to really consider it, be worried about it only if there is really a request coming from the community to add something to v2 binding, and that it is critical and there is no other way to do it. Once we let in v2 support for one binding, it is opening door for precedence to do it for other bindings, and event the spec, and you know EDA and AsyncAPI maintenance is complex enough with one version in place 😅 And in the end, if one day, we see there is a really critical reason to improve some v2 binding, then it can be done as "one-time-exception" with some dedicated branch/tag and clear story in issue/PR why we had to do it. |
@dpwdec @iancooper thoughts? |
As AsyncAPI moves forward, it will have to accept that users will lag behind the latest version of the specification. Adoption has some dependency on support for earlier versions. Now, admittedly, we are towards the start of this journey, but where folks have tooling built against V2, we will break them if we don't retain compatibility with it. So, at JET, we have tooling that uses V2. We can't shift all those folks over to V3 overnight. There are many endpoints, and even if we automated the process of converting their scripts, the review process would take weeks, and involve a lot of sign-offs. That would likely lead us to fork, so that we could maintain V2. So I think we need a policy here. A typical one is to support the current release, and one release earlier. The problem then becomes, do we match bindings version to AsyncAPI version? I think for sanity yes, so we have V2 bindings for V2 and V3 for V3 etc. Now, I would caveat that. I would ensure that once V3 is out, V2 only gets additive, non-breaking changes. So you can't change the binding for V2 in a non-backwards compatible way. That is because, the only reason to have V2 is backwards compatibility, and if a new release of the middleware comes out, whilst you are still on V2, just upgrade your AsyncAPI to V3 But that also means that in V3 we might need to have breaking changes. That is because we might find that the API for middleware changes in a fashion that is not backwards compatible. We might have to use a non-SemVer approach at that point and use V3.X where X is a breaking change. It is a slightly different painpoint than with OpenAPI, because it does not need to version. |
BTW, I am not sure if we need to communicate binding version in the binding specification. I suspect that is mostly out-of-band, but not really thought that through @dpwdec ? |
100%, I don't think anybody really thinks people always move to latest ASAP, even though we provide proper conversion solutions.
Tooling is a bit different thing. We still have tools, like parser, generator and many others that support v2 and provide bug fixes there. So nobody here is saying: stop using tools for v2 - just at the moment the message is, if you want new features that are not yet in the spec, add them to new spec or new spec binding and support this new spec feature in the tool, then just make sure you migrate to new spec. If someone can switch to using a newer binding version, why not switch to a newer spec version?
100% as we already had this discussion in the case of kafka for v3: #182 So yeah, please make sure |
@dpwdec @iancooper kind reminder |
Hi @derberg Apologies for the slow reply. So to clarify, you would like V2 bindings entirely overwritten for V3 to master? And for a separate thread/PR to be raised on how to handle the legacy V2 bindings? |
exactly if you really need to do some improvements in v2 lets figure out the way. We can always open a v2 branch if you really think it is needed. Although I would suggest we do it when it is really needed. As in the kafka issue I linked - we had concerns that people might want to improve v2 related binding but after so many months the reality is that nobody asked for it |
@dpwdec any news? |
Hi @derberg I've updated this to be only V3 bindings. |
I've also incremented the version. @derberg Not sure if this should be a major version change for V3? But the other bindings don't seem to have done a major version bump. |
lgtm, yeah, for now all bindings are at version can you do the same revert in https://github.com/asyncapi/bindings/tree/master/sns ? |
Maybe we need to establish a working group. Obviously, if folks are doing work, based on our experience of using AsyncAPI bindings, and then meet resistance to proposed changes, that is "wasted effort." I also think that it is important to understand the AsyncAPI versioning policy, as it would make it very difficult for tool authors, both internal to organizations, and externally to support tooling, if they can't support changes for earlier versions of the specification, either to support changes to the underlying protocol used in the binding with the earlier version, or to fix issues. We are not going to be able to debate that in this issue. But, we ought to be able to debate it somewhere. |
Update to SQS binding definitions for AsyncAPI V3 compatibility.
#255