-
-
Notifications
You must be signed in to change notification settings - Fork 286
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
Add security mechanism info to Kafka bindings for server objects #466
Comments
This issue has been automatically marked as stale because it has not had recent activity 😴 |
There are a huge number of Kafka client configs we could add to server bindings, but I'm skeptical of the value of just copying them all across. Most client config values have sensible defaults that are suitable in most cases. cf. https://kafka.apache.org/documentation/#consumerconfigs Two values are essential for code generation with secured Kafka clusters, however - identifying the security mechanism and protocol to use. This commit adds these two most commonly-used parameters to the Kafka server bindings. I suggest we start with these and gauge usage before starting to add many more, as these are enough to enable code generation for secured Kafka clusters. Closes: asyncapi/spec#466 Signed-off-by: Dale Lane <[email protected]>
I wonder if adding another security mechanism to the AsyncAPI JSON Schema it makes sense in the long term. I mean looking at this table asyncapi/bindings#56 (comment) I have this problem that we may forget something and will have to tweak it in the AsyncAPI scheme and publish new version etc. Would treating # extension
id: saslSecurityScheme
type: securityScheme # new type of extension
title: ...
...
# spec
components:
securitySchemes:
usingSaslSecurityScheme
type: saslSecurityScheme
... I am aware that the above schema is not fully correct, but I hope that the idea itself is understandable. @fmvilas @derberg @jonaslagoni @smoya @dalelane Any thoughts? |
That's not a problem. Publishing a new version of the JSON Schema definition of the spec is not the same as publishing a new version of the spec. Remember, the spec is only the Markdown file. |
@fmvilas @derberg A few PRs ready for this now: #502 asyncapi/spec-json-schemas#53 asyncapi/parser-js#289 |
* feat: add SASL security scheme types for use by Kafka specs As discussed in asyncapi/bindings#56 this adds additional security scheme types. The motivation for adding them is to enable description of secured Kafka clusters, however the security protocols and mechanisms being added are not unique to Kafka, so this commit adds them as generic security schemes so they could be used by other protocols as well. Contributes to: #466 Signed-off-by: Dale Lane <[email protected]> * chore: update for grammar Moved the "and" to the end of the list. Signed-off-by: Dale Lane <[email protected]> * docs: additional SASL documentation Contributes to: #466 Signed-off-by: Dale Lane <[email protected]>
* chore: Start new schema file for 2.1.0 Copy of 2.0.0.json Contributes to: asyncapi/spec#466 Signed-off-by: Dale Lane <[email protected]> * feat: Add SASL mechanisms to the schema Contributes to: asyncapi/spec#466 Signed-off-by: Dale Lane <[email protected]> * chore: Update schema version number Contributes to: asyncapi/spec#466 Signed-off-by: Dale Lane <[email protected]>
🎉 This issue has been resolved in version 2.1.0-2021-06-release.2 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
* feat: update version for updated spec Contributes to: asyncapi/spec#466 Signed-off-by: Dale Lane <[email protected]> * Use @asyncapi/[email protected] Co-authored-by: Fran Mendez <[email protected]>
Main motivation of this was to provide a place to demonstrate the new Kafka-specific security schemes introduced in AsyncAPI 2.1.0. It was also a chance to remove the Kafka bindings from the otherwise-MQTT sample. The need for this was discussed in #502 Contributes to: #466 Signed-off-by: Dale Lane <[email protected]>
🎉 This issue has been resolved in version 2.2.0-2021-06-release.1 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
I guess we can close this right? 🤔 |
Is your feature request related to a problem? Please describe.
Kafka has several values that are essential to know when preparing to connect to a secured Kafka cluster, such as
sasl.mechanism
andsecurity.protocol
. Adding these to the Kafka binding for server objects would allow these to be documented.Can't it be tackled using specification extensions?
It could be captured in extensions.
e.g.
However I think this is a common enough request that there would be value in doing it in a consistent way. In particular, it would enable code generation to set up the right Kafka client properties.
Describe the solution you'd like
Strawman suggestion:
Describe alternatives you've considered
Fran Méndez suggested:
The text was updated successfully, but these errors were encountered: