From 60af66d9ba77a61e61ef71d02c8e30198c433c87 Mon Sep 17 00:00:00 2001 From: Nick White Date: Tue, 19 May 2020 15:23:55 +0100 Subject: Add getandpurgequeue debugging tool --- aws.go | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'aws.go') diff --git a/aws.go b/aws.go index 59f1a7e..da89146 100644 --- a/aws.go +++ b/aws.go @@ -149,6 +149,35 @@ func (a *AwsConn) CheckQueue(url string, timeout int64) (Qmsg, error) { } } +func (a *AwsConn) LogAndPurgeQueue(url string) error { + for { + msgResult, err := a.sqssvc.ReceiveMessage(&sqs.ReceiveMessageInput{ + MaxNumberOfMessages: aws.Int64(10), + VisibilityTimeout: aws.Int64(300), + QueueUrl: &url, + }) + if err != nil { + return err + } + + if len(msgResult.Messages) > 0 { + for _, m := range msgResult.Messages { + a.Logger.Println(*m.Body) + _, err = a.sqssvc.DeleteMessage(&sqs.DeleteMessageInput{ + QueueUrl: &url, + ReceiptHandle: m.ReceiptHandle, + }) + if err != nil { + return err + } + } + } else { + break + } + } + return nil +} + // QueueHeartbeat updates the visibility timeout of a message. This // ensures that the message remains "in flight", meaning that it // cannot be seen by other processes, but if this process fails the -- cgit v1.2.1-24-ge1ad