diff --git a/docs/services/awssqs.md b/docs/services/awssqs.md index 6b744f47..74126893 100644 --- a/docs/services/awssqs.md +++ b/docs/services/awssqs.md @@ -1,8 +1,8 @@ -# AWS SQS +# AWS SQS ## Parameters -This notification service is capable of sending simple messages to AWS SQS queue. +This notification service is capable of sending simple messages to AWS SQS queue. * `queue` - name of the queue you are intending to send messages to. Can be overridden with target destination annotation. * `region` - region of the sqs queue can be provided via env variable AWS_DEFAULT_REGION @@ -104,3 +104,16 @@ data: - oncePer: obj.metadata.annotations["generation"] ``` + +## FIFO SQS Queues + +FIFO queues require a [MessageGroupId](https://docs.aws.amazon.com/AWSSimpleQueueService/latest/APIReference/API_SendMessage.html#SQS-SendMessage-request-MessageGroupId) to be sent along with every message, every message with a matching MessageGroupId will be processed one by one in order. + +To send to a FIFO SQS Queue you must include a `messageGroupId` in the template such as in the example below: + +```yaml +template.deployment-ready: | + message: | + Deployment {{.obj.metadata.name}} is ready! + messageGroupId: {{.obj.metadata.name}}-deployment +``` diff --git a/pkg/services/awssqs.go b/pkg/services/awssqs.go index 995fb7ed..026f9e2e 100644 --- a/pkg/services/awssqs.go +++ b/pkg/services/awssqs.go @@ -16,6 +16,7 @@ import ( type AwsSqsNotification struct { MessageAttributes map[string]string `json:"messageAttributes"` + MessageGroupId string `json:"messageGroupId,omitempty"` } type AwsSqsOptions struct { @@ -130,6 +131,11 @@ func (s awsSqsService) getCustomResolver(endpointRegion string) func(service, re } func (n *AwsSqsNotification) GetTemplater(name string, f texttemplate.FuncMap) (Templater, error) { + groupId, err := texttemplate.New(name).Funcs(f).Parse(n.MessageGroupId) + if err != nil { + return nil, err + } + return func(notification *Notification, vars map[string]interface{}) error { if notification.AwsSqs == nil { notification.AwsSqs = &AwsSqsNotification{} @@ -142,6 +148,14 @@ func (n *AwsSqsNotification) GetTemplater(name string, f texttemplate.FuncMap) ( } } + var groupIdBuff bytes.Buffer + if err := groupId.Execute(&groupIdBuff, vars); err != nil { + return err + } + if val := groupIdBuff.String(); val != "" { + notification.AwsSqs.MessageGroupId = val + } + return nil }, nil } diff --git a/pkg/services/awssqs_test.go b/pkg/services/awssqs_test.go index 97b67c75..95e5708e 100644 --- a/pkg/services/awssqs_test.go +++ b/pkg/services/awssqs_test.go @@ -20,6 +20,7 @@ func TestGetTemplater_AwsSqs(t *testing.T) { MessageAttributes: map[string]string{ "attributeKey": "{{.messageAttributeValue}}", }, + MessageGroupId: "{{.messageGroupId}}", }, } @@ -33,6 +34,7 @@ func TestGetTemplater_AwsSqs(t *testing.T) { err = templater(¬ification, map[string]interface{}{ "message": "abcdef", "messageAttributeValue": "123456", + "messageGroupId": "a1b2c3", }) if !assert.NoError(t, err) { @@ -42,6 +44,7 @@ func TestGetTemplater_AwsSqs(t *testing.T) { assert.Equal(t, map[string]string{ "attributeKey": "123456", }, notification.AwsSqs.MessageAttributes) + assert.Equal(t, "a1b2c3", notification.AwsSqs.MessageGroupId) } func TestSend_AwsSqs(t *testing.T) {