Skip to content
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

[event-hubs] add AmqpAnnotatedMessage support #15939

Merged
merged 4 commits into from
Jun 30, 2021

Conversation

chradek
Copy link
Contributor

@chradek chradek commented Jun 24, 2021

Resolves #15769

Goal

Increase interopability with other AMQP-based services (e.g. Service Bus).

Background

EventData currently exposes the curated set of information available from messages using the AMQP protocol. There isn't currently a way for users to send or receive a raw AMQP message. The Service Bus client library was updated to add support for reading the AmqpAnnotatedMessage from a received message, and sending an AmqpAnnotatedMessage via adding it to a batch, or sending it directly to the service.

Changes

  • Updates ReceivedEventData with a getRawAmqpMessage() method that returns AmqpAnnotatedMessage.
  • Add the following properties to EventData:
    • contentType: string
    • messageId: string
    • correlationId: string

Differences from Service Bus

ServiceBus has a readonly _rawAmqpMessage property on ServiceBusReceivedMessage instead of the getRawAmqpMessage() method. Since this is a public API, we should not have prefixed the field with an underscore. Changing this to a method has us similar to what other languages are doing, and gives us flexibility to pass options in the future (for example, if we decide we want to parse timestamps as dates instead of numbers, we can control that in an option in the future)

If this API is accepted, I will deprecate _rawAmqpMessage and add the same method in Service Bus.

References:

Azure/azure-sdk-for-net#20105

@chradek
Copy link
Contributor Author

chradek commented Jun 24, 2021

/azp run js - event-hubs - tests

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

Copy link
Member

@richardpark-msft richardpark-msft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some small things, nothing fatal.

There's quite a bit of code here and it looks pretty much like what Service Bus has. Is there anything notable that I should pay more attention to?

// customer on receive.
if (body === undefined) body = null;
if (bodyType === "value") {
// TODO: Expose value_section from `rhea` similar to the data_section and sequence_section.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I know this is actually my TODO but we should probably file an issue to push this change into rhea.

// string, undefined, null, boolean, array, object, number should end up here
// coercing undefined to null as that will ensure that null value will be given to the
// customer on receive.
if (body === undefined) body = null;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'd throw in a blank line here - it's really easy to think the 'if' and the 'underlying else's' all are part of the same chain.

With that said - the 'body being null' thing seems incorrect to me. I know this came from SB, so it's potentially wrong there as well.

For instance, if you pass null you get this from JSON.stringify:

> Buffer.from(JSON.stringify(null), "utf8")
<Buffer 6e 75 6c 6c>

> Buffer.from(JSON.stringify(null), "utf8").toString()
'null'

I haven't looked, but perhaps this all plays nicely with the rhea encoding method for message.<data|value|sequence>_section() methods?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The only time null would have some transformation done on it is for the data_section, which case it will be JSON stringified. I'd agree that this would cause a problem, except we also attempt to JSON parse any data_section bodies. This would result in the body being null, not "null".

That said, we might run into a problem is when talking to the other languages. There's no guarantee other languages are also calling JSON.parse (in fact I doubt they are), so they may see 'null' as a string rather than a null type. It looks like this is already existing behavior, but since null and 'null' both result in null being returned from JSON.parse, updating this is safe.

return { body: body.content, bodyType: "value" };
}
} else {
// TODO: test case
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this a TODO because it's not done yet or is there an interesting challenge here?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Haha, I meant to erase that but the problem with adding TODOs is you have to actually go back and grep them...

};
} else {
let bodyType: BodyTypes = "data";
if (typeof (data as EventDataInternal).getRawAmqpMessage === "function") {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So this check is basically isReceivedEventData(), more or less?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Right now, yes, exactly.

properties: data.properties,
offset: data.offset!,
sequenceNumber: data.sequenceNumber!,
enqueuedTimeUtc: data.enqueuedTimeUtc!,
partitionKey: data.partitionKey!,
systemProperties: data.systemProperties
systemProperties: data.systemProperties,
getRawAmqpMessage() {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I take the lack of an underscore here is a personal rebuke.

@chradek
Copy link
Contributor Author

chradek commented Jun 28, 2021

Is there anything notable that I should pay more attention to?

The only notable difference is that in Event Hubs, I'm using getRawAmqpMessage() instead of _rawAmqpMessage to get the AmqpAnnotatedMessage.

@chradek
Copy link
Contributor Author

chradek commented Jun 28, 2021

/azp run js - event-hubs - tests

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@chradek
Copy link
Contributor Author

chradek commented Jun 29, 2021

/azp run js - event-hubs - tests

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@chradek chradek merged commit 19d0e76 into Azure:main Jun 30, 2021
@chradek chradek deleted the eh-annotated-message branch June 30, 2021 17:38
openapi-sdkautomation bot pushed a commit to AzureSDKAutomation/azure-sdk-for-js that referenced this pull request Sep 15, 2021
[Hub Generated] Review request for Microsoft.LabServices to add version preview/2021-10-01-preview (Azure#15939)

* Adds base for updating Microsoft.LabServices from version stable/2018-10-15 to version 2021-10-01-preview

* Updates readme

* Updates API version in new specs and examples

* remove 2018 api spec files

* add 2021-10-01-preview spec files from generation

* update preview api files in readme.md input

* update 2020 -> 2021 in new api version in readme

* spelling fixes

* fix object body mutability

* add type:object where missing

* added default error response

* tracker resource operation naming and description adding

* fix shutdownOnIdleEnabled in examples

* fix shutdownonIdle enum in examples

* examples update username to adminUser object and remove locations from vmprofile

* fix examples for vmprofile

* rest of model validaiton fixes

* prettier fix

* removed skus api from 2021-10-01 version since it's not finished

* fix operationresults

* small images fix

Co-authored-by: Nick Depinet <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[event-hubs] add support for sending AmqpAnnotatedMessage
2 participants