-
-
Notifications
You must be signed in to change notification settings - Fork 280
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
[FEATURE REQUEST] Natively support envelopes, e.g., CloudEvents #432
Comments
That's a very interesting point and a super valid usecase. In the next community call I wanted to suggest something similar called event metadata. In the past months I found a lot of useful usecase based on generalised metadata. I am wondering whether the envelope concept is too related to cloudevents or it can be easily generalised. From what I remember about cloudevents, their envelope has a very specific schema. |
I usually recommend putting metadata in headers but agree it's not always possible. For instance, when using WebSockets, there are no headers. Let's discuss it on the next call (I've added it).
In my example, I'm trying to make it generic enough, that's why it has an optional |
do we really need a new |
That would work for CloudEvents but not for custom envelope formats, which are even more common than CloudEvents, especially in the enterprise. Also, I have the feeling that if we start putting too much stuff in the bindings it's gonna become a black box nobody wants to open. |
So I guess something to consider, as I understand CloudEvents when working with HTTP as an example, the 'Envelope' can be wrapping the message body, which of course fits nicely into the proposal or it could be with the message headers, with unchanged body or it can be a wrapper and also in the headers. That for me at least gets a little confusing if defined as an Envelope block. Of course not all protocols support these options. So I guess you could place a configuration flag in the envelope specifying where the envelope is to be placed but this is surely protocol dependent. My 2 cents on how could this be handled,
IMHO I think [1] might be a good option as the protocol different handling can be restricted to the binding. |
Let me recap and clarify what this proposal is and isn't about, just to make sure we're all aligned here: ✅ Add a way to specify that a message's payload is wrapped in an envelope. ❌ Create something specific to CloudEvents. Now, IMO, there are a couple of interesting points that were raised during the last call and on the last comment from @Paul-T-AU:
I'm adding these questions/thoughts to the original comment. Anything else I should be adding in your opinion? |
@fmvilas A point of clarification, when we say CloudEvents, is the proposal to be CloudEvents compliant or CloudEvents like/inspired? |
CloudEvents compliant. The idea is to allow users of CloudEvents reuse their existing messages. |
I am interested in the envelope feature for built in-house case. Our current set up is done over Kafka with json format and it looks to something like this with current capabilities:
Does this match with the intended feature scope? |
Following previous comment, firstly say that we have come with an alternative for not having to repeat envelope in each message by using composition with allOf.
I guess this must have other cons besides than not declaring explicitely that an envelope may have different concerns for the clients, but the result looks quite similar with what would be expected with the proposal. This said, following the proposal for being CloudEvents friendly, what I would need for being also friendly with my case, is being able to define which one in the key containing "the payload data". In the case of CloudEvents, it is contained under "data", in my case it is under "payload". So, if I take the proposal to convert it into my example, it could be looking to something like this:
payload-ref (or a better name), would act somehow like discriminator do to define polymorphism. |
This issue has been automatically marked as stale because it has not had recent activity 😴 |
Hi. I read your related article. |
This issue has been automatically marked as stale because it has not had recent activity 😴 |
This issue has been automatically marked as stale because it has not had recent activity 😴 |
Any updates on this? seems like a critical feature that an async API schema natively documents the message envelope |
I'm gonna work on this for v3.0.0, that's all I can say so far. No plans to have it for v2.x. |
Just for the record, I meant "I haven't really looked at it in detail yet so don't know". Hope it didn't look like I'm hiding information or something 😅 |
It would be nice if there was a way to describe the CE metadata/context without having to also understand the way that information is encoded into the payload (structured mode) or transport headers (binary mode). Also note that when using structured JSON (application/cloudevents+json) the business data may appear in either 'data' or 'data_base64'. Also note that CE's allow for events that only contain metadata, ie no business data. |
This feels like "HTTP header fields for events", i.e. a way how there's some agreement on syntax and semantics of how events work. It feels very powerful and relevant, but also rather tricky because unlike HTTP, we don't have a shared foundation that's designed for openness and extensibility. I sincerely hope that this will come to fruition at some point! |
I am also stumbling upon this.
This envelope can be used:
or this envelope:
And these are only 2 examples. It would be nice not to specify the wrapping as part of the payload, but as a separate concern. |
I haven't touched this issue in a while because we're working on the v3 release but this is one of my favorites for v3.1. The way I'd do it is similar to what we already have in the spec regarding correlationId. You pass whatever you want as the envelope and specify the path in which the data is contained. For instance, roughly something like this: messages:
MyMessage:
envelopes:
payload: # <- This is the payload definition (could be extracted from current message payload definition)
type: object
properties:
type:
type: string
data:
type: object
dataPath: '#/data' # <- This is to indicate where the "data" field is We can then also have |
It's a common practice to use message envelopes in event-driven architectures. Most of the time, these envelopes contain information about the company, the domain context, or other application-specific data. Envelopes are also a great way to standardize messages structure across the whole organization, making it easier to build code around it.
The most common case I've found so far —aside from custom formats— is the usage of CloudEvents. Especially, when used together with Kafka and Avro. Trying to define such a system, comes with confusing decisions:
schemaFormat
look like? Should it be JSON Schema, Avro, or CloudEvents? Everything could be defined using JSON Schema or Avro, but since the "data" of the envelope is Avro, things get confusing here. Is CloudEvents a schema format at all? I don't think so.For these reasons, I think it would be interesting to come up with a first-class solution for envelopes in AsyncAPI. This would make people feel everything is integrated better instead of hacking the spec here and there.
Example
Please, take this example as an illustration of what I'm trying to accomplish here. By no means, it's a final solution.
Open Questions/Thoughts
envelope
+bindings
. For instance, in the case of CE, we could use a binding calledcloudevents
that will allow us to define how it's used (not used, binary, structured, both). I don't think we want to define that the envelope fields are going to be placed on the headers section because then they would not be an envelope anymore, right? Food for thought tho.The text was updated successfully, but these errors were encountered: