it's always a good idea to keep track of your learning.
Search This Blog
How to Publish message to SNS with AWS Golang
Publish to SNS With Golang
SNS is a notification service. A user can send a notification to a topic. Each topic can have multiple subscribers, which receive a copy of every message sent to the topic – something like an HTTP endpoint, an email address, or an Amazon SQS queue. Sending a single notification can go to multiple places.
Steps to publish an SNS message on an Amazon SNS Topic
An AWS Account to set up an SNS topic and 1 queue that receives from the topic you just created.
type SnsStruct struct {
Type string `json:"type"`
Title string `json:"title"`
Model map[string]string `json:"model"`
}
Main Function to Call Publish Sns Notification Message
func main(){
var sns SnsStruct sns.Type = Type
sns.title= test SNSMap := make(map[string]string)
SNSMap["Description"] = "test"
sns.Model = SNSMap
fmt.Println("Input: ", sns)
fmt.Println("Output:",PublishSns(sns,"SNS_Topic_Name"))
}
Publish Sns Function Thought Send Notification Message to topic
func PublishSns(message SnsStruct, topic string) string {
//marshal the struct to json
snsMessage, err := json.Marshal(message)
if err != nil {
return "Failed! Json Invaild"
}
fmt.Println("SNS MESSAGE to be sent ", string(snsMessage))
topicArn := "arn:aws:sns:ap-south-1:<topicArnNumber>:<topicName>"
region := "SNS_REGION"
sess, err := session.NewSession(&aws.Config{
Region: aws.String(region),
})
if err != nil {
return "Error creating SNS session"
}
svc := sns.New(sess)
params := &sns.PublishInput{
Message: aws.String(string(snsMessage)),// This is the message itself (can be XML / JSON / Text - anything you want)
TopicArn: aws.String(topicArn),//Get this from the Topic in the AWS console.
}
resp, err := svc.Publish(params) //Call to publish the message
if err != nil {
return "Error Call to publish message" + cast.ToString(err)
}
return "Success"
}
(Note that by default anything written to Console will be logged as CloudWatch Logs events.)
Given a double-precision number, , denoting an amount of money, use the NumberFormat class' getCurrencyInstance method to convert into the US, Indian, Chinese, and French currency formats. Then print the formatted values as follows: US: formattedPayment India: formattedPayment China: formattedPayment France: formattedPayment where is formatted according to the appropriate Locale 's currency. Note: India does not have a built-in Locale, so you must construct one where the language is en (i.e., English). Input Format A single double-precision number denoting . Constraints Output Format On the first line, print US: u where is formatted for US currency. On the second line, print India: i where is formatted for Indian currency. On the third line...
We use the integers , , and to create the following series: You are given queries in the form of , , and . For each query, print the series corresponding to the given , , and values as a single line of space-separated integers. Input Format The first line contains an integer, , denoting the number of queries. Each line of the subsequent lines contains three space-separated integers describing the respective , , and values for that query. Constraints Output Format For each query, print the corresponding series on a new line. Each series must be printed in order as a single line of space-separated integers. Sample Input 2 0 2 10 5 3 5 Sample Output 2 6 14 30 62 126 254 510 1022 2046 8 14 26 50 98 Explanation We have two queries: We use ...
Unirest is a set of lightweight HTTP libraries available in multiple languages, built and maintained by Mashape, who also maintain the open-source API Gateway Kong. Do yourself a favor, and start making HTTP requests like this: Creating Function : /** * Unirest API call return jsonResponse handle * Function Name: ApiCallFunction * @param vEmail, Url * @return status */ public static String ApiCallFunction(String vEmail, String Url) { try{ HttpResponse<JsonNode> jsonResponse = Unirest.post(Url) .field("vEmail",vEmail) .asJson(); JSONObject output= jsonResponse.getBody().getObject(); String status= output.getString("status"); return status; }catch(UnirestException e){ return "error"; } } Type Of Response Handle : // Response to String Sting bookResponse = Unirest.get(Url).asString(); //Respo...
Thank you for the nice article here. Really nice and keep update to explore more health and safety tips and ideas. Nebosh Courses In Chennai Nebosh IGC Course in Chennai International Safety Courses
ReplyDelete