How JustSaying Uses SQS/SNS
Lower level details on which API's JustSaying calls to achieve its mission
Publishing to SNS
JustSaying uses the SNS Publish API to send messages to SNS (documented here). The following parameters are set:
TopicArn
The ARN of the topic to which the message is being published.
Subject
JustSaying will set this to the type name of the .NET message class - "OrderAccepted", for example.
Since a JustSaying subscriber relies on this string to know what type to deserialise the JSON in the Message parameter into, non-JustSaying publishers should restrict this parameter to alphanumeric characters.
MessageAttributes
Any message attributes that you have chosen to send along with the message.
Message
The actual message object, serialised to JSON. It is worth noting that the JSON sent in this parameter becomes a subset of the JSON that will be delivered (by the SNS service) to an SQS subscriber. This is described here and here.
In addition to those properties you will define in your own messages, the following are available to a JustSaying publisher:
Property | Type | Description | Populated by default? |
---|---|---|---|
Id | GUID | A random GUID which uniquely identifies the message. | Yes |
TimeStamp | DateTime | The current time, in UTC, in ISO 8601 format. | Yes |
RaisingComponent | string | A string which identifies the publishing application - "orderapi", for example. | No |
Version | string | The message version - "2", for example. | No |
SourceIp | string | The IP address of the machine which published the message. | No |
Tenant | string | In a multi-tenant architecture, a string to identify the tenant for which the message is applicable. | No |
Conversation | string | A string which can be used to correlate multiple messages (to identify messages belonging to a single operation/customer journey, for example). | No |
Properties which are not populated will not appear in the message JSON. Enumerations are serialised as strings.
In summary, suppose we have the following message class:
And suppose I create a message object from that class:
This will result in the following JSON being created and populated on that Message parameter to the SNS Publish API:
Sending to SQS ("point to point")
JustSaying uses the SQS SendMessage API to send messages to SQS (documented here). The following parameters are set:
QueueUrl
The URL of the queue to which the message is being sent.
DelaySeconds
JustSaying will set this value to be that of the Delay
property on the PublishMetadata
class which is supplied as a parameter to the PublishAsync
method.
MessageBody
A JSON object containing two properties, Subject
and Message
. Subject
, as with the SNS publisher, will be the type name of the .NET message class. Message
will be the actual message object, serialised to JSON. The same serialisation applies as for the SNS publisher.
As an example, if I create the same OrderAccepted object as before and send that to SQS, then the value of this parameter will be:
This structure is to ensure that messages that are delivered to SQS queues as a result of directly publishing to the queue have the same format as messages delivered to a queue as a result of being subscribed to an SNS topic to which a message was published. So, from the point of view of a subscriber, whether the message was originally delivered to SNS or SQS is not important.
Last updated