Welcome to the AWS Code Examples Repository. This repo contains code examples used in the AWS documentation, AWS SDK Developer Guides, and more. For more information, see the Readme.md file below.
Apache License 2.0
9.5k
stars
5.61k
forks
source link
[little updates to deleteMessage.go for sqs]: i have replaced few lines to make code look a little better #3679
if err { fmt.Println("problem statement") fmt.Println(err) return }
which can be condensed into log.Fatalf("error statement : %s", err.Error())
i will attach my edits in example code section
What does this example accomplish?
makes example looks a bit more clean
Which AWS service(s)?
sqs
Which AWS SDKs or tools?
[ ] All languages
[ ] .NET
[X] Go (v2)
[ ] Java
[ ] Java (v2)
[ ] JavaScript
[ ] JavaScript (v3)
[ ] Kotlin
[ ] PHP
[ ] Python
[ ] Ruby
[ ] Rust
[ ] Swift
[ ] Not applicable
Are there existing code examples to leverage?
No response
Do you have any reference code?
/*
Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
This file is licensed under the Apache License, Version 2.0 (the "License").
You may not use this file except in compliance with the License. A copy of
the License is located at
http://aws.amazon.com/apache2.0/
This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
CONDITIONS OF ANY KIND, either express or implied. See the License for the
specific language governing permissions and limitations under the License.
*/
// snippet-start:[sqs.go.delete_message]
package main
// snippet-start:[sqs.go.delete_message.imports]
import (
"flag"
"fmt"
"log"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sqs"
)
// snippet-end:[sqs.go.delete_message.imports]
// GetQueueURL gets the URL of an Amazon SQS queue
// Inputs:
//
// sess is the current session, which provides configuration for the SDK's service clients
// queueName is the name of the queue
//
// Output:
//
// If success, the URL of the queue and nil
// Otherwise, an empty string and an error from the call to
func GetQueueURL(sess *session.Session, queue *string) (*sqs.GetQueueUrlOutput, error) {
// Create an SQS service client
svc := sqs.New(sess)
result, err := svc.GetQueueUrl(&sqs.GetQueueUrlInput{
QueueName: queue,
})
if err != nil {
return nil, err
}
return result, nil
}
// DeleteMessage deletes a message from an Amazon SQS queue
// Inputs:
//
// sess is the current session, which provides configuration for the SDK's service clients
// queueURL is the URL of the queue
// messageID is the ID of the message
//
// Output:
//
// If success, nil
// Otherwise, an error from the call to DeleteMessage
func DeleteMessage(sess *session.Session, queueURL *string, messageHandle *string) error {
// snippet-start:[sqs.go.delete_message.call]
svc := sqs.New(sess)
_, err := svc.DeleteMessage(&sqs.DeleteMessageInput{
QueueUrl: queueURL,
ReceiptHandle: messageHandle,
})
// snippet-end:[sqs.go.delete_message.call]
if err != nil {
return err
}
return nil
}
func main() {
// snippet-start:[sqs.go.delete_message.args]
queue := flag.String("q", "", "The name of the queue")
messageHandle := flag.String("m", "", "The receipt handle of the message")
flag.Parse()
if *queue == "" || *messageHandle == "" {
log.Fatal("You must supply a queue name (-q QUEUE) and message receipt handle (-m MESSAGE-HANDLE)")
}
// snippet-end:[sqs.go.delete_message.args]
// Create a session that gets credential values from ~/.aws/credentials
// and the default region from ~/.aws/config
// snippet-start:[sqs.go.delete_message.sess]
sess := session.Must(session.NewSessionWithOptions(session.Options{
SharedConfigState: session.SharedConfigEnable,
}))
// snippet-end:[sqs.go.delete_message.sess]
// Get URL of queue
result, err := GetQueueURL(sess, queue)
if err != nil {
log.Fatalf("Got an error getting the queue URL:%s", err.Error())
}
queueURL := result.QueueUrl
err = DeleteMessage(sess, queueURL, messageHandle)
if err != nil {
log.Fatalf("Got an error deleting the message:%s", err.Error())
}
fmt.Println("Deleted message from queue with URL " + *queueURL)
}
// snippet-end:[sqs.go.delete_message]
Background story
in multiple places the pattern goes like this
if err { fmt.Println("problem statement") fmt.Println(err) return }
which can be condensed into
log.Fatalf("error statement : %s", err.Error())
i will attach my edits in example code sectionWhat does this example accomplish?
makes example looks a bit more clean
Which AWS service(s)?
sqs
Which AWS SDKs or tools?
Are there existing code examples to leverage?
No response
Do you have any reference code?