forked from awsdocs/aws-doc-sdk-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
SendMessage.go
126 lines (108 loc) · 3.9 KB
/
SendMessage.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
/*
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.send_message]
package main
// snippet-start:[sqs.go.send_message.imports]
import (
"flag"
"fmt"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sqs"
)
// snippet-end:[sqs.go.send_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
}
// SendMsg sends a message to 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
// Output:
// If success, nil
// Otherwise, an error from the call to SendMessage
func SendMsg(sess *session.Session, queueURL *string) error {
// Create an SQS service client
// snippet-start:[sqs.go.send_message.call]
svc := sqs.New(sess)
_, err := svc.SendMessage(&sqs.SendMessageInput{
DelaySeconds: aws.Int64(10),
MessageAttributes: map[string]*sqs.MessageAttributeValue{
"Title": &sqs.MessageAttributeValue{
DataType: aws.String("String"),
StringValue: aws.String("The Whistler"),
},
"Author": &sqs.MessageAttributeValue{
DataType: aws.String("String"),
StringValue: aws.String("John Grisham"),
},
"WeeksOn": &sqs.MessageAttributeValue{
DataType: aws.String("Number"),
StringValue: aws.String("6"),
},
},
MessageBody: aws.String("Information about current NY Times fiction bestseller for week of 12/11/2016."),
QueueUrl: queueURL,
})
// snippet-end:[sqs.go.send_message.call]
if err != nil {
return err
}
return nil
}
func main() {
// snippet-start:[sqs.go.send_message.args]
queue := flag.String("q", "", "The name of the queue")
flag.Parse()
if *queue == "" {
fmt.Println("You must supply the name of a queue (-q QUEUE)")
return
}
// snippet-end:[sqs.go.send_message.args]
// Create a session that gets credential values from ~/.aws/credentials
// and the default region from ~/.aws/config
// snippet-start:[sqs.go.send_message.sess]
sess := session.Must(session.NewSessionWithOptions(session.Options{
SharedConfigState: session.SharedConfigEnable,
}))
// snippet-end:[sqs.go.send_message.sess]
// Get URL of queue
result, err := GetQueueURL(sess, queue)
if err != nil {
fmt.Println("Got an error getting the queue URL:")
fmt.Println(err)
return
}
queueURL := result.QueueUrl
err = SendMsg(sess, queueURL)
if err != nil {
fmt.Println("Got an error sending the message:")
fmt.Println(err)
return
}
fmt.Println("Sent message to queue ")
}
// snippet-end:[sqs.go.send_message]