(JavaScript) SQS Send Message
Note: This example requires a patch to work properly. It requires Chilkat v9.5.0.61, which can be obtained upon request to support@chilkatsoft.com
Delivers a message to the specified queue. With Amazon SQS, you now have the ability to send large payload messages that are up to 256KB (262,144 bytes) in size.
See SQS SendMessage or detailed information.
var success = false;
// Note: This example requires a patch to work properly.
// It requires Chilkat v9.5.0.61, which can be obtained upon request to support@chilkatsoft.com
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
var rest = new CkRest();
// Connect to the Amazon AWS REST server.
// such as https://sqs.us-west-2.amazonaws.com/
var bTls = true;
var port = 443;
var bAutoReconnect = true;
success = rest.Connect("sqs.us-west-2.amazonaws.com",port,bTls,bAutoReconnect);
// Provide AWS credentials for the REST call.
var authAws = new CkAuthAws();
authAws.AccessKey = "AWS_ACCESS_KEY";
authAws.SecretKey = "AWS_SECRET_KEY";
// the region should match our URL above..
authAws.Region = "us-west-2";
authAws.ServiceName = "sqs";
rest.SetAuthAws(authAws);
rest.AddQueryParam("Action","SendMessage");
rest.AddQueryParam("MessageBody","This is the message body which can be up to 256K in size.");
rest.AddQueryParam("MessageAttribute.1.Name","test_attribute_name_1");
rest.AddQueryParam("MessageAttribute.1.Value.StringValue","test_attribute_value_1");
rest.AddQueryParam("MessageAttribute.1.Value.DataType","String");
rest.AddQueryParam("MessageAttribute.2.Name","test_attribute_name_2");
rest.AddQueryParam("MessageAttribute.2.Value.StringValue","test_attribute_value_2");
rest.AddQueryParam("MessageAttribute.2.Value.DataType","String");
// Use the actual path part of your SQS queue URL here:
var responseXml = rest.FullRequestFormUrlEncoded("POST","/123456789123/chilkatTest");
if (rest.LastMethodSuccess !== true) {
console.log(rest.LastErrorText);
return;
}
var xml = new CkXml();
// A successful response will have a status code equal to 200.
if (rest.ResponseStatusCode !== 200) {
console.log("request header = " + rest.LastRequestHeader);
console.log("response status code = " + rest.ResponseStatusCode);
console.log("response status text = " + rest.ResponseStatusText);
console.log("response header: " + rest.ResponseHeader);
xml.LoadXml(responseXml);
console.log(xml.GetXml());
return;
}
// Examine the successful XML response.
xml.LoadXml(responseXml);
console.log(xml.GetXml());
console.log("----");
// A successful response looks like this:
// <?xml version="1.0" encoding="utf-8" ?>
// <SendMessageResponse>
// <SendMessageResult>
// <MD5OfMessageBody>
// fafb00f5732ab283681e124bf8747ed1
// </MD5OfMessageBody>
// <MD5OfMessageAttributes>
// 3ae8f24a165a8cedc005670c81a27295
// </MD5OfMessageAttributes>
// <MessageId>
// 5fea7756-0ea4-451a-a703-a558b933e274
// </MessageId>
// </SendMessageResult>
// <ResponseMetadata>
// <RequestId>
// 27daac76-34dd-47df-bd01-1f6e873584a0
// </RequestId>
// </ResponseMetadata>
// </SendMessageResponse>
// Get some values from the response XML:
console.log("Body: " + xml.ChilkatPath("SendMessageResult|MD5OfMessageBody|*"));
console.log("MessageId: " + xml.ChilkatPath("SendMessageResult|MessageId|*"));
console.log("RequestId: " + xml.ChilkatPath("ResponseMetadata|RequestId|*"));
|